Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Side by Side Diff: webrequest.js

Issue 8354161: Align whitelisting behavior in Chrome with Firefox (Closed)
Patch Set: Created Sept. 17, 2012, 2:52 p.m.
Left:
Right:
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View unified diff | Download patch
« background.js ('K') | « include.preload.js ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * This Source Code is subject to the terms of the Mozilla Public License 2 * This Source Code is subject to the terms of the Mozilla Public License
3 * version 2.0 (the "License"). You can obtain a copy of the License at 3 * version 2.0 (the "License"). You can obtain a copy of the License at
4 * http://mozilla.org/MPL/2.0/. 4 * http://mozilla.org/MPL/2.0/.
5 */ 5 */
6 6
7 chrome.webRequest.onBeforeRequest.addListener(onBeforeRequest, {urls: ["http://* /*", "https://*/*"]}, ["blocking"]); 7 chrome.webRequest.onBeforeRequest.addListener(onBeforeRequest, {urls: ["http://* /*", "https://*/*"]}, ["blocking"]);
8 chrome.webRequest.onBeforeSendHeaders.addListener(onBeforeSendHeaders, {urls: [" http://*/*", "https://*/*"]}, ["requestHeaders", "blocking"]); 8 chrome.webRequest.onBeforeSendHeaders.addListener(onBeforeSendHeaders, {urls: [" http://*/*", "https://*/*"]}, ["requestHeaders", "blocking"]);
9 chrome.tabs.onRemoved.addListener(forgetTab); 9 chrome.tabs.onRemoved.addListener(forgetTab);
10 10
11 var frames = {}; 11 var frames = {};
12 var tabs = {};
13 12
14 function onBeforeRequest(details) 13 function onBeforeRequest(details)
15 { 14 {
15 if (details.tabId == -1)
16 return {};
17
16 var type = details.type; 18 var type = details.type;
17 if (type == "main_frame" || type == "sub_frame") 19 if (type == "main_frame" || type == "sub_frame")
18 recordFrame(details.tabId, details.frameId, details.url, type == "main_frame "); 20 recordFrame(details.tabId, details.frameId, details.parentFrameId, details.u rl, type == "main_frame");
Felix Dahlke 2012/09/18 13:23:14 type == "main_frame" is redundant here, I'd assign
19 21
20 if (type == "main_frame") 22 if (type == "main_frame")
21 return; 23 return {};
22 24
23 // Type names match Mozilla's with main_frame and sub_frame being the only exc eptions. 25 // Type names match Mozilla's with main_frame and sub_frame being the only exc eptions.
24 if (type == "sub_frame") 26 if (type == "sub_frame")
25 type = "SUBDOCUMENT"; 27 type = "SUBDOCUMENT";
26 else 28 else
27 type = type.toUpperCase(); 29 type = type.toUpperCase();
28 30
29 var documentUrl = getFrameUrl(details.tabId, details.frameId); 31 var frame = (type != "SUBDOCUMENT" ? details.frameId : details.parentFrameId);
30 var topUrl = getTabUrl(details.tabId); 32 var filter = checkRequest(type, details.tabId, details.url, frame);
31 if (type == "SUBDOCUMENT")
32 documentUrl = getFrameUrl(details.tabId, details.parentFrameId) || topUrl;
33
34 var filter = checkRequest(type, details.url, documentUrl, topUrl);
35 if (filter instanceof BlockingFilter) 33 if (filter instanceof BlockingFilter)
36 { 34 {
37 var collapse = filter.collapse; 35 var collapse = filter.collapse;
38 if (collapse == null) 36 if (collapse == null)
39 collapse = (localStorage["hidePlaceholders"] != "false"); 37 collapse = (localStorage["hidePlaceholders"] != "false");
40 if (collapse && type == "SUBDOCUMENT") 38 if (collapse && type == "SUBDOCUMENT")
41 return {redirectUrl: "about:blank"}; 39 return {redirectUrl: "about:blank"};
42 else if (collapse && type == "IMAGE") 40 else if (collapse && type == "IMAGE")
43 return {redirectUrl: " ABCAYAAAAfFcSJAAAACklEQVR4nGMAAQAABQABDQottAAAAABJRU5ErkJggg=="}; 41 return {redirectUrl: " ABCAYAAAAfFcSJAAAACklEQVR4nGMAAQAABQABDQottAAAAABJRU5ErkJggg=="};
44 else 42 else
(...skipping 11 matching lines...) Expand all
56 var headers = details.requestHeaders || []; 54 var headers = details.requestHeaders || [];
57 if (!headers.some(function(header) { header.name == "DNT";})) 55 if (!headers.some(function(header) { header.name == "DNT";}))
58 { 56 {
59 headers.push({name: "DNT", value: "1"}); 57 headers.push({name: "DNT", value: "1"});
60 return {requestHeaders: headers}; 58 return {requestHeaders: headers};
61 } 59 }
62 } 60 }
63 return null; 61 return null;
64 } 62 }
65 63
66 function recordFrame(tabId, frameId, frameUrl, isMain) 64 function recordFrame(tabId, frameId, parentFrameId, frameUrl, isMain)
Felix Dahlke 2012/09/18 13:23:14 This parameter is no longer used, it could be remo
67 { 65 {
68 if (!(tabId in frames)) 66 if (!(tabId in frames))
69 frames[tabId] = {}; 67 frames[tabId] = {};
70 frames[tabId][frameId] = frameUrl; 68 frames[tabId][frameId] = {url: frameUrl, parent: parentFrameId};
71
72 if (isMain)
73 tabs[tabId] = frameUrl;
74 } 69 }
75 70
76 function getFrameUrl(tabId, frameId) 71 function getFrameUrl(tabId, frameId)
77 { 72 {
78 if (tabId in frames && frameId in frames[tabId]) 73 if (tabId in frames && frameId in frames[tabId])
79 return frames[tabId][frameId]; 74 return frames[tabId][frameId].url;
80 return null; 75 return null;
81 } 76 }
82 77
83 function getTabUrl(tabId) 78 function getFrameParent(tabId, frameId)
84 { 79 {
85 if (tabId in tabs) 80 if (tabId in frames && frameId in frames[tabId])
86 return tabs[tabId]; 81 return frames[tabId][frameId].parent;
87 return null; 82 return -1;
88 } 83 }
89 84
90 function forgetTab(tabId) 85 function forgetTab(tabId)
91 { 86 {
92 delete frames[tabId]; 87 delete frames[tabId];
93 delete tabs[tabId];
94 } 88 }
95 89
96 function checkRequest(type, url, documentUrl, topUrl) 90 function checkRequest(type, tabId, url, frameId)
97 { 91 {
98 if (topUrl && isWhitelisted(topUrl)) 92 if (isFrameWhitelisted(tabId, frameId))
99 return false; 93 return false;
100 94
95 var documentUrl = getFrameUrl(tabId, frameId);
101 if (!documentUrl) 96 if (!documentUrl)
102 documentUrl = topUrl; 97 return false;
103 98
104 var requestHost = extractHostFromURL(url); 99 var requestHost = extractHostFromURL(url);
105 var documentHost = extractHostFromURL(documentUrl); 100 var documentHost = extractHostFromURL(documentUrl);
106 var thirdParty = isThirdParty(requestHost, documentHost); 101 var thirdParty = isThirdParty(requestHost, documentHost);
107 return defaultMatcher.matchesAny(url, type, documentHost, thirdParty); 102 return defaultMatcher.matchesAny(url, type, documentHost, thirdParty);
108 } 103 }
104
105 function isFrameWhitelisted(tabId, frameId, type)
106 {
107 var parent = frameId;
108 while (parent != -1)
109 {
110 var parentUrl = getFrameUrl(tabId, parent);
111 if (parentUrl && isWhitelisted(parentUrl, type))
112 return true;
113 parent = getFrameParent(tabId, parent);
114 }
115 return false;
116 }
OLDNEW
« background.js ('K') | « include.preload.js ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld