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

Unified Diff: extensions/browser/api/web_request/web_request_api.cc

Issue 2495353003: chrome.webRequest support for ExtensionSettings (Closed)
Patch Set: Clean up tests & comments Created 3 years, 7 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/browser/api/web_request/web_request_api.cc
diff --git a/extensions/browser/api/web_request/web_request_api.cc b/extensions/browser/api/web_request/web_request_api.cc
index d2e230904eab9a3009dd1badf2bc0149b903aa46..c04ced36354e476a8e9dfe9be204d22c93a3fb62 100644
--- a/extensions/browser/api/web_request/web_request_api.cc
+++ b/extensions/browser/api/web_request/web_request_api.cc
@@ -1499,6 +1499,18 @@ void ExtensionWebRequestEventRouter::GetMatchingListenersImpl(
extension_info_map, listener->id.extension_id, url,
frame_data.tab_id, crosses_incognito,
WebRequestPermissions::REQUIRE_HOST_PERMISSION);
+
+ // Check if URL blocked from view/modification due to a policy protected
+ // origin.
+ if (extension_info_map) {
+ const extensions::Extension* extension =
+ extension_info_map->extensions().GetByID(listener->id.extension_id);
+ if (request->initiator() &&
+ extension->permissions_data()->IsRuntimeBlockedHost(
+ request->initiator()->GetURLWithoutSuborigin()))
+ access = PermissionsData::ACCESS_DENIED;
+ }
+
if (access != PermissionsData::ACCESS_ALLOWED) {
if (access == PermissionsData::ACCESS_WITHHELD &&
web_request_event_router_delegate_) {

Powered by Google App Engine
This is Rietveld 408576698