mirror of
https://github.com/kkapsner/CanvasBlocker
synced 2025-01-25 21:10:41 +01:00
152 lines
4.1 KiB
JavaScript
152 lines
4.1 KiB
JavaScript
/* globals iframeAPI*/
|
|
const createLog = function(){
|
|
"use strict";
|
|
|
|
const div = document.getElementById("log");
|
|
|
|
return function createLog(){
|
|
const logDiv = document.createElement("div");
|
|
logDiv.className = "log";
|
|
div.appendChild(logDiv);
|
|
return function createLine(str){
|
|
const logLine = document.createElement("div");
|
|
logLine.className = "logLine";
|
|
logDiv.appendChild(logLine);
|
|
logLine.textContent = str;
|
|
return {
|
|
update: function updateLine(str){
|
|
str = str.replace("{old content}", logLine.textContent);
|
|
logLine.textContent = str;
|
|
},
|
|
mark: function mark(marktext){
|
|
logLine.classList.add("marked");
|
|
logLine.title += marktext + "\n";
|
|
}
|
|
};
|
|
};
|
|
};
|
|
}();
|
|
|
|
const log = createLog();
|
|
|
|
const userAgentIsConsistent = document.getElementById("serverUserAgent").text === navigator.userAgent;
|
|
const consistencyLine = log("user agent equal between server and client: " + userAgentIsConsistent);
|
|
if (!userAgentIsConsistent){
|
|
consistencyLine.mark();
|
|
}
|
|
const lines = {};
|
|
|
|
function processNavigatorObject(navigator, keys, name){
|
|
"use strict";
|
|
|
|
keys.sort().forEach(function(property){
|
|
const value = navigator[property];
|
|
if ((typeof value) === "string"){
|
|
if (!lines[property]){
|
|
lines[property] = {
|
|
values: [],
|
|
log: log(property + ": ")
|
|
};
|
|
}
|
|
const propertyLine = lines[property];
|
|
if (propertyLine.values.indexOf(value) === -1){
|
|
propertyLine.log.update("{old content}" + (propertyLine.values.length? " | ": "") + value);
|
|
propertyLine.values.push(value);
|
|
}
|
|
if (propertyLine.values[0] !== value){
|
|
propertyLine.log.mark("failed test " + name);
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
iframeAPI.forEachMethod(async function(windowToUse, name){
|
|
"use strict";
|
|
|
|
const navigator = windowToUse.navigator;
|
|
const values = {};
|
|
const keys = Object.keys(navigator.__proto__);
|
|
keys.forEach(function(property){
|
|
const value = navigator[property];
|
|
if ((typeof value) === "string"){
|
|
values[property] = value;
|
|
}
|
|
});
|
|
const storage = await navigator.storage.estimate();
|
|
values.storage_quota = storage.quota.toString(10);
|
|
keys.push("storage_quota");
|
|
console.log(name, values);
|
|
processNavigatorObject(values, keys, name);
|
|
});
|
|
|
|
function processWorkerNavigatorObject(data, name){
|
|
"use strict";
|
|
console.log(name, data);
|
|
processNavigatorObject(data.values, Object.keys(data.values), name);
|
|
if (data.nestedValues){
|
|
processWorkerNavigatorObject(data.nestedValues, "nested " + name);
|
|
}
|
|
}
|
|
|
|
const worker = new Worker("navigatorTestWorker.js", {name: "Worker"});
|
|
worker.addEventListener("message", function(event){
|
|
"use strict";
|
|
|
|
processWorkerNavigatorObject(event.data, "Worker");
|
|
worker.terminate();
|
|
});
|
|
|
|
fetch("navigatorTestWorker.js").then(function(response){
|
|
"use strict";
|
|
|
|
return response.text();
|
|
}).then(function(code){
|
|
"use strict";
|
|
|
|
const blob = new Blob([code], {type: "text/javascript"});
|
|
const blobWorker = new Worker(URL.createObjectURL(blob), {name: "BlobWorker"});
|
|
blobWorker.addEventListener("message", function(event){
|
|
processWorkerNavigatorObject(event.data, "BlobWorker");
|
|
blobWorker.terminate();
|
|
});
|
|
|
|
return blobWorker;
|
|
}).catch(function(error){
|
|
"use strict";
|
|
|
|
console.error("Unable to create BlobWorker:", error);
|
|
});
|
|
|
|
const sharedWorker = new SharedWorker("navigatorTestWorker.js", {name: "SharedWorker"});
|
|
sharedWorker.port.addEventListener("message", function(event){
|
|
"use strict";
|
|
|
|
processWorkerNavigatorObject(event.data, "SharedWorker");
|
|
sharedWorker.port.close();
|
|
});
|
|
sharedWorker.port.start();
|
|
|
|
navigator.serviceWorker.register("navigatorTestWorker.js").then(function(registration){
|
|
"use strict";
|
|
|
|
const worker = (registration.active || registration.waiting || registration.installing);
|
|
navigator.serviceWorker.addEventListener("message", function(event){
|
|
processWorkerNavigatorObject(event.data, "ServiceWorker");
|
|
registration.unregister();
|
|
});
|
|
if (worker.state !== "activated"){
|
|
worker.addEventListener("statechange", function(){
|
|
if (worker.state === "activated"){
|
|
worker.postMessage("send");
|
|
}
|
|
});
|
|
}
|
|
else {
|
|
worker.postMessage("send");
|
|
}
|
|
return registration;
|
|
}).catch(function(error){
|
|
"use strict";
|
|
console.error("Unable to register service worker:", error);
|
|
});
|