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

Unified Diff: extensions/common/permissions/permissions_data.cc

Issue 439843002: Merge 280354 "Have the Debugger extension api check that it has ..." (Closed) Base URL: svn://svn.chromium.org/chrome/branches/2062/src/
Patch Set: Created 6 years, 4 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: extensions/common/permissions/permissions_data.cc
===================================================================
--- extensions/common/permissions/permissions_data.cc (revision 287393)
+++ extensions/common/permissions/permissions_data.cc (working copy)
@@ -17,6 +17,7 @@
#include "extensions/common/url_pattern_set.h"
#include "extensions/common/user_script.h"
#include "url/gurl.h"
+#include "url/url_constants.h"
namespace extensions {
@@ -70,6 +71,48 @@
whitelist.end();
}
+// static
+bool PermissionsData::IsRestrictedUrl(const GURL& document_url,
+ const GURL& top_frame_url,
+ const Extension* extension,
+ std::string* error) {
+ if (CanExecuteScriptEverywhere(extension))
+ return false;
+
+ // Check if the scheme is valid for extensions. If not, return.
+ if (!URLPattern::IsValidSchemeForExtensions(document_url.scheme()) &&
+ document_url.spec() != url::kAboutBlankURL) {
+ if (error) {
+ *error = ErrorUtils::FormatErrorMessage(
+ manifest_errors::kCannotAccessPage,
+ document_url.spec());
+ }
+ return true;
+ }
+
+ if (!ExtensionsClient::Get()->IsScriptableURL(document_url, error))
+ return true;
+
+ bool allow_on_chrome_urls = base::CommandLine::ForCurrentProcess()->HasSwitch(
+ switches::kExtensionsOnChromeURLs);
+ if (document_url.SchemeIs(content::kChromeUIScheme) &&
+ !allow_on_chrome_urls) {
+ if (error)
+ *error = manifest_errors::kCannotAccessChromeUrl;
+ return true;
+ }
+
+ if (top_frame_url.SchemeIs(kExtensionScheme) &&
+ top_frame_url.host() != extension->id() &&
+ !allow_on_chrome_urls) {
+ if (error)
+ *error = manifest_errors::kCannotAccessExtensionUrl;
+ return true;
+ }
+
+ return false;
+}
+
void PermissionsData::SetActivePermissions(
const PermissionSet* permissions) const {
base::AutoLock auto_lock(runtime_lock_);
@@ -283,31 +326,9 @@
return false;
}
- bool can_execute_everywhere = CanExecuteScriptEverywhere(extension);
- if (!can_execute_everywhere &&
- !ExtensionsClient::Get()->IsScriptableURL(document_url, error)) {
+ if (IsRestrictedUrl(document_url, top_frame_url, extension, error))
return false;
- }
- if (!base::CommandLine::ForCurrentProcess()->HasSwitch(
- switches::kExtensionsOnChromeURLs)) {
- if (document_url.SchemeIs(content::kChromeUIScheme) &&
- !can_execute_everywhere) {
- if (error)
- *error = manifest_errors::kCannotAccessChromeUrl;
- return false;
- }
- }
-
- if (top_frame_url.SchemeIs(kExtensionScheme) &&
- top_frame_url.GetOrigin() !=
- Extension::GetBaseURLFromExtensionId(extension->id()).GetOrigin() &&
- !can_execute_everywhere) {
- if (error)
- *error = manifest_errors::kCannotAccessExtensionUrl;
- return false;
- }
-
if (HasTabSpecificPermissionToExecuteScript(tab_id, top_frame_url))
return true;
« no previous file with comments | « extensions/common/permissions/permissions_data.h ('k') | extensions/common/permissions/permissions_data_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698