| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/extensions/chrome_extension_web_contents_observer.h" | 5 #include "chrome/browser/extensions/chrome_extension_web_contents_observer.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/metrics/field_trial.h" | 8 #include "base/metrics/field_trial.h" |
| 9 #include "chrome/browser/browser_process.h" | 9 #include "chrome/browser/browser_process.h" |
| 10 #include "chrome/browser/extensions/api/developer_private/developer_private_mojo
.h" |
| 10 #include "chrome/browser/extensions/error_console/error_console.h" | 11 #include "chrome/browser/extensions/error_console/error_console.h" |
| 11 #include "chrome/browser/extensions/extension_service.h" | 12 #include "chrome/browser/extensions/extension_service.h" |
| 12 #include "chrome/browser/extensions/window_controller.h" | 13 #include "chrome/browser/extensions/window_controller.h" |
| 13 #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" | 14 #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" |
| 14 #include "chrome/common/extensions/chrome_extension_messages.h" | 15 #include "chrome/common/extensions/chrome_extension_messages.h" |
| 15 #include "chrome/common/extensions/extension_process_policy.h" | 16 #include "chrome/common/extensions/extension_process_policy.h" |
| 16 #include "chrome/common/url_constants.h" | 17 #include "chrome/common/url_constants.h" |
| 17 #include "components/rappor/rappor_service.h" | 18 #include "components/rappor/rappor_service.h" |
| 18 #include "content/public/browser/browser_context.h" | 19 #include "content/public/browser/browser_context.h" |
| 19 #include "content/public/browser/child_process_security_policy.h" | 20 #include "content/public/browser/child_process_security_policy.h" |
| 20 #include "content/public/browser/render_frame_host.h" | 21 #include "content/public/browser/render_frame_host.h" |
| 21 #include "content/public/browser/render_process_host.h" | 22 #include "content/public/browser/render_process_host.h" |
| 22 #include "content/public/browser/render_view_host.h" | 23 #include "content/public/browser/render_view_host.h" |
| 23 #include "content/public/common/content_switches.h" | 24 #include "content/public/common/content_switches.h" |
| 25 #include "content/public/common/service_registry.h" |
| 24 #include "extensions/browser/extension_registry.h" | 26 #include "extensions/browser/extension_registry.h" |
| 25 #include "extensions/browser/extension_system.h" | 27 #include "extensions/browser/extension_system.h" |
| 26 #include "extensions/common/constants.h" | 28 #include "extensions/common/constants.h" |
| 27 #include "extensions/common/extension_messages.h" | 29 #include "extensions/common/extension_messages.h" |
| 28 #include "extensions/common/extension_urls.h" | 30 #include "extensions/common/extension_urls.h" |
| 29 #include "extensions/common/switches.h" | 31 #include "extensions/common/switches.h" |
| 30 | 32 |
| 31 using content::BrowserContext; | 33 using content::BrowserContext; |
| 32 | 34 |
| 33 DEFINE_WEB_CONTENTS_USER_DATA_KEY( | 35 DEFINE_WEB_CONTENTS_USER_DATA_KEY( |
| (...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 122 ->ReportError(std::unique_ptr<ExtensionError>(new RuntimeError( | 124 ->ReportError(std::unique_ptr<ExtensionError>(new RuntimeError( |
| 123 extension_id, browser_context()->IsOffTheRecord(), source, message, | 125 extension_id, browser_context()->IsOffTheRecord(), source, message, |
| 124 stack_trace, web_contents()->GetLastCommittedURL(), | 126 stack_trace, web_contents()->GetLastCommittedURL(), |
| 125 static_cast<logging::LogSeverity>(severity_level), | 127 static_cast<logging::LogSeverity>(severity_level), |
| 126 render_frame_host->GetRoutingID(), | 128 render_frame_host->GetRoutingID(), |
| 127 render_frame_host->GetProcess()->GetID()))); | 129 render_frame_host->GetProcess()->GetID()))); |
| 128 } | 130 } |
| 129 | 131 |
| 130 void ChromeExtensionWebContentsObserver::InitializeRenderFrame( | 132 void ChromeExtensionWebContentsObserver::InitializeRenderFrame( |
| 131 content::RenderFrameHost* render_frame_host) { | 133 content::RenderFrameHost* render_frame_host) { |
| 134 render_frame_host->GetServiceRegistry()->AddService( |
| 135 base::Bind(&DeveloperPrivateMojo::Create, browser_context())); |
| 136 |
| 132 ExtensionWebContentsObserver::InitializeRenderFrame(render_frame_host); | 137 ExtensionWebContentsObserver::InitializeRenderFrame(render_frame_host); |
| 133 WindowController* controller = dispatcher()->GetExtensionWindowController(); | 138 WindowController* controller = dispatcher()->GetExtensionWindowController(); |
| 134 if (controller) { | 139 if (controller) { |
| 135 render_frame_host->Send(new ExtensionMsg_UpdateBrowserWindowId( | 140 render_frame_host->Send(new ExtensionMsg_UpdateBrowserWindowId( |
| 136 render_frame_host->GetRoutingID(), controller->GetWindowId())); | 141 render_frame_host->GetRoutingID(), controller->GetWindowId())); |
| 137 } | 142 } |
| 138 } | 143 } |
| 139 | 144 |
| 140 void ChromeExtensionWebContentsObserver::ReloadIfTerminated( | 145 void ChromeExtensionWebContentsObserver::ReloadIfTerminated( |
| 141 content::RenderViewHost* render_view_host) { | 146 content::RenderViewHost* render_view_host) { |
| (...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 222 if (rappor::RapporService* rappor = g_browser_process->rappor_service()) { | 227 if (rappor::RapporService* rappor = g_browser_process->rappor_service()) { |
| 223 const std::string& extension_id = | 228 const std::string& extension_id = |
| 224 parent_is_extension ? parent_url.host() : frame_url.host(); | 229 parent_is_extension ? parent_url.host() : frame_url.host(); |
| 225 rappor->RecordSample("Extensions.AffectedByIsolateExtensions", | 230 rappor->RecordSample("Extensions.AffectedByIsolateExtensions", |
| 226 rappor::UMA_RAPPOR_TYPE, extension_id); | 231 rappor::UMA_RAPPOR_TYPE, extension_id); |
| 227 } | 232 } |
| 228 } | 233 } |
| 229 } | 234 } |
| 230 | 235 |
| 231 } // namespace extensions | 236 } // namespace extensions |
| OLD | NEW |