@browserless.io/browserless 2.34.0 → 2.34.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +5 -0
- package/extensions/ublocklite/README.md +1 -1
- package/extensions/ublocklite/_locales/bs/messages.json +58 -58
- package/extensions/ublocklite/_locales/ro/messages.json +1 -1
- package/extensions/ublocklite/_locales/sr/messages.json +28 -28
- package/extensions/ublocklite/css/unpicker-ui.css +1 -0
- package/extensions/ublocklite/js/background.js +5 -3
- package/extensions/ublocklite/js/fetch.js +1 -1
- package/extensions/ublocklite/js/filter-manager.js +45 -9
- package/extensions/ublocklite/js/ruleset-manager.js +5 -5
- package/extensions/ublocklite/js/scripting/css-procedural.js +2 -0
- package/extensions/ublocklite/js/scripting/css-specific.js +2 -0
- package/extensions/ublocklite/js/scripting-manager.js +2 -2
- package/extensions/ublocklite/js/static-filtering-parser.js +17 -10
- package/extensions/ublocklite/manifest.json +2 -2
- package/extensions/ublocklite/rulesets/generic-details.json +1 -1
- package/extensions/ublocklite/rulesets/main/adguard-mobile.json +1 -1
- package/extensions/ublocklite/rulesets/main/annoyances-cookies.json +6 -5
- package/extensions/ublocklite/rulesets/main/annoyances-others.json +2 -1
- package/extensions/ublocklite/rulesets/main/chn-0.json +12 -8
- package/extensions/ublocklite/rulesets/main/deu-0.json +5 -7
- package/extensions/ublocklite/rulesets/main/dpollock-0.json +2 -0
- package/extensions/ublocklite/rulesets/main/easylist.json +13 -71
- package/extensions/ublocklite/rulesets/main/easyprivacy.json +20 -8
- package/extensions/ublocklite/rulesets/main/fra-0.json +2 -0
- package/extensions/ublocklite/rulesets/main/ind-0.json +10 -7
- package/extensions/ublocklite/rulesets/main/irn-0.json +1 -4
- package/extensions/ublocklite/rulesets/main/jpn-1.json +12 -12
- package/extensions/ublocklite/rulesets/main/kor-1.json +3 -1
- package/extensions/ublocklite/rulesets/main/nor-0.json +1 -1
- package/extensions/ublocklite/rulesets/main/pgl.json +1 -3
- package/extensions/ublocklite/rulesets/main/pol-0.json +1 -2
- package/extensions/ublocklite/rulesets/main/rus-0.json +4 -4
- package/extensions/ublocklite/rulesets/main/rus-1.json +3 -1
- package/extensions/ublocklite/rulesets/main/spa-1.json +6 -2
- package/extensions/ublocklite/rulesets/main/stevenblack-hosts.json +2966 -2308
- package/extensions/ublocklite/rulesets/main/swe-1.json +17 -14
- package/extensions/ublocklite/rulesets/main/tur-0.json +11 -3
- package/extensions/ublocklite/rulesets/main/ublock-badware.json +5 -6
- package/extensions/ublocklite/rulesets/main/ublock-filters.json +32 -20
- package/extensions/ublocklite/rulesets/main/ubol-tests.json +17 -0
- package/extensions/ublocklite/rulesets/main/urlhaus-full.json +230 -164
- package/extensions/ublocklite/rulesets/main/vie-1.json +22 -16
- package/extensions/ublocklite/rulesets/modify-headers/rus-0.json +0 -1
- package/extensions/ublocklite/rulesets/modify-headers/ublock-filters.json +3 -2
- package/extensions/ublocklite/rulesets/redirect/annoyances-overlays.json +1 -1
- package/extensions/ublocklite/rulesets/redirect/jpn-1.json +0 -1
- package/extensions/ublocklite/rulesets/redirect/ublock-filters.json +15 -23
- package/extensions/ublocklite/rulesets/redirect/vie-1.json +34 -2
- package/extensions/ublocklite/rulesets/regex/chn-0.json +3 -1
- package/extensions/ublocklite/rulesets/regex/easylist.json +0 -2
- package/extensions/ublocklite/rulesets/regex/jpn-1.json +1 -1
- package/extensions/ublocklite/rulesets/regex/ublock-filters.json +4 -5
- package/extensions/ublocklite/rulesets/removeparam/adguard-spyware-url.json +4 -4
- package/extensions/ublocklite/rulesets/removeparam/rus-1.json +1 -0
- package/extensions/ublocklite/rulesets/removeparam/ublock-filters.json +2 -1
- package/extensions/ublocklite/rulesets/ruleset-details.json +151 -151
- package/extensions/ublocklite/rulesets/scripting/generic/chn-0.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/generic/deu-0.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/generic/easylist.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/generic/idn-0.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/generic/jpn-1.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/generic/ublock-filters.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/generichigh/easylist.css +1 -12
- package/extensions/ublocklite/rulesets/scripting/generichigh/idn-0.css +3 -0
- package/extensions/ublocklite/rulesets/scripting/generichigh/rus-0.css +1 -0
- package/extensions/ublocklite/rulesets/scripting/procedural/adguard-mobile.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/procedural/annoyances-notifications.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/procedural/annoyances-others.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/procedural/annoyances-overlays.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/procedural/annoyances-social.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/procedural/chn-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/procedural/easylist.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/procedural/irn-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/procedural/jpn-1.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/procedural/rus-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/procedural/swe-1.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/procedural/tur-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/procedural/ublock-filters.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/scriptlet/adguard-mobile.set-cookie-reload.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-cookies.set-cookie.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-cookies.set-local-storage-item.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-cookies.trusted-click-element.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-cookies.trusted-set-cookie.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-overlays.addEventListener-defuser.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-overlays.prevent-setTimeout.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-overlays.set-constant.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-overlays.set-cookie.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-overlays.trusted-click-element.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/scriptlet/annoyances-overlays.trusted-replace-outbound-text.js +427 -0
- package/extensions/ublocklite/rulesets/scripting/scriptlet/chn-0.abort-current-script.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/chn-0.json-prune-fetch-response.js +588 -0
- package/extensions/ublocklite/rulesets/scripting/scriptlet/irn-0.prevent-window-open.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/scriptlet/irn-0.remove-node-text.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/jpn-1.abort-current-script.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/rus-0.abort-on-property-write.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/rus-0.addEventListener-defuser.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/scriptlet/spa-1.abort-on-property-read.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/spa-1.addEventListener-defuser.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/spa-1.prevent-fetch.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/scriptlet/spa-1.prevent-window-open.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/scriptlet/spa-1.set-constant.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/tur-0.abort-on-property-read.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/scriptlet/tur-0.addEventListener-defuser.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/tur-0.adjust-setInterval.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/tur-0.prevent-window-open.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/scriptlet/tur-0.set-constant.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.abort-current-script.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.abort-on-property-read.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.abort-on-stack-trace.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.addEventListener-defuser.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.adjust-setInterval.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.adjust-setTimeout.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.json-edit-fetch-response.js +927 -0
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.json-prune-fetch-response.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.json-prune.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.noeval-if.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.prevent-fetch.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.prevent-window-open.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.prevent-xhr.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.remove-cookie.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.remove-node-text.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.set-constant.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.set-cookie.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.set-local-storage-item.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-replace-argument.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-replace-node-text.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-replace-outbound-text.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-set-constant.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/ublock-filters.trusted-set-local-storage-item.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/scriptlet/vie-1.abort-current-script.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/scriptlet/vie-1.abort-on-property-read.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/specific/adguard-mobile.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/annoyances-cookies.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/annoyances-notifications.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/annoyances-others.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/annoyances-overlays.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/annoyances-social.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/chn-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/deu-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/easylist.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/fra-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/hun-0.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/specific/idn-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/ind-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/irn-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/isr-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/ita-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/jpn-1.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/kor-1.js +2 -2
- package/extensions/ublocklite/rulesets/scripting/specific/nld-0.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/specific/nor-0.js +1 -1
- package/extensions/ublocklite/rulesets/scripting/specific/pol-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/rus-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/spa-1.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/swe-1.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/tur-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/ublock-filters.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/ukr-0.js +3 -3
- package/extensions/ublocklite/rulesets/scripting/specific/vie-1.js +3 -3
- package/extensions/ublocklite/rulesets/scriptlet-details.json +63 -32
- package/extensions/ublocklite/rulesets/strictblock/adguard-mobile.json +9 -0
- package/extensions/ublocklite/rulesets/strictblock/chn-0.json +69 -0
- package/extensions/ublocklite/rulesets/strictblock/dpollock-0.json +2 -0
- package/extensions/ublocklite/rulesets/strictblock/easylist.json +1 -1
- package/extensions/ublocklite/rulesets/strictblock/easyprivacy.json +14 -70
- package/extensions/ublocklite/rulesets/strictblock/jpn-1.json +176 -174
- package/extensions/ublocklite/rulesets/strictblock/nor-0.json +1 -1
- package/extensions/ublocklite/rulesets/strictblock/pgl.json +1 -3
- package/extensions/ublocklite/rulesets/strictblock/pol-0.json +1 -0
- package/extensions/ublocklite/rulesets/strictblock/spa-1.json +1 -0
- package/extensions/ublocklite/rulesets/strictblock/stevenblack-hosts.json +2966 -2308
- package/extensions/ublocklite/rulesets/strictblock/ublock-badware.json +486 -484
- package/extensions/ublocklite/rulesets/strictblock/ublock-filters.json +1 -1
- package/extensions/ublocklite/rulesets/strictblock/urlhaus-full.json +230 -164
- package/extensions/ublocklite/rulesets/strictblock/vie-1.json +1 -1
- package/extensions/ublocklite/ublock.zip +0 -0
- package/package.json +7 -7
- package/scripts/build-open-api.js +15 -1
- package/static/docs/swagger.json +2 -2
- package/static/docs/swagger.min.json +1 -1
- package/static/function/client.js +71 -68
- package/static/function/index.html +71 -68
|
@@ -0,0 +1,588 @@
|
|
|
1
|
+
/*******************************************************************************
|
|
2
|
+
|
|
3
|
+
uBlock Origin Lite - a comprehensive, MV3-compliant content blocker
|
|
4
|
+
Copyright (C) 2014-present Raymond Hill
|
|
5
|
+
|
|
6
|
+
This program is free software: you can redistribute it and/or modify
|
|
7
|
+
it under the terms of the GNU General Public License as published by
|
|
8
|
+
the Free Software Foundation, either version 3 of the License, or
|
|
9
|
+
(at your option) any later version.
|
|
10
|
+
|
|
11
|
+
This program is distributed in the hope that it will be useful,
|
|
12
|
+
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
13
|
+
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
14
|
+
GNU General Public License for more details.
|
|
15
|
+
|
|
16
|
+
You should have received a copy of the GNU General Public License
|
|
17
|
+
along with this program. If not, see {http://www.gnu.org/licenses/}.
|
|
18
|
+
|
|
19
|
+
Home: https://github.com/gorhill/uBlock
|
|
20
|
+
|
|
21
|
+
*/
|
|
22
|
+
|
|
23
|
+
// ruleset: chn-0
|
|
24
|
+
|
|
25
|
+
// Important!
|
|
26
|
+
// Isolate from global scope
|
|
27
|
+
|
|
28
|
+
// Start of local scope
|
|
29
|
+
(function uBOL_jsonPruneFetchResponse() {
|
|
30
|
+
|
|
31
|
+
/******************************************************************************/
|
|
32
|
+
|
|
33
|
+
function jsonPruneFetchResponse(
|
|
34
|
+
rawPrunePaths = '',
|
|
35
|
+
rawNeedlePaths = ''
|
|
36
|
+
) {
|
|
37
|
+
const safe = safeSelf();
|
|
38
|
+
const logPrefix = safe.makeLogPrefix('json-prune-fetch-response', rawPrunePaths, rawNeedlePaths);
|
|
39
|
+
const extraArgs = safe.getExtraArgs(Array.from(arguments), 2);
|
|
40
|
+
const propNeedles = parsePropertiesToMatchFn(extraArgs.propsToMatch, 'url');
|
|
41
|
+
const stackNeedle = safe.initPattern(extraArgs.stackToMatch || '', { canNegate: true });
|
|
42
|
+
const logall = rawPrunePaths === '';
|
|
43
|
+
const applyHandler = function(target, thisArg, args) {
|
|
44
|
+
const fetchPromise = Reflect.apply(target, thisArg, args);
|
|
45
|
+
if ( propNeedles.size !== 0 ) {
|
|
46
|
+
const objs = [ args[0] instanceof Object ? args[0] : { url: args[0] } ];
|
|
47
|
+
if ( objs[0] instanceof Request ) {
|
|
48
|
+
try {
|
|
49
|
+
objs[0] = safe.Request_clone.call(objs[0]);
|
|
50
|
+
} catch(ex) {
|
|
51
|
+
safe.uboErr(logPrefix, 'Error:', ex);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
if ( args[1] instanceof Object ) {
|
|
55
|
+
objs.push(args[1]);
|
|
56
|
+
}
|
|
57
|
+
const matched = matchObjectPropertiesFn(propNeedles, ...objs);
|
|
58
|
+
if ( matched === undefined ) { return fetchPromise; }
|
|
59
|
+
if ( safe.logLevel > 1 ) {
|
|
60
|
+
safe.uboLog(logPrefix, `Matched "propsToMatch":\n\t${matched.join('\n\t')}`);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return fetchPromise.then(responseBefore => {
|
|
64
|
+
const response = responseBefore.clone();
|
|
65
|
+
return response.json().then(objBefore => {
|
|
66
|
+
if ( typeof objBefore !== 'object' ) { return responseBefore; }
|
|
67
|
+
if ( logall ) {
|
|
68
|
+
safe.uboLog(logPrefix, safe.JSON_stringify(objBefore, null, 2));
|
|
69
|
+
return responseBefore;
|
|
70
|
+
}
|
|
71
|
+
const objAfter = objectPruneFn(
|
|
72
|
+
objBefore,
|
|
73
|
+
rawPrunePaths,
|
|
74
|
+
rawNeedlePaths,
|
|
75
|
+
stackNeedle,
|
|
76
|
+
extraArgs
|
|
77
|
+
);
|
|
78
|
+
if ( typeof objAfter !== 'object' ) { return responseBefore; }
|
|
79
|
+
safe.uboLog(logPrefix, 'Pruned');
|
|
80
|
+
const responseAfter = Response.json(objAfter, {
|
|
81
|
+
status: responseBefore.status,
|
|
82
|
+
statusText: responseBefore.statusText,
|
|
83
|
+
headers: responseBefore.headers,
|
|
84
|
+
});
|
|
85
|
+
Object.defineProperties(responseAfter, {
|
|
86
|
+
ok: { value: responseBefore.ok },
|
|
87
|
+
redirected: { value: responseBefore.redirected },
|
|
88
|
+
type: { value: responseBefore.type },
|
|
89
|
+
url: { value: responseBefore.url },
|
|
90
|
+
});
|
|
91
|
+
return responseAfter;
|
|
92
|
+
}).catch(reason => {
|
|
93
|
+
safe.uboErr(logPrefix, 'Error:', reason);
|
|
94
|
+
return responseBefore;
|
|
95
|
+
});
|
|
96
|
+
}).catch(reason => {
|
|
97
|
+
safe.uboErr(logPrefix, 'Error:', reason);
|
|
98
|
+
return fetchPromise;
|
|
99
|
+
});
|
|
100
|
+
};
|
|
101
|
+
self.fetch = new Proxy(self.fetch, {
|
|
102
|
+
apply: applyHandler
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
function matchObjectPropertiesFn(propNeedles, ...objs) {
|
|
107
|
+
const safe = safeSelf();
|
|
108
|
+
const matched = [];
|
|
109
|
+
for ( const obj of objs ) {
|
|
110
|
+
if ( obj instanceof Object === false ) { continue; }
|
|
111
|
+
for ( const [ prop, details ] of propNeedles ) {
|
|
112
|
+
let value = obj[prop];
|
|
113
|
+
if ( value === undefined ) { continue; }
|
|
114
|
+
if ( typeof value !== 'string' ) {
|
|
115
|
+
try { value = safe.JSON_stringify(value); }
|
|
116
|
+
catch { }
|
|
117
|
+
if ( typeof value !== 'string' ) { continue; }
|
|
118
|
+
}
|
|
119
|
+
if ( safe.testPattern(details, value) === false ) { return; }
|
|
120
|
+
matched.push(`${prop}: ${value}`);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
return matched;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
function objectPruneFn(
|
|
127
|
+
obj,
|
|
128
|
+
rawPrunePaths,
|
|
129
|
+
rawNeedlePaths,
|
|
130
|
+
stackNeedleDetails = { matchAll: true },
|
|
131
|
+
extraArgs = {}
|
|
132
|
+
) {
|
|
133
|
+
if ( typeof rawPrunePaths !== 'string' ) { return; }
|
|
134
|
+
const safe = safeSelf();
|
|
135
|
+
const prunePaths = rawPrunePaths !== ''
|
|
136
|
+
? safe.String_split.call(rawPrunePaths, / +/)
|
|
137
|
+
: [];
|
|
138
|
+
const needlePaths = prunePaths.length !== 0 && rawNeedlePaths !== ''
|
|
139
|
+
? safe.String_split.call(rawNeedlePaths, / +/)
|
|
140
|
+
: [];
|
|
141
|
+
if ( stackNeedleDetails.matchAll !== true ) {
|
|
142
|
+
if ( matchesStackTraceFn(stackNeedleDetails, extraArgs.logstack) === false ) {
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
if ( objectPruneFn.mustProcess === undefined ) {
|
|
147
|
+
objectPruneFn.mustProcess = (root, needlePaths) => {
|
|
148
|
+
for ( const needlePath of needlePaths ) {
|
|
149
|
+
if ( objectFindOwnerFn(root, needlePath) === false ) {
|
|
150
|
+
return false;
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
return true;
|
|
154
|
+
};
|
|
155
|
+
}
|
|
156
|
+
if ( prunePaths.length === 0 ) { return; }
|
|
157
|
+
let outcome = 'nomatch';
|
|
158
|
+
if ( objectPruneFn.mustProcess(obj, needlePaths) ) {
|
|
159
|
+
for ( const path of prunePaths ) {
|
|
160
|
+
if ( objectFindOwnerFn(obj, path, true) ) {
|
|
161
|
+
outcome = 'match';
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
if ( outcome === 'match' ) { return obj; }
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
function parsePropertiesToMatchFn(propsToMatch, implicit = '') {
|
|
169
|
+
const safe = safeSelf();
|
|
170
|
+
const needles = new Map();
|
|
171
|
+
if ( propsToMatch === undefined || propsToMatch === '' ) { return needles; }
|
|
172
|
+
const options = { canNegate: true };
|
|
173
|
+
for ( const needle of safe.String_split.call(propsToMatch, /\s+/) ) {
|
|
174
|
+
let [ prop, pattern ] = safe.String_split.call(needle, ':');
|
|
175
|
+
if ( prop === '' ) { continue; }
|
|
176
|
+
if ( pattern !== undefined && /[^$\w -]/.test(prop) ) {
|
|
177
|
+
prop = `${prop}:${pattern}`;
|
|
178
|
+
pattern = undefined;
|
|
179
|
+
}
|
|
180
|
+
if ( pattern !== undefined ) {
|
|
181
|
+
needles.set(prop, safe.initPattern(pattern, options));
|
|
182
|
+
} else if ( implicit !== '' ) {
|
|
183
|
+
needles.set(implicit, safe.initPattern(prop, options));
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
return needles;
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
function safeSelf() {
|
|
190
|
+
if ( scriptletGlobals.safeSelf ) {
|
|
191
|
+
return scriptletGlobals.safeSelf;
|
|
192
|
+
}
|
|
193
|
+
const self = globalThis;
|
|
194
|
+
const safe = {
|
|
195
|
+
'Array_from': Array.from,
|
|
196
|
+
'Error': self.Error,
|
|
197
|
+
'Function_toStringFn': self.Function.prototype.toString,
|
|
198
|
+
'Function_toString': thisArg => safe.Function_toStringFn.call(thisArg),
|
|
199
|
+
'Math_floor': Math.floor,
|
|
200
|
+
'Math_max': Math.max,
|
|
201
|
+
'Math_min': Math.min,
|
|
202
|
+
'Math_random': Math.random,
|
|
203
|
+
'Object': Object,
|
|
204
|
+
'Object_defineProperty': Object.defineProperty.bind(Object),
|
|
205
|
+
'Object_defineProperties': Object.defineProperties.bind(Object),
|
|
206
|
+
'Object_fromEntries': Object.fromEntries.bind(Object),
|
|
207
|
+
'Object_getOwnPropertyDescriptor': Object.getOwnPropertyDescriptor.bind(Object),
|
|
208
|
+
'Object_hasOwn': Object.hasOwn.bind(Object),
|
|
209
|
+
'RegExp': self.RegExp,
|
|
210
|
+
'RegExp_test': self.RegExp.prototype.test,
|
|
211
|
+
'RegExp_exec': self.RegExp.prototype.exec,
|
|
212
|
+
'Request_clone': self.Request.prototype.clone,
|
|
213
|
+
'String': self.String,
|
|
214
|
+
'String_fromCharCode': String.fromCharCode,
|
|
215
|
+
'String_split': String.prototype.split,
|
|
216
|
+
'XMLHttpRequest': self.XMLHttpRequest,
|
|
217
|
+
'addEventListener': self.EventTarget.prototype.addEventListener,
|
|
218
|
+
'removeEventListener': self.EventTarget.prototype.removeEventListener,
|
|
219
|
+
'fetch': self.fetch,
|
|
220
|
+
'JSON': self.JSON,
|
|
221
|
+
'JSON_parseFn': self.JSON.parse,
|
|
222
|
+
'JSON_stringifyFn': self.JSON.stringify,
|
|
223
|
+
'JSON_parse': (...args) => safe.JSON_parseFn.call(safe.JSON, ...args),
|
|
224
|
+
'JSON_stringify': (...args) => safe.JSON_stringifyFn.call(safe.JSON, ...args),
|
|
225
|
+
'log': console.log.bind(console),
|
|
226
|
+
// Properties
|
|
227
|
+
logLevel: 0,
|
|
228
|
+
// Methods
|
|
229
|
+
makeLogPrefix(...args) {
|
|
230
|
+
return this.sendToLogger && `[${args.join(' \u205D ')}]` || '';
|
|
231
|
+
},
|
|
232
|
+
uboLog(...args) {
|
|
233
|
+
if ( this.sendToLogger === undefined ) { return; }
|
|
234
|
+
if ( args === undefined || args[0] === '' ) { return; }
|
|
235
|
+
return this.sendToLogger('info', ...args);
|
|
236
|
+
|
|
237
|
+
},
|
|
238
|
+
uboErr(...args) {
|
|
239
|
+
if ( this.sendToLogger === undefined ) { return; }
|
|
240
|
+
if ( args === undefined || args[0] === '' ) { return; }
|
|
241
|
+
return this.sendToLogger('error', ...args);
|
|
242
|
+
},
|
|
243
|
+
escapeRegexChars(s) {
|
|
244
|
+
return s.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
245
|
+
},
|
|
246
|
+
initPattern(pattern, options = {}) {
|
|
247
|
+
if ( pattern === '' ) {
|
|
248
|
+
return { matchAll: true, expect: true };
|
|
249
|
+
}
|
|
250
|
+
const expect = (options.canNegate !== true || pattern.startsWith('!') === false);
|
|
251
|
+
if ( expect === false ) {
|
|
252
|
+
pattern = pattern.slice(1);
|
|
253
|
+
}
|
|
254
|
+
const match = /^\/(.+)\/([gimsu]*)$/.exec(pattern);
|
|
255
|
+
if ( match !== null ) {
|
|
256
|
+
return {
|
|
257
|
+
re: new this.RegExp(
|
|
258
|
+
match[1],
|
|
259
|
+
match[2] || options.flags
|
|
260
|
+
),
|
|
261
|
+
expect,
|
|
262
|
+
};
|
|
263
|
+
}
|
|
264
|
+
if ( options.flags !== undefined ) {
|
|
265
|
+
return {
|
|
266
|
+
re: new this.RegExp(this.escapeRegexChars(pattern),
|
|
267
|
+
options.flags
|
|
268
|
+
),
|
|
269
|
+
expect,
|
|
270
|
+
};
|
|
271
|
+
}
|
|
272
|
+
return { pattern, expect };
|
|
273
|
+
},
|
|
274
|
+
testPattern(details, haystack) {
|
|
275
|
+
if ( details.matchAll ) { return true; }
|
|
276
|
+
if ( details.re ) {
|
|
277
|
+
return this.RegExp_test.call(details.re, haystack) === details.expect;
|
|
278
|
+
}
|
|
279
|
+
return haystack.includes(details.pattern) === details.expect;
|
|
280
|
+
},
|
|
281
|
+
patternToRegex(pattern, flags = undefined, verbatim = false) {
|
|
282
|
+
if ( pattern === '' ) { return /^/; }
|
|
283
|
+
const match = /^\/(.+)\/([gimsu]*)$/.exec(pattern);
|
|
284
|
+
if ( match === null ) {
|
|
285
|
+
const reStr = this.escapeRegexChars(pattern);
|
|
286
|
+
return new RegExp(verbatim ? `^${reStr}$` : reStr, flags);
|
|
287
|
+
}
|
|
288
|
+
try {
|
|
289
|
+
return new RegExp(match[1], match[2] || undefined);
|
|
290
|
+
}
|
|
291
|
+
catch {
|
|
292
|
+
}
|
|
293
|
+
return /^/;
|
|
294
|
+
},
|
|
295
|
+
getExtraArgs(args, offset = 0) {
|
|
296
|
+
const entries = args.slice(offset).reduce((out, v, i, a) => {
|
|
297
|
+
if ( (i & 1) === 0 ) {
|
|
298
|
+
const rawValue = a[i+1];
|
|
299
|
+
const value = /^\d+$/.test(rawValue)
|
|
300
|
+
? parseInt(rawValue, 10)
|
|
301
|
+
: rawValue;
|
|
302
|
+
out.push([ a[i], value ]);
|
|
303
|
+
}
|
|
304
|
+
return out;
|
|
305
|
+
}, []);
|
|
306
|
+
return this.Object_fromEntries(entries);
|
|
307
|
+
},
|
|
308
|
+
onIdle(fn, options) {
|
|
309
|
+
if ( self.requestIdleCallback ) {
|
|
310
|
+
return self.requestIdleCallback(fn, options);
|
|
311
|
+
}
|
|
312
|
+
return self.requestAnimationFrame(fn);
|
|
313
|
+
},
|
|
314
|
+
offIdle(id) {
|
|
315
|
+
if ( self.requestIdleCallback ) {
|
|
316
|
+
return self.cancelIdleCallback(id);
|
|
317
|
+
}
|
|
318
|
+
return self.cancelAnimationFrame(id);
|
|
319
|
+
}
|
|
320
|
+
};
|
|
321
|
+
scriptletGlobals.safeSelf = safe;
|
|
322
|
+
if ( scriptletGlobals.bcSecret === undefined ) { return safe; }
|
|
323
|
+
// This is executed only when the logger is opened
|
|
324
|
+
safe.logLevel = scriptletGlobals.logLevel || 1;
|
|
325
|
+
let lastLogType = '';
|
|
326
|
+
let lastLogText = '';
|
|
327
|
+
let lastLogTime = 0;
|
|
328
|
+
safe.toLogText = (type, ...args) => {
|
|
329
|
+
if ( args.length === 0 ) { return; }
|
|
330
|
+
const text = `[${document.location.hostname || document.location.href}]${args.join(' ')}`;
|
|
331
|
+
if ( text === lastLogText && type === lastLogType ) {
|
|
332
|
+
if ( (Date.now() - lastLogTime) < 5000 ) { return; }
|
|
333
|
+
}
|
|
334
|
+
lastLogType = type;
|
|
335
|
+
lastLogText = text;
|
|
336
|
+
lastLogTime = Date.now();
|
|
337
|
+
return text;
|
|
338
|
+
};
|
|
339
|
+
try {
|
|
340
|
+
const bc = new self.BroadcastChannel(scriptletGlobals.bcSecret);
|
|
341
|
+
let bcBuffer = [];
|
|
342
|
+
safe.sendToLogger = (type, ...args) => {
|
|
343
|
+
const text = safe.toLogText(type, ...args);
|
|
344
|
+
if ( text === undefined ) { return; }
|
|
345
|
+
if ( bcBuffer === undefined ) {
|
|
346
|
+
return bc.postMessage({ what: 'messageToLogger', type, text });
|
|
347
|
+
}
|
|
348
|
+
bcBuffer.push({ type, text });
|
|
349
|
+
};
|
|
350
|
+
bc.onmessage = ev => {
|
|
351
|
+
const msg = ev.data;
|
|
352
|
+
switch ( msg ) {
|
|
353
|
+
case 'iamready!':
|
|
354
|
+
if ( bcBuffer === undefined ) { break; }
|
|
355
|
+
bcBuffer.forEach(({ type, text }) =>
|
|
356
|
+
bc.postMessage({ what: 'messageToLogger', type, text })
|
|
357
|
+
);
|
|
358
|
+
bcBuffer = undefined;
|
|
359
|
+
break;
|
|
360
|
+
case 'setScriptletLogLevelToOne':
|
|
361
|
+
safe.logLevel = 1;
|
|
362
|
+
break;
|
|
363
|
+
case 'setScriptletLogLevelToTwo':
|
|
364
|
+
safe.logLevel = 2;
|
|
365
|
+
break;
|
|
366
|
+
}
|
|
367
|
+
};
|
|
368
|
+
bc.postMessage('areyouready?');
|
|
369
|
+
} catch {
|
|
370
|
+
safe.sendToLogger = (type, ...args) => {
|
|
371
|
+
const text = safe.toLogText(type, ...args);
|
|
372
|
+
if ( text === undefined ) { return; }
|
|
373
|
+
safe.log(`uBO ${text}`);
|
|
374
|
+
};
|
|
375
|
+
}
|
|
376
|
+
return safe;
|
|
377
|
+
}
|
|
378
|
+
|
|
379
|
+
function matchesStackTraceFn(
|
|
380
|
+
needleDetails,
|
|
381
|
+
logLevel = ''
|
|
382
|
+
) {
|
|
383
|
+
const safe = safeSelf();
|
|
384
|
+
const exceptionToken = getExceptionTokenFn();
|
|
385
|
+
const error = new safe.Error(exceptionToken);
|
|
386
|
+
const docURL = new URL(self.location.href);
|
|
387
|
+
docURL.hash = '';
|
|
388
|
+
// Normalize stack trace
|
|
389
|
+
const reLine = /(.*?@)?(\S+)(:\d+):\d+\)?$/;
|
|
390
|
+
const lines = [];
|
|
391
|
+
for ( let line of safe.String_split.call(error.stack, /[\n\r]+/) ) {
|
|
392
|
+
if ( line.includes(exceptionToken) ) { continue; }
|
|
393
|
+
line = line.trim();
|
|
394
|
+
const match = safe.RegExp_exec.call(reLine, line);
|
|
395
|
+
if ( match === null ) { continue; }
|
|
396
|
+
let url = match[2];
|
|
397
|
+
if ( url.startsWith('(') ) { url = url.slice(1); }
|
|
398
|
+
if ( url === docURL.href ) {
|
|
399
|
+
url = 'inlineScript';
|
|
400
|
+
} else if ( url.startsWith('<anonymous>') ) {
|
|
401
|
+
url = 'injectedScript';
|
|
402
|
+
}
|
|
403
|
+
let fn = match[1] !== undefined
|
|
404
|
+
? match[1].slice(0, -1)
|
|
405
|
+
: line.slice(0, match.index).trim();
|
|
406
|
+
if ( fn.startsWith('at') ) { fn = fn.slice(2).trim(); }
|
|
407
|
+
let rowcol = match[3];
|
|
408
|
+
lines.push(' ' + `${fn} ${url}${rowcol}:1`.trim());
|
|
409
|
+
}
|
|
410
|
+
lines[0] = `stackDepth:${lines.length-1}`;
|
|
411
|
+
const stack = lines.join('\t');
|
|
412
|
+
const r = needleDetails.matchAll !== true &&
|
|
413
|
+
safe.testPattern(needleDetails, stack);
|
|
414
|
+
if (
|
|
415
|
+
logLevel === 'all' ||
|
|
416
|
+
logLevel === 'match' && r ||
|
|
417
|
+
logLevel === 'nomatch' && !r
|
|
418
|
+
) {
|
|
419
|
+
safe.uboLog(stack.replace(/\t/g, '\n'));
|
|
420
|
+
}
|
|
421
|
+
return r;
|
|
422
|
+
}
|
|
423
|
+
|
|
424
|
+
function objectFindOwnerFn(
|
|
425
|
+
root,
|
|
426
|
+
path,
|
|
427
|
+
prune = false
|
|
428
|
+
) {
|
|
429
|
+
const safe = safeSelf();
|
|
430
|
+
let owner = root;
|
|
431
|
+
let chain = path;
|
|
432
|
+
for (;;) {
|
|
433
|
+
if ( typeof owner !== 'object' || owner === null ) { return false; }
|
|
434
|
+
const pos = chain.indexOf('.');
|
|
435
|
+
if ( pos === -1 ) {
|
|
436
|
+
if ( prune === false ) {
|
|
437
|
+
return safe.Object_hasOwn(owner, chain);
|
|
438
|
+
}
|
|
439
|
+
let modified = false;
|
|
440
|
+
if ( chain === '*' ) {
|
|
441
|
+
for ( const key in owner ) {
|
|
442
|
+
if ( safe.Object_hasOwn(owner, key) === false ) { continue; }
|
|
443
|
+
delete owner[key];
|
|
444
|
+
modified = true;
|
|
445
|
+
}
|
|
446
|
+
} else if ( safe.Object_hasOwn(owner, chain) ) {
|
|
447
|
+
delete owner[chain];
|
|
448
|
+
modified = true;
|
|
449
|
+
}
|
|
450
|
+
return modified;
|
|
451
|
+
}
|
|
452
|
+
const prop = chain.slice(0, pos);
|
|
453
|
+
const next = chain.slice(pos + 1);
|
|
454
|
+
let found = false;
|
|
455
|
+
if ( prop === '[-]' && Array.isArray(owner) ) {
|
|
456
|
+
let i = owner.length;
|
|
457
|
+
while ( i-- ) {
|
|
458
|
+
if ( objectFindOwnerFn(owner[i], next) === false ) { continue; }
|
|
459
|
+
owner.splice(i, 1);
|
|
460
|
+
found = true;
|
|
461
|
+
}
|
|
462
|
+
return found;
|
|
463
|
+
}
|
|
464
|
+
if ( prop === '{-}' && owner instanceof Object ) {
|
|
465
|
+
for ( const key of Object.keys(owner) ) {
|
|
466
|
+
if ( objectFindOwnerFn(owner[key], next) === false ) { continue; }
|
|
467
|
+
delete owner[key];
|
|
468
|
+
found = true;
|
|
469
|
+
}
|
|
470
|
+
return found;
|
|
471
|
+
}
|
|
472
|
+
if (
|
|
473
|
+
prop === '[]' && Array.isArray(owner) ||
|
|
474
|
+
prop === '{}' && owner instanceof Object ||
|
|
475
|
+
prop === '*' && owner instanceof Object
|
|
476
|
+
) {
|
|
477
|
+
for ( const key of Object.keys(owner) ) {
|
|
478
|
+
if (objectFindOwnerFn(owner[key], next, prune) === false ) { continue; }
|
|
479
|
+
found = true;
|
|
480
|
+
}
|
|
481
|
+
return found;
|
|
482
|
+
}
|
|
483
|
+
if ( safe.Object_hasOwn(owner, prop) === false ) { return false; }
|
|
484
|
+
owner = owner[prop];
|
|
485
|
+
chain = chain.slice(pos + 1);
|
|
486
|
+
}
|
|
487
|
+
}
|
|
488
|
+
|
|
489
|
+
function getExceptionTokenFn() {
|
|
490
|
+
const token = getRandomTokenFn();
|
|
491
|
+
const oe = self.onerror;
|
|
492
|
+
self.onerror = function(msg, ...args) {
|
|
493
|
+
if ( typeof msg === 'string' && msg.includes(token) ) { return true; }
|
|
494
|
+
if ( oe instanceof Function ) {
|
|
495
|
+
return oe.call(this, msg, ...args);
|
|
496
|
+
}
|
|
497
|
+
}.bind();
|
|
498
|
+
return token;
|
|
499
|
+
}
|
|
500
|
+
|
|
501
|
+
function getRandomTokenFn() {
|
|
502
|
+
const safe = safeSelf();
|
|
503
|
+
return safe.String_fromCharCode(Date.now() % 26 + 97) +
|
|
504
|
+
safe.Math_floor(safe.Math_random() * 982451653 + 982451653).toString(36);
|
|
505
|
+
}
|
|
506
|
+
|
|
507
|
+
/******************************************************************************/
|
|
508
|
+
|
|
509
|
+
const scriptletGlobals = {}; // eslint-disable-line
|
|
510
|
+
const argsList = [["data.item.[-].business_info.ad_desc","","/feed/rcmd"]];
|
|
511
|
+
const hostnamesMap = new Map([["bilibili.com",0]]);
|
|
512
|
+
const exceptionsMap = new Map([]);
|
|
513
|
+
const hasEntities = false;
|
|
514
|
+
const hasAncestors = false;
|
|
515
|
+
|
|
516
|
+
const collectArgIndices = (hn, map, out) => {
|
|
517
|
+
let argsIndices = map.get(hn);
|
|
518
|
+
if ( argsIndices === undefined ) { return; }
|
|
519
|
+
if ( typeof argsIndices !== 'number' ) {
|
|
520
|
+
for ( const argsIndex of argsIndices ) {
|
|
521
|
+
out.add(argsIndex);
|
|
522
|
+
}
|
|
523
|
+
} else {
|
|
524
|
+
out.add(argsIndices);
|
|
525
|
+
}
|
|
526
|
+
};
|
|
527
|
+
|
|
528
|
+
const indicesFromHostname = (hostname, suffix = '') => {
|
|
529
|
+
const hnParts = hostname.split('.');
|
|
530
|
+
const hnpartslen = hnParts.length;
|
|
531
|
+
if ( hnpartslen === 0 ) { return; }
|
|
532
|
+
for ( let i = 0; i < hnpartslen; i++ ) {
|
|
533
|
+
const hn = `${hnParts.slice(i).join('.')}${suffix}`;
|
|
534
|
+
collectArgIndices(hn, hostnamesMap, todoIndices);
|
|
535
|
+
collectArgIndices(hn, exceptionsMap, tonotdoIndices);
|
|
536
|
+
}
|
|
537
|
+
if ( hasEntities ) {
|
|
538
|
+
const n = hnpartslen - 1;
|
|
539
|
+
for ( let i = 0; i < n; i++ ) {
|
|
540
|
+
for ( let j = n; j > i; j-- ) {
|
|
541
|
+
const en = `${hnParts.slice(i,j).join('.')}.*${suffix}`;
|
|
542
|
+
collectArgIndices(en, hostnamesMap, todoIndices);
|
|
543
|
+
collectArgIndices(en, exceptionsMap, tonotdoIndices);
|
|
544
|
+
}
|
|
545
|
+
}
|
|
546
|
+
}
|
|
547
|
+
};
|
|
548
|
+
|
|
549
|
+
const entries = (( ) => {
|
|
550
|
+
const docloc = document.location;
|
|
551
|
+
const origins = [ docloc.origin ];
|
|
552
|
+
if ( docloc.ancestorOrigins ) {
|
|
553
|
+
origins.push(...docloc.ancestorOrigins);
|
|
554
|
+
}
|
|
555
|
+
return origins.map((origin, i) => {
|
|
556
|
+
const beg = origin.lastIndexOf('://');
|
|
557
|
+
if ( beg === -1 ) { return; }
|
|
558
|
+
const hn = origin.slice(beg+3)
|
|
559
|
+
const end = hn.indexOf(':');
|
|
560
|
+
return { hn: end === -1 ? hn : hn.slice(0, end), i };
|
|
561
|
+
}).filter(a => a !== undefined);
|
|
562
|
+
})();
|
|
563
|
+
if ( entries.length === 0 ) { return; }
|
|
564
|
+
|
|
565
|
+
const todoIndices = new Set();
|
|
566
|
+
const tonotdoIndices = new Set();
|
|
567
|
+
|
|
568
|
+
indicesFromHostname(entries[0].hn);
|
|
569
|
+
if ( hasAncestors ) {
|
|
570
|
+
for ( const entry of entries ) {
|
|
571
|
+
if ( entry.i === 0 ) { continue; }
|
|
572
|
+
indicesFromHostname(entry.hn, '>>');
|
|
573
|
+
}
|
|
574
|
+
}
|
|
575
|
+
|
|
576
|
+
// Apply scriplets
|
|
577
|
+
for ( const i of todoIndices ) {
|
|
578
|
+
if ( tonotdoIndices.has(i) ) { continue; }
|
|
579
|
+
try { jsonPruneFetchResponse(...argsList[i]); }
|
|
580
|
+
catch { }
|
|
581
|
+
}
|
|
582
|
+
|
|
583
|
+
/******************************************************************************/
|
|
584
|
+
|
|
585
|
+
// End of local scope
|
|
586
|
+
})();
|
|
587
|
+
|
|
588
|
+
void 0;
|
|
@@ -391,7 +391,7 @@ function safeSelf() {
|
|
|
391
391
|
|
|
392
392
|
const scriptletGlobals = {}; // eslint-disable-line
|
|
393
393
|
const argsList = [[]];
|
|
394
|
-
const hostnamesMap = new Map([["artmusics.top",0],["musicpars3.ir",0],["musicguitars.ir",0],["subf2m.ir",0],["zeemusic.ir",0],["najiremix.ir",0],["musichi.ir",0],["likeemusic.ir",0],["appiroid.ir",0],["androidtime.com",0],["
|
|
394
|
+
const hostnamesMap = new Map([["artmusics.top",0],["musicpars3.ir",0],["musicguitars.ir",0],["subf2m.ir",0],["zeemusic.ir",0],["najiremix.ir",0],["musichi.ir",0],["likeemusic.ir",0],["appiroid.ir",0],["androidtime.com",0],["getandroid.ir",0],["musictag.ir",0],["musickhone.com",0],["naslmusic.ir",0],["power-music.ir",0],["uploadgoogle.ir",0],["uptrack.ir",0]]);
|
|
395
395
|
const exceptionsMap = new Map([]);
|
|
396
396
|
const hasEntities = false;
|
|
397
397
|
const hasAncestors = false;
|
|
@@ -368,8 +368,8 @@ function safeSelf() {
|
|
|
368
368
|
/******************************************************************************/
|
|
369
369
|
|
|
370
370
|
const scriptletGlobals = {}; // eslint-disable-line
|
|
371
|
-
const argsList = [["script","document.oncontextmenu ="],["script","
|
|
372
|
-
const hostnamesMap = new Map([["delta3da.cam",0],["public-psychology.ir",0],["sclinic.ir",0],["
|
|
371
|
+
const argsList = [["script","document.oncontextmenu ="],["script","document.oncontextmenu="],["script","/popTimes_|document\\.onkeydown|'contextmenu'/"],["script","window.location="],["script","displayCountryInConsole"],["script","popTimes_"],["script","ad.setAttribute"],["script","showScrollAlert"],["script","Event.MOUSEDOWN"]];
|
|
372
|
+
const hostnamesMap = new Map([["delta3da.cam",0],["public-psychology.ir",0],["sclinic.ir",0],["kihanb.ir",1],["musiceman.net",2],["najiremix.ir",3],["persian-fa.ir",4],["iran-music.com",5],["tgju.org",6],["tarafdari.com",7],["vaamfaa.ir",8]]);
|
|
373
373
|
const exceptionsMap = new Map([]);
|
|
374
374
|
const hasEntities = false;
|
|
375
375
|
const hasAncestors = false;
|
|
@@ -371,8 +371,8 @@ function getRandomTokenFn() {
|
|
|
371
371
|
/******************************************************************************/
|
|
372
372
|
|
|
373
373
|
const scriptletGlobals = {}; // eslint-disable-line
|
|
374
|
-
const argsList = [["EventTarget.prototype.addEventListener","eval"],["onload","google_esf"],["onload","adsCount"],["navigator.brave"],["document.getElementById","_0x"],["document.querySelector","_0x"],["jQuery","decodeURIComponent"],["document.write","sitejack"],["document.createElement","overview"],["document.getElementById","imageUrls"],["$","google_ads_iframe_"],["document.referrer","gmo_bb"],["document.currentScript","insertAdjacentHTML"],["jQuery","floatingAd"],["tag","Math.random"],["addEventListener","style.display"],["jmp","Math"],["document.getElementById","lists"],["document.
|
|
375
|
-
const hostnamesMap = new Map([["exploader.net",0],["qa.crefan.jp",1],["blog-and-destroy.com",2],["musenboya.com",3],["kledgeb.blogspot.com",4],["manga1001.*",5],["connect.coron.tech",6],["akibablog.blog.jp",7],["blog.livedoor.jp",[7,13,16]],["erommd-street.com",8],["twivideo.net",9],["ac-illust.com",10],["photo-ac.com",10],["chibanippo.co.jp",11],["engineweb.jp",11],["kenshonavi.com",11],["maidonanews.jp",11],["nkreport.jp",11],["riajo.com",11],["searchkoreanews.jp",11],["trafficnews.jp",11],["yougakumap.com",11],["encount.press",11],["realsound.jp",11],["h1g.jp",11],["agora-web.jp",12],["2chblog.jp",13],["yugioh-starlight.com",13],["kijomatomelog.com",13],["gundamlog.com",13],["doorblog.jp",13],["digital-thread.com",13],["livedoor.blog",13],["blog.jp",13],["majikichi.com",14],["xn--gmq92kd2rm1kx34a.com",15],["javmix.*",15],["momoiroadult.com",17],["
|
|
374
|
+
const argsList = [["EventTarget.prototype.addEventListener","eval"],["onload","google_esf"],["onload","adsCount"],["navigator.brave"],["document.getElementById","_0x"],["document.querySelector","_0x"],["jQuery","decodeURIComponent"],["document.write","sitejack"],["document.createElement","overview"],["document.getElementById","imageUrls"],["$","google_ads_iframe_"],["document.referrer","gmo_bb"],["document.currentScript","insertAdjacentHTML"],["jQuery","floatingAd"],["tag","Math.random"],["addEventListener","style.display"],["jmp","Math"],["document.getElementById","lists"],["document.currentScript","IFTG"],["document.createElement","randomad"]];
|
|
375
|
+
const hostnamesMap = new Map([["exploader.net",0],["qa.crefan.jp",1],["blog-and-destroy.com",2],["musenboya.com",3],["kledgeb.blogspot.com",4],["manga1001.*",5],["connect.coron.tech",6],["akibablog.blog.jp",7],["blog.livedoor.jp",[7,13,16]],["erommd-street.com",8],["twivideo.net",9],["ac-illust.com",10],["photo-ac.com",10],["chibanippo.co.jp",11],["engineweb.jp",11],["kenshonavi.com",11],["maidonanews.jp",11],["nkreport.jp",11],["riajo.com",11],["searchkoreanews.jp",11],["trafficnews.jp",11],["yougakumap.com",11],["encount.press",11],["realsound.jp",11],["h1g.jp",11],["agora-web.jp",12],["2chblog.jp",13],["yugioh-starlight.com",13],["kijomatomelog.com",13],["gundamlog.com",13],["doorblog.jp",13],["digital-thread.com",13],["livedoor.blog",13],["blog.jp",13],["majikichi.com",14],["xn--gmq92kd2rm1kx34a.com",15],["javmix.*",15],["momoiroadult.com",17],["jukenbbs.com",18],["figsoku.net",19]]);
|
|
376
376
|
const exceptionsMap = new Map([]);
|
|
377
377
|
const hasEntities = true;
|
|
378
378
|
const hasAncestors = false;
|
|
@@ -266,8 +266,8 @@ function getRandomTokenFn() {
|
|
|
266
266
|
/******************************************************************************/
|
|
267
267
|
|
|
268
268
|
const scriptletGlobals = {}; // eslint-disable-line
|
|
269
|
-
const argsList = [["NiceScroll"],["adsBlocked"],["ai_front"],["disableSelection"],["disable_keystrokes"],["document.oncontextmenu"],["document.ondragstart"],["document.onselectstart"],["fetch"],["keepAdblock"],["window.yaProxy"],["mailruEnabled"]];
|
|
270
|
-
const hostnamesMap = new Map([["transkarpatia.net",0],["24pdd.ru",1],["doctorrouter.ru",2],["ranobe-novels.ru",2],["tests24.su",2],["ufchgu.ru",[3,4]],["fssp.gov.ru",[5,6,7]],["southpark.su",[5,6,7]],["turkcinema.org",[5,6,7]],["phys-kids.com",8],["gamemag.ru",9],["kakprosto.ru",
|
|
269
|
+
const argsList = [["NiceScroll"],["adsBlocked"],["ai_front"],["disableSelection"],["disable_keystrokes"],["document.oncontextmenu"],["document.ondragstart"],["document.onselectstart"],["fetch"],["keepAdblock"],["showHelpProjectModal"],["window.yaProxy"],["mailruEnabled"]];
|
|
270
|
+
const hostnamesMap = new Map([["transkarpatia.net",0],["24pdd.ru",1],["doctorrouter.ru",2],["ranobe-novels.ru",2],["tests24.su",2],["ufchgu.ru",[3,4]],["fssp.gov.ru",[5,6,7]],["southpark.su",[5,6,7]],["turkcinema.org",[5,6,7]],["phys-kids.com",8],["gamemag.ru",9],["searchfloor.org",10],["kakprosto.ru",11],["ok.ru",12]]);
|
|
271
271
|
const exceptionsMap = new Map([]);
|
|
272
272
|
const hasEntities = false;
|
|
273
273
|
const hasAncestors = false;
|