| Index: webrequest.js |
| =================================================================== |
| --- a/webrequest.js |
| +++ b/webrequest.js |
| @@ -46,102 +46,24 @@ |
| } |
| }); |
| -var frames = new TabMap(); |
| - |
| -function onBeforeRequest(url, type, tab, frameId, parentFrameId) |
| +function onBeforeRequest(url, type, tab, frame) |
| { |
| - if (!tab) |
| + if (isFrameWhitelisted(tab, frame)) |
| return true; |
| - // Assume that the first request belongs to the top frame. Chrome may give the |
| - // top frame the type "object" instead of "main_frame". |
| - // https://code.google.com/p/chromium/issues/detail?id=281711 |
| - if (frameId == 0 && !frames.has(tab) && type == "object") |
| - type = "main_frame"; |
| + var docDomain = extractHostFromURL(frame.url); |
| + var filter = defaultMatcher.matchesAny( |
| + url, |
| + type == "sub_frame" ? "SUBDOCUMENT" : type.toUpperCase(), |
| + docDomain, |
| + isThirdParty(extractHostFromURL(url), docDomain) |
| + ); |
| - if (type == "main_frame" || type == "sub_frame") |
| - { |
| - recordFrame(tab, frameId, parentFrameId, url); |
| - |
| - if (type == "main_frame") |
| - return true; |
| - |
| - type = "subdocument"; |
| - frameId = parentFrameId; |
| - } |
| - |
| - var filter = checkRequest(type.toUpperCase(), tab, url, frameId); |
| FilterNotifier.triggerListeners("filter.hitCount", filter, 0, 0, tab); |
| return !(filter instanceof BlockingFilter); |
| } |
| -function recordFrame(tab, frameId, parentFrameId, url) |
| -{ |
| - var framesOfTab = frames.get(tab); |
| - |
| - if (!framesOfTab) |
| - frames.set(tab, (framesOfTab = {})); |
| - |
| - framesOfTab[frameId] = {url: url, parent: parentFrameId}; |
| -} |
| - |
| -function getFrameData(tab, frameId) |
| -{ |
| - var framesOfTab = frames.get(tab); |
| - |
| - if (framesOfTab) |
| - { |
| - if (frameId in framesOfTab) |
| - return framesOfTab[frameId]; |
| - |
| - // We don't know anything about javascript: or data: frames, use top frame |
| - if (frameId != -1) |
| - return framesOfTab[0]; |
| - } |
| -} |
| - |
| -function getFrameUrl(tab, frameId) |
| -{ |
| - var frameData = getFrameData(tab, frameId); |
| - return (frameData ? frameData.url : null); |
| -} |
| - |
| -function checkRequest(type, tab, url, frameId) |
| -{ |
| - if (isFrameWhitelisted(tab, frameId)) |
| - return false; |
| - |
| - var documentUrl = getFrameUrl(tab, frameId); |
| - if (!documentUrl) |
| - return false; |
| - |
| - var requestHost = extractHostFromURL(url); |
| - var documentHost = extractHostFromURL(documentUrl); |
| - var thirdParty = isThirdParty(requestHost, documentHost); |
| - return defaultMatcher.matchesAny(url, type, documentHost, thirdParty); |
| -} |
| - |
| -function isFrameWhitelisted(tab, frameId, type) |
| -{ |
| - var parent = frameId; |
| - var parentData = getFrameData(tab, parent); |
| - while (parentData) |
| - { |
| - var frame = parent; |
| - var frameData = parentData; |
| - |
| - parent = frameData.parent; |
| - parentData = getFrameData(tab, parent); |
| - |
| - var frameUrl = frameData.url; |
| - var parentUrl = (parentData ? parentData.url : frameUrl); |
| - if ("keyException" in frameData || isWhitelisted(frameUrl, parentUrl, type)) |
| - return true; |
| - } |
| - return false; |
| -} |
| - |
| -ext.webRequest.onBeforeRequest.addListener(onBeforeRequest, ["http://*/*", "https://*/*"]); |
| +ext.webRequest.onBeforeRequest.addListener(onBeforeRequest); |
| if (require("info").platform == "chromium") |
| { |
| @@ -150,58 +72,22 @@ |
| if (details.tabId == -1) |
| return; |
| - var type = details.type; |
| - if (type != "main_frame" && type != "sub_frame") |
| + if (details.type != "main_frame" && details.type != "sub_frame") |
| return; |
| var tab = new Tab({id: details.tabId}); |
| - var url = getFrameUrl(tab, details.frameId); |
| - if (url != details.url) |
| + var frame = new Frame({id: details.frameId, tab: tab}); |
| + |
| + if (frame.url != details.url) |
| return; |
| - var key = null; |
| - var signature = null; |
| for (var i = 0; i < details.responseHeaders.length; i++) |
| { |
| var header = details.responseHeaders[i]; |
| if (header.name.toLowerCase() == "x-adblock-key" && header.value) |
| - { |
| - var index = header.value.indexOf("_"); |
| - if (index >= 0) |
| - { |
| - key = header.value.substr(0, index); |
| - signature = header.value.substr(index + 1); |
| - break; |
| - } |
| - } |
| - } |
| - if (!key) |
| - return; |
| - |
| - var parentUrl = null; |
| - if (type == "sub_frame") |
| - parentUrl = getFrameUrl(tab, details.parentFrameId); |
| - if (!parentUrl) |
| - parentUrl = url; |
| - var docDomain = extractHostFromURL(parentUrl); |
| - var keyMatch = defaultMatcher.matchesByKey(url, key.replace(/=/g, ""), docDomain); |
| - if (keyMatch) |
| - { |
| - // Website specifies a key that we know but is the signature valid? |
| - var uri = new URI(url); |
| - var host = uri.asciiHost; |
| - if (uri.port > 0) |
| - host += ":" + uri.port; |
| - |
| - var params = [ |
| - uri.path.replace(/#.*/, ""), // REQUEST_URI |
| - host, // HTTP_HOST |
| - window.navigator.userAgent // HTTP_USER_AGENT |
| - ]; |
| - if (verifySignature(key, signature, params.join("\0"))) |
| - frames.get(tab)[details.frameId].keyException = true; |
| + processKeyException(header.value, tab, frame); |
| } |
| } |
| - chrome.webRequest.onHeadersReceived.addListener(onHeadersReceived, {urls: ["http://*/*", "https://*/*"]}, ["responseHeaders"]); |
| + chrome.webRequest.onHeadersReceived.addListener(onHeadersReceived, {urls: ["<all_urls>"]}, ["responseHeaders"]); |
| } |