mirror of
https://github.com/kkapsner/CanvasBlocker
synced 2025-01-22 03:18:31 +01:00
Added clear interval
Also ensures that the persistent data is loaded correctly in ESR. Fixes #139 and #143
This commit is contained in:
parent
ec1c5ae7d8
commit
3cb1974b18
@ -189,6 +189,43 @@
|
|||||||
"description": ""
|
"description": ""
|
||||||
},
|
},
|
||||||
|
|
||||||
|
"persistentRndClearInterval_title": {
|
||||||
|
"message": "Löschintervall der persistenten Daten",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearInterval_description": {
|
||||||
|
"message": "Nach dem eingestellten Intervall werden die persistenten Daten automatisch gelöscht. (Null eingeben, um es zu deaktivieren.)",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.seconds": {
|
||||||
|
"message": "Sekunden",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.minutes": {
|
||||||
|
"message": "Minuten",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.hours": {
|
||||||
|
"message": "Stunden",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.days": {
|
||||||
|
"message": "Tage",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.weeks": {
|
||||||
|
"message": "Wochen",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.months": {
|
||||||
|
"message": "Monate",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.years": {
|
||||||
|
"message": "Jahre",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
|
||||||
"clearPersistentRnd_title": {
|
"clearPersistentRnd_title": {
|
||||||
"message": "Persistenten Speicher leeren",
|
"message": "Persistenten Speicher leeren",
|
||||||
"description": ""
|
"description": ""
|
||||||
|
@ -189,6 +189,43 @@
|
|||||||
"description": ""
|
"description": ""
|
||||||
},
|
},
|
||||||
|
|
||||||
|
"persistentRndClearInterval_title": {
|
||||||
|
"message": "Clear interval of the persistent data",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearInterval_description": {
|
||||||
|
"message": "After the specified interval the persistent data is cleared automatically. (Enter zero to disable.)",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.seconds": {
|
||||||
|
"message": "seconds",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.minutes": {
|
||||||
|
"message": "minutes",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.hours": {
|
||||||
|
"message": "hours",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.days": {
|
||||||
|
"message": "days",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.weeks": {
|
||||||
|
"message": "weeks",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.months": {
|
||||||
|
"message": "months",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
"persistentRndClearIntervalUnit_options.years": {
|
||||||
|
"message": "years",
|
||||||
|
"description": ""
|
||||||
|
},
|
||||||
|
|
||||||
"clearPersistentRnd_title": {
|
"clearPersistentRnd_title": {
|
||||||
"message": "Clear persistent random storage",
|
"message": "Clear persistent random storage",
|
||||||
"description": ""
|
"description": ""
|
||||||
|
@ -85,13 +85,13 @@
|
|||||||
metaLog("logging queue cleared");
|
metaLog("logging queue cleared");
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
settings.on("isStillDefault", scope.clearQueue);
|
settings.loaded.then(scope.clearQueue);
|
||||||
scope.error = error;
|
scope.error = error;
|
||||||
scope.warning = warning;
|
scope.warning = warning;
|
||||||
scope.message = message;
|
scope.message = message;
|
||||||
scope.notice = notice;
|
scope.notice = notice;
|
||||||
scope.verbose = verbose;
|
scope.verbose = verbose;
|
||||||
|
|
||||||
require.emit("./logging");
|
require.emit("./logging");
|
||||||
|
|
||||||
metaLog("logging available");
|
metaLog("logging available");
|
||||||
|
49
lib/main.js
49
lib/main.js
@ -9,33 +9,13 @@
|
|||||||
const {error, warning, message, notice, verbose, } = logging;
|
const {error, warning, message, notice, verbose, } = logging;
|
||||||
const lists = require("./lists");
|
const lists = require("./lists");
|
||||||
logging.setPrefix("main script");
|
logging.setPrefix("main script");
|
||||||
|
const persistentRndStorage = require("./persistentRndStorage");
|
||||||
|
|
||||||
message("start of background script");
|
message("start of background script");
|
||||||
message("waiting for settings to be loaded");
|
message("waiting for settings to be loaded");
|
||||||
settings.onloaded(function(){
|
settings.onloaded(function(){
|
||||||
notice("everything loaded");
|
notice("everything loaded");
|
||||||
|
|
||||||
notice("build persistent storage");
|
|
||||||
var persistentRnd = Object.create(null);
|
|
||||||
try {
|
|
||||||
let storedData = JSON.parse(settings.persistentRndStorage);
|
|
||||||
for (var domain in storedData){
|
|
||||||
var value = storedData[domain];
|
|
||||||
if (
|
|
||||||
Array.isArray(value) &&
|
|
||||||
value.length === 128 &&
|
|
||||||
value.every(function(value){
|
|
||||||
return typeof value === "number" && value >= 0 && value < 256;
|
|
||||||
})
|
|
||||||
){
|
|
||||||
persistentRnd[domain] = value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch(e){
|
|
||||||
// JSON is not valid -> ignore it
|
|
||||||
}
|
|
||||||
|
|
||||||
function updateContentScripts(){
|
function updateContentScripts(){
|
||||||
message("update content scripts");
|
message("update content scripts");
|
||||||
notice("build settings blob");
|
notice("build settings blob");
|
||||||
@ -51,24 +31,26 @@
|
|||||||
warning("TODO: register content scripts -> have to wait for the API to be released");
|
warning("TODO: register content scripts -> have to wait for the API to be released");
|
||||||
}
|
}
|
||||||
updateContentScripts();
|
updateContentScripts();
|
||||||
|
persistentRndStorage.init();
|
||||||
|
|
||||||
message("register non port message listener");
|
message("register non port message listener");
|
||||||
browser.runtime.onMessage.addListener(function(data){
|
browser.runtime.onMessage.addListener(function(data){
|
||||||
notice("got data without port", data);
|
notice("got data without port", data);
|
||||||
|
var keys = Object.keys(data);
|
||||||
if (data["canvasBlocker-new-domain-rnd"]){
|
if (data["canvasBlocker-new-domain-rnd"]){
|
||||||
verbose("got new domain rnd", data["canvasBlocker-new-domain-rnd"]);
|
persistentRndStorage.setDomainData(
|
||||||
data["canvasBlocker-set-domain-rnd"] = data["canvasBlocker-new-domain-rnd"];
|
data["canvasBlocker-new-domain-rnd"].domain,
|
||||||
persistentRnd[data["canvasBlocker-new-domain-rnd"].domain] = data["canvasBlocker-new-domain-rnd"].rnd;
|
data["canvasBlocker-new-domain-rnd"].rnd
|
||||||
if (settings.storePersistentRnd){
|
);
|
||||||
settings.persistentRndStorage = JSON.stringify(persistentRnd);
|
if (keys.length === 1){
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
updateContentScripts();
|
updateContentScripts();
|
||||||
}
|
}
|
||||||
if (data["canvasBlocker-clear-domain-rnd"]){
|
if (data["canvasBlocker-clear-domain-rnd"]){
|
||||||
verbose("domain rnd cleared");
|
persistentRndStorage.clear();
|
||||||
persistentRnd = Object.create(null);
|
if (keys.length === 1){
|
||||||
if (settings.storePersistentRnd){
|
return;
|
||||||
settings.persistentRndStorage = JSON.stringify(persistentRnd);
|
|
||||||
}
|
}
|
||||||
updateContentScripts();
|
updateContentScripts();
|
||||||
}
|
}
|
||||||
@ -84,10 +66,10 @@
|
|||||||
browser.runtime.onConnect.addListener(function(port){
|
browser.runtime.onConnect.addListener(function(port){
|
||||||
notice("got port", port);
|
notice("got port", port);
|
||||||
verbose("send back the tab id", port.sender.tab.id);
|
verbose("send back the tab id", port.sender.tab.id);
|
||||||
verbose("send back the persistent random seeds", persistentRnd);
|
verbose("send back the persistent random seeds", persistentRndStorage.persistentRnd);
|
||||||
port.postMessage({
|
port.postMessage({
|
||||||
tabId: port.sender.tab.id,
|
tabId: port.sender.tab.id,
|
||||||
persistentRnd: persistentRnd
|
persistentRnd: persistentRndStorage.persistentRnd
|
||||||
});
|
});
|
||||||
var url = new URL(port.sender.url);
|
var url = new URL(port.sender.url);
|
||||||
port.onMessage.addListener(function(data){
|
port.onMessage.addListener(function(data){
|
||||||
@ -116,9 +98,6 @@
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
settings.on("storePersistentRnd", function({newValue}){
|
|
||||||
settings.persistentRndStorage = newValue? JSON.stringify(persistentRnd): "";
|
|
||||||
});
|
|
||||||
|
|
||||||
// hide page action when a tab is refreshed
|
// hide page action when a tab is refreshed
|
||||||
browser.tabs.onUpdated.addListener(function(tabId, data){
|
browser.tabs.onUpdated.addListener(function(tabId, data){
|
||||||
|
111
lib/persistentRndStorage.js
Normal file
111
lib/persistentRndStorage.js
Normal file
@ -0,0 +1,111 @@
|
|||||||
|
/* 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 {
|
||||||
|
scope = {};
|
||||||
|
window.scope.persistentRndStorage = scope;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const settings = require("./settings");
|
||||||
|
const logging = require("./logging");
|
||||||
|
|
||||||
|
scope.persistentRnd = Object.create(null);
|
||||||
|
scope.init = function init(){
|
||||||
|
logging.message("initializing persistent rng storage");
|
||||||
|
|
||||||
|
logging.notice("build persistent storage");
|
||||||
|
|
||||||
|
if (settings.storePersistentRnd){
|
||||||
|
try {
|
||||||
|
let storedData = JSON.parse(settings.persistentRndStorage);
|
||||||
|
for (var domain in storedData){
|
||||||
|
var value = storedData[domain];
|
||||||
|
if (
|
||||||
|
Array.isArray(value) &&
|
||||||
|
value.length === 128 &&
|
||||||
|
value.every(function(value){
|
||||||
|
return typeof value === "number" && value >= 0 && value < 256;
|
||||||
|
})
|
||||||
|
){
|
||||||
|
scope.persistentRnd[domain] = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (e){
|
||||||
|
// JSON is not valid -> ignore it
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
settings.persistentRndStorage = "";
|
||||||
|
settings.lastPersistentRndClearing = Date.now();
|
||||||
|
}
|
||||||
|
|
||||||
|
registerTimeout();
|
||||||
|
|
||||||
|
logging.notice("register settings change event listener");
|
||||||
|
settings.on(["persistentRndClearIntervalValue", "persistentRndClearIntervalUnit"], function(){
|
||||||
|
window.clearTimeout(clearTimeout);
|
||||||
|
registerTimeout();
|
||||||
|
});
|
||||||
|
settings.on("storePersistentRnd", function({newValue}){
|
||||||
|
settings.persistentRndStorage = newValue? JSON.stringify(scope.persistentRnd): "";
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
const getInterval = function(){
|
||||||
|
var units = {
|
||||||
|
seconds: 1000,
|
||||||
|
minutes: 60 * 1000,
|
||||||
|
hours: 60 * 60 * 1000,
|
||||||
|
days: 24 * 60 * 60 * 1000,
|
||||||
|
weeks: 7 * 24 * 60 * 60 * 1000,
|
||||||
|
months: 30 * 24 * 60 * 60 * 1000,
|
||||||
|
years: 365 * 24 * 60 * 60 * 1000,
|
||||||
|
};
|
||||||
|
return function getInterval(){
|
||||||
|
return settings.persistentRndClearIntervalValue * units[settings.persistentRndClearIntervalUnit] || 0;
|
||||||
|
};
|
||||||
|
}();
|
||||||
|
|
||||||
|
let clearTimeout;
|
||||||
|
function registerTimeout(){
|
||||||
|
var interval = getInterval();
|
||||||
|
if (interval > 0){
|
||||||
|
var timeout = settings.lastPersistentRndClearing + interval - Date.now();
|
||||||
|
logging.message("registering persistent rng data clearing timeout. Clearing in ", timeout, "ms");
|
||||||
|
clearTimeout = window.setTimeout(clear, timeout);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function broadcast(data){
|
||||||
|
browser.tabs.query({}).then(function(tabs){
|
||||||
|
tabs.forEach(function(tab){
|
||||||
|
browser.tabs.sendMessage(tab.id, data);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
function clear(){
|
||||||
|
logging.verbose("domain rnd cleared");
|
||||||
|
scope.persistentRnd = Object.create(null);
|
||||||
|
settings.persistentRndStorage = JSON.stringify(scope.persistentRnd);
|
||||||
|
settings.lastPersistentRndClearing = Date.now();
|
||||||
|
registerTimeout();
|
||||||
|
broadcast({"canvasBlocker-clear-domain-rnd": true});
|
||||||
|
}
|
||||||
|
function setDomainData(domain, rnd){
|
||||||
|
logging.verbose("got new domain rnd for ", domain, ":", rnd);
|
||||||
|
scope.persistentRnd[domain] = rnd;
|
||||||
|
settings.persistentRndStorage = JSON.stringify(scope.persistentRnd);
|
||||||
|
broadcast({"canvasBlocker-set-domain-rnd": {domain, rnd}});
|
||||||
|
}
|
||||||
|
|
||||||
|
scope.clear = clear;
|
||||||
|
scope.setDomainData = setDomainData;
|
||||||
|
}());
|
@ -12,6 +12,8 @@
|
|||||||
window.scope.randomSupplies = {};
|
window.scope.randomSupplies = {};
|
||||||
scope = window.scope.randomSupplies;
|
scope = window.scope.randomSupplies;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const settings = require("./settings");
|
||||||
|
|
||||||
function getDomain(window){
|
function getDomain(window){
|
||||||
if (!window.location.href || window.location.href === "about:blank"){
|
if (!window.location.href || window.location.href === "about:blank"){
|
||||||
@ -26,6 +28,26 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
var persistentRnd = Object.create(null);
|
var persistentRnd = Object.create(null);
|
||||||
|
settings.onloaded(function(){
|
||||||
|
try {
|
||||||
|
let storedData = JSON.parse(settings.persistentRndStorage);
|
||||||
|
for (var domain in storedData){
|
||||||
|
var value = storedData[domain];
|
||||||
|
if (
|
||||||
|
Array.isArray(value) &&
|
||||||
|
value.length === 128 &&
|
||||||
|
value.every(function(value){
|
||||||
|
return typeof value === "number" && value >= 0 && value < 256;
|
||||||
|
})
|
||||||
|
){
|
||||||
|
persistentRnd[domain] = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (e){
|
||||||
|
// JSON is not valid -> ignore it
|
||||||
|
}
|
||||||
|
});
|
||||||
const getPersistentRnd = (function(){
|
const getPersistentRnd = (function(){
|
||||||
|
|
||||||
browser.runtime.onMessage.addListener(function(data){
|
browser.runtime.onMessage.addListener(function(data){
|
||||||
|
@ -59,6 +59,19 @@
|
|||||||
name: "storePersistentRnd",
|
name: "storePersistentRnd",
|
||||||
defaultValue: false
|
defaultValue: false
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: "persistentRndClearIntervalValue",
|
||||||
|
defaultValue: 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "persistentRndClearIntervalUnit",
|
||||||
|
defaultValue: "days",
|
||||||
|
options: ["seconds", "minutes", "hours", "days", "weeks", "months", "years"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "lastPersistentRndClearing",
|
||||||
|
defaultValue: 0
|
||||||
|
},
|
||||||
{
|
{
|
||||||
name: "askOnlyOnce",
|
name: "askOnlyOnce",
|
||||||
defaultValue: true
|
defaultValue: true
|
||||||
|
@ -98,11 +98,18 @@
|
|||||||
}).forEach(...args);
|
}).forEach(...args);
|
||||||
};
|
};
|
||||||
scope.on = function onSettingsChange(name, callback){
|
scope.on = function onSettingsChange(name, callback){
|
||||||
if (eventHandler.hasOwnProperty(name)){
|
if (Array.isArray(name)){
|
||||||
eventHandler[name].push(callback);
|
name.forEach(function(name){
|
||||||
|
onSettingsChange(name, callback);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
logging.warning("Unable to register event handler for unknown setting", name);
|
if (eventHandler.hasOwnProperty(name)){
|
||||||
|
eventHandler[name].push(callback);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
logging.warning("Unable to register event handler for unknown setting", name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -13,6 +13,7 @@
|
|||||||
"lib/settings.js",
|
"lib/settings.js",
|
||||||
"lib/logging.js",
|
"lib/logging.js",
|
||||||
"lib/lists.js",
|
"lib/lists.js",
|
||||||
|
"lib/persistentRndStorage.js",
|
||||||
"lib/main.js"
|
"lib/main.js"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -25,4 +25,13 @@
|
|||||||
input[type=""], input[type="text"], input[type="number"], select {
|
input[type=""], input[type="text"], input[type="number"], select {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
*.multiple2 {
|
||||||
|
width: 50% !important;
|
||||||
|
}
|
||||||
|
*.multiple3 {
|
||||||
|
width: 33% !important;
|
||||||
|
}
|
||||||
|
*.multiple4 {
|
||||||
|
width: 25% !important;
|
||||||
}
|
}
|
@ -31,7 +31,13 @@
|
|||||||
settingsDisplay.forEach(function(display){
|
settingsDisplay.forEach(function(display){
|
||||||
var setting = settings.getDefinition(display.name);
|
var setting = settings.getDefinition(display.name);
|
||||||
if (!setting){
|
if (!setting){
|
||||||
if (callbacks[display.name]){
|
if (display.inputs){
|
||||||
|
setting = {
|
||||||
|
name: display.name,
|
||||||
|
inputs: display.inputs.map(settings.getDefinition)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
else if (callbacks[display.name]){
|
||||||
setting = {
|
setting = {
|
||||||
name: display.name,
|
name: display.name,
|
||||||
action: callbacks[display.name]
|
action: callbacks[display.name]
|
||||||
|
@ -140,6 +140,14 @@
|
|||||||
if (setting.action){
|
if (setting.action){
|
||||||
interaction = createButton(setting);
|
interaction = createButton(setting);
|
||||||
}
|
}
|
||||||
|
else if (setting.inputs){
|
||||||
|
interaction = document.createElement("span");
|
||||||
|
setting.inputs.forEach(function(inputSetting){
|
||||||
|
var input = createInput(inputSetting);
|
||||||
|
input.classList.add("multiple" + setting.inputs.length);
|
||||||
|
interaction.appendChild(input);
|
||||||
|
});
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
interaction = createInput(setting);
|
interaction = createInput(setting);
|
||||||
}
|
}
|
||||||
|
@ -51,6 +51,15 @@
|
|||||||
"displayAdvancedSettings": [true]
|
"displayAdvancedSettings": [true]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "persistentRndClearInterval",
|
||||||
|
"inputs": ["persistentRndClearIntervalValue", "persistentRndClearIntervalUnit"],
|
||||||
|
"displayDependencies": {
|
||||||
|
"blockMode": ["fakeReadout", "fakeInput"],
|
||||||
|
"rng": ["persistent"],
|
||||||
|
"displayAdvancedSettings": [true]
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "clearPersistentRnd",
|
"name": "clearPersistentRnd",
|
||||||
"displayDependencies": {
|
"displayDependencies": {
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
Version 0.4.1:
|
Version 0.4.1:
|
||||||
changes:
|
changes:
|
||||||
- improved design of the page action display
|
- improved design of the page action display
|
||||||
-
|
- Enabled Firefox ESR
|
||||||
|
- persistent random generator data is always stored in the settings but cleared on restart if the store flag is not set
|
||||||
|
|
||||||
new features:
|
new features:
|
||||||
-
|
- setting to set an interval to clear the persistent random generator data
|
||||||
|
|
||||||
fixes:
|
fixes:
|
||||||
- unnecessary check for context type in getImageData broke websites
|
- unnecessary check for context type in getImageData broke websites
|
||||||
|
Loading…
x
Reference in New Issue
Block a user