mirror of
https://github.com/kkapsner/CanvasBlocker
synced 2025-01-08 20:54:49 +01:00
Simplified code structure
This commit is contained in:
parent
0d331d91a6
commit
af1dfe755c
187
lib/intercept.js
187
lib/intercept.js
@ -315,40 +315,42 @@
|
|||||||
const changedFunction = changedFunctions[name];
|
const changedFunction = changedFunctions[name];
|
||||||
const functionStatus = changedFunction.getStatus(undefined, siteStatus, prefs);
|
const functionStatus = changedFunction.getStatus(undefined, siteStatus, prefs);
|
||||||
logging.verbose("status for", name, ":", functionStatus);
|
logging.verbose("status for", name, ":", functionStatus);
|
||||||
if (functionStatus.active){
|
if (!functionStatus.active) return;
|
||||||
getAllFunctionObjects(windowToProcess, changedFunction).forEach(function(object){
|
|
||||||
if (object){
|
getAllFunctionObjects(windowToProcess, changedFunction).forEach(function(object){
|
||||||
const original = object[name];
|
if (!object) return;
|
||||||
const checker = generateChecker({
|
|
||||||
name, changedFunction, siteStatus, original,
|
const original = object[name];
|
||||||
window: windowToProcess, prefs, checkStack, ask, notify
|
const checker = generateChecker({
|
||||||
});
|
name, changedFunction, siteStatus, original,
|
||||||
const descriptor = Object.getOwnPropertyDescriptor(object, name);
|
window: windowToProcess, prefs, checkStack, ask, notify
|
||||||
if (descriptor){
|
|
||||||
if (descriptor.hasOwnProperty("value")){
|
|
||||||
if (changedFunction.fakeGenerator){
|
|
||||||
descriptor.value = exportFunction(
|
|
||||||
changedFunction.fakeGenerator(checker, original, windowToProcess),
|
|
||||||
windowToProcess
|
|
||||||
);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
descriptor.value = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
descriptor.get = exportFunction(function(){
|
|
||||||
return exportFunction(
|
|
||||||
changedFunction.fakeGenerator(checker),
|
|
||||||
windowToProcess
|
|
||||||
);
|
|
||||||
}, windowToProcess);
|
|
||||||
}
|
|
||||||
Object.defineProperty(object, name, descriptor);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
const descriptor = Object.getOwnPropertyDescriptor(object, name);
|
||||||
|
if (!descriptor) return;
|
||||||
|
|
||||||
|
if (descriptor.hasOwnProperty("value")){
|
||||||
|
if (changedFunction.fakeGenerator){
|
||||||
|
descriptor.value = extension.exportFunctionWithName(
|
||||||
|
changedFunction.fakeGenerator(checker, original, windowToProcess),
|
||||||
|
windowToProcess,
|
||||||
|
original.name
|
||||||
|
);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
descriptor.value = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
descriptor.get = extension.exportFunctionWithName(function(){
|
||||||
|
return extension.exportFunctionWithName(
|
||||||
|
changedFunction.fakeGenerator(checker),
|
||||||
|
windowToProcess,
|
||||||
|
original.name
|
||||||
|
);
|
||||||
|
}, windowToProcess, descriptor.get.name);
|
||||||
|
}
|
||||||
|
Object.defineProperty(object, name, descriptor);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
function interceptGetters(windowToProcess, siteStatus, {checkStack, ask, notify, prefs}){
|
function interceptGetters(windowToProcess, siteStatus, {checkStack, ask, notify, prefs}){
|
||||||
@ -356,71 +358,70 @@
|
|||||||
const name = changedGetter.name;
|
const name = changedGetter.name;
|
||||||
const functionStatus = changedGetter.getStatus(undefined, siteStatus, prefs);
|
const functionStatus = changedGetter.getStatus(undefined, siteStatus, prefs);
|
||||||
logging.verbose("status for", changedGetter, ":", functionStatus);
|
logging.verbose("status for", changedGetter, ":", functionStatus);
|
||||||
if (functionStatus.active){
|
if (!functionStatus.active) return;
|
||||||
changedGetter.objectGetters.forEach(function(objectGetter){
|
|
||||||
const object = objectGetter(extension.getWrapped(windowToProcess));
|
|
||||||
if (object){
|
|
||||||
const descriptor = Object.getOwnPropertyDescriptor(object, name);
|
|
||||||
if (descriptor && descriptor.hasOwnProperty("get")){
|
|
||||||
const original = descriptor.get;
|
|
||||||
const checker = generateChecker({
|
|
||||||
name, changedFunction: changedGetter, siteStatus, original,
|
|
||||||
window: windowToProcess, prefs, checkStack, ask, notify
|
|
||||||
});
|
|
||||||
const getter = changedGetter.getterGenerator(checker, original, windowToProcess);
|
|
||||||
descriptor.get = extension.exportFunctionWithName(getter, windowToProcess, original.name);
|
|
||||||
|
|
||||||
if (descriptor.hasOwnProperty("set") && descriptor.set && changedGetter.setterGenerator){
|
changedGetter.objectGetters.forEach(function(objectGetter){
|
||||||
const original = descriptor.set;
|
const object = objectGetter(extension.getWrapped(windowToProcess));
|
||||||
const setter = changedGetter.setterGenerator(
|
if (!object) return;
|
||||||
windowToProcess,
|
|
||||||
original,
|
|
||||||
prefs
|
|
||||||
);
|
|
||||||
descriptor.set = extension.exportFunctionWithName(setter, windowToProcess, original.name);
|
|
||||||
}
|
|
||||||
|
|
||||||
Object.defineProperty(object, name, descriptor);
|
const descriptor = Object.getOwnPropertyDescriptor(object, name);
|
||||||
}
|
if (!descriptor) return;
|
||||||
else if (
|
|
||||||
changedGetter.valueGenerator &&
|
if (descriptor.hasOwnProperty("get")){
|
||||||
descriptor && descriptor.hasOwnProperty("value")
|
const original = descriptor.get;
|
||||||
){
|
const checker = generateChecker({
|
||||||
const protectedAPIFeatures = prefs("protectedAPIFeatures");
|
name, changedFunction: changedGetter, siteStatus, original,
|
||||||
if (
|
window: windowToProcess, prefs, checkStack, ask, notify
|
||||||
functionStatus.active &&
|
});
|
||||||
(
|
const getter = changedGetter.getterGenerator(checker, original, windowToProcess);
|
||||||
!protectedAPIFeatures.hasOwnProperty(name + " @ " + changedGetter.api) ||
|
descriptor.get = extension.exportFunctionWithName(getter, windowToProcess, original.name);
|
||||||
protectedAPIFeatures[name + " @ " + changedGetter.api]
|
|
||||||
)
|
if (descriptor.hasOwnProperty("set") && descriptor.set && changedGetter.setterGenerator){
|
||||||
){
|
const original = descriptor.set;
|
||||||
switch (functionStatus.mode){
|
const setter = changedGetter.setterGenerator(
|
||||||
case "ask": case "block": case "fake":
|
windowToProcess,
|
||||||
descriptor.value = changedGetter.valueGenerator({
|
original,
|
||||||
mode: functionStatus.mode,
|
prefs
|
||||||
original: descriptor.value,
|
);
|
||||||
notify: function notifyCallback(messageId){
|
descriptor.set = extension.exportFunctionWithName(setter, windowToProcess, original.name);
|
||||||
notify({
|
}
|
||||||
url: getURL(windowToProcess),
|
|
||||||
errorStack: (new Error()).stack,
|
Object.defineProperty(object, name, descriptor);
|
||||||
messageId,
|
}
|
||||||
timestamp: new Date(),
|
else if (
|
||||||
functionName: name,
|
changedGetter.valueGenerator &&
|
||||||
api: changedGetter.api
|
descriptor.hasOwnProperty("value")
|
||||||
});
|
){
|
||||||
}
|
const protectedAPIFeatures = prefs("protectedAPIFeatures");
|
||||||
|
if (
|
||||||
|
!protectedAPIFeatures.hasOwnProperty(name + " @ " + changedGetter.api) ||
|
||||||
|
protectedAPIFeatures[name + " @ " + changedGetter.api]
|
||||||
|
){
|
||||||
|
switch (functionStatus.mode){
|
||||||
|
case "ask": case "block": case "fake":
|
||||||
|
descriptor.value = changedGetter.valueGenerator({
|
||||||
|
mode: functionStatus.mode,
|
||||||
|
original: descriptor.value,
|
||||||
|
notify: function notifyCallback(messageId){
|
||||||
|
notify({
|
||||||
|
url: getURL(windowToProcess),
|
||||||
|
errorStack: (new Error()).stack,
|
||||||
|
messageId,
|
||||||
|
timestamp: new Date(),
|
||||||
|
functionName: name,
|
||||||
|
api: changedGetter.api
|
||||||
});
|
});
|
||||||
Object.defineProperty(object, name, descriptor);
|
}
|
||||||
break;
|
});
|
||||||
}
|
Object.defineProperty(object, name, descriptor);
|
||||||
}
|
break;
|
||||||
}
|
|
||||||
else {
|
|
||||||
logging.error("Try to fake non getter property:", changedGetter);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
}
|
||||||
}
|
else {
|
||||||
|
logging.error("Try to fake non getter property:", changedGetter);
|
||||||
|
}
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
scope.intercept = function intercept({subject: windowToProcess}, apis){
|
scope.intercept = function intercept({subject: windowToProcess}, apis){
|
||||||
|
@ -85,6 +85,10 @@
|
|||||||
{
|
{
|
||||||
"version": "0.5.15RC1",
|
"version": "0.5.15RC1",
|
||||||
"update_link": "https://canvasblocker.kkapsner.de/versions/canvasblocker_beta-0.5.15RC1-an+fx.xpi"
|
"update_link": "https://canvasblocker.kkapsner.de/versions/canvasblocker_beta-0.5.15RC1-an+fx.xpi"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"version": "0.5.15RC2",
|
||||||
|
"update_link": "https://canvasblocker.kkapsner.de/versions/canvasblocker_beta-0.5.15RC2-an+fx.xpi"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user