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 MAX_HIGHLIGHTABLE_LENGTH = 0; /* 0 is no max length for highlight */ export const MAX_TITLE_LENGTH = 140; export const MAX_URL_LENGTH = 140; /* text nodes inside these elements that are ignored */ 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)); }