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/extension_settings_handler.h" | 5 #include "chrome/browser/ui/webui/extensions/extension_settings_handler.h" |
| 6 | 6 |
| 7 #include "base/auto_reset.h" | 7 #include "base/auto_reset.h" |
| 8 #include "base/base64.h" | 8 #include "base/base64.h" |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
| 11 #include "base/command_line.h" | 11 #include "base/command_line.h" |
| 12 #include "base/file_util.h" | 12 #include "base/file_util.h" |
| 13 #include "base/string_util.h" | |
| 13 #include "base/string_number_conversions.h" | 14 #include "base/string_number_conversions.h" |
| 14 #include "base/utf_string_conversions.h" | 15 #include "base/utf_string_conversions.h" |
| 15 #include "base/values.h" | 16 #include "base/values.h" |
| 16 #include "base/version.h" | 17 #include "base/version.h" |
| 17 #include "chrome/browser/browser_process.h" | 18 #include "chrome/browser/browser_process.h" |
| 18 #include "chrome/browser/debugger/devtools_window.h" | 19 #include "chrome/browser/debugger/devtools_window.h" |
| 19 #include "chrome/browser/extensions/crx_installer.h" | 20 #include "chrome/browser/extensions/crx_installer.h" |
| 20 #include "chrome/browser/extensions/extension_disabled_ui.h" | 21 #include "chrome/browser/extensions/extension_disabled_ui.h" |
| 22 #include "chrome/browser/extensions/extension_error_reporter.h" | |
| 21 #include "chrome/browser/extensions/extension_host.h" | 23 #include "chrome/browser/extensions/extension_host.h" |
| 22 #include "chrome/browser/extensions/extension_service.h" | 24 #include "chrome/browser/extensions/extension_service.h" |
| 23 #include "chrome/browser/extensions/extension_system.h" | 25 #include "chrome/browser/extensions/extension_system.h" |
| 24 #include "chrome/browser/extensions/extension_warning_set.h" | 26 #include "chrome/browser/extensions/extension_warning_set.h" |
| 25 #include "chrome/browser/extensions/lazy_background_task_queue.h" | 27 #include "chrome/browser/extensions/lazy_background_task_queue.h" |
| 26 #include "chrome/browser/extensions/unpacked_installer.h" | 28 #include "chrome/browser/extensions/unpacked_installer.h" |
| 27 #include "chrome/browser/extensions/updater/extension_updater.h" | 29 #include "chrome/browser/extensions/updater/extension_updater.h" |
| 28 #include "chrome/browser/google/google_util.h" | 30 #include "chrome/browser/google/google_util.h" |
| 29 #include "chrome/browser/managed_mode.h" | 31 #include "chrome/browser/managed_mode.h" |
| 30 #include "chrome/browser/prefs/pref_service.h" | 32 #include "chrome/browser/prefs/pref_service.h" |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 68 // | 70 // |
| 69 // ExtensionSettingsHandler | 71 // ExtensionSettingsHandler |
| 70 // | 72 // |
| 71 /////////////////////////////////////////////////////////////////////////////// | 73 /////////////////////////////////////////////////////////////////////////////// |
| 72 | 74 |
| 73 ExtensionSettingsHandler::ExtensionSettingsHandler() | 75 ExtensionSettingsHandler::ExtensionSettingsHandler() |
| 74 : extension_service_(NULL), | 76 : extension_service_(NULL), |
| 75 management_policy_(NULL), | 77 management_policy_(NULL), |
| 76 ignore_notifications_(false), | 78 ignore_notifications_(false), |
| 77 deleting_rvh_(NULL), | 79 deleting_rvh_(NULL), |
| 78 registered_for_notifications_(false) { | 80 registered_for_notifications_(false), |
| 81 requirements_checker_(new extensions::RequirementsChecker()) { | |
|
Aaron Boodman
2012/09/04 21:48:57
Nit: Can delay creating this until needed.
eaugusti
2012/09/04 23:52:15
Done.
| |
| 79 } | 82 } |
| 80 | 83 |
| 81 ExtensionSettingsHandler::~ExtensionSettingsHandler() { | 84 ExtensionSettingsHandler::~ExtensionSettingsHandler() { |
| 82 // There may be pending file dialogs, we need to tell them that we've gone | 85 // There may be pending file dialogs, we need to tell them that we've gone |
| 83 // away so they don't try and call back to us. | 86 // away so they don't try and call back to us. |
| 84 if (load_extension_dialog_) | 87 if (load_extension_dialog_) |
| 85 load_extension_dialog_->ListenerDestroyed(); | 88 load_extension_dialog_->ListenerDestroyed(); |
| 86 | 89 |
| 87 registrar_.RemoveAll(); | 90 registrar_.RemoveAll(); |
| 88 } | 91 } |
| 89 | 92 |
| 90 ExtensionSettingsHandler::ExtensionSettingsHandler(ExtensionService* service, | 93 ExtensionSettingsHandler::ExtensionSettingsHandler(ExtensionService* service, |
| 91 ManagementPolicy* policy) | 94 ManagementPolicy* policy) |
| 92 : extension_service_(service), | 95 : extension_service_(service), |
| 93 management_policy_(policy), | 96 management_policy_(policy), |
| 94 ignore_notifications_(false), | 97 ignore_notifications_(false), |
| 95 deleting_rvh_(NULL), | 98 deleting_rvh_(NULL), |
| 96 registered_for_notifications_(false) { | 99 registered_for_notifications_(false), |
| 100 requirements_checker_(new extensions::RequirementsChecker()) { | |
| 97 } | 101 } |
| 98 | 102 |
| 99 // static | 103 // static |
| 100 void ExtensionSettingsHandler::RegisterUserPrefs(PrefService* prefs) { | 104 void ExtensionSettingsHandler::RegisterUserPrefs(PrefService* prefs) { |
| 101 prefs->RegisterBooleanPref(prefs::kExtensionsUIDeveloperMode, | 105 prefs->RegisterBooleanPref(prefs::kExtensionsUIDeveloperMode, |
| 102 false, | 106 false, |
| 103 PrefService::SYNCABLE_PREF); | 107 PrefService::SYNCABLE_PREF); |
| 104 } | 108 } |
| 105 | 109 |
| 106 DictionaryValue* ExtensionSettingsHandler::CreateExtensionDetailValue( | 110 DictionaryValue* ExtensionSettingsHandler::CreateExtensionDetailValue( |
| (...skipping 510 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 617 return; | 621 return; |
| 618 } | 622 } |
| 619 | 623 |
| 620 if (enable_str == "true") { | 624 if (enable_str == "true") { |
| 621 extensions::ExtensionPrefs* prefs = extension_service_->extension_prefs(); | 625 extensions::ExtensionPrefs* prefs = extension_service_->extension_prefs(); |
| 622 if (prefs->DidExtensionEscalatePermissions(extension_id)) { | 626 if (prefs->DidExtensionEscalatePermissions(extension_id)) { |
| 623 Browser* browser = browser::FindBrowserWithWebContents( | 627 Browser* browser = browser::FindBrowserWithWebContents( |
| 624 web_ui()->GetWebContents()); | 628 web_ui()->GetWebContents()); |
| 625 extensions::ShowExtensionDisabledDialog( | 629 extensions::ShowExtensionDisabledDialog( |
| 626 extension_service_, browser, extension); | 630 extension_service_, browser, extension); |
| 631 } else if (prefs->GetDisableReasons(extension_id) & | |
| 632 Extension::DISABLE_UNSUPPORTED_REQUIREMENT) { | |
| 633 // Recheck the requirements. | |
| 634 scoped_refptr<const Extension> extension = | |
| 635 extension_service_->GetExtensionById(extension_id, | |
| 636 true /* include disabled */); | |
| 637 requirements_checker_->Check( | |
| 638 extension, | |
| 639 base::Bind(&ExtensionSettingsHandler::OnRequirementsChecked, | |
| 640 AsWeakPtr(), extension_id)); | |
| 627 } else { | 641 } else { |
| 628 extension_service_->EnableExtension(extension_id); | 642 extension_service_->EnableExtension(extension_id); |
| 629 } | 643 } |
| 630 } else { | 644 } else { |
| 631 extension_service_->DisableExtension( | 645 extension_service_->DisableExtension( |
| 632 extension_id, Extension::DISABLE_USER_ACTION); | 646 extension_id, Extension::DISABLE_USER_ACTION); |
| 633 } | 647 } |
| 634 } | 648 } |
| 635 | 649 |
| 636 void ExtensionSettingsHandler::HandleEnableIncognitoMessage( | 650 void ExtensionSettingsHandler::HandleEnableIncognitoMessage( |
| (...skipping 243 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 880 #else | 894 #else |
| 881 return NULL; | 895 return NULL; |
| 882 #endif // !defined(OS_ANDROID) | 896 #endif // !defined(OS_ANDROID) |
| 883 } | 897 } |
| 884 | 898 |
| 885 void ExtensionSettingsHandler::InspectExtensionHost( | 899 void ExtensionSettingsHandler::InspectExtensionHost( |
| 886 extensions::ExtensionHost* host) { | 900 extensions::ExtensionHost* host) { |
| 887 if (host) | 901 if (host) |
| 888 DevToolsWindow::OpenDevToolsWindow(host->render_view_host()); | 902 DevToolsWindow::OpenDevToolsWindow(host->render_view_host()); |
| 889 } | 903 } |
| 904 | |
| 905 void ExtensionSettingsHandler::OnRequirementsChecked( | |
| 906 std::string extension_id, | |
| 907 std::vector<std::string> requirement_errors) { | |
| 908 if (requirement_errors.empty()) { | |
| 909 extension_service_->EnableExtension(extension_id); | |
| 910 } else { | |
| 911 ExtensionErrorReporter::GetInstance()->ReportError( | |
| 912 UTF8ToUTF16(JoinString(requirement_errors, ' ')), | |
| 913 true /* be noisy */); | |
| 914 } | |
| 915 } | |
| OLD | NEW |