Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(5500)

Unified Diff: chrome/browser/extensions/api/developer_private/developer_private_api.cc

Issue 1085113002: [Extensions UI] Use developerPrivate API for repair, options, show path (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/extensions/api/developer_private/developer_private_api.cc
diff --git a/chrome/browser/extensions/api/developer_private/developer_private_api.cc b/chrome/browser/extensions/api/developer_private/developer_private_api.cc
index 7a8ea017b7ea0239a29604e45c3b7986ba652a04..68c050749cd4e46f08daa42c138dc668f6e3b8ec 100644
--- a/chrome/browser/extensions/api/developer_private/developer_private_api.cc
+++ b/chrome/browser/extensions/api/developer_private/developer_private_api.cc
@@ -21,16 +21,21 @@
#include "chrome/browser/extensions/api/file_handlers/app_file_handler_util.h"
#include "chrome/browser/extensions/devtools_util.h"
#include "chrome/browser/extensions/extension_service.h"
+#include "chrome/browser/extensions/extension_tab_util.h"
#include "chrome/browser/extensions/extension_ui_util.h"
#include "chrome/browser/extensions/extension_util.h"
#include "chrome/browser/extensions/install_verifier.h"
#include "chrome/browser/extensions/shared_module_service.h"
#include "chrome/browser/extensions/unpacked_installer.h"
#include "chrome/browser/extensions/updater/extension_updater.h"
+#include "chrome/browser/extensions/webstore_reinstaller.h"
+#include "chrome/browser/platform_util.h"
#include "chrome/browser/prefs/incognito_mode_prefs.h"
#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/ui/apps/app_info_dialog.h"
#include "chrome/browser/ui/browser_finder.h"
+#include "chrome/browser/ui/extensions/app_launch_params.h"
+#include "chrome/browser/ui/extensions/application_launch.h"
#include "chrome/browser/ui/tabs/tab_strip_model.h"
#include "chrome/common/extensions/api/developer_private.h"
#include "chrome/common/extensions/manifest_handlers/app_launch_info.h"
@@ -62,6 +67,7 @@
#include "extensions/common/install_warning.h"
#include "extensions/common/manifest.h"
#include "extensions/common/manifest_handlers/icons_handler.h"
+#include "extensions/common/manifest_handlers/options_page_info.h"
#include "extensions/common/permissions/permissions_data.h"
#include "extensions/grit/extensions_browser_resources.h"
#include "storage/browser/fileapi/external_mount_points.h"
@@ -95,6 +101,8 @@ const char kCouldNotFindWebContentsError[] =
"Could not find a valid web contents.";
const char kCannotUpdateSupervisedProfileSettingsError[] =
"Cannot change settings for a supervised profile.";
+const char kNoOptionsPageForExtensionError[] =
+ "Extension does not have an options page.";
const char kUnpackedAppsFolder[] = "apps_target";
const char kManifestFile[] = "manifest.json";
@@ -103,10 +111,6 @@ ExtensionService* GetExtensionService(content::BrowserContext* context) {
return ExtensionSystem::Get(context)->extension_service();
}
-ExtensionUpdater* GetExtensionUpdater(Profile* profile) {
- return GetExtensionService(profile)->updater();
-}
-
GURL GetImageURLFromData(const std::string& contents) {
std::string contents_base64;
base::Base64Encode(contents, &contents_base64);
@@ -365,16 +369,19 @@ const Extension* DeveloperPrivateAPIFunction::GetExtensionById(
id, ExtensionRegistry::EVERYTHING);
}
-bool DeveloperPrivateAutoUpdateFunction::RunSync() {
- ExtensionUpdater* updater = GetExtensionUpdater(GetProfile());
- if (updater)
- updater->CheckNow(ExtensionUpdater::CheckParams());
- SetResult(new base::FundamentalValue(true));
- return true;
-}
-
DeveloperPrivateAutoUpdateFunction::~DeveloperPrivateAutoUpdateFunction() {}
+ExtensionFunction::ResponseAction DeveloperPrivateAutoUpdateFunction::Run() {
+ ExtensionUpdater* updater =
+ ExtensionSystem::Get(browser_context())->extension_service()->updater();
+ if (updater) {
+ ExtensionUpdater::CheckParams params;
+ params.install_immediately = true;
+ updater->CheckNow(params);
+ }
+ return RespondNow(NoArguments());
+}
+
DeveloperPrivateGetExtensionsInfoFunction::
~DeveloperPrivateGetExtensionsInfoFunction() {
}
@@ -1271,6 +1278,81 @@ DeveloperPrivateDeleteExtensionErrorsFunction::Run() {
return RespondNow(NoArguments());
}
+DeveloperPrivateRepairExtensionFunction::
+~DeveloperPrivateRepairExtensionFunction() {}
+
+ExtensionFunction::ResponseAction
+DeveloperPrivateRepairExtensionFunction::Run() {
+ scoped_ptr<developer::RepairExtension::Params> params(
+ developer::RepairExtension::Params::Create(*args_));
+ EXTENSION_FUNCTION_VALIDATE(params);
+ const Extension* extension = GetExtensionById(params->extension_id);
+ if (!extension)
+ return RespondNow(Error(kNoSuchExtensionError));
+
+ content::WebContents* web_contents = GetSenderWebContents();
+ if (!web_contents)
+ return RespondNow(Error(kCouldNotFindWebContentsError));
+
+ scoped_refptr<WebstoreReinstaller> reinstaller(new WebstoreReinstaller(
+ web_contents,
+ params->extension_id,
+ base::Bind(&DeveloperPrivateRepairExtensionFunction::OnReinstallComplete,
+ this)));
+ reinstaller->BeginReinstall();
+
+ return RespondLater();
+}
+
+void DeveloperPrivateRepairExtensionFunction::OnReinstallComplete(
+ bool success,
+ const std::string& error,
+ webstore_install::Result result) {
+ if (!success)
+ Respond(Error(error));
+ else
+ Respond(NoArguments());
not at google - send to devlin 2015/04/16 17:33:25 There is a single precedent in this file to do Res
Devlin 2015/04/16 17:59:12 Done.
+}
+
+DeveloperPrivateShowOptionsFunction::~DeveloperPrivateShowOptionsFunction() {}
+
+ExtensionFunction::ResponseAction DeveloperPrivateShowOptionsFunction::Run() {
+ scoped_ptr<developer::ShowOptions::Params> params(
+ developer::ShowOptions::Params::Create(*args_));
+ EXTENSION_FUNCTION_VALIDATE(params);
+ const Extension* extension =
+ ExtensionRegistry::Get(browser_context())->enabled_extensions().GetByID(
+ params->extension_id);
not at google - send to devlin 2015/04/16 17:33:25 Use GetExtensionById?
Devlin 2015/04/16 17:59:12 Well, we only want enabled extensions. But maybe t
+ if (!extension)
+ return RespondNow(Error(kNoSuchExtensionError));
+ if (OptionsPageInfo::GetOptionsPage(extension).is_empty())
+ return RespondNow(Error(kNoOptionsPageForExtensionError));
+ content::WebContents* web_contents = GetSenderWebContents();
+ if (!web_contents)
+ return RespondNow(Error(kCouldNotFindWebContentsError));
+ ExtensionTabUtil::OpenOptionsPage(
+ extension,
+ chrome::FindBrowserWithWebContents(web_contents));
+ return RespondNow(NoArguments());
+}
+
+DeveloperPrivateShowPathFunction::~DeveloperPrivateShowPathFunction() {}
+
+ExtensionFunction::ResponseAction DeveloperPrivateShowPathFunction::Run() {
+ scoped_ptr<developer::ShowPath::Params> params(
+ developer::ShowPath::Params::Create(*args_));
+ EXTENSION_FUNCTION_VALIDATE(params);
+ const Extension* extension = GetExtensionById(params->extension_id);
+ if (!extension)
+ return RespondNow(Error(kNoSuchExtensionError));
+
+ // We explicitly show manifest.json in order to work around an issue in OSX
+ // where opening the directory doesn't focus the Finder.
+ platform_util::ShowItemInFolder(GetProfile(),
+ extension->path().Append(kManifestFilename));
+ return RespondNow(NoArguments());
+}
+
} // namespace api
} // namespace extensions

Powered by Google App Engine
This is Rietveld 408576698