Fix permission regression where warnings aren't shown in the dialog

A regression was introduced in r275142 causing the permissions dialog to not
show permissions. Obviously very bad. Fixed, and added a regression test.

BUG=397900

Review URL: https://codereview.chromium.org/448883002

Cr-Commit-Position: refs/heads/master@{#288365}
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@288365 0039d316-1c4b-4281-b951-d872f2087c98
parent 6827a944
...@@ -711,22 +711,18 @@ void ExtensionInstallPrompt::ShowConfirmation() { ...@@ -711,22 +711,18 @@ void ExtensionInstallPrompt::ShowConfirmation() {
else else
prompt_->set_experiment(ExtensionInstallPromptExperiment::ControlGroup()); prompt_->set_experiment(ExtensionInstallPromptExperiment::ControlGroup());
if (permissions_.get()) { if (permissions_.get() &&
if (extension_) { (!extension_ ||
const extensions::PermissionsData* permissions_data = !extensions::PermissionsData::ShouldSkipPermissionWarnings(
extension_->permissions_data(); extension_->id()))) {
prompt_->SetPermissions(permissions_data->GetPermissionMessageStrings()); Manifest::Type type =
prompt_->SetPermissionsDetails( extension_ ? extension_->GetType() : Manifest::TYPE_UNKNOWN;
permissions_data->GetPermissionMessageDetailsStrings()); const extensions::PermissionMessageProvider* message_provider =
} else { extensions::PermissionMessageProvider::Get();
const extensions::PermissionMessageProvider* message_provider = prompt_->SetPermissions(
extensions::PermissionMessageProvider::Get(); message_provider->GetWarningMessages(permissions_, type));
prompt_->SetPermissions(message_provider->GetWarningMessages( prompt_->SetPermissionsDetails(
permissions_, Manifest::TYPE_UNKNOWN)); message_provider->GetWarningMessagesDetails(permissions_, type));
prompt_->SetPermissionsDetails(
message_provider->GetWarningMessagesDetails(permissions_,
Manifest::TYPE_UNKNOWN));
}
} }
switch (prompt_->type()) { switch (prompt_->type()) {
......
...@@ -362,6 +362,10 @@ class ExtensionInstallPrompt ...@@ -362,6 +362,10 @@ class ExtensionInstallPrompt
// Installation failed. This is declared virtual for testing. // Installation failed. This is declared virtual for testing.
virtual void OnInstallFailure(const extensions::CrxInstallerError& error); virtual void OnInstallFailure(const extensions::CrxInstallerError& error);
void set_callback_for_test(const ShowDialogCallback& show_dialog_callback) {
show_dialog_callback_ = show_dialog_callback;
}
protected: protected:
friend class extensions::ExtensionWebstorePrivateApiTest; friend class extensions::ExtensionWebstorePrivateApiTest;
friend class WebstoreStartupInstallUnpackFailureTest; friend class WebstoreStartupInstallUnpackFailureTest;
......
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "base/bind.h"
#include "base/memory/ref_counted.h"
#include "base/run_loop.h"
#include "chrome/browser/extensions/extension_install_prompt.h"
#include "content/public/test/test_browser_thread_bundle.h"
#include "extensions/common/extension.h"
#include "extensions/common/extension_builder.h"
#include "extensions/common/permissions/api_permission.h"
#include "extensions/common/permissions/api_permission_set.h"
#include "extensions/common/permissions/manifest_permission_set.h"
#include "extensions/common/permissions/permission_set.h"
#include "extensions/common/url_pattern_set.h"
#include "extensions/common/value_builder.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace extensions {
void VerifyPromptPermissionsCallback(
const base::Closure& quit_closure,
const ExtensionInstallPrompt::ShowParams& params,
ExtensionInstallPrompt::Delegate* delegate,
scoped_refptr<ExtensionInstallPrompt::Prompt> install_prompt) {
ASSERT_TRUE(install_prompt.get());
EXPECT_EQ(1u, install_prompt->GetPermissionCount());
quit_closure.Run();
}
TEST(ExtensionInstallPromptUnittest, PromptShowsPermissionWarnings) {
content::TestBrowserThreadBundle thread_bundle;
APIPermissionSet api_permissions;
api_permissions.insert(APIPermission::kTab);
scoped_refptr<PermissionSet> permission_set =
new PermissionSet(api_permissions,
ManifestPermissionSet(),
URLPatternSet(),
URLPatternSet());
scoped_refptr<const Extension> extension =
ExtensionBuilder().SetManifest(
DictionaryBuilder().Set("name", "foo")
.Set("version", "1.0")
.Set("manifest_version", 2)
.Set("description", "Random Ext")).Build();
ExtensionInstallPrompt prompt(NULL /* no web contents in this test */);
base::RunLoop run_loop;
prompt.set_callback_for_test(base::Bind(&VerifyPromptPermissionsCallback,
run_loop.QuitClosure()));
prompt.ConfirmPermissions(NULL, // no delegate
extension,
permission_set);
run_loop.Run();
}
} // namespace extensions
...@@ -944,6 +944,7 @@ ...@@ -944,6 +944,7 @@
'browser/extensions/extension_gcm_app_handler_unittest.cc', 'browser/extensions/extension_gcm_app_handler_unittest.cc',
'browser/extensions/extension_icon_manager_unittest.cc', 'browser/extensions/extension_icon_manager_unittest.cc',
'browser/extensions/extension_install_checker_unittest.cc', 'browser/extensions/extension_install_checker_unittest.cc',
'browser/extensions/extension_install_prompt_unittest.cc',
'browser/extensions/extension_message_bubble_controller_unittest.cc', 'browser/extensions/extension_message_bubble_controller_unittest.cc',
'browser/extensions/extension_path_util_unittest.cc', 'browser/extensions/extension_path_util_unittest.cc',
'browser/extensions/extension_prefs_unittest.cc', 'browser/extensions/extension_prefs_unittest.cc',
......
...@@ -25,12 +25,6 @@ namespace { ...@@ -25,12 +25,6 @@ namespace {
PermissionsData::PolicyDelegate* g_policy_delegate = NULL; PermissionsData::PolicyDelegate* g_policy_delegate = NULL;
// Returns true if this extension id is from a trusted provider.
bool ShouldSkipPermissionWarnings(const std::string& extension_id) {
// See http://b/4946060 for more details.
return extension_id == std::string("nckgahadagoaajjgafhacjanaoiihapd");
}
} // namespace } // namespace
PermissionsData::PermissionsData(const Extension* extension) PermissionsData::PermissionsData(const Extension* extension)
...@@ -72,6 +66,12 @@ bool PermissionsData::CanExecuteScriptEverywhere(const Extension* extension) { ...@@ -72,6 +66,12 @@ bool PermissionsData::CanExecuteScriptEverywhere(const Extension* extension) {
whitelist.end(); whitelist.end();
} }
bool PermissionsData::ShouldSkipPermissionWarnings(
const std::string& extension_id) {
// See http://b/4946060 for more details.
return extension_id == std::string("nckgahadagoaajjgafhacjanaoiihapd");
}
// static // static
bool PermissionsData::IsRestrictedUrl(const GURL& document_url, bool PermissionsData::IsRestrictedUrl(const GURL& document_url,
const GURL& top_frame_url, const GURL& top_frame_url,
......
...@@ -76,6 +76,10 @@ class PermissionsData { ...@@ -76,6 +76,10 @@ class PermissionsData {
// whitelist of extensions that can script all pages. // whitelist of extensions that can script all pages.
static bool CanExecuteScriptEverywhere(const Extension* extension); static bool CanExecuteScriptEverywhere(const Extension* extension);
// Returns true if we should skip the permisisons warning for the extension
// with the given |extension_id|.
static bool ShouldSkipPermissionWarnings(const std::string& extension_id);
// Returns true if the given |url| is restricted for the given |extension|, // Returns true if the given |url| is restricted for the given |extension|,
// as is commonly the case for chrome:// urls. // as is commonly the case for chrome:// urls.
// NOTE: You probably want to use CanAccessPage(). // NOTE: You probably want to use CanAccessPage().
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment