| Index: chrome/browser/ui/webui/options/extension_settings_handler.cc
|
| ===================================================================
|
| --- chrome/browser/ui/webui/options/extension_settings_handler.cc (revision 99349)
|
| +++ chrome/browser/ui/webui/options/extension_settings_handler.cc (working copy)
|
| @@ -2,42 +2,27 @@
|
| // Use of this source code is governed by a BSD-style license that can be
|
| // found in the LICENSE file.
|
|
|
| -#include "chrome/browser/extensions/extensions_ui.h"
|
| +#include "chrome/browser/ui/webui/options/extension_settings_handler.h"
|
|
|
| -#include <algorithm>
|
| -
|
| #include "base/base64.h"
|
| -#include "base/callback.h"
|
| #include "base/file_util.h"
|
| -#include "base/memory/singleton.h"
|
| #include "base/string_number_conversions.h"
|
| -#include "base/string_util.h"
|
| -#include "base/threading/thread.h"
|
| #include "base/utf_string_conversions.h"
|
| +#include "base/values.h"
|
| #include "base/version.h"
|
| +#include "chrome/browser/debugger/devtools_window.h"
|
| #include "chrome/browser/extensions/crx_installer.h"
|
| #include "chrome/browser/extensions/extension_disabled_infobar_delegate.h"
|
| -#include "chrome/browser/extensions/extension_error_reporter.h"
|
| -#include "chrome/browser/extensions/extension_host.h"
|
| -#include "chrome/browser/extensions/extension_message_service.h"
|
| #include "chrome/browser/extensions/extension_service.h"
|
| #include "chrome/browser/extensions/extension_updater.h"
|
| #include "chrome/browser/google/google_util.h"
|
| -#include "chrome/browser/prefs/pref_service.h"
|
| #include "chrome/browser/profiles/profile.h"
|
| #include "chrome/browser/tab_contents/background_contents.h"
|
| -#include "chrome/browser/ui/browser_list.h"
|
| #include "chrome/common/extensions/extension.h"
|
| -#include "chrome/common/extensions/extension_icon_set.h"
|
| -#include "chrome/common/extensions/url_pattern.h"
|
| -#include "chrome/common/extensions/user_script.h"
|
| -#include "chrome/common/jstemplate_builder.h"
|
| #include "chrome/common/pref_names.h"
|
| #include "chrome/common/url_constants.h"
|
| -#include "content/browser/debugger/devtools_window.h"
|
| #include "content/browser/renderer_host/render_process_host.h"
|
| #include "content/browser/renderer_host/render_view_host.h"
|
| -#include "content/browser/renderer_host/render_widget_host.h"
|
| #include "content/browser/tab_contents/tab_contents.h"
|
| #include "content/browser/tab_contents/tab_contents_view.h"
|
| #include "content/common/content_notification_types.h"
|
| @@ -46,7 +31,6 @@
|
| #include "grit/chromium_strings.h"
|
| #include "grit/generated_resources.h"
|
| #include "grit/theme_resources.h"
|
| -#include "net/base/net_util.h"
|
| #include "ui/base/l10n/l10n_util.h"
|
| #include "ui/base/resource/resource_bundle.h"
|
| #include "ui/gfx/codec/png_codec.h"
|
| @@ -81,130 +65,16 @@
|
|
|
| ////////////////////////////////////////////////////////////////////////////////
|
| //
|
| -// ExtensionsHTMLSource
|
| +// ExtensionSettingsHandler::IconLoader
|
| //
|
| ////////////////////////////////////////////////////////////////////////////////
|
|
|
| -ExtensionsUIHTMLSource::ExtensionsUIHTMLSource()
|
| - : DataSource(chrome::kChromeUIExtensionsHost, MessageLoop::current()) {
|
| -}
|
| -
|
| -void ExtensionsUIHTMLSource::StartDataRequest(const std::string& path,
|
| - bool is_incognito,
|
| - int request_id) {
|
| - DictionaryValue localized_strings;
|
| - localized_strings.SetString("title",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_TITLE));
|
| - localized_strings.SetString("devModeLink",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_DEVELOPER_MODE_LINK));
|
| - localized_strings.SetString("devModePrefix",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_DEVELOPER_MODE_PREFIX));
|
| - localized_strings.SetString("loadUnpackedButton",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_LOAD_UNPACKED_BUTTON));
|
| - localized_strings.SetString("packButton",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_PACK_BUTTON));
|
| - localized_strings.SetString("updateButton",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_UPDATE_BUTTON));
|
| - localized_strings.SetString("noExtensions",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_NONE_INSTALLED));
|
| - localized_strings.SetString("suggestGallery",
|
| - l10n_util::GetStringFUTF16(IDS_EXTENSIONS_NONE_INSTALLED_SUGGEST_GALLERY,
|
| - ASCIIToUTF16("<a href='") +
|
| - ASCIIToUTF16(google_util::AppendGoogleLocaleParam(
|
| - GURL(Extension::ChromeStoreLaunchURL())).spec()) +
|
| - ASCIIToUTF16("'>"),
|
| - ASCIIToUTF16("</a>")));
|
| - localized_strings.SetString("getMoreExtensions",
|
| - ASCIIToUTF16("<a href='") +
|
| - ASCIIToUTF16(google_util::AppendGoogleLocaleParam(
|
| - GURL(Extension::ChromeStoreLaunchURL())).spec()) +
|
| - ASCIIToUTF16("'>") +
|
| - l10n_util::GetStringUTF16(IDS_GET_MORE_EXTENSIONS) +
|
| - ASCIIToUTF16("</a>"));
|
| - localized_strings.SetString("extensionCrashed",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_CRASHED_EXTENSION));
|
| - localized_strings.SetString("extensionDisabled",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_DISABLED_EXTENSION));
|
| - localized_strings.SetString("inDevelopment",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_IN_DEVELOPMENT));
|
| - localized_strings.SetString("viewIncognito",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_VIEW_INCOGNITO));
|
| - localized_strings.SetString("extensionId",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_ID));
|
| - localized_strings.SetString("extensionVersion",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_VERSION));
|
| - localized_strings.SetString("inspectViews",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSPECT_VIEWS));
|
| - localized_strings.SetString("inspectPopupsInstructions",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSPECT_POPUPS_INSTRUCTIONS));
|
| - localized_strings.SetString("disable",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_DISABLE));
|
| - localized_strings.SetString("enable",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_ENABLE));
|
| - localized_strings.SetString("enableIncognito",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_ENABLE_INCOGNITO));
|
| - localized_strings.SetString("allowFileAccess",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_ALLOW_FILE_ACCESS));
|
| - localized_strings.SetString("incognitoWarning",
|
| - l10n_util::GetStringFUTF16(IDS_EXTENSIONS_INCOGNITO_WARNING,
|
| - l10n_util::GetStringUTF16(IDS_PRODUCT_NAME)));
|
| - localized_strings.SetString("reload",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_RELOAD));
|
| - localized_strings.SetString("uninstall",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_UNINSTALL));
|
| - localized_strings.SetString("options",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_OPTIONS));
|
| - localized_strings.SetString("packDialogTitle",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSION_PACK_DIALOG_TITLE));
|
| - localized_strings.SetString("packDialogHeading",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSION_PACK_DIALOG_HEADING));
|
| - localized_strings.SetString("rootDirectoryLabel",
|
| - l10n_util::GetStringUTF16(
|
| - IDS_EXTENSION_PACK_DIALOG_ROOT_DIRECTORY_LABEL));
|
| - localized_strings.SetString("packDialogBrowse",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSION_PACK_DIALOG_BROWSE));
|
| - localized_strings.SetString("privateKeyLabel",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSION_PACK_DIALOG_PRIVATE_KEY_LABEL));
|
| - localized_strings.SetString("okButton",
|
| - l10n_util::GetStringUTF16(IDS_OK));
|
| - localized_strings.SetString("cancelButton",
|
| - l10n_util::GetStringUTF16(IDS_CANCEL));
|
| - localized_strings.SetString("showButton",
|
| - l10n_util::GetStringUTF16(IDS_EXTENSIONS_SHOW_BUTTON));
|
| -
|
| - SetFontAndTextDirection(&localized_strings);
|
| -
|
| - static const base::StringPiece extensions_html(
|
| - ResourceBundle::GetSharedInstance().GetRawDataResource(
|
| - IDR_EXTENSIONS_UI_HTML));
|
| - std::string full_html(extensions_html.data(), extensions_html.size());
|
| - jstemplate_builder::AppendJsonHtml(&localized_strings, &full_html);
|
| - jstemplate_builder::AppendI18nTemplateSourceHtml(&full_html);
|
| - jstemplate_builder::AppendI18nTemplateProcessHtml(&full_html);
|
| - jstemplate_builder::AppendJsTemplateSourceHtml(&full_html);
|
| -
|
| - scoped_refptr<RefCountedBytes> html_bytes(new RefCountedBytes);
|
| - html_bytes->data.resize(full_html.size());
|
| - std::copy(full_html.begin(), full_html.end(), html_bytes->data.begin());
|
| -
|
| - SendResponse(request_id, html_bytes);
|
| -}
|
| -
|
| -std::string ExtensionsUIHTMLSource::GetMimeType(const std::string&) const {
|
| - return "text/html";
|
| -}
|
| -
|
| -////////////////////////////////////////////////////////////////////////////////
|
| -//
|
| -// ExtensionsDOMHandler::IconLoader
|
| -//
|
| -////////////////////////////////////////////////////////////////////////////////
|
| -
|
| -ExtensionsDOMHandler::IconLoader::IconLoader(ExtensionsDOMHandler* handler)
|
| +ExtensionSettingsHandler::IconLoader::IconLoader(
|
| + ExtensionSettingsHandler* handler)
|
| : handler_(handler) {
|
| }
|
|
|
| -void ExtensionsDOMHandler::IconLoader::LoadIcons(
|
| +void ExtensionSettingsHandler::IconLoader::LoadIcons(
|
| std::vector<ExtensionResource>* icons, DictionaryValue* json) {
|
| BrowserThread::PostTask(
|
| BrowserThread::FILE, FROM_HERE,
|
| @@ -212,11 +82,11 @@
|
| &IconLoader::LoadIconsOnFileThread, icons, json));
|
| }
|
|
|
| -void ExtensionsDOMHandler::IconLoader::Cancel() {
|
| +void ExtensionSettingsHandler::IconLoader::Cancel() {
|
| handler_ = NULL;
|
| }
|
|
|
| -void ExtensionsDOMHandler::IconLoader::LoadIconsOnFileThread(
|
| +void ExtensionSettingsHandler::IconLoader::LoadIconsOnFileThread(
|
| std::vector<ExtensionResource>* icons, DictionaryValue* json) {
|
| scoped_ptr<std::vector<ExtensionResource> > icons_deleter(icons);
|
| scoped_ptr<DictionaryValue> json_deleter(json);
|
| @@ -279,7 +149,7 @@
|
| json_deleter.release()));
|
| }
|
|
|
| -void ExtensionsDOMHandler::IconLoader::ReportResultOnUIThread(
|
| +void ExtensionSettingsHandler::IconLoader::ReportResultOnUIThread(
|
| DictionaryValue* json) {
|
| if (handler_)
|
| handler_->OnIconsLoaded(json);
|
| @@ -288,48 +158,62 @@
|
|
|
| ///////////////////////////////////////////////////////////////////////////////
|
| //
|
| -// ExtensionsDOMHandler
|
| +// ExtensionSettingsHandler
|
| //
|
| ///////////////////////////////////////////////////////////////////////////////
|
|
|
| -ExtensionsDOMHandler::ExtensionsDOMHandler(ExtensionService* extension_service)
|
| - : extension_service_(extension_service),
|
| +ExtensionSettingsHandler::ExtensionSettingsHandler()
|
| + : extension_service_(NULL),
|
| ignore_notifications_(false),
|
| deleting_rvh_(NULL) {
|
| }
|
|
|
| -void ExtensionsDOMHandler::RegisterMessages() {
|
| - web_ui_->RegisterMessageCallback("requestExtensionsData",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandleRequestExtensionsData));
|
| - web_ui_->RegisterMessageCallback("toggleDeveloperMode",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandleToggleDeveloperMode));
|
| - web_ui_->RegisterMessageCallback("inspect",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandleInspectMessage));
|
| - web_ui_->RegisterMessageCallback("reload",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandleReloadMessage));
|
| - web_ui_->RegisterMessageCallback("enable",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandleEnableMessage));
|
| - web_ui_->RegisterMessageCallback("enableIncognito",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandleEnableIncognitoMessage));
|
| - web_ui_->RegisterMessageCallback("allowFileAccess",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandleAllowFileAccessMessage));
|
| - web_ui_->RegisterMessageCallback("uninstall",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandleUninstallMessage));
|
| - web_ui_->RegisterMessageCallback("options",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandleOptionsMessage));
|
| - web_ui_->RegisterMessageCallback("showButton",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandleShowButtonMessage));
|
| - web_ui_->RegisterMessageCallback("load",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandleLoadMessage));
|
| - web_ui_->RegisterMessageCallback("pack",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandlePackMessage));
|
| - web_ui_->RegisterMessageCallback("autoupdate",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandleAutoUpdateMessage));
|
| - web_ui_->RegisterMessageCallback("selectFilePath",
|
| - NewCallback(this, &ExtensionsDOMHandler::HandleSelectFilePathMessage));
|
| +ExtensionSettingsHandler::~ExtensionSettingsHandler() {
|
| + // There may be pending file dialogs, we need to tell them that we've gone
|
| + // away so they don't try and call back to us.
|
| + if (load_extension_dialog_.get())
|
| + load_extension_dialog_->ListenerDestroyed();
|
| +
|
| + if (icon_loader_.get())
|
| + icon_loader_->Cancel();
|
| }
|
|
|
| -void ExtensionsDOMHandler::HandleRequestExtensionsData(const ListValue* args) {
|
| +void ExtensionSettingsHandler::RegisterMessages() {
|
| + web_ui_->RegisterMessageCallback("extensionSettingsRequestExtensionsData",
|
| + NewCallback(this,
|
| + &ExtensionSettingsHandler::HandleRequestExtensionsData));
|
| + web_ui_->RegisterMessageCallback("extensionSettingsToggleDeveloperMode",
|
| + NewCallback(this, &ExtensionSettingsHandler::HandleToggleDeveloperMode));
|
| + web_ui_->RegisterMessageCallback("extensionSettingsInspect",
|
| + NewCallback(this, &ExtensionSettingsHandler::HandleInspectMessage));
|
| + web_ui_->RegisterMessageCallback("extensionSettingsReload",
|
| + NewCallback(this, &ExtensionSettingsHandler::HandleReloadMessage));
|
| + web_ui_->RegisterMessageCallback("extensionSettingsEnable",
|
| + NewCallback(this,
|
| + &ExtensionSettingsHandler::HandleEnableMessage));
|
| + web_ui_->RegisterMessageCallback("extensionSettingsEnableIncognito",
|
| + NewCallback(this,
|
| + &ExtensionSettingsHandler::HandleEnableIncognitoMessage));
|
| + web_ui_->RegisterMessageCallback("extensionSettingsAllowFileAccess",
|
| + NewCallback(this,
|
| + &ExtensionSettingsHandler::HandleAllowFileAccessMessage));
|
| + web_ui_->RegisterMessageCallback("extensionSettingsUninstall",
|
| + NewCallback(this, &ExtensionSettingsHandler::HandleUninstallMessage));
|
| + web_ui_->RegisterMessageCallback("extensionSettingsOptions",
|
| + NewCallback(this, &ExtensionSettingsHandler::HandleOptionsMessage));
|
| + web_ui_->RegisterMessageCallback("extensionSettingsShowButton",
|
| + NewCallback(this, &ExtensionSettingsHandler::HandleShowButtonMessage));
|
| + web_ui_->RegisterMessageCallback("extensionSettingsLoad",
|
| + NewCallback(this, &ExtensionSettingsHandler::HandleLoadMessage));
|
| + web_ui_->RegisterMessageCallback("extensionSettingsAutoupdate",
|
| + NewCallback(this, &ExtensionSettingsHandler::HandleAutoUpdateMessage));
|
| + web_ui_->RegisterMessageCallback("extensionSettingsSelectFilePath",
|
| + NewCallback(this,
|
| + &ExtensionSettingsHandler::HandleSelectFilePathMessage));
|
| +}
|
| +
|
| +void ExtensionSettingsHandler::HandleRequestExtensionsData(
|
| + const ListValue* args) {
|
| DictionaryValue* results = new DictionaryValue();
|
|
|
| // Add the extensions to the results structure.
|
| @@ -346,7 +230,7 @@
|
| extension != extensions->end(); ++extension) {
|
| if (ShouldShowExtension(*extension)) {
|
| extensions_list->Append(CreateExtensionDetailValue(
|
| - extension_service_.get(),
|
| + extension_service_,
|
| *extension,
|
| GetActivePagesForExtension(*extension),
|
| true, false)); // enabled, terminated
|
| @@ -358,7 +242,7 @@
|
| extension != extensions->end(); ++extension) {
|
| if (ShouldShowExtension(*extension)) {
|
| extensions_list->Append(CreateExtensionDetailValue(
|
| - extension_service_.get(),
|
| + extension_service_,
|
| *extension,
|
| GetActivePagesForExtension(*extension),
|
| false, false)); // enabled, terminated
|
| @@ -371,7 +255,7 @@
|
| extension != extensions->end(); ++extension) {
|
| if (ShouldShowExtension(*extension)) {
|
| extensions_list->Append(CreateExtensionDetailValue(
|
| - extension_service_.get(),
|
| + extension_service_,
|
| *extension,
|
| empty_pages, // Terminated process has no active pages.
|
| false, true)); // enabled, terminated
|
| @@ -380,8 +264,9 @@
|
| }
|
| results->Set("extensions", extensions_list);
|
|
|
| - bool developer_mode = web_ui_->GetProfile()->GetPrefs()
|
| - ->GetBoolean(prefs::kExtensionsUIDeveloperMode);
|
| + Profile* profile = Profile::FromWebUI(web_ui_);
|
| + bool developer_mode =
|
| + profile->GetPrefs()->GetBoolean(prefs::kExtensionsUIDeveloperMode);
|
| results->SetBoolean("developerMode", developer_mode);
|
|
|
| if (icon_loader_.get())
|
| @@ -391,67 +276,72 @@
|
| icon_loader_->LoadIcons(extension_icons, results);
|
| }
|
|
|
| -void ExtensionsDOMHandler::OnIconsLoaded(DictionaryValue* json) {
|
| - web_ui_->CallJavascriptFunction(L"returnExtensionsData", *json);
|
| +void ExtensionSettingsHandler::OnIconsLoaded(DictionaryValue* json) {
|
| + web_ui_->CallJavascriptFunction("ExtensionSettings.returnExtensionsData",
|
| + *json);
|
| delete json;
|
|
|
| // Register for notifications that we need to reload the page.
|
| registrar_.RemoveAll();
|
| - registrar_.Add(this, chrome::EXTENSION_LOADED,
|
| + registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_LOADED,
|
| NotificationService::AllSources());
|
| - registrar_.Add(this, chrome::EXTENSION_PROCESS_CREATED,
|
| + registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_PROCESS_CREATED,
|
| NotificationService::AllSources());
|
| - registrar_.Add(this, chrome::EXTENSION_UNLOADED,
|
| + registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_UNLOADED,
|
| NotificationService::AllSources());
|
| - registrar_.Add(this, chrome::EXTENSION_UPDATE_DISABLED,
|
| + registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_UPDATE_DISABLED,
|
| NotificationService::AllSources());
|
| registrar_.Add(this,
|
| - chrome::NAV_ENTRY_COMMITTED,
|
| + content::NOTIFICATION_NAV_ENTRY_COMMITTED,
|
| NotificationService::AllSources());
|
| registrar_.Add(this,
|
| - chrome::RENDER_VIEW_HOST_CREATED,
|
| + content::NOTIFICATION_RENDER_VIEW_HOST_CREATED,
|
| NotificationService::AllSources());
|
| registrar_.Add(this,
|
| - chrome::RENDER_VIEW_HOST_DELETED,
|
| + content::NOTIFICATION_RENDER_VIEW_HOST_DELETED,
|
| NotificationService::AllSources());
|
| registrar_.Add(this,
|
| - chrome::BACKGROUND_CONTENTS_NAVIGATED,
|
| + chrome::NOTIFICATION_BACKGROUND_CONTENTS_NAVIGATED,
|
| NotificationService::AllSources());
|
| registrar_.Add(this,
|
| - chrome::BACKGROUND_CONTENTS_DELETED,
|
| + chrome::NOTIFICATION_BACKGROUND_CONTENTS_DELETED,
|
| NotificationService::AllSources());
|
| registrar_.Add(this,
|
| - chrome::EXTENSION_BROWSER_ACTION_VISIBILITY_CHANGED,
|
| + chrome::NOTIFICATION_EXTENSION_BROWSER_ACTION_VISIBILITY_CHANGED,
|
| NotificationService::AllSources());
|
| }
|
|
|
| -ExtensionResource ExtensionsDOMHandler::PickExtensionIcon(
|
| +ExtensionResource ExtensionSettingsHandler::PickExtensionIcon(
|
| const Extension* extension) {
|
| return extension->GetIconResource(Extension::EXTENSION_ICON_MEDIUM,
|
| ExtensionIconSet::MATCH_BIGGER);
|
| }
|
|
|
| -ExtensionUninstallDialog* ExtensionsDOMHandler::GetExtensionUninstallDialog() {
|
| +ExtensionUninstallDialog*
|
| +ExtensionSettingsHandler::GetExtensionUninstallDialog() {
|
| if (!extension_uninstall_dialog_.get()) {
|
| extension_uninstall_dialog_.reset(
|
| - new ExtensionUninstallDialog(web_ui_->GetProfile()));
|
| + new ExtensionUninstallDialog(Profile::FromWebUI(web_ui_)));
|
| }
|
| return extension_uninstall_dialog_.get();
|
| }
|
|
|
| -void ExtensionsDOMHandler::HandleToggleDeveloperMode(const ListValue* args) {
|
| - bool developer_mode = web_ui_->GetProfile()->GetPrefs()
|
| - ->GetBoolean(prefs::kExtensionsUIDeveloperMode);
|
| - web_ui_->GetProfile()->GetPrefs()->SetBoolean(
|
| +void ExtensionSettingsHandler::HandleToggleDeveloperMode(
|
| + const ListValue* args) {
|
| + Profile* profile = Profile::FromWebUI(web_ui_);
|
| + bool developer_mode =
|
| + profile->GetPrefs()->GetBoolean(prefs::kExtensionsUIDeveloperMode);
|
| + profile->GetPrefs()->SetBoolean(
|
| prefs::kExtensionsUIDeveloperMode, !developer_mode);
|
| + HandleRequestExtensionsData(NULL);
|
| }
|
|
|
| -void ExtensionsDOMHandler::HandleInspectMessage(const ListValue* args) {
|
| +void ExtensionSettingsHandler::HandleInspectMessage(const ListValue* args) {
|
| std::string render_process_id_str;
|
| std::string render_view_id_str;
|
| int render_process_id;
|
| int render_view_id;
|
| - CHECK(args->GetSize() == 2);
|
| + CHECK_EQ(2U, args->GetSize());
|
| CHECK(args->GetString(0, &render_process_id_str));
|
| CHECK(args->GetString(1, &render_view_id_str));
|
| CHECK(base::StringToInt(render_process_id_str, &render_process_id));
|
| @@ -466,24 +356,31 @@
|
| DevToolsWindow::OpenDevToolsWindow(host);
|
| }
|
|
|
| -void ExtensionsDOMHandler::HandleReloadMessage(const ListValue* args) {
|
| - std::string extension_id = WideToASCII(ExtractStringValue(args));
|
| +void ExtensionSettingsHandler::HandleReloadMessage(const ListValue* args) {
|
| + std::string extension_id = UTF16ToUTF8(ExtractStringValue(args));
|
| CHECK(!extension_id.empty());
|
| extension_service_->ReloadExtension(extension_id);
|
| }
|
|
|
| -void ExtensionsDOMHandler::HandleEnableMessage(const ListValue* args) {
|
| - CHECK(args->GetSize() == 2);
|
| +void ExtensionSettingsHandler::HandleEnableMessage(const ListValue* args) {
|
| + CHECK_EQ(2U, args->GetSize());
|
| std::string extension_id, enable_str;
|
| CHECK(args->GetString(0, &extension_id));
|
| CHECK(args->GetString(1, &enable_str));
|
| +
|
| + const Extension* extension =
|
| + extension_service_->GetExtensionById(extension_id, true);
|
| + if (!Extension::UserMayDisable(extension->location())) {
|
| + LOG(ERROR) << "Attempt to enable an extension that is non-usermanagable was"
|
| + << "made. Extension id: " << extension->id();
|
| + return;
|
| + }
|
| +
|
| if (enable_str == "true") {
|
| ExtensionPrefs* prefs = extension_service_->extension_prefs();
|
| if (prefs->DidExtensionEscalatePermissions(extension_id)) {
|
| - const Extension* extension =
|
| - extension_service_->GetExtensionById(extension_id, true);
|
| ShowExtensionDisabledDialog(extension_service_,
|
| - web_ui_->GetProfile(), extension);
|
| + Profile::FromWebUI(web_ui_), extension);
|
| } else {
|
| extension_service_->EnableExtension(extension_id);
|
| }
|
| @@ -492,8 +389,9 @@
|
| }
|
| }
|
|
|
| -void ExtensionsDOMHandler::HandleEnableIncognitoMessage(const ListValue* args) {
|
| - CHECK(args->GetSize() == 2);
|
| +void ExtensionSettingsHandler::HandleEnableIncognitoMessage(
|
| + const ListValue* args) {
|
| + CHECK_EQ(2U, args->GetSize());
|
| std::string extension_id, enable_str;
|
| CHECK(args->GetString(0, &extension_id));
|
| CHECK(args->GetString(1, &enable_str));
|
| @@ -513,12 +411,14 @@
|
| //
|
| // Bug: http://crbug.com/41384
|
| ignore_notifications_ = true;
|
| - extension_service_->SetIsIncognitoEnabled(extension, enable_str == "true");
|
| + extension_service_->SetIsIncognitoEnabled(extension->id(),
|
| + enable_str == "true");
|
| ignore_notifications_ = false;
|
| }
|
|
|
| -void ExtensionsDOMHandler::HandleAllowFileAccessMessage(const ListValue* args) {
|
| - CHECK(args->GetSize() == 2);
|
| +void ExtensionSettingsHandler::HandleAllowFileAccessMessage(
|
| + const ListValue* args) {
|
| + CHECK_EQ(2U, args->GetSize());
|
| std::string extension_id, allow_str;
|
| CHECK(args->GetString(0, &extension_id));
|
| CHECK(args->GetString(1, &allow_str));
|
| @@ -526,11 +426,18 @@
|
| extension_service_->GetExtensionById(extension_id, true);
|
| DCHECK(extension);
|
|
|
| + if (!Extension::UserMayDisable(extension->location())) {
|
| + LOG(ERROR) << "Attempt to change allow file access of an extension that is "
|
| + << "non-usermanagable was made. Extension id : "
|
| + << extension->id();
|
| + return;
|
| + }
|
| +
|
| extension_service_->SetAllowFileAccess(extension, allow_str == "true");
|
| }
|
|
|
| -void ExtensionsDOMHandler::HandleUninstallMessage(const ListValue* args) {
|
| - std::string extension_id = WideToASCII(ExtractStringValue(args));
|
| +void ExtensionSettingsHandler::HandleUninstallMessage(const ListValue* args) {
|
| + std::string extension_id = UTF16ToUTF8(ExtractStringValue(args));
|
| CHECK(!extension_id.empty());
|
| const Extension* extension =
|
| extension_service_->GetExtensionById(extension_id, true);
|
| @@ -539,6 +446,12 @@
|
| if (!extension)
|
| return;
|
|
|
| + if (!Extension::UserMayDisable(extension->location())) {
|
| + LOG(ERROR) << "Attempt to uninstall an extension that is non-usermanagable "
|
| + << "was made. Extension id : " << extension->id();
|
| + return;
|
| + }
|
| +
|
| if (!extension_id_prompting_.empty())
|
| return; // Only one prompt at a time.
|
|
|
| @@ -547,7 +460,7 @@
|
| GetExtensionUninstallDialog()->ConfirmUninstall(this, extension);
|
| }
|
|
|
| -void ExtensionsDOMHandler::ExtensionDialogAccepted() {
|
| +void ExtensionSettingsHandler::ExtensionDialogAccepted() {
|
| DCHECK(!extension_id_prompting_.empty());
|
|
|
| bool was_terminated = false;
|
| @@ -565,7 +478,8 @@
|
| return;
|
|
|
| extension_service_->UninstallExtension(extension_id_prompting_,
|
| - false /* external_uninstall */, NULL);
|
| + false, // External uninstall.
|
| + NULL); // Error.
|
| extension_id_prompting_ = "";
|
|
|
| // There will be no EXTENSION_UNLOADED notification for terminated
|
| @@ -574,92 +488,47 @@
|
| HandleRequestExtensionsData(NULL);
|
| }
|
|
|
| -void ExtensionsDOMHandler::ExtensionDialogCanceled() {
|
| +void ExtensionSettingsHandler::ExtensionDialogCanceled() {
|
| extension_id_prompting_ = "";
|
| }
|
|
|
| -void ExtensionsDOMHandler::HandleOptionsMessage(const ListValue* args) {
|
| +void ExtensionSettingsHandler::HandleOptionsMessage(const ListValue* args) {
|
| const Extension* extension = GetExtension(args);
|
| if (!extension || extension->options_url().is_empty())
|
| return;
|
| - web_ui_->GetProfile()->GetExtensionProcessManager()->OpenOptionsPage(
|
| + Profile::FromWebUI(web_ui_)->GetExtensionProcessManager()->OpenOptionsPage(
|
| extension, NULL);
|
| }
|
|
|
| -void ExtensionsDOMHandler::HandleShowButtonMessage(const ListValue* args) {
|
| +void ExtensionSettingsHandler::HandleShowButtonMessage(const ListValue* args) {
|
| const Extension* extension = GetExtension(args);
|
| extension_service_->SetBrowserActionVisibility(extension, true);
|
| }
|
|
|
| -void ExtensionsDOMHandler::HandleLoadMessage(const ListValue* args) {
|
| +void ExtensionSettingsHandler::HandleLoadMessage(const ListValue* args) {
|
| FilePath::StringType string_path;
|
| - CHECK(args->GetSize() == 1) << args->GetSize();
|
| + CHECK_EQ(1U, args->GetSize()) << args->GetSize();
|
| CHECK(args->GetString(0, &string_path));
|
| extension_service_->LoadExtension(FilePath(string_path));
|
| }
|
|
|
| -void ExtensionsDOMHandler::ShowAlert(const std::string& message) {
|
| +void ExtensionSettingsHandler::ShowAlert(const std::string& message) {
|
| ListValue arguments;
|
| arguments.Append(Value::CreateStringValue(message));
|
| - web_ui_->CallJavascriptFunction(L"alert", arguments);
|
| + web_ui_->CallJavascriptFunction("alert", arguments);
|
| }
|
|
|
| -void ExtensionsDOMHandler::HandlePackMessage(const ListValue* args) {
|
| - std::string extension_path;
|
| - std::string private_key_path;
|
| - CHECK(args->GetSize() == 2);
|
| - CHECK(args->GetString(0, &extension_path));
|
| - CHECK(args->GetString(1, &private_key_path));
|
| -
|
| - FilePath root_directory =
|
| - FilePath::FromWStringHack(UTF8ToWide(extension_path));
|
| - FilePath key_file = FilePath::FromWStringHack(UTF8ToWide(private_key_path));
|
| -
|
| - if (root_directory.empty()) {
|
| - if (extension_path.empty()) {
|
| - ShowAlert(l10n_util::GetStringUTF8(
|
| - IDS_EXTENSION_PACK_DIALOG_ERROR_ROOT_REQUIRED));
|
| - } else {
|
| - ShowAlert(l10n_util::GetStringUTF8(
|
| - IDS_EXTENSION_PACK_DIALOG_ERROR_ROOT_INVALID));
|
| - }
|
| -
|
| - return;
|
| - }
|
| -
|
| - if (!private_key_path.empty() && key_file.empty()) {
|
| - ShowAlert(l10n_util::GetStringUTF8(
|
| - IDS_EXTENSION_PACK_DIALOG_ERROR_KEY_INVALID));
|
| - return;
|
| - }
|
| -
|
| - pack_job_ = new PackExtensionJob(this, root_directory, key_file);
|
| - pack_job_->Start();
|
| -}
|
| -
|
| -void ExtensionsDOMHandler::OnPackSuccess(const FilePath& crx_file,
|
| - const FilePath& pem_file) {
|
| - ShowAlert(UTF16ToUTF8(PackExtensionJob::StandardSuccessMessage(crx_file,
|
| - pem_file)));
|
| -
|
| - ListValue results;
|
| - web_ui_->CallJavascriptFunction(L"hidePackDialog", results);
|
| -}
|
| -
|
| -void ExtensionsDOMHandler::OnPackFailure(const std::string& error) {
|
| - ShowAlert(error);
|
| -}
|
| -
|
| -void ExtensionsDOMHandler::HandleAutoUpdateMessage(const ListValue* args) {
|
| +void ExtensionSettingsHandler::HandleAutoUpdateMessage(const ListValue* args) {
|
| ExtensionUpdater* updater = extension_service_->updater();
|
| if (updater)
|
| updater->CheckNow();
|
| }
|
|
|
| -void ExtensionsDOMHandler::HandleSelectFilePathMessage(const ListValue* args) {
|
| +void ExtensionSettingsHandler::HandleSelectFilePathMessage(
|
| + const ListValue* args) {
|
| std::string select_type;
|
| std::string operation;
|
| - CHECK(args->GetSize() == 2);
|
| + CHECK_EQ(2U, args->GetSize());
|
| CHECK(args->GetString(0, &select_type));
|
| CHECK(args->GetString(1, &operation));
|
|
|
| @@ -697,22 +566,101 @@
|
| }
|
|
|
|
|
| -void ExtensionsDOMHandler::FileSelected(const FilePath& path, int index,
|
| - void* params) {
|
| +void ExtensionSettingsHandler::FileSelected(const FilePath& path, int index,
|
| + void* params) {
|
| // Add the extensions to the results structure.
|
| ListValue results;
|
| results.Append(Value::CreateStringValue(path.value()));
|
| - web_ui_->CallJavascriptFunction(L"window.handleFilePathSelected", results);
|
| + web_ui_->CallJavascriptFunction("window.handleFilePathSelected", results);
|
| }
|
|
|
| -void ExtensionsDOMHandler::MultiFilesSelected(
|
| +void ExtensionSettingsHandler::MultiFilesSelected(
|
| const std::vector<FilePath>& files, void* params) {
|
| NOTREACHED();
|
| }
|
|
|
| -void ExtensionsDOMHandler::Observe(int type,
|
| - const NotificationSource& source,
|
| - const NotificationDetails& details) {
|
| +void ExtensionSettingsHandler::GetLocalizedValues(
|
| + DictionaryValue* localized_strings) {
|
| + DCHECK(localized_strings);
|
| +
|
| + RegisterTitle(localized_strings, "extensionSettings",
|
| + IDS_OPTIONS_GENERAL_TAB_LABEL);
|
| +
|
| + localized_strings->SetString("extensionSettingsTitle",
|
| + l10n_util::GetStringUTF16(IDS_MANAGE_EXTENSIONS_SETTING_WINDOWS_TITLE));
|
| + localized_strings->SetString("extensionSettingsVisitWebsite",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_VISIT_WEBSITE));
|
| +
|
| + localized_strings->SetString("extensionSettingsDeveloperMode",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_DEVELOPER_MODE_LINK));
|
| + localized_strings->SetString("extensionSettingsNoExtensions",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_NONE_INSTALLED));
|
| + localized_strings->SetString("extensionSettingsSuggestGallery",
|
| + l10n_util::GetStringFUTF16(IDS_EXTENSIONS_NONE_INSTALLED_SUGGEST_GALLERY,
|
| + ASCIIToUTF16("<a href='") +
|
| + ASCIIToUTF16(google_util::AppendGoogleLocaleParam(
|
| + GURL(extension_urls::GetWebstoreLaunchURL())).spec()) +
|
| + ASCIIToUTF16("'>"),
|
| + ASCIIToUTF16("</a>")));
|
| + localized_strings->SetString("extensionSettingsGetMoreExtensions",
|
| + ASCIIToUTF16("<a href='") +
|
| + ASCIIToUTF16(google_util::AppendGoogleLocaleParam(
|
| + GURL(extension_urls::GetWebstoreLaunchURL())).spec()) +
|
| + ASCIIToUTF16("'>") +
|
| + l10n_util::GetStringUTF16(IDS_GET_MORE_EXTENSIONS) +
|
| + ASCIIToUTF16("</a>"));
|
| + localized_strings->SetString("extensionSettingsExtensionId",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_ID));
|
| + localized_strings->SetString("extensionSettingsExtensionPath",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_PATH));
|
| + localized_strings->SetString("extensionSettingsInspectViews",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_INSPECT_VIEWS));
|
| + localized_strings->SetString("extensionSettingsEnable",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_ENABLE));
|
| + localized_strings->SetString("extensionSettingsEnabled",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_ENABLED));
|
| + localized_strings->SetString("extensionSettingsRemove",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_REMOVE));
|
| + localized_strings->SetString("extensionSettingsEnableIncognito",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_ENABLE_INCOGNITO));
|
| + localized_strings->SetString("extensionSettingsAllowFileAccess",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_ALLOW_FILE_ACCESS));
|
| + localized_strings->SetString("extensionSettingsIncognitoWarning",
|
| + l10n_util::GetStringFUTF16(IDS_EXTENSIONS_INCOGNITO_WARNING,
|
| + l10n_util::GetStringUTF16(IDS_PRODUCT_NAME)));
|
| + localized_strings->SetString("extensionSettingsReload",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_RELOAD));
|
| + localized_strings->SetString("extensionSettingsOptions",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_OPTIONS));
|
| + localized_strings->SetString("extensionSettingsPolicyControlled",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_POLICY_CONTROLLED));
|
| + localized_strings->SetString("extensionSettingsShowButton",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_SHOW_BUTTON));
|
| + localized_strings->SetString("extensionSettingsLoadUnpackedButton",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_LOAD_UNPACKED_BUTTON));
|
| + localized_strings->SetString("extensionSettingsPackButton",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_PACK_BUTTON));
|
| + localized_strings->SetString("extensionSettingsUpdateButton",
|
| + l10n_util::GetStringUTF16(IDS_EXTENSIONS_UPDATE_BUTTON));
|
| +}
|
| +
|
| +void ExtensionSettingsHandler::Initialize() {
|
| +}
|
| +
|
| +WebUIMessageHandler* ExtensionSettingsHandler::Attach(WebUI* web_ui) {
|
| + // Call through to superclass.
|
| + WebUIMessageHandler* handler = OptionsPageUIHandler::Attach(web_ui);
|
| +
|
| + extension_service_ = Profile::FromWebUI(web_ui_)
|
| + ->GetOriginalProfile()->GetExtensionService();
|
| +
|
| + // Return result from the superclass.
|
| + return handler;
|
| +}
|
| +
|
| +void ExtensionSettingsHandler::Observe(int type,
|
| + const NotificationSource& source,
|
| + const NotificationDetails& details) {
|
| switch (type) {
|
| // We listen for notifications that will result in the page being
|
| // repopulated with data twice for the same event in certain cases.
|
| @@ -728,22 +676,22 @@
|
| //
|
| // Doing it this way gets everything but causes the page to be rendered
|
| // more than we need. It doesn't seem to result in any noticeable flicker.
|
| - case chrome::RENDER_VIEW_HOST_DELETED:
|
| - deleting_rvh_ = Details<RenderViewHost>(details).ptr();
|
| + case content::NOTIFICATION_RENDER_VIEW_HOST_DELETED:
|
| + deleting_rvh_ = Source<RenderViewHost>(source).ptr();
|
| MaybeUpdateAfterNotification();
|
| break;
|
| - case chrome::BACKGROUND_CONTENTS_DELETED:
|
| + case chrome::NOTIFICATION_BACKGROUND_CONTENTS_DELETED:
|
| deleting_rvh_ = Details<BackgroundContents>(details)->render_view_host();
|
| MaybeUpdateAfterNotification();
|
| break;
|
| - case chrome::EXTENSION_LOADED:
|
| - case chrome::EXTENSION_PROCESS_CREATED:
|
| - case chrome::EXTENSION_UNLOADED:
|
| - case chrome::EXTENSION_UPDATE_DISABLED:
|
| - case chrome::RENDER_VIEW_HOST_CREATED:
|
| - case chrome::NAV_ENTRY_COMMITTED:
|
| - case chrome::BACKGROUND_CONTENTS_NAVIGATED:
|
| - case chrome::EXTENSION_BROWSER_ACTION_VISIBILITY_CHANGED:
|
| + case chrome::NOTIFICATION_EXTENSION_LOADED:
|
| + case chrome::NOTIFICATION_EXTENSION_PROCESS_CREATED:
|
| + case chrome::NOTIFICATION_EXTENSION_UNLOADED:
|
| + case chrome::NOTIFICATION_EXTENSION_UPDATE_DISABLED:
|
| + case content::NOTIFICATION_RENDER_VIEW_HOST_CREATED:
|
| + case content::NOTIFICATION_NAV_ENTRY_COMMITTED:
|
| + case chrome::NOTIFICATION_BACKGROUND_CONTENTS_NAVIGATED:
|
| + case chrome::NOTIFICATION_EXTENSION_BROWSER_ACTION_VISIBILITY_CHANGED:
|
| MaybeUpdateAfterNotification();
|
| break;
|
| default:
|
| @@ -751,20 +699,20 @@
|
| }
|
| }
|
|
|
| -const Extension* ExtensionsDOMHandler::GetExtension(const ListValue* args) {
|
| - std::string extension_id = WideToASCII(ExtractStringValue(args));
|
| +const Extension* ExtensionSettingsHandler::GetExtension(const ListValue* args) {
|
| + std::string extension_id = UTF16ToUTF8(ExtractStringValue(args));
|
| CHECK(!extension_id.empty());
|
| return extension_service_->GetExtensionById(extension_id, true);
|
| }
|
|
|
| -void ExtensionsDOMHandler::MaybeUpdateAfterNotification() {
|
| +void ExtensionSettingsHandler::MaybeUpdateAfterNotification() {
|
| if (!ignore_notifications_ && web_ui_->tab_contents())
|
| HandleRequestExtensionsData(NULL);
|
| deleting_rvh_ = NULL;
|
| }
|
|
|
| // Static
|
| -DictionaryValue* ExtensionsDOMHandler::CreateExtensionDetailValue(
|
| +DictionaryValue* ExtensionSettingsHandler::CreateExtensionDetailValue(
|
| ExtensionService* service, const Extension* extension,
|
| const std::vector<ExtensionPage>& pages, bool enabled, bool terminated) {
|
| DictionaryValue* extension_data = new DictionaryValue();
|
| @@ -772,11 +720,16 @@
|
| extension_data->SetString("id", extension->id());
|
| extension_data->SetString("name", extension->name());
|
| extension_data->SetString("description", extension->description());
|
| + extension_data->SetString("path", extension->path().value());
|
| extension_data->SetString("version", extension->version()->GetString());
|
| + extension_data->SetBoolean("isUnpacked",
|
| + extension->location() == Extension::LOAD);
|
| + extension_data->SetBoolean("mayDisable",
|
| + Extension::UserMayDisable(extension->location()));
|
| extension_data->SetBoolean("enabled", enabled);
|
| extension_data->SetBoolean("terminated", terminated);
|
| extension_data->SetBoolean("enabledIncognito",
|
| - service ? service->IsIncognitoEnabled(extension) : false);
|
| + service ? service->IsIncognitoEnabled(extension->id()) : false);
|
| extension_data->SetBoolean("wantsFileAccess", extension->wants_file_access());
|
| extension_data->SetBoolean("allowFileAccess",
|
| service ? service->AllowFileAccess(extension) : false);
|
| @@ -791,7 +744,7 @@
|
| else
|
| extension_data->SetInteger("order", 2);
|
|
|
| - if (!extension->options_url().is_empty())
|
| + if (!extension->options_url().is_empty() && enabled)
|
| extension_data->SetString("options_url", extension->options_url().spec());
|
|
|
| if (service && !service->GetBrowserActionVisibility(extension))
|
| @@ -822,7 +775,7 @@
|
| return extension_data;
|
| }
|
|
|
| -std::vector<ExtensionPage> ExtensionsDOMHandler::GetActivePagesForExtension(
|
| +std::vector<ExtensionPage> ExtensionSettingsHandler::GetActivePagesForExtension(
|
| const Extension* extension) {
|
| std::vector<ExtensionPage> result;
|
|
|
| @@ -847,7 +800,7 @@
|
| return result;
|
| }
|
|
|
| -void ExtensionsDOMHandler::GetActivePagesForExtensionProcess(
|
| +void ExtensionSettingsHandler::GetActivePagesForExtensionProcess(
|
| RenderProcessHost* process,
|
| const Extension* extension,
|
| std::vector<ExtensionPage> *result) {
|
| @@ -875,49 +828,8 @@
|
| continue;
|
| }
|
|
|
| - result->push_back(ExtensionPage(url, process->id(), host->routing_id(),
|
| - process->profile()->IsOffTheRecord()));
|
| + result->push_back(
|
| + ExtensionPage(url, process->id(), host->routing_id(),
|
| + process->browser_context()->IsOffTheRecord()));
|
| }
|
| }
|
| -
|
| -ExtensionsDOMHandler::~ExtensionsDOMHandler() {
|
| - // There may be pending file dialogs, we need to tell them that we've gone
|
| - // away so they don't try and call back to us.
|
| - if (load_extension_dialog_.get())
|
| - load_extension_dialog_->ListenerDestroyed();
|
| -
|
| - if (pack_job_.get())
|
| - pack_job_->ClearClient();
|
| -
|
| - if (icon_loader_.get())
|
| - icon_loader_->Cancel();
|
| -}
|
| -
|
| -// ExtensionsDOMHandler, public: -----------------------------------------------
|
| -
|
| -ExtensionsUI::ExtensionsUI(TabContents* contents) : ChromeWebUI(contents) {
|
| - ExtensionService *exstension_service =
|
| - GetProfile()->GetOriginalProfile()->GetExtensionService();
|
| -
|
| - ExtensionsDOMHandler* handler = new ExtensionsDOMHandler(exstension_service);
|
| - AddMessageHandler(handler);
|
| - handler->Attach(this);
|
| -
|
| - ExtensionsUIHTMLSource* html_source = new ExtensionsUIHTMLSource();
|
| -
|
| - // Set up the chrome://extensions/ source.
|
| - contents->profile()->GetChromeURLDataManager()->AddDataSource(html_source);
|
| -}
|
| -
|
| -// static
|
| -RefCountedMemory* ExtensionsUI::GetFaviconResourceBytes() {
|
| - return ResourceBundle::GetSharedInstance().
|
| - LoadDataResourceBytes(IDR_PLUGIN);
|
| -}
|
| -
|
| -// static
|
| -void ExtensionsUI::RegisterUserPrefs(PrefService* prefs) {
|
| - prefs->RegisterBooleanPref(prefs::kExtensionsUIDeveloperMode,
|
| - false,
|
| - PrefService::SYNCABLE_PREF);
|
| -}
|
|
|