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 |