mirror of
https://github.com/kkapsner/CanvasBlocker
synced 2025-01-10 13:45:07 +01:00
8389165b70
They are protected and do not need to be blocked (like data-URLs). Fixes #212 and fixes #213.
42 lines
1.0 KiB
JavaScript
42 lines
1.0 KiB
JavaScript
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
(function(){
|
|
"use strict";
|
|
|
|
var scope;
|
|
if ((typeof exports) !== "undefined"){
|
|
scope = exports;
|
|
}
|
|
else {
|
|
window.scope.dataUrls = {};
|
|
scope = window.scope.dataUrls;
|
|
}
|
|
|
|
const logging = require("./logging");
|
|
const settings = require("./settings");
|
|
|
|
scope.init = function(){
|
|
const cspMatch = "blob: filesystem: *";
|
|
browser.webRequest.onHeadersReceived.addListener(
|
|
function(details){
|
|
const headers = details.responseHeaders;
|
|
if (settings.blockDataURLs){
|
|
logging.verbose("Adding CSP header to", details);
|
|
headers.push({
|
|
name: "Content-Security-Policy",
|
|
value: `object-src ${cspMatch}; frame-src ${cspMatch}; worker-src ${cspMatch}`
|
|
});
|
|
}
|
|
return {
|
|
responseHeaders: headers
|
|
};
|
|
},
|
|
{
|
|
urls: ["<all_urls>"]
|
|
},
|
|
["blocking", "responseHeaders"]
|
|
);
|
|
};
|
|
|
|
}()); |