65 lines
1.9 KiB
JavaScript
65 lines
1.9 KiB
JavaScript
import path from 'path';
|
|
import {fileURLToPath} from 'url';
|
|
|
|
|
|
// determine where this code is running
|
|
let Context = 'unknown';
|
|
|
|
// ignore the possibility that window or global or chrome could be overwritten
|
|
const isBrowser = function () { try {return window && window.fetch;}catch(e){ return false;} };
|
|
const isNode = function () { try {return global && global.Math;}catch(e){return false;} };
|
|
const isExtension = function () { try {return chrome.runtime && chrome.debugger;}catch(e){return false;} };
|
|
|
|
if ( isNode() ) {
|
|
Context = 'node';
|
|
} else if ( isBrowser() ) {
|
|
Context = 'browser';
|
|
if ( isExtension() ) {
|
|
Context = 'extension';
|
|
}
|
|
}
|
|
|
|
export const context = Context;
|
|
|
|
export const DEBUG = process.env.DEBUG_22120 || false;
|
|
export const SHOW_FETCH = false;
|
|
|
|
export const CHECK_INTERVAL = 400;
|
|
export const TEXT_NODE = 3;
|
|
export const FORBIDDEN_TEXT_PARENT = new Set([
|
|
'STYLE',
|
|
'SCRIPT',
|
|
'NOSCRIPT'
|
|
]);
|
|
export const ERROR_CODE_SAFE_TO_IGNORE = new Set([
|
|
-32000, /* message:
|
|
Can only get response body on requests captured after headers received.
|
|
* ignore because:
|
|
seems to only happen when new navigation aborts all
|
|
pending requests of the unloading page
|
|
*/
|
|
-32602, /* message:
|
|
Invalid InterceptionId.
|
|
* ignore because:
|
|
seems to only happen when new navigation aborts all
|
|
pending requests of the unloading page
|
|
*/
|
|
]);
|
|
|
|
export const SNIP_CONTEXT = 31;
|
|
|
|
export const NO_SANDBOX = process.env.DEBUG_22120 || false;
|
|
|
|
//export const APP_ROOT = __dirname;
|
|
export const APP_ROOT = path.dirname(fileURLToPath(import.meta.url));
|
|
|
|
export const sleep = ms => new Promise(res => setTimeout(res, ms));
|
|
|
|
export function say(o) {
|
|
console.log(JSON.stringify(o));
|
|
}
|
|
|
|
export function clone(o) {
|
|
return JSON.parse(JSON.stringify(o));
|
|
}
|