Index: apps/shell/shell_content_renderer_client.cc |
diff --git a/apps/shell/shell_content_renderer_client.cc b/apps/shell/shell_content_renderer_client.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..0414700a9a03f44bad5b9d13c5c60a350edb964b |
--- /dev/null |
+++ b/apps/shell/shell_content_renderer_client.cc |
@@ -0,0 +1,76 @@ |
+// Copyright 2014 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "apps/shell/shell_content_renderer_client.h" |
+ |
+#include "apps/shell/shell_extensions_client.h" |
+#include "chrome/renderer/extensions/dispatcher.h" |
+#include "chrome/renderer/extensions/extension_helper.h" |
+#include "content/public/renderer/render_thread.h" |
+#include "extensions/common/extensions_client.h" |
+ |
+using blink::WebFrame; |
+using blink::WebString; |
+using content::RenderThread; |
+ |
+namespace apps { |
+ |
+ShellContentRendererClient::ShellContentRendererClient() {} |
+ |
+ShellContentRendererClient::~ShellContentRendererClient() {} |
+ |
+void ShellContentRendererClient::RenderThreadStarted() { |
+ RenderThread* thread = RenderThread::Get(); |
+ |
+ extension_dispatcher_.reset(new extensions::Dispatcher()); |
+ thread->AddObserver(extension_dispatcher_.get()); |
+ |
+ // TODO(jamescook): Init WebSecurityPolicy for chrome-extension: schemes. |
+ // See ChromeContentRendererClient for details. |
+ |
+ extensions_client_.reset(new ShellExtensionsClient); |
+ extensions::ExtensionsClient::Set(extensions_client_.get()); |
+} |
+ |
+void ShellContentRendererClient::RenderFrameCreated( |
+ content::RenderFrame* render_frame) { |
+ // TODO(jamescook): Create ContentSettingsObserver for allowScript? |
Yoyo Zhou
2014/01/30 00:49:54
This doesn't look extension-related but it might s
James Cook
2014/01/30 01:10:13
Removed TODO. We'll solve that problem if we need
|
+ // TODO(jamescook): Create ExtensionFrameHelper? |
Yoyo Zhou
2014/01/30 00:49:54
Looks like this is for Pepper web plugins? https:/
James Cook
2014/01/30 01:10:13
Hrm, so we might need it eventually if we want Pep
|
+} |
+ |
+void ShellContentRendererClient::RenderViewCreated( |
+ content::RenderView* render_view) { |
+ new extensions::ExtensionHelper(render_view, extension_dispatcher_.get()); |
+} |
+ |
+bool ShellContentRendererClient::WillSendRequest( |
+ blink::WebFrame* frame, |
+ content::PageTransition transition_type, |
+ const GURL& url, |
+ const GURL& first_party_for_cookies, |
+ GURL* new_url) { |
+ // TODO(jamescook): Cause an error for bad extension scheme requests? |
+ return false; |
+} |
+ |
+void ShellContentRendererClient::DidCreateScriptContext( |
+ WebFrame* frame, v8::Handle<v8::Context> context, int extension_group, |
+ int world_id) { |
+ // TODO(jamescook): We need to make sure not to load PermissionFeatures |
+ // that our PermissionsProvider doesn't know about. Once that is fixed we |
+ // can call extension_dispatcher_->DidCreateScriptContext() to set up the |
+ // extension's script context. |
+} |
+ |
+void ShellContentRendererClient::WillReleaseScriptContext( |
+ WebFrame* frame, v8::Handle<v8::Context> context, int world_id) { |
+ // TODO(jamescook): As above, but to release the extension script context. |
+} |
+ |
+bool ShellContentRendererClient::ShouldEnableSiteIsolationPolicy() const { |
+ // Extension renderers don't need site isolation. |
+ return false; |
+} |
+ |
+} // namespace apps |