Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/ui/webui/extensions/extensions_ui.h" | 5 #include "chrome/browser/ui/webui/extensions/extensions_ui.h" |
| 6 | 6 |
|
Dan Beam
2016/09/13 23:40:13
nit:
#include <memory>
for std::unique_ptr
Devlin
2016/09/14 00:33:48
Done.
| |
| 7 #include "base/metrics/histogram_macros.h" | |
| 7 #include "base/strings/utf_string_conversions.h" | 8 #include "base/strings/utf_string_conversions.h" |
| 9 #include "base/timer/elapsed_timer.h" | |
| 8 #include "build/build_config.h" | 10 #include "build/build_config.h" |
| 9 #include "chrome/browser/browser_process.h" | 11 #include "chrome/browser/browser_process.h" |
| 10 #include "chrome/browser/profiles/profile.h" | 12 #include "chrome/browser/profiles/profile.h" |
| 11 #include "chrome/browser/ui/webui/extensions/extension_loader_handler.h" | 13 #include "chrome/browser/ui/webui/extensions/extension_loader_handler.h" |
| 12 #include "chrome/browser/ui/webui/extensions/extension_settings_handler.h" | 14 #include "chrome/browser/ui/webui/extensions/extension_settings_handler.h" |
| 13 #include "chrome/browser/ui/webui/extensions/install_extension_handler.h" | 15 #include "chrome/browser/ui/webui/extensions/install_extension_handler.h" |
| 14 #include "chrome/browser/ui/webui/metrics_handler.h" | 16 #include "chrome/browser/ui/webui/metrics_handler.h" |
| 15 #include "chrome/common/chrome_features.h" | 17 #include "chrome/common/chrome_features.h" |
| 16 #include "chrome/common/url_constants.h" | 18 #include "chrome/common/url_constants.h" |
| 17 #include "chrome/grit/browser_resources.h" | 19 #include "chrome/grit/browser_resources.h" |
| 18 #include "chrome/grit/chromium_strings.h" | 20 #include "chrome/grit/chromium_strings.h" |
| 19 #include "chrome/grit/generated_resources.h" | 21 #include "chrome/grit/generated_resources.h" |
| 20 #include "chrome/grit/theme_resources.h" | 22 #include "chrome/grit/theme_resources.h" |
| 21 #include "components/google/core/browser/google_util.h" | 23 #include "components/google/core/browser/google_util.h" |
| 24 #include "content/public/browser/web_contents.h" | |
| 25 #include "content/public/browser/web_contents_observer.h" | |
| 22 #include "content/public/browser/web_ui.h" | 26 #include "content/public/browser/web_ui.h" |
| 23 #include "content/public/browser/web_ui_data_source.h" | 27 #include "content/public/browser/web_ui_data_source.h" |
| 24 #include "extensions/common/extension_urls.h" | 28 #include "extensions/common/extension_urls.h" |
| 25 #include "ui/base/l10n/l10n_util.h" | 29 #include "ui/base/l10n/l10n_util.h" |
| 26 #include "ui/base/resource/resource_bundle.h" | 30 #include "ui/base/resource/resource_bundle.h" |
| 27 | 31 |
| 28 #if defined(OS_CHROMEOS) | 32 #if defined(OS_CHROMEOS) |
| 29 #include "chrome/browser/chromeos/ownership/owner_settings_service_chromeos_fact ory.h" | 33 #include "chrome/browser/chromeos/ownership/owner_settings_service_chromeos_fact ory.h" |
| 30 #include "chrome/browser/ui/webui/extensions/chromeos/kiosk_apps_handler.h" | 34 #include "chrome/browser/ui/webui/extensions/chromeos/kiosk_apps_handler.h" |
| 31 #endif | 35 #endif |
| 32 | 36 |
| 33 namespace extensions { | 37 namespace extensions { |
| 34 | 38 |
| 35 namespace { | 39 namespace { |
| 36 | 40 |
| 41 class ExtensionWebUiTimer : public content::WebContentsObserver { | |
| 42 public: | |
| 43 explicit ExtensionWebUiTimer(content::WebContents* web_contents, bool is_md) | |
| 44 : content::WebContentsObserver(web_contents), is_md_(is_md) {} | |
| 45 ~ExtensionWebUiTimer() override {} | |
| 46 | |
| 47 void DidStartProvisionalLoadForFrame( | |
| 48 content::RenderFrameHost* render_frame_host, | |
| 49 const GURL& validated_url, | |
| 50 bool is_error_page, | |
| 51 bool is_iframe_srcdoc) override { | |
| 52 timer_.reset(new base::ElapsedTimer()); | |
|
Dan Beam
2016/09/13 23:40:13
i assume this captures reloads correctly?
Devlin
2016/09/14 00:33:48
Yep, it seems to. FWIW, this is also what setting
| |
| 53 } | |
| 54 | |
| 55 void DocumentLoadedInFrame( | |
| 56 content::RenderFrameHost* render_frame_host) override { | |
| 57 if (render_frame_host != web_contents()->GetMainFrame()) | |
| 58 return; | |
| 59 if (is_md_) { | |
| 60 UMA_HISTOGRAM_TIMES("Extensions.WebUi.DocumentLoadedInMainFrameTime.MD", | |
| 61 timer_->Elapsed()); | |
| 62 } else { | |
| 63 UMA_HISTOGRAM_TIMES("Extensions.WebUi.DocumentLoadedInMainFrameTime.Uber", | |
| 64 timer_->Elapsed()); | |
| 65 } | |
| 66 } | |
| 67 | |
| 68 void DocumentOnLoadCompletedInMainFrame() override { | |
| 69 if (is_md_) { | |
| 70 UMA_HISTOGRAM_TIMES("Extensions.WebUi.LoadCompletedInMainFrame.MD", | |
| 71 timer_->Elapsed()); | |
| 72 } else { | |
| 73 UMA_HISTOGRAM_TIMES("Extensions.WebUi.LoadCompletedInMainFrame.Uber", | |
| 74 timer_->Elapsed()); | |
| 75 } | |
| 76 } | |
| 77 | |
| 78 void WebContentsDestroyed() override { delete this; } | |
| 79 | |
| 80 private: | |
| 81 // Whether this is the MD version of the chrome://extensions page. | |
| 82 bool is_md_; | |
| 83 | |
| 84 std::unique_ptr<base::ElapsedTimer> timer_; | |
| 85 | |
| 86 DISALLOW_COPY_AND_ASSIGN(ExtensionWebUiTimer); | |
| 87 }; | |
| 88 | |
| 37 content::WebUIDataSource* CreateMdExtensionsSource() { | 89 content::WebUIDataSource* CreateMdExtensionsSource() { |
| 38 content::WebUIDataSource* source = | 90 content::WebUIDataSource* source = |
| 39 content::WebUIDataSource::Create(chrome::kChromeUIExtensionsHost); | 91 content::WebUIDataSource::Create(chrome::kChromeUIExtensionsHost); |
| 40 | 92 |
| 41 source->SetJsonPath("strings.js"); | 93 source->SetJsonPath("strings.js"); |
| 42 | 94 |
| 43 source->AddLocalizedString("title", | 95 source->AddLocalizedString("title", |
| 44 IDS_MANAGE_EXTENSIONS_SETTING_WINDOWS_TITLE); | 96 IDS_MANAGE_EXTENSIONS_SETTING_WINDOWS_TITLE); |
| 45 source->AddLocalizedString("toolbarTitle", IDS_MD_EXTENSIONS_TOOLBAR_TITLE); | 97 source->AddLocalizedString("toolbarTitle", IDS_MD_EXTENSIONS_TOOLBAR_TITLE); |
| 46 source->AddLocalizedString("search", IDS_MD_EXTENSIONS_SEARCH); | 98 source->AddLocalizedString("search", IDS_MD_EXTENSIONS_SEARCH); |
| (...skipping 162 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 209 source->DisableDenyXFrameOptions(); | 261 source->DisableDenyXFrameOptions(); |
| 210 return source; | 262 return source; |
| 211 } | 263 } |
| 212 | 264 |
| 213 } // namespace | 265 } // namespace |
| 214 | 266 |
| 215 ExtensionsUI::ExtensionsUI(content::WebUI* web_ui) : WebUIController(web_ui) { | 267 ExtensionsUI::ExtensionsUI(content::WebUI* web_ui) : WebUIController(web_ui) { |
| 216 Profile* profile = Profile::FromWebUI(web_ui); | 268 Profile* profile = Profile::FromWebUI(web_ui); |
| 217 content::WebUIDataSource* source = nullptr; | 269 content::WebUIDataSource* source = nullptr; |
| 218 | 270 |
| 219 if (base::FeatureList::IsEnabled(features::kMaterialDesignExtensions)) { | 271 bool is_md = |
| 272 base::FeatureList::IsEnabled(features::kMaterialDesignExtensions); | |
| 273 | |
| 274 if (is_md) { | |
| 220 source = CreateMdExtensionsSource(); | 275 source = CreateMdExtensionsSource(); |
| 221 InstallExtensionHandler* install_extension_handler = | 276 InstallExtensionHandler* install_extension_handler = |
| 222 new InstallExtensionHandler(); | 277 new InstallExtensionHandler(); |
| 223 install_extension_handler->GetLocalizedValues(source); | 278 install_extension_handler->GetLocalizedValues(source); |
| 224 web_ui->AddMessageHandler(install_extension_handler); | 279 web_ui->AddMessageHandler(install_extension_handler); |
| 225 } else { | 280 } else { |
| 226 source = CreateExtensionsHTMLSource(); | 281 source = CreateExtensionsHTMLSource(); |
| 227 | 282 |
| 228 ExtensionSettingsHandler* handler = new ExtensionSettingsHandler(); | 283 ExtensionSettingsHandler* handler = new ExtensionSettingsHandler(); |
| 229 web_ui->AddMessageHandler(handler); | 284 web_ui->AddMessageHandler(handler); |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 249 #endif | 304 #endif |
| 250 | 305 |
| 251 web_ui->AddMessageHandler(new MetricsHandler()); | 306 web_ui->AddMessageHandler(new MetricsHandler()); |
| 252 | 307 |
| 253 // Need to allow <object> elements so that the <extensionoptions> browser | 308 // Need to allow <object> elements so that the <extensionoptions> browser |
| 254 // plugin can be loaded within chrome://extensions. | 309 // plugin can be loaded within chrome://extensions. |
| 255 source->OverrideContentSecurityPolicyObjectSrc("object-src 'self';"); | 310 source->OverrideContentSecurityPolicyObjectSrc("object-src 'self';"); |
| 256 } | 311 } |
| 257 | 312 |
| 258 content::WebUIDataSource::Add(profile, source); | 313 content::WebUIDataSource::Add(profile, source); |
| 314 // Handles its own lifetime. | |
| 315 new ExtensionWebUiTimer(web_ui->GetWebContents(), is_md); | |
| 259 } | 316 } |
| 260 | 317 |
| 261 ExtensionsUI::~ExtensionsUI() {} | 318 ExtensionsUI::~ExtensionsUI() {} |
| 262 | 319 |
| 263 // static | 320 // static |
| 264 base::RefCountedMemory* ExtensionsUI::GetFaviconResourceBytes( | 321 base::RefCountedMemory* ExtensionsUI::GetFaviconResourceBytes( |
| 265 ui::ScaleFactor scale_factor) { | 322 ui::ScaleFactor scale_factor) { |
| 266 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); | 323 ui::ResourceBundle& rb = ui::ResourceBundle::GetSharedInstance(); |
| 267 return rb.LoadDataResourceBytesForScale(IDR_EXTENSIONS_FAVICON, scale_factor); | 324 return rb.LoadDataResourceBytesForScale(IDR_EXTENSIONS_FAVICON, scale_factor); |
| 268 } | 325 } |
| 269 | 326 |
| 270 } // namespace extensions | 327 } // namespace extensions |
| OLD | NEW |