{"version":3,"file":"main.js?fdb3320769aab4bb1a11","mappings":"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","sources":["webpack:///../node_modules/tslib/tslib.es6.js","webpack:///../src/utils/async.ts","webpack:///../src/utils/data.ts","webpack:///../src/utils/hashing.ts","webpack:///../src/utils/entropy_source.ts","webpack:///../src/utils/browser.ts","webpack:///../src/utils/misc.ts","webpack:///../src/utils/dom.ts","webpack:///../src/sources/audio.ts","webpack:///../src/sources/fonts.ts","webpack:///../src/sources/canvas.ts","webpack:///../src/sources/screen_frame.ts","webpack:///../src/sources/cpu_class.ts","webpack:///../src/sources/dom_blockers.ts","webpack:///../src/sources/inverted_colors.ts","webpack:///../src/sources/forced_colors.ts","webpack:///../src/sources/contrast.ts","webpack:///../src/sources/reduced_motion.ts","webpack:///../src/sources/reduced_transparency.ts","webpack:///../src/sources/hdr.ts","webpack:///../src/sources/math.ts","webpack:///../src/sources/font_preferences.ts","webpack:///../src/sources/webgl.ts","webpack:///../src/sources/index.ts","webpack:///../src/sources/os_cpu.ts","webpack:///../src/sources/languages.ts","webpack:///../src/sources/color_depth.ts","webpack:///../src/sources/device_memory.ts","webpack:///../src/sources/screen_resolution.ts","webpack:///../src/sources/hardware_concurrency.ts","webpack:///../src/sources/timezone.ts","webpack:///../src/sources/session_storage.ts","webpack:///../src/sources/local_storage.ts","webpack:///../src/sources/indexed_db.ts","webpack:///../src/sources/open_database.ts","webpack:///../src/sources/platform.ts","webpack:///../src/sources/plugins.ts","webpack:///../src/sources/touch_support.ts","webpack:///../src/sources/vendor.ts","webpack:///../src/sources/vendor_flavors.ts","webpack:///../src/sources/cookies_enabled.ts","webpack:///../src/sources/color_gamut.ts","webpack:///../src/sources/monochrome.ts","webpack:///../src/sources/pdf_viewer_enabled.ts","webpack:///../src/sources/architecture.ts","webpack:///../src/sources/apple_pay.ts","webpack:///../src/sources/private_click_measurement.ts","webpack:///../src/confidence.ts","webpack:///../src/agent.ts","webpack:///./index.ts"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","export type MaybePromise = Promise | T\n\nexport function wait(durationMs: number, resolveWith?: T): Promise {\n return new Promise((resolve) => setTimeout(resolve, durationMs, resolveWith))\n}\n\n/**\n * Allows asynchronous actions and microtasks to happen.\n */\nexport function releaseEventLoop(): Promise {\n return wait(0)\n}\n\nexport function requestIdleCallbackIfAvailable(fallbackTimeout: number, deadlineTimeout = Infinity): Promise {\n const { requestIdleCallback } = window\n if (requestIdleCallback) {\n // The function `requestIdleCallback` loses the binding to `window` here.\n // `globalThis` isn't always equal `window` (see https://github.com/fingerprintjs/fingerprintjs/issues/683).\n // Therefore, an error can occur. `call(window,` prevents the error.\n return new Promise((resolve) => requestIdleCallback.call(window, () => resolve(), { timeout: deadlineTimeout }))\n } else {\n return wait(Math.min(fallbackTimeout, deadlineTimeout))\n }\n}\n\nexport function isPromise(value: PromiseLike | unknown): value is PromiseLike {\n return !!value && typeof (value as PromiseLike).then === 'function'\n}\n\n/**\n * Calls a maybe asynchronous function without creating microtasks when the function is synchronous.\n * Catches errors in both cases.\n *\n * If just you run a code like this:\n * ```\n * console.time('Action duration')\n * await action()\n * console.timeEnd('Action duration')\n * ```\n * The synchronous function time can be measured incorrectly because another microtask may run before the `await`\n * returns the control back to the code.\n */\nexport function awaitIfAsync(\n action: () => MaybePromise,\n callback: (...args: [success: true, result: TResult] | [success: false, error: TError]) => unknown,\n): void {\n try {\n const returnedValue = action()\n if (isPromise(returnedValue)) {\n returnedValue.then(\n (result) => callback(true, result),\n (error: TError) => callback(false, error),\n )\n } else {\n callback(true, returnedValue)\n }\n } catch (error) {\n callback(false, error as TError)\n }\n}\n\n/**\n * If you run many synchronous tasks without using this function, the JS main loop will be busy and asynchronous tasks\n * (e.g. completing a network request, rendering the page) won't be able to happen.\n * This function allows running many synchronous tasks such way that asynchronous tasks can run too in background.\n */\nexport async function mapWithBreaks(\n items: readonly T[],\n callback: (item: T, index: number) => U,\n loopReleaseInterval = 16,\n): Promise {\n const results = Array(items.length)\n let lastLoopReleaseTime = Date.now()\n\n for (let i = 0; i < items.length; ++i) {\n results[i] = callback(items[i], i)\n\n const now = Date.now()\n if (now >= lastLoopReleaseTime + loopReleaseInterval) {\n lastLoopReleaseTime = now\n // Allows asynchronous actions and microtasks to happen\n await wait(0)\n }\n }\n\n return results\n}\n\n/**\n * Makes the given promise never emit an unhandled promise rejection console warning.\n * The promise will still pass errors to the next promises.\n *\n * Otherwise, promise emits a console warning unless it has a `catch` listener.\n */\nexport function suppressUnhandledRejectionWarning(promise: PromiseLike): void {\n promise.then(undefined, () => undefined)\n}\n","/*\n * This file contains functions to work with pure data only (no browser features, DOM, side effects, etc).\n */\n\n/**\n * Does the same as Array.prototype.includes but has better typing\n */\nexport function includes(haystack: ArrayLike, needle: unknown): needle is THaystack {\n for (let i = 0, l = haystack.length; i < l; ++i) {\n if (haystack[i] === needle) {\n return true\n }\n }\n return false\n}\n\n/**\n * Like `!includes()` but with proper typing\n */\nexport function excludes(\n haystack: ArrayLike,\n needle: TNeedle,\n): needle is Exclude {\n return !includes(haystack, needle)\n}\n\n/**\n * Be careful, NaN can return\n */\nexport function toInt(value: unknown): number {\n return parseInt(value as string)\n}\n\n/**\n * Be careful, NaN can return\n */\nexport function toFloat(value: unknown): number {\n return parseFloat(value as string)\n}\n\nexport function replaceNaN(value: T, replacement: U): T | U {\n return typeof value === 'number' && isNaN(value) ? replacement : value\n}\n\nexport function countTruthy(values: unknown[]): number {\n return values.reduce((sum, value) => sum + (value ? 1 : 0), 0)\n}\n\nexport function round(value: number, base = 1): number {\n if (Math.abs(base) >= 1) {\n return Math.round(value / base) * base\n } else {\n // Sometimes when a number is multiplied by a small number, precision is lost,\n // for example 1234 * 0.0001 === 0.12340000000000001, and it's more precise divide: 1234 / (1 / 0.0001) === 0.1234.\n const counterBase = 1 / base\n return Math.round(value * counterBase) / counterBase\n }\n}\n\n/**\n * Parses a CSS selector into tag name with HTML attributes.\n * Only single element selector are supported (without operators like space, +, >, etc).\n *\n * Multiple values can be returned for each attribute. You decide how to handle them.\n */\nexport function parseSimpleCssSelector(\n selector: string,\n): [tag: string | undefined, attributes: Record] {\n const errorMessage = `Unexpected syntax '${selector}'`\n const tagMatch = /^\\s*([a-z-]*)(.*)$/i.exec(selector) as RegExpExecArray\n const tag = tagMatch[1] || undefined\n const attributes: Record = {}\n const partsRegex = /([.:#][\\w-]+|\\[.+?\\])/gi\n\n const addAttribute = (name: string, value: string) => {\n attributes[name] = attributes[name] || []\n attributes[name].push(value)\n }\n\n for (;;) {\n const match = partsRegex.exec(tagMatch[2])\n if (!match) {\n break\n }\n const part = match[0]\n switch (part[0]) {\n case '.':\n addAttribute('class', part.slice(1))\n break\n case '#':\n addAttribute('id', part.slice(1))\n break\n case '[': {\n const attributeMatch = /^\\[([\\w-]+)([~|^$*]?=(\"(.*?)\"|([\\w-]+)))?(\\s+[is])?\\]$/.exec(part)\n if (attributeMatch) {\n addAttribute(attributeMatch[1], attributeMatch[4] ?? attributeMatch[5] ?? '')\n } else {\n throw new Error(errorMessage)\n }\n break\n }\n default:\n throw new Error(errorMessage)\n }\n }\n\n return [tag, attributes]\n}\n\nexport function areSetsEqual(set1: Set, set2: Set): boolean {\n if (set1 === set2) {\n return true\n }\n if (set1.size !== set2.size) {\n return false\n }\n\n for (let iter = set1.values(), step = iter.next(); !step.done; step = iter.next()) {\n if (!set2.has(step.value)) {\n return false\n }\n }\n return true\n}\n\nexport function maxInIterator(iterator: Iterator, getItemScore: (item: T) => number): T | undefined {\n let maxItem: T | undefined\n let maxItemScore: number | undefined\n\n for (let step = iterator.next(); !step.done; step = iterator.next()) {\n const item = step.value\n const score = getItemScore(item)\n if (maxItemScore === undefined || score > maxItemScore) {\n maxItem = item\n maxItemScore = score\n }\n }\n\n return maxItem\n}\n\n/**\n * Converts a string to UTF8 bytes\n */\nexport function getUTF8Bytes(input: string): Uint8Array {\n // Benchmark: https://jsbench.me/b6klaaxgwq/1\n // If you want to just count bytes, see solutions at https://jsbench.me/ehklab415e/1\n const result = new Uint8Array(input.length)\n for (let i = 0; i < input.length; i++) {\n // `charCode` is faster than encoding, so we prefer that when it's possible\n const charCode = input.charCodeAt(i)\n\n // In case of non-ASCII symbols we use proper encoding\n if (charCode > 127) {\n return new TextEncoder().encode(input)\n }\n result[i] = charCode\n }\n return result\n}\n","/*\n * Based on https://github.com/karanlyons/murmurHash3.js/blob/a33d0723127e2e5415056c455f8aed2451ace208/murmurHash3.js\n */\n\nimport { getUTF8Bytes } from './data'\n\n/**\n * Adds two 64-bit values (provided as tuples of 32-bit values)\n * and updates (mutates) first value to write the result\n */\nfunction x64Add(m: number[], n: number[]): void {\n const m0 = m[0] >>> 16,\n m1 = m[0] & 0xffff,\n m2 = m[1] >>> 16,\n m3 = m[1] & 0xffff\n\n const n0 = n[0] >>> 16,\n n1 = n[0] & 0xffff,\n n2 = n[1] >>> 16,\n n3 = n[1] & 0xffff\n\n let o0 = 0,\n o1 = 0,\n o2 = 0,\n o3 = 0\n o3 += m3 + n3\n o2 += o3 >>> 16\n o3 &= 0xffff\n o2 += m2 + n2\n o1 += o2 >>> 16\n o2 &= 0xffff\n o1 += m1 + n1\n o0 += o1 >>> 16\n o1 &= 0xffff\n o0 += m0 + n0\n o0 &= 0xffff\n\n m[0] = (o0 << 16) | o1\n m[1] = (o2 << 16) | o3\n}\n\n/**\n * Multiplies two 64-bit values (provided as tuples of 32-bit values)\n * and updates (mutates) first value to write the result\n */\nfunction x64Multiply(m: number[], n: number[]): void {\n const m0 = m[0] >>> 16,\n m1 = m[0] & 0xffff,\n m2 = m[1] >>> 16,\n m3 = m[1] & 0xffff\n\n const n0 = n[0] >>> 16,\n n1 = n[0] & 0xffff,\n n2 = n[1] >>> 16,\n n3 = n[1] & 0xffff\n let o0 = 0,\n o1 = 0,\n o2 = 0,\n o3 = 0\n\n o3 += m3 * n3\n o2 += o3 >>> 16\n o3 &= 0xffff\n o2 += m2 * n3\n o1 += o2 >>> 16\n o2 &= 0xffff\n o2 += m3 * n2\n o1 += o2 >>> 16\n o2 &= 0xffff\n o1 += m1 * n3\n o0 += o1 >>> 16\n o1 &= 0xffff\n o1 += m2 * n2\n o0 += o1 >>> 16\n o1 &= 0xffff\n o1 += m3 * n1\n o0 += o1 >>> 16\n o1 &= 0xffff\n o0 += m0 * n3 + m1 * n2 + m2 * n1 + m3 * n0\n o0 &= 0xffff\n\n m[0] = (o0 << 16) | o1\n m[1] = (o2 << 16) | o3\n}\n\n/**\n * Provides left rotation of the given int64 value (provided as tuple of two int32)\n * by given number of bits. Result is written back to the value\n */\nfunction x64Rotl(m: number[], bits: number): void {\n const m0 = m[0]\n bits %= 64\n if (bits === 32) {\n m[0] = m[1]\n m[1] = m0\n } else if (bits < 32) {\n m[0] = (m0 << bits) | (m[1] >>> (32 - bits))\n m[1] = (m[1] << bits) | (m0 >>> (32 - bits))\n } else {\n bits -= 32\n m[0] = (m[1] << bits) | (m0 >>> (32 - bits))\n m[1] = (m0 << bits) | (m[1] >>> (32 - bits))\n }\n}\n\n/**\n * Provides a left shift of the given int32 value (provided as tuple of [0, int32])\n * by given number of bits. Result is written back to the value\n */\nfunction x64LeftShift(m: number[], bits: number): void {\n bits %= 64\n if (bits === 0) {\n return\n } else if (bits < 32) {\n m[0] = m[1] >>> (32 - bits)\n m[1] = m[1] << bits\n } else {\n m[0] = m[1] << (bits - 32)\n m[1] = 0\n }\n}\n/**\n * Provides a XOR of the given int64 values(provided as tuple of two int32).\n * Result is written back to the first value\n */\nfunction x64Xor(m: number[], n: number[]): void {\n m[0] ^= n[0]\n m[1] ^= n[1]\n}\n\nconst F1 = [0xff51afd7, 0xed558ccd]\nconst F2 = [0xc4ceb9fe, 0x1a85ec53]\n/**\n * Calculates murmurHash3's final x64 mix of that block and writes result back to the input value.\n * (`[0, h[0] >>> 1]` is a 33 bit unsigned right shift. This is the\n * only place where we need to right shift 64bit ints.)\n */\nfunction x64Fmix(h: number[]): void {\n const shifted = [0, h[0] >>> 1]\n x64Xor(h, shifted)\n x64Multiply(h, F1)\n shifted[1] = h[0] >>> 1\n x64Xor(h, shifted)\n x64Multiply(h, F2)\n shifted[1] = h[0] >>> 1\n x64Xor(h, shifted)\n}\n\nconst C1 = [0x87c37b91, 0x114253d5]\nconst C2 = [0x4cf5ad43, 0x2745937f]\nconst M = [0, 5]\nconst N1 = [0, 0x52dce729]\nconst N2 = [0, 0x38495ab5]\n/**\n * Given a string and an optional seed as an int, returns a 128 bit\n * hash using the x64 flavor of MurmurHash3, as an unsigned hex.\n * All internal functions mutates passed value to achieve minimal memory allocations and GC load\n *\n * Benchmark https://jsbench.me/p4lkpaoabi/1\n */\nexport function x64hash128(input: string, seed?: number): string {\n const key = getUTF8Bytes(input)\n seed = seed || 0\n const length = [0, key.length]\n const remainder = length[1] % 16\n const bytes = length[1] - remainder\n const h1 = [0, seed]\n const h2 = [0, seed]\n const k1 = [0, 0]\n const k2 = [0, 0]\n\n let i: number\n for (i = 0; i < bytes; i = i + 16) {\n k1[0] = key[i + 4] | (key[i + 5] << 8) | (key[i + 6] << 16) | (key[i + 7] << 24)\n k1[1] = key[i] | (key[i + 1] << 8) | (key[i + 2] << 16) | (key[i + 3] << 24)\n k2[0] = key[i + 12] | (key[i + 13] << 8) | (key[i + 14] << 16) | (key[i + 15] << 24)\n k2[1] = key[i + 8] | (key[i + 9] << 8) | (key[i + 10] << 16) | (key[i + 11] << 24)\n\n x64Multiply(k1, C1)\n x64Rotl(k1, 31)\n x64Multiply(k1, C2)\n x64Xor(h1, k1)\n x64Rotl(h1, 27)\n x64Add(h1, h2)\n x64Multiply(h1, M)\n x64Add(h1, N1)\n x64Multiply(k2, C2)\n x64Rotl(k2, 33)\n x64Multiply(k2, C1)\n x64Xor(h2, k2)\n x64Rotl(h2, 31)\n x64Add(h2, h1)\n x64Multiply(h2, M)\n x64Add(h2, N2)\n }\n k1[0] = 0\n k1[1] = 0\n k2[0] = 0\n k2[1] = 0\n const val = [0, 0]\n switch (remainder) {\n case 15:\n val[1] = key[i + 14]\n x64LeftShift(val, 48)\n x64Xor(k2, val)\n // fallthrough\n case 14:\n val[1] = key[i + 13]\n x64LeftShift(val, 40)\n x64Xor(k2, val)\n // fallthrough\n case 13:\n val[1] = key[i + 12]\n x64LeftShift(val, 32)\n x64Xor(k2, val)\n // fallthrough\n case 12:\n val[1] = key[i + 11]\n x64LeftShift(val, 24)\n x64Xor(k2, val)\n // fallthrough\n case 11:\n val[1] = key[i + 10]\n x64LeftShift(val, 16)\n x64Xor(k2, val)\n // fallthrough\n case 10:\n val[1] = key[i + 9]\n x64LeftShift(val, 8)\n x64Xor(k2, val)\n // fallthrough\n case 9:\n val[1] = key[i + 8]\n\n x64Xor(k2, val)\n x64Multiply(k2, C2)\n x64Rotl(k2, 33)\n x64Multiply(k2, C1)\n x64Xor(h2, k2)\n // fallthrough\n case 8:\n val[1] = key[i + 7]\n x64LeftShift(val, 56)\n x64Xor(k1, val)\n // fallthrough\n case 7:\n val[1] = key[i + 6]\n x64LeftShift(val, 48)\n x64Xor(k1, val)\n // fallthrough\n case 6:\n val[1] = key[i + 5]\n x64LeftShift(val, 40)\n x64Xor(k1, val)\n // fallthrough\n case 5:\n val[1] = key[i + 4]\n x64LeftShift(val, 32)\n x64Xor(k1, val)\n // fallthrough\n case 4:\n val[1] = key[i + 3]\n x64LeftShift(val, 24)\n x64Xor(k1, val)\n // fallthrough\n case 3:\n val[1] = key[i + 2]\n x64LeftShift(val, 16)\n x64Xor(k1, val)\n // fallthrough\n case 2:\n val[1] = key[i + 1]\n x64LeftShift(val, 8)\n x64Xor(k1, val)\n // fallthrough\n case 1:\n val[1] = key[i]\n\n x64Xor(k1, val)\n x64Multiply(k1, C1)\n x64Rotl(k1, 31)\n x64Multiply(k1, C2)\n x64Xor(h1, k1)\n // fallthrough\n }\n x64Xor(h1, length)\n x64Xor(h2, length)\n x64Add(h1, h2)\n x64Add(h2, h1)\n x64Fmix(h1)\n x64Fmix(h2)\n x64Add(h1, h2)\n x64Add(h2, h1)\n return (\n ('00000000' + (h1[0] >>> 0).toString(16)).slice(-8) +\n ('00000000' + (h1[1] >>> 0).toString(16)).slice(-8) +\n ('00000000' + (h2[0] >>> 0).toString(16)).slice(-8) +\n ('00000000' + (h2[1] >>> 0).toString(16)).slice(-8)\n )\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { awaitIfAsync, isPromise, mapWithBreaks, MaybePromise, suppressUnhandledRejectionWarning } from './async'\nimport { excludes } from './data'\n\n/**\n * A functions that returns data with entropy to identify visitor.\n *\n * See https://github.com/fingerprintjs/fingerprintjs/blob/master/contributing.md#how-to-make-an-entropy-source\n * to learn how entropy source works and how to make your own.\n */\nexport type Source = (options: TOptions) => MaybePromise MaybePromise)>\n\n/**\n * Generic dictionary of unknown sources\n */\nexport type UnknownSources = Record>\n\n/**\n * Converts an entropy source type into the component type\n */\nexport type SourceValue> = TSource extends Source ? T : never\n\n/**\n * Result of getting entropy data from a source\n */\nexport type Component = (\n | {\n value: T\n }\n | {\n error: unknown\n }\n) & {\n duration: number\n}\n\n/**\n * Generic dictionary of unknown components\n */\nexport type UnknownComponents = Record>\n\n/**\n * Converts an entropy source list type to a corresponding component list type.\n *\n * Warning for package users:\n * This type is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport type SourcesToComponents> = {\n [K in keyof TSources]: Component>\n}\n\nfunction isFinalResultLoaded(loadResult: TValue | (() => MaybePromise)): loadResult is TValue {\n return typeof loadResult !== 'function'\n}\n\n/**\n * Loads the given entropy source. Returns a function that gets an entropy component from the source.\n *\n * The result is returned synchronously to prevent `loadSources` from\n * waiting for one source to load before getting the components from the other sources.\n */\nexport function loadSource(\n source: Source,\n sourceOptions: TOptions,\n): () => Promise> {\n const sourceLoadPromise = new Promise<() => MaybePromise>>((resolveLoad) => {\n const loadStartTime = Date.now()\n\n // `awaitIfAsync` is used instead of just `await` in order to measure the duration of synchronous sources\n // correctly (other microtasks won't affect the duration).\n awaitIfAsync(source.bind(null, sourceOptions), (...loadArgs) => {\n const loadDuration = Date.now() - loadStartTime\n\n // Source loading failed\n if (!loadArgs[0]) {\n return resolveLoad(() => ({ error: loadArgs[1], duration: loadDuration }))\n }\n\n const loadResult = loadArgs[1]\n\n // Source loaded with the final result\n if (isFinalResultLoaded(loadResult)) {\n return resolveLoad(() => ({ value: loadResult, duration: loadDuration }))\n }\n\n // Source loaded with \"get\" stage\n resolveLoad(\n () =>\n new Promise>((resolveGet) => {\n const getStartTime = Date.now()\n\n awaitIfAsync(loadResult, (...getArgs) => {\n const duration = loadDuration + Date.now() - getStartTime\n\n // Source getting failed\n if (!getArgs[0]) {\n return resolveGet({ error: getArgs[1], duration })\n }\n\n // Source getting succeeded\n resolveGet({ value: getArgs[1], duration })\n })\n }),\n )\n })\n })\n\n suppressUnhandledRejectionWarning(sourceLoadPromise)\n\n return function getComponent() {\n return sourceLoadPromise.then((finalizeSource) => finalizeSource())\n }\n}\n\n/**\n * Loads the given entropy sources. Returns a function that collects the entropy components.\n *\n * The result is returned synchronously in order to allow start getting the components\n * before the sources are loaded completely.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function loadSources, TExclude extends string>(\n sources: TSources,\n sourceOptions: TSourceOptions,\n excludeSources: readonly TExclude[],\n): () => Promise, TExclude>> {\n const includedSources = Object.keys(sources).filter((sourceKey) => excludes(excludeSources, sourceKey)) as Exclude<\n keyof TSources,\n TExclude\n >[]\n // Using `mapWithBreaks` allows asynchronous sources to complete between synchronous sources\n // and measure the duration correctly\n const sourceGettersPromise = mapWithBreaks(includedSources, (sourceKey) =>\n loadSource(sources[sourceKey], sourceOptions),\n )\n suppressUnhandledRejectionWarning(sourceGettersPromise)\n\n return async function getComponents() {\n const sourceGetters = await sourceGettersPromise\n\n const componentPromises = await mapWithBreaks(sourceGetters, (sourceGetter) => {\n const componentPromise = sourceGetter()\n suppressUnhandledRejectionWarning(componentPromise)\n return componentPromise\n })\n\n const componentArray = await Promise.all(componentPromises)\n // Keeping the component keys order the same as the source keys order\n const components = {} as Omit, TExclude>\n for (let index = 0; index < includedSources.length; ++index) {\n components[includedSources[index]] = componentArray[index] as Component\n }\n\n return components\n }\n}\n\n/**\n * Modifies an entropy source by transforming its returned value with the given function.\n * Keeps the source properties: sync/async, 1/2 stages.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function transformSource(\n source: Source,\n transformValue: (value: TValueBefore) => TValueAfter,\n): Source {\n const transformLoadResult = (loadResult: TValueBefore | (() => MaybePromise)) => {\n if (isFinalResultLoaded(loadResult)) {\n return transformValue(loadResult)\n }\n\n return () => {\n const getResult = loadResult()\n\n if (isPromise(getResult)) {\n return getResult.then(transformValue)\n }\n\n return transformValue(getResult)\n }\n }\n\n return (options) => {\n const loadResult = source(options)\n\n if (isPromise(loadResult)) {\n return loadResult.then(transformLoadResult)\n }\n\n return transformLoadResult(loadResult)\n }\n}\n","import { countTruthy } from './data'\nimport { isFunctionNative } from './misc'\n\n/*\n * Functions to help with features that vary through browsers\n */\n\n/**\n * Checks whether the browser is based on Trident (the Internet Explorer engine) without using user-agent.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function isTrident(): boolean {\n const w = window\n const n = navigator\n\n // The properties are checked to be in IE 10, IE 11 and not to be in other browsers in October 2020\n return (\n countTruthy([\n 'MSCSSMatrix' in w,\n 'msSetImmediate' in w,\n 'msIndexedDB' in w,\n 'msMaxTouchPoints' in n,\n 'msPointerEnabled' in n,\n ]) >= 4\n )\n}\n\n/**\n * Checks whether the browser is based on EdgeHTML (the pre-Chromium Edge engine) without using user-agent.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function isEdgeHTML(): boolean {\n // Based on research in October 2020\n const w = window\n const n = navigator\n\n return (\n countTruthy(['msWriteProfilerMark' in w, 'MSStream' in w, 'msLaunchUri' in n, 'msSaveBlob' in n]) >= 3 &&\n !isTrident()\n )\n}\n\n/**\n * Checks whether the browser is based on Chromium without using user-agent.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function isChromium(): boolean {\n // Based on research in October 2020. Tested to detect Chromium 42-86.\n const w = window\n const n = navigator\n\n return (\n countTruthy([\n 'webkitPersistentStorage' in n,\n 'webkitTemporaryStorage' in n,\n n.vendor.indexOf('Google') === 0,\n 'webkitResolveLocalFileSystemURL' in w,\n 'BatteryManager' in w,\n 'webkitMediaStream' in w,\n 'webkitSpeechGrammar' in w,\n ]) >= 5\n )\n}\n\n/**\n * Checks whether the browser is based on mobile or desktop Safari without using user-agent.\n * All iOS browsers use WebKit (the Safari engine).\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function isWebKit(): boolean {\n // Based on research in September 2020\n const w = window\n const n = navigator\n\n return (\n countTruthy([\n 'ApplePayError' in w,\n 'CSSPrimitiveValue' in w,\n 'Counter' in w,\n n.vendor.indexOf('Apple') === 0,\n 'getStorageUpdates' in n,\n 'WebKitMediaKeys' in w,\n ]) >= 4\n )\n}\n\n/**\n * Checks whether this WebKit browser is a desktop browser.\n * It doesn't check that the browser is based on WebKit, there is a separate function for this.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function isDesktopWebKit(): boolean {\n // Checked in Safari and DuckDuckGo\n\n const w = window\n const { HTMLElement, Document } = w\n\n return (\n countTruthy([\n 'safari' in w, // Always false in Karma and BrowserStack Automate\n !('ongestureend' in w),\n !('TouchEvent' in w),\n !('orientation' in w),\n HTMLElement && !('autocapitalize' in HTMLElement.prototype),\n Document && 'pointerLockElement' in Document.prototype,\n ]) >= 4\n )\n}\n\n/**\n * Checks whether this WebKit browser is Safari.\n * It doesn't check that the browser is based on WebKit, there is a separate function for this.\n *\n * Warning! The function works properly only for Safari version 15 and newer.\n */\nexport function isSafariWebKit(): boolean {\n // Checked in Safari, Chrome, Firefox, Yandex, UC Browser, Opera, Edge and DuckDuckGo.\n // iOS Safari and Chrome were checked on iOS 11-17. DuckDuckGo was checked on iOS 17 and macOS 14.\n // Desktop Safari versions 12-17 were checked.\n // The other browsers were checked on iOS 17; there was no chance to check them on the other OS versions.\n\n const w = window\n\n if (!isFunctionNative(w.print)) {\n return false // Chrome, Firefox, Yandex, DuckDuckGo macOS, Edge\n }\n\n return (\n countTruthy([\n // Incorrect in Safari <= 14 (iOS and macOS)\n String((w as unknown as Record).browser) === '[object WebPageNamespace]',\n // Incorrect in desktop Safari and iOS Safari <= 15\n 'MicrodataExtractor' in w,\n ]) >= 1\n )\n}\n\n/**\n * Checks whether the browser is based on Gecko (Firefox engine) without using user-agent.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function isGecko(): boolean {\n const w = window\n\n // Based on research in September 2020\n return (\n countTruthy([\n 'buildID' in navigator,\n 'MozAppearance' in (document.documentElement?.style ?? {}),\n 'onmozfullscreenchange' in w,\n 'mozInnerScreenX' in w,\n 'CSSMozDocumentRule' in w,\n 'CanvasCaptureMediaStream' in w,\n ]) >= 4\n )\n}\n\n/**\n * Checks whether the browser is based on Chromium version ≥86 without using user-agent.\n * It doesn't check that the browser is based on Chromium, there is a separate function for this.\n */\nexport function isChromium86OrNewer(): boolean {\n // Checked in Chrome 85 vs Chrome 86 both on desktop and Android\n const w = window\n\n return (\n countTruthy([\n !('MediaSettingsRange' in w),\n 'RTCEncodedAudioFrame' in w,\n '' + w.Intl === '[object Intl]',\n '' + w.Reflect === '[object Reflect]',\n ]) >= 3\n )\n}\n\n/**\n * Checks whether the browser is based on WebKit version ≥606 (Safari ≥12) without using user-agent.\n * It doesn't check that the browser is based on WebKit, there is a separate function for this.\n *\n * @see https://en.wikipedia.org/wiki/Safari_version_history#Release_history Safari-WebKit versions map\n */\nexport function isWebKit606OrNewer(): boolean {\n // Checked in Safari 9–17\n const w = window\n\n return (\n countTruthy([\n 'DOMRectList' in w,\n 'RTCPeerConnectionIceEvent' in w,\n 'SVGGeometryElement' in w,\n 'ontransitioncancel' in w,\n ]) >= 3\n )\n}\n\n/**\n * Checks whether the browser is based on WebKit version ≥616 (Safari ≥17) without using user-agent.\n * It doesn't check that the browser is based on WebKit, there is a separate function for this.\n *\n * @see https://developer.apple.com/documentation/safari-release-notes/safari-17-release-notes Safari 17 release notes\n * @see https://tauri.app/v1/references/webview-versions/#webkit-versions-in-safari Safari-WebKit versions map\n */\nexport function isWebKit616OrNewer(): boolean {\n const w = window\n const n = navigator\n const { CSS, HTMLButtonElement } = w\n\n return (\n countTruthy([\n !('getStorageUpdates' in n),\n HTMLButtonElement && 'popover' in HTMLButtonElement.prototype,\n 'CSSCounterStyleRule' in w,\n CSS.supports('font-size-adjust: ex-height 0.5'),\n CSS.supports('text-transform: full-width'),\n ]) >= 4\n )\n}\n\n/**\n * Checks whether the device is an iPad.\n * It doesn't check that the engine is WebKit and that the WebKit isn't desktop.\n */\nexport function isIPad(): boolean {\n // Checked on:\n // Safari on iPadOS (both mobile and desktop modes): 8, 11-17\n // Chrome on iPadOS (both mobile and desktop modes): 11-17\n // Safari on iOS (both mobile and desktop modes): 9-17\n // Chrome on iOS (both mobile and desktop modes): 9-17\n\n // Before iOS 13. Safari tampers the value in \"request desktop site\" mode since iOS 13.\n if (navigator.platform === 'iPad') {\n return true\n }\n\n const s = screen\n const screenRatio = s.width / s.height\n\n return (\n countTruthy([\n 'MediaSource' in window, // Since iOS 13\n !!Element.prototype.webkitRequestFullscreen, // Since iOS 12\n // iPhone 4S that runs iOS 9 matches this, but it is not supported\n screenRatio > 0.65 && screenRatio < 1.53,\n ]) >= 2\n )\n}\n\n/**\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function getFullscreenElement(): Element | null {\n const d = document\n return d.fullscreenElement || d.msFullscreenElement || d.mozFullScreenElement || d.webkitFullscreenElement || null\n}\n\nexport function exitFullscreen(): Promise {\n const d = document\n // `call` is required because the function throws an error without a proper \"this\" context\n return (d.exitFullscreen || d.msExitFullscreen || d.mozCancelFullScreen || d.webkitExitFullscreen).call(d)\n}\n\n/**\n * Checks whether the device runs on Android without using user-agent.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function isAndroid(): boolean {\n const isItChromium = isChromium()\n const isItGecko = isGecko()\n const w = window\n const n = navigator\n const c = 'connection'\n\n // Chrome removes all words \"Android\" from `navigator` when desktop version is requested\n // Firefox keeps \"Android\" in `navigator.appVersion` when desktop version is requested\n if (isItChromium) {\n return (\n countTruthy([\n !('SharedWorker' in w),\n // `typechange` is deprecated, but it's still present on Android (tested on Chrome Mobile 117)\n // Removal proposal https://bugs.chromium.org/p/chromium/issues/detail?id=699892\n // Note: this expression returns true on ChromeOS, so additional detectors are required to avoid false-positives\n n[c] && 'ontypechange' in n[c],\n !('sinkId' in new window.Audio()),\n ]) >= 2\n )\n } else if (isItGecko) {\n return countTruthy(['onorientationchange' in w, 'orientation' in w, /android/i.test(navigator.appVersion)]) >= 2\n } else {\n // Only 2 browser engines are presented on Android.\n // Actually, there is also Android 4.1 browser, but it's not worth detecting it at the moment.\n return false\n }\n}\n","/**\n * Converts an error object to a plain object that can be used with `JSON.stringify`.\n * If you just run `JSON.stringify(error)`, you'll get `'{}'`.\n */\nexport function errorToObject(error: Readonly): Record {\n return {\n name: error.name,\n message: error.message,\n stack: error.stack?.split('\\n'),\n // The fields are not enumerable, so TS is wrong saying that they will be overridden\n ...(error as Omit),\n }\n}\n\nexport function isFunctionNative(func: (...args: unknown[]) => unknown): boolean {\n return /^function\\s.*?\\{\\s*\\[native code]\\s*}$/.test(String(func))\n}\n","import { MaybePromise, wait } from './async'\nimport { parseSimpleCssSelector } from './data'\n\n/**\n * Creates and keeps an invisible iframe while the given function runs.\n * The given function is called when the iframe is loaded and has a body.\n * The iframe allows to measure DOM sizes inside itself.\n *\n * Notice: passing an initial HTML code doesn't work in IE.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport async function withIframe(\n action: (iframe: HTMLIFrameElement, iWindow: Window) => MaybePromise,\n initialHtml?: string,\n domPollInterval = 50,\n): Promise {\n const d = document\n\n // document.body can be null while the page is loading\n while (!d.body) {\n await wait(domPollInterval)\n }\n\n const iframe = d.createElement('iframe')\n\n try {\n await new Promise((_resolve, _reject) => {\n let isComplete = false\n const resolve = () => {\n isComplete = true\n _resolve()\n }\n const reject = (error: unknown) => {\n isComplete = true\n _reject(error)\n }\n\n iframe.onload = resolve\n iframe.onerror = reject\n const { style } = iframe\n style.setProperty('display', 'block', 'important') // Required for browsers to calculate the layout\n style.position = 'absolute'\n style.top = '0'\n style.left = '0'\n style.visibility = 'hidden'\n if (initialHtml && 'srcdoc' in iframe) {\n iframe.srcdoc = initialHtml\n } else {\n iframe.src = 'about:blank'\n }\n d.body.appendChild(iframe)\n\n // WebKit in WeChat doesn't fire the iframe's `onload` for some reason.\n // This code checks for the loading state manually.\n // See https://github.com/fingerprintjs/fingerprintjs/issues/645\n const checkReadyState = () => {\n // The ready state may never become 'complete' in Firefox despite the 'load' event being fired.\n // So an infinite setTimeout loop can happen without this check.\n // See https://github.com/fingerprintjs/fingerprintjs/pull/716#issuecomment-986898796\n if (isComplete) {\n return\n }\n\n // Make sure iframe.contentWindow and iframe.contentWindow.document are both loaded\n // The contentWindow.document can miss in JSDOM (https://github.com/jsdom/jsdom).\n if (iframe.contentWindow?.document?.readyState === 'complete') {\n resolve()\n } else {\n setTimeout(checkReadyState, 10)\n }\n }\n checkReadyState()\n })\n\n while (!iframe.contentWindow?.document?.body) {\n await wait(domPollInterval)\n }\n\n return await action(iframe, iframe.contentWindow)\n } finally {\n iframe.parentNode?.removeChild(iframe)\n }\n}\n\n/**\n * Creates a DOM element that matches the given selector.\n * Only single element selector are supported (without operators like space, +, >, etc).\n */\nexport function selectorToElement(selector: string): HTMLElement {\n const [tag, attributes] = parseSimpleCssSelector(selector)\n const element = document.createElement(tag ?? 'div')\n for (const name of Object.keys(attributes)) {\n const value = attributes[name].join(' ')\n // Changing the `style` attribute can cause a CSP error, therefore we change the `style.cssText` property.\n // https://github.com/fingerprintjs/fingerprintjs/issues/733\n if (name === 'style') {\n addStyleString(element.style, value)\n } else {\n element.setAttribute(name, value)\n }\n }\n return element\n}\n\n/**\n * Adds CSS styles from a string in such a way that doesn't trigger a CSP warning (unsafe-inline or unsafe-eval)\n */\nexport function addStyleString(style: CSSStyleDeclaration, source: string): void {\n // We don't use `style.cssText` because browsers must block it when no `unsafe-eval` CSP is presented: https://csplite.com/csp145/#w3c_note\n // Even though the browsers ignore this standard, we don't use `cssText` just in case.\n for (const property of source.split(';')) {\n const match = /^\\s*([\\w-]+)\\s*:\\s*(.+?)(\\s*!([\\w-]+))?\\s*$/.exec(property)\n if (match) {\n const [, name, value, , priority] = match\n style.setProperty(name, value, priority || '') // The last argument can't be undefined in IE11\n }\n }\n}\n\n/**\n * The returned promise resolves when the tab becomes visible (in foreground).\n * If the tab is already visible, resolves immediately.\n */\nexport function whenDocumentVisible(): Promise {\n return new Promise((resolve) => {\n const d = document\n const eventName = 'visibilitychange'\n const handleVisibilityChange = () => {\n if (!d.hidden) {\n d.removeEventListener(eventName, handleVisibilityChange)\n resolve()\n }\n }\n d.addEventListener(eventName, handleVisibilityChange)\n handleVisibilityChange()\n })\n}\n","import { isDesktopWebKit, isWebKit, isWebKit606OrNewer } from '../utils/browser'\nimport { isPromise, suppressUnhandledRejectionWarning, wait } from '../utils/async'\nimport { whenDocumentVisible } from '../utils/dom'\n\nexport const enum SpecialFingerprint {\n /** The browser is known for always suspending audio context, thus making fingerprinting impossible */\n KnownForSuspending = -1,\n /** The browser doesn't support audio context */\n NotSupported = -2,\n /** An unexpected timeout has happened */\n Timeout = -3,\n}\n\nconst sampleRate = 44100\nconst cloneCount = 40000\nconst stabilizationPrecision = 6.2\n\n/**\n * A version of the entropy source with stabilization to make it suitable for static fingerprinting.\n * Audio signal is noised in private mode of Safari 17.\n */\nexport default async function getAudioFingerprint(): Promise<() => number> {\n const finish = await getUnstableAudioFingerprint()\n return () => {\n const rawFingerprint = finish()\n return stabilize(rawFingerprint, stabilizationPrecision)\n }\n}\n\n/**\n * A version of the entropy source without stabilization.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport async function getUnstableAudioFingerprint(): Promise<() => number> {\n let fingerprintResult: [true, number] | [false, unknown] | undefined\n\n // The timeout is not started until the browser tab becomes visible because some browsers may not want to render\n // an audio context in background.\n const timeoutPromise = whenDocumentVisible().then(() => wait(500))\n const fingerprintPromise = getBaseAudioFingerprint().then(\n (result) => (fingerprintResult = [true, result]),\n (error) => (fingerprintResult = [false, error]),\n )\n await Promise.race([timeoutPromise, fingerprintPromise])\n\n return () => {\n if (!fingerprintResult) {\n return SpecialFingerprint.Timeout\n }\n if (!fingerprintResult[0]) {\n throw fingerprintResult[1]\n }\n return fingerprintResult[1]\n }\n}\n\nasync function getBaseAudioFingerprint(): Promise {\n const w = window\n const AudioContext = w.OfflineAudioContext || w.webkitOfflineAudioContext\n if (!AudioContext) {\n return SpecialFingerprint.NotSupported\n }\n\n // In some browsers, audio context always stays suspended unless the context is started in response to a user action\n // (e.g. a click or a tap). It prevents audio fingerprint from being taken at an arbitrary moment of time.\n // Such browsers are old and unpopular, so the audio fingerprinting is just skipped in them.\n // See a similar case explanation at https://stackoverflow.com/questions/46363048/onaudioprocess-not-called-on-ios11#46534088\n if (doesBrowserSuspendAudioContext()) {\n return SpecialFingerprint.KnownForSuspending\n }\n\n const baseSignal = await getBaseSignal(AudioContext)\n if (!baseSignal) {\n return SpecialFingerprint.Timeout\n }\n\n // This context copies the last sample of the base signal many times.\n // The array of copies helps to cancel the noise.\n const context = new AudioContext(1, baseSignal.length - 1 + cloneCount, sampleRate)\n const sourceNode = context.createBufferSource()\n sourceNode.buffer = baseSignal\n sourceNode.loop = true\n sourceNode.loopStart = (baseSignal.length - 1) / sampleRate\n sourceNode.loopEnd = baseSignal.length / sampleRate\n sourceNode.connect(context.destination)\n sourceNode.start()\n\n const clonedSignal = await renderAudio(context)\n if (!clonedSignal) {\n return SpecialFingerprint.Timeout\n }\n const fingerprint = extractFingerprint(baseSignal, clonedSignal.getChannelData(0).subarray(baseSignal.length - 1))\n return Math.abs(fingerprint) // The fingerprint is made positive to avoid confusion with the special fingerprints\n}\n\n/**\n * Checks if the current browser is known for always suspending audio context.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function doesBrowserSuspendAudioContext() {\n // Mobile Safari 11 and older\n return isWebKit() && !isDesktopWebKit() && !isWebKit606OrNewer()\n}\n\n/**\n * Produces an arbitrary audio signal\n */\nasync function getBaseSignal(AudioContext: typeof OfflineAudioContext) {\n const targetSampleIndex = 3395\n const context = new AudioContext(1, targetSampleIndex + 1, sampleRate)\n\n const oscillator = context.createOscillator()\n oscillator.type = 'square'\n oscillator.frequency.value = 1000\n\n const compressor = context.createDynamicsCompressor()\n compressor.threshold.value = -70\n compressor.knee.value = 40\n compressor.ratio.value = 12\n compressor.attack.value = 0\n compressor.release.value = 0.25\n\n const filter = context.createBiquadFilter()\n filter.type = 'allpass'\n filter.frequency.value = 5.239622852977861\n filter.Q.value = 0.1\n\n oscillator.connect(compressor)\n compressor.connect(filter)\n filter.connect(context.destination)\n oscillator.start(0)\n\n return await renderAudio(context)\n}\n\n/**\n * Renders the given audio context with configured nodes.\n * Returns `null` when the rendering runs out of attempts.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function renderAudio(context: OfflineAudioContext) {\n return new Promise((resolve, reject) => {\n const retryDelay = 200\n let attemptsLeft = 25\n\n context.oncomplete = (event) => resolve(event.renderedBuffer)\n\n const tryRender = () => {\n try {\n const renderingPromise = context.startRendering()\n\n // `context.startRendering` has two APIs: Promise and callback, we check that it's really a promise just in case\n if (isPromise(renderingPromise)) {\n // Suppresses all unhandled rejections in case of scheduled redundant retries after successful rendering\n suppressUnhandledRejectionWarning(renderingPromise)\n }\n\n // Sometimes the audio context doesn't start after calling `startRendering` (in addition to the cases where\n // audio context doesn't start at all). A known case is starting an audio context when the browser tab is in\n // background on iPhone. Retries usually help in this case.\n if (context.state === 'suspended') {\n // The audio context can reject starting until the tab is in foreground. Long fingerprint duration\n // in background isn't a problem, therefore the retry attempts don't count in background. It can lead to\n // a situation when a fingerprint takes very long time and finishes successfully. FYI, the audio context\n // can be suspended when `document.hidden === false` and start running after a retry.\n if (!document.hidden) {\n attemptsLeft--\n }\n if (attemptsLeft > 0) {\n setTimeout(tryRender, retryDelay)\n } else {\n resolve(null)\n }\n }\n } catch (error) {\n reject(error)\n }\n }\n\n tryRender()\n })\n}\n\nfunction extractFingerprint(baseSignal: AudioBuffer, clonedSample: Float32Array): number {\n let fingerprint = undefined\n let needsDenoising = false\n\n for (let i = 0; i < clonedSample.length; i += Math.floor(clonedSample.length / 10)) {\n if (clonedSample[i] === 0) {\n // In some cases the signal is 0 on a short range for some reason. Ignoring such samples.\n } else if (fingerprint === undefined) {\n fingerprint = clonedSample[i]\n } else if (fingerprint !== clonedSample[i]) {\n needsDenoising = true\n break\n }\n }\n\n // The looped buffer source works incorrectly in old Safari versions (>14 desktop, >15 mobile).\n // The looped signal contains only 0s. To fix it, the loop start should be `baseSignal.length - 1.00000000001` and\n // the loop end should be `baseSignal.length + 0.00000000001` (there can be 10 or 11 0s after the point). But this\n // solution breaks the looped signal in other browsers. Instead of checking the browser version, we check that the\n // looped signals comprises only 0s, and if it does, we return the last value of the base signal, because old Safari\n // versions don't add noise that we want to cancel.\n if (fingerprint === undefined) {\n fingerprint = baseSignal.getChannelData(0)[baseSignal.length - 1]\n } else if (needsDenoising) {\n fingerprint = getMiddle(clonedSample)\n }\n\n return fingerprint\n}\n\n/**\n * Calculates the middle between the minimum and the maximum array item\n */\nexport function getMiddle(signal: ArrayLike): number {\n let min = Infinity\n let max = -Infinity\n\n for (let i = 0; i < signal.length; i++) {\n const value = signal[i]\n // In very rare cases the signal is 0 on a short range for some reason. Ignoring such samples.\n if (value === 0) {\n continue\n }\n if (value < min) {\n min = value\n }\n if (value > max) {\n max = value\n }\n }\n\n return (min + max) / 2\n}\n\n/**\n * Truncates some digits of the number to make it stable.\n * `precision` is the number of significant digits to keep. The number may be not integer:\n * - If it ends with `.2`, the last digit is rounded to the nearest multiple of 5;\n * - If it ends with `.5`, the last digit is rounded to the nearest even number;\n */\nexport function stabilize(value: number, precision: number): number {\n if (value === 0) {\n return value\n }\n\n const power = Math.floor(Math.log10(Math.abs(value)))\n const precisionPower = power - Math.floor(precision) + 1\n const precisionBase = 10 ** -precisionPower * ((precision * 10) % 10 || 1)\n return Math.round(value * precisionBase) / precisionBase\n}\n","import { releaseEventLoop } from '../utils/async'\nimport { withIframe } from '../utils/dom'\n\n// We use m or w because these two characters take up the maximum width.\n// And we use a LLi so that the same matching fonts can get separated.\nconst testString = 'mmMwWLliI0O&1'\n\n// We test using 48px font size, we may use any size. I guess larger the better.\nconst textSize = '48px'\n\n// A font will be compared against all the three default fonts.\n// And if for any default fonts it doesn't match, then that font is available.\nconst baseFonts = ['monospace', 'sans-serif', 'serif'] as const\n\nconst fontList = [\n // This is android-specific font from \"Roboto\" family\n 'sans-serif-thin',\n 'ARNO PRO',\n 'Agency FB',\n 'Arabic Typesetting',\n 'Arial Unicode MS',\n 'AvantGarde Bk BT',\n 'BankGothic Md BT',\n 'Batang',\n 'Bitstream Vera Sans Mono',\n 'Calibri',\n 'Century',\n 'Century Gothic',\n 'Clarendon',\n 'EUROSTILE',\n 'Franklin Gothic',\n 'Futura Bk BT',\n 'Futura Md BT',\n 'GOTHAM',\n 'Gill Sans',\n 'HELV',\n 'Haettenschweiler',\n 'Helvetica Neue',\n 'Humanst521 BT',\n 'Leelawadee',\n 'Letter Gothic',\n 'Levenim MT',\n 'Lucida Bright',\n 'Lucida Sans',\n 'Menlo',\n 'MS Mincho',\n 'MS Outlook',\n 'MS Reference Specialty',\n 'MS UI Gothic',\n 'MT Extra',\n 'MYRIAD PRO',\n 'Marlett',\n 'Meiryo UI',\n 'Microsoft Uighur',\n 'Minion Pro',\n 'Monotype Corsiva',\n 'PMingLiU',\n 'Pristina',\n 'SCRIPTINA',\n 'Segoe UI Light',\n 'Serifa',\n 'SimHei',\n 'Small Fonts',\n 'Staccato222 BT',\n 'TRAJAN PRO',\n 'Univers CE 55 Medium',\n 'Vrinda',\n 'ZWAdobeF',\n] as const\n\n// kudos to http://www.lalit.org/lab/javascript-css-font-detect/\nexport default function getFonts(): Promise {\n // Running the script in an iframe makes it not affect the page look and not be affected by the page CSS. See:\n // https://github.com/fingerprintjs/fingerprintjs/issues/592\n // https://github.com/fingerprintjs/fingerprintjs/issues/628\n return withIframe(async (_, { document }) => {\n const holder = document.body\n holder.style.fontSize = textSize\n\n // div to load spans for the default fonts and the fonts to detect\n const spansContainer = document.createElement('div')\n spansContainer.style.setProperty('visibility', 'hidden', 'important')\n\n const defaultWidth: Partial> = {}\n const defaultHeight: Partial> = {}\n\n // creates a span where the fonts will be loaded\n const createSpan = (fontFamily: string) => {\n const span = document.createElement('span')\n const { style } = span\n style.position = 'absolute'\n style.top = '0'\n style.left = '0'\n style.fontFamily = fontFamily\n span.textContent = testString\n spansContainer.appendChild(span)\n return span\n }\n\n // creates a span and load the font to detect and a base font for fallback\n const createSpanWithFonts = (fontToDetect: string, baseFont: string) => {\n return createSpan(`'${fontToDetect}',${baseFont}`)\n }\n\n // creates spans for the base fonts and adds them to baseFontsDiv\n const initializeBaseFontsSpans = () => {\n return baseFonts.map(createSpan)\n }\n\n // creates spans for the fonts to detect and adds them to fontsDiv\n const initializeFontsSpans = () => {\n // Stores {fontName : [spans for that font]}\n const spans: Record = {}\n\n for (const font of fontList) {\n spans[font] = baseFonts.map((baseFont) => createSpanWithFonts(font, baseFont))\n }\n\n return spans\n }\n\n // checks if a font is available\n const isFontAvailable = (fontSpans: HTMLElement[]) => {\n return baseFonts.some(\n (baseFont, baseFontIndex) =>\n fontSpans[baseFontIndex].offsetWidth !== defaultWidth[baseFont] ||\n fontSpans[baseFontIndex].offsetHeight !== defaultHeight[baseFont],\n )\n }\n\n // create spans for base fonts\n const baseFontsSpans = initializeBaseFontsSpans()\n\n // create spans for fonts to detect\n const fontsSpans = initializeFontsSpans()\n\n // add all the spans to the DOM\n holder.appendChild(spansContainer)\n\n await releaseEventLoop()\n\n // get the default width for the three base fonts\n for (let index = 0; index < baseFonts.length; index++) {\n defaultWidth[baseFonts[index]] = baseFontsSpans[index].offsetWidth // width for the default font\n defaultHeight[baseFonts[index]] = baseFontsSpans[index].offsetHeight // height for the default font\n }\n\n // check available fonts\n return fontList.filter((font) => isFontAvailable(fontsSpans[font]))\n })\n}\n","import { releaseEventLoop } from '../utils/async'\nimport { isSafariWebKit, isWebKit, isWebKit616OrNewer } from '../utils/browser'\n\nexport interface CanvasFingerprint {\n winding: boolean\n geometry: string\n text: string\n}\n\nexport const enum ImageStatus {\n Unsupported = 'unsupported',\n Skipped = 'skipped',\n Unstable = 'unstable',\n}\n\n/**\n * @see https://www.browserleaks.com/canvas#how-does-it-work\n *\n * A version of the entropy source with stabilization to make it suitable for static fingerprinting.\n * Canvas image is noised in private mode of Safari 17, so image rendering is skipped in Safari 17.\n */\nexport default function getCanvasFingerprint(): Promise {\n return getUnstableCanvasFingerprint(doesBrowserPerformAntifingerprinting())\n}\n\n/**\n * A version of the entropy source without stabilization.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport async function getUnstableCanvasFingerprint(skipImages?: boolean): Promise {\n let winding = false\n let geometry: string\n let text: string\n\n const [canvas, context] = makeCanvasContext()\n if (!isSupported(canvas, context)) {\n geometry = text = ImageStatus.Unsupported\n } else {\n winding = doesSupportWinding(context)\n\n if (skipImages) {\n geometry = text = ImageStatus.Skipped\n } else {\n ;[geometry, text] = await renderImages(canvas, context)\n }\n }\n\n return { winding, geometry, text }\n}\n\nfunction makeCanvasContext() {\n const canvas = document.createElement('canvas')\n canvas.width = 1\n canvas.height = 1\n return [canvas, canvas.getContext('2d')] as const\n}\n\nfunction isSupported(\n canvas: HTMLCanvasElement,\n context?: CanvasRenderingContext2D | null,\n): context is CanvasRenderingContext2D {\n return !!(context && canvas.toDataURL)\n}\n\nfunction doesSupportWinding(context: CanvasRenderingContext2D) {\n // https://web.archive.org/web/20170825024655/http://blogs.adobe.com/webplatform/2013/01/30/winding-rules-in-canvas/\n // https://github.com/Modernizr/Modernizr/blob/master/feature-detects/canvas/winding.js\n context.rect(0, 0, 10, 10)\n context.rect(2, 2, 6, 6)\n return !context.isPointInPath(5, 5, 'evenodd')\n}\n\nasync function renderImages(\n canvas: HTMLCanvasElement,\n context: CanvasRenderingContext2D,\n): Promise<[geometry: string, text: string]> {\n renderTextImage(canvas, context)\n await releaseEventLoop()\n const textImage1 = canvasToString(canvas)\n const textImage2 = canvasToString(canvas) // It's slightly faster to double-encode the text image\n\n // Some browsers add a noise to the canvas: https://github.com/fingerprintjs/fingerprintjs/issues/791\n // The canvas is excluded from the fingerprint in this case\n if (textImage1 !== textImage2) {\n return [ImageStatus.Unstable, ImageStatus.Unstable]\n }\n\n // Text is unstable:\n // https://github.com/fingerprintjs/fingerprintjs/issues/583\n // https://github.com/fingerprintjs/fingerprintjs/issues/103\n // Therefore it's extracted into a separate image.\n renderGeometryImage(canvas, context)\n await releaseEventLoop()\n const geometryImage = canvasToString(canvas)\n return [textImage1, geometryImage]\n}\n\nfunction renderTextImage(canvas: HTMLCanvasElement, context: CanvasRenderingContext2D) {\n // Resizing the canvas cleans it\n canvas.width = 240\n canvas.height = 60\n\n context.textBaseline = 'alphabetic'\n context.fillStyle = '#f60'\n context.fillRect(100, 1, 62, 20)\n\n context.fillStyle = '#069'\n // It's important to use explicit built-in fonts in order to exclude the affect of font preferences\n // (there is a separate entropy source for them).\n context.font = '11pt \"Times New Roman\"'\n // The choice of emojis has a gigantic impact on rendering performance (especially in FF).\n // Some newer emojis cause it to slow down 50-200 times.\n // There must be no text to the right of the emoji, see https://github.com/fingerprintjs/fingerprintjs/issues/574\n // A bare emoji shouldn't be used because the canvas will change depending on the script encoding:\n // https://github.com/fingerprintjs/fingerprintjs/issues/66\n // Escape sequence shouldn't be used too because Terser will turn it into a bare unicode.\n const printedText = `Cwm fjordbank gly ${String.fromCharCode(55357, 56835) /* 😃 */}`\n context.fillText(printedText, 2, 15)\n context.fillStyle = 'rgba(102, 204, 0, 0.2)'\n context.font = '18pt Arial'\n context.fillText(printedText, 4, 45)\n}\n\nfunction renderGeometryImage(canvas: HTMLCanvasElement, context: CanvasRenderingContext2D) {\n // Resizing the canvas cleans it\n canvas.width = 122\n canvas.height = 110\n\n // Canvas blending\n // https://web.archive.org/web/20170826194121/http://blogs.adobe.com/webplatform/2013/01/28/blending-features-in-canvas/\n // http://jsfiddle.net/NDYV8/16/\n context.globalCompositeOperation = 'multiply'\n for (const [color, x, y] of [\n ['#f2f', 40, 40],\n ['#2ff', 80, 40],\n ['#ff2', 60, 80],\n ] as const) {\n context.fillStyle = color\n context.beginPath()\n context.arc(x, y, 40, 0, Math.PI * 2, true)\n context.closePath()\n context.fill()\n }\n\n // Canvas winding\n // https://web.archive.org/web/20130913061632/http://blogs.adobe.com/webplatform/2013/01/30/winding-rules-in-canvas/\n // http://jsfiddle.net/NDYV8/19/\n context.fillStyle = '#f9c'\n context.arc(60, 60, 60, 0, Math.PI * 2, true)\n context.arc(60, 60, 20, 0, Math.PI * 2, true)\n context.fill('evenodd')\n}\n\nfunction canvasToString(canvas: HTMLCanvasElement) {\n return canvas.toDataURL()\n}\n\n/**\n * Checks if the current browser is known for applying anti-fingerprinting measures in all or some critical modes\n */\nfunction doesBrowserPerformAntifingerprinting() {\n // Safari 17\n return isWebKit() && isWebKit616OrNewer() && isSafariWebKit()\n}\n","import { replaceNaN, round, toFloat } from '../utils/data'\nimport { exitFullscreen, getFullscreenElement, isSafariWebKit, isWebKit, isWebKit616OrNewer } from '../utils/browser'\n\n/**\n * The order matches the CSS side order: top, right, bottom, left.\n *\n * @ignore Named array elements aren't used because of multiple TypeScript compatibility complaints from users\n */\nexport type FrameSize = [number | null, number | null, number | null, number | null]\n\nexport const screenFrameCheckInterval = 2500\nconst roundingPrecision = 10\n\n// The type is readonly to protect from unwanted mutations\nlet screenFrameBackup: Readonly | undefined\nlet screenFrameSizeTimeoutId: number | undefined\n\n/**\n * Starts watching the screen frame size. When a non-zero size appears, the size is saved and the watch is stopped.\n * Later, when `getScreenFrame` runs, it will return the saved non-zero size if the current size is null.\n *\n * This trick is required to mitigate the fact that the screen frame turns null in some cases.\n * See more on this at https://github.com/fingerprintjs/fingerprintjs/issues/568\n */\nfunction watchScreenFrame() {\n if (screenFrameSizeTimeoutId !== undefined) {\n return\n }\n const checkScreenFrame = () => {\n const frameSize = getCurrentScreenFrame()\n if (isFrameSizeNull(frameSize)) {\n screenFrameSizeTimeoutId = (setTimeout as typeof window.setTimeout)(checkScreenFrame, screenFrameCheckInterval)\n } else {\n screenFrameBackup = frameSize\n screenFrameSizeTimeoutId = undefined\n }\n }\n checkScreenFrame()\n}\n\n/**\n * For tests only\n */\nexport function resetScreenFrameWatch(): void {\n if (screenFrameSizeTimeoutId !== undefined) {\n clearTimeout(screenFrameSizeTimeoutId)\n screenFrameSizeTimeoutId = undefined\n }\n screenFrameBackup = undefined\n}\n\n/**\n * A version of the entropy source without stabilization.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function getUnstableScreenFrame(): () => Promise {\n watchScreenFrame()\n\n return async () => {\n let frameSize = getCurrentScreenFrame()\n\n if (isFrameSizeNull(frameSize)) {\n if (screenFrameBackup) {\n return [...screenFrameBackup]\n }\n\n if (getFullscreenElement()) {\n // Some browsers set the screen frame to zero when programmatic fullscreen is on.\n // There is a chance of getting a non-zero frame after exiting the fullscreen.\n // See more on this at https://github.com/fingerprintjs/fingerprintjs/issues/568\n await exitFullscreen()\n frameSize = getCurrentScreenFrame()\n }\n }\n\n if (!isFrameSizeNull(frameSize)) {\n screenFrameBackup = frameSize\n }\n\n return frameSize\n }\n}\n\n/**\n * A version of the entropy source with stabilization to make it suitable for static fingerprinting.\n *\n * Sometimes the available screen resolution changes a bit, e.g. 1900x1440 → 1900x1439. A possible reason: macOS Dock\n * shrinks to fit more icons when there is too little space. The rounding is used to mitigate the difference.\n *\n * The frame width is always 0 in private mode of Safari 17, so the frame is not used in Safari 17.\n */\nexport default function getScreenFrame(): () => Promise {\n if (isWebKit() && isWebKit616OrNewer() && isSafariWebKit()) {\n return () => Promise.resolve(undefined)\n }\n\n const screenFrameGetter = getUnstableScreenFrame()\n\n return async () => {\n const frameSize = await screenFrameGetter()\n const processSize = (sideSize: FrameSize[number]) => (sideSize === null ? null : round(sideSize, roundingPrecision))\n\n // It might look like I don't know about `for` and `map`.\n // In fact, such code is used to avoid TypeScript issues without using `as`.\n return [processSize(frameSize[0]), processSize(frameSize[1]), processSize(frameSize[2]), processSize(frameSize[3])]\n }\n}\n\nfunction getCurrentScreenFrame(): FrameSize {\n const s = screen\n\n // Some browsers return screen resolution as strings, e.g. \"1200\", instead of a number, e.g. 1200.\n // I suspect it's done by certain plugins that randomize browser properties to prevent fingerprinting.\n //\n // Some browsers (IE, Edge ≤18) don't provide `screen.availLeft` and `screen.availTop`. The property values are\n // replaced with 0 in such cases to not lose the entropy from `screen.availWidth` and `screen.availHeight`.\n return [\n replaceNaN(toFloat(s.availTop), null),\n replaceNaN(toFloat(s.width) - toFloat(s.availWidth) - replaceNaN(toFloat(s.availLeft), 0), null),\n replaceNaN(toFloat(s.height) - toFloat(s.availHeight) - replaceNaN(toFloat(s.availTop), 0), null),\n replaceNaN(toFloat(s.availLeft), null),\n ]\n}\n\nfunction isFrameSizeNull(frameSize: FrameSize) {\n for (let i = 0; i < 4; ++i) {\n if (frameSize[i]) {\n return false\n }\n }\n return true\n}\n","export default function getCpuClass(): string | undefined {\n isSourceLoaded.x = true\n return navigator.cpuClass\n}\n\n/**\n * A little dirty hack to check whether an entropy source is loaded in the tests.\n * The value is exported only for tests.\n */\nexport const isSourceLoaded = {\n x: false,\n}\n","import { isAndroid, isWebKit } from '../utils/browser'\nimport { selectorToElement } from '../utils/dom'\nimport { countTruthy } from '../utils/data'\nimport { releaseEventLoop, wait } from '../utils/async'\n\ntype Filters = Record\n\n/**\n * Only single element selector are supported (no operators like space, +, >, etc).\n * `embed` and `position: fixed;` will be considered as blocked anyway because it always has no offsetParent.\n * Avoid `iframe` and anything with `[src=]` because they produce excess HTTP requests.\n *\n * The \"inappropriate\" selectors are obfuscated. See https://github.com/fingerprintjs/fingerprintjs/issues/734.\n * A function is used instead of a plain object to help tree-shaking.\n *\n * The function code is generated automatically. See docs/content_blockers.md to learn how to make the list.\n */\nexport function getFilters(): Filters {\n const fromB64 = atob // Just for better minification\n\n return {\n abpIndo: [\n '#Iklan-Melayang',\n '#Kolom-Iklan-728',\n '#SidebarIklan-wrapper',\n '[title=\"ALIENBOLA\" i]',\n fromB64('I0JveC1CYW5uZXItYWRz'),\n ],\n abpvn: ['.quangcao', '#mobileCatfish', fromB64('LmNsb3NlLWFkcw=='), '[id^=\"bn_bottom_fixed_\"]', '#pmadv'],\n adBlockFinland: [\n '.mainostila',\n fromB64('LnNwb25zb3JpdA=='),\n '.ylamainos',\n fromB64('YVtocmVmKj0iL2NsaWNrdGhyZ2guYXNwPyJd'),\n fromB64('YVtocmVmXj0iaHR0cHM6Ly9hcHAucmVhZHBlYWsuY29tL2FkcyJd'),\n ],\n adBlockPersian: [\n '#navbar_notice_50',\n '.kadr',\n 'TABLE[width=\"140px\"]',\n '#divAgahi',\n fromB64('YVtocmVmXj0iaHR0cDovL2cxLnYuZndtcm0ubmV0L2FkLyJd'),\n ],\n adBlockWarningRemoval: [\n '#adblock-honeypot',\n '.adblocker-root',\n '.wp_adblock_detect',\n fromB64('LmhlYWRlci1ibG9ja2VkLWFk'),\n fromB64('I2FkX2Jsb2NrZXI='),\n ],\n adGuardAnnoyances: [\n '.hs-sosyal',\n '#cookieconsentdiv',\n 'div[class^=\"app_gdpr\"]',\n '.as-oil',\n '[data-cypress=\"soft-push-notification-modal\"]',\n ],\n adGuardBase: [\n '.BetterJsPopOverlay',\n fromB64('I2FkXzMwMFgyNTA='),\n fromB64('I2Jhbm5lcmZsb2F0MjI='),\n fromB64('I2NhbXBhaWduLWJhbm5lcg=='),\n fromB64('I0FkLUNvbnRlbnQ='),\n ],\n adGuardChinese: [\n fromB64('LlppX2FkX2FfSA=='),\n fromB64('YVtocmVmKj0iLmh0aGJldDM0LmNvbSJd'),\n '#widget-quan',\n fromB64('YVtocmVmKj0iLzg0OTkyMDIwLnh5eiJd'),\n fromB64('YVtocmVmKj0iLjE5NTZobC5jb20vIl0='),\n ],\n adGuardFrench: [\n '#pavePub',\n fromB64('LmFkLWRlc2t0b3AtcmVjdGFuZ2xl'),\n '.mobile_adhesion',\n '.widgetadv',\n fromB64('LmFkc19iYW4='),\n ],\n adGuardGerman: ['aside[data-portal-id=\"leaderboard\"]'],\n adGuardJapanese: [\n '#kauli_yad_1',\n fromB64('YVtocmVmXj0iaHR0cDovL2FkMi50cmFmZmljZ2F0ZS5uZXQvIl0='),\n fromB64('Ll9wb3BJbl9pbmZpbml0ZV9hZA=='),\n fromB64('LmFkZ29vZ2xl'),\n fromB64('Ll9faXNib29zdFJldHVybkFk'),\n ],\n adGuardMobile: [\n fromB64('YW1wLWF1dG8tYWRz'),\n fromB64('LmFtcF9hZA=='),\n 'amp-embed[type=\"24smi\"]',\n '#mgid_iframe1',\n fromB64('I2FkX2ludmlld19hcmVh'),\n ],\n adGuardRussian: [\n fromB64('YVtocmVmXj0iaHR0cHM6Ly9hZC5sZXRtZWFkcy5jb20vIl0='),\n fromB64('LnJlY2xhbWE='),\n 'div[id^=\"smi2adblock\"]',\n fromB64('ZGl2W2lkXj0iQWRGb3hfYmFubmVyXyJd'),\n '#psyduckpockeball',\n ],\n adGuardSocial: [\n fromB64('YVtocmVmXj0iLy93d3cuc3R1bWJsZXVwb24uY29tL3N1Ym1pdD91cmw9Il0='),\n fromB64('YVtocmVmXj0iLy90ZWxlZ3JhbS5tZS9zaGFyZS91cmw/Il0='),\n '.etsy-tweet',\n '#inlineShare',\n '.popup-social',\n ],\n adGuardSpanishPortuguese: ['#barraPublicidade', '#Publicidade', '#publiEspecial', '#queTooltip', '.cnt-publi'],\n adGuardTrackingProtection: [\n '#qoo-counter',\n fromB64('YVtocmVmXj0iaHR0cDovL2NsaWNrLmhvdGxvZy5ydS8iXQ=='),\n fromB64('YVtocmVmXj0iaHR0cDovL2hpdGNvdW50ZXIucnUvdG9wL3N0YXQucGhwIl0='),\n fromB64('YVtocmVmXj0iaHR0cDovL3RvcC5tYWlsLnJ1L2p1bXAiXQ=='),\n '#top100counter',\n ],\n adGuardTurkish: [\n '#backkapat',\n fromB64('I3Jla2xhbWk='),\n fromB64('YVtocmVmXj0iaHR0cDovL2Fkc2Vydi5vbnRlay5jb20udHIvIl0='),\n fromB64('YVtocmVmXj0iaHR0cDovL2l6bGVuemkuY29tL2NhbXBhaWduLyJd'),\n fromB64('YVtocmVmXj0iaHR0cDovL3d3dy5pbnN0YWxsYWRzLm5ldC8iXQ=='),\n ],\n bulgarian: [fromB64('dGQjZnJlZW5ldF90YWJsZV9hZHM='), '#ea_intext_div', '.lapni-pop-over', '#xenium_hot_offers'],\n easyList: [\n '.yb-floorad',\n fromB64('LndpZGdldF9wb19hZHNfd2lkZ2V0'),\n fromB64('LnRyYWZmaWNqdW5reS1hZA=='),\n '.textad_headline',\n fromB64('LnNwb25zb3JlZC10ZXh0LWxpbmtz'),\n ],\n easyListChina: [\n fromB64('LmFwcGd1aWRlLXdyYXBbb25jbGljayo9ImJjZWJvcy5jb20iXQ=='),\n fromB64('LmZyb250cGFnZUFkdk0='),\n '#taotaole',\n '#aafoot.top_box',\n '.cfa_popup',\n ],\n easyListCookie: [\n '.ezmob-footer',\n '.cc-CookieWarning',\n '[data-cookie-number]',\n fromB64('LmF3LWNvb2tpZS1iYW5uZXI='),\n '.sygnal24-gdpr-modal-wrap',\n ],\n easyListCzechSlovak: [\n '#onlajny-stickers',\n fromB64('I3Jla2xhbW5pLWJveA=='),\n fromB64('LnJla2xhbWEtbWVnYWJvYXJk'),\n '.sklik',\n fromB64('W2lkXj0ic2tsaWtSZWtsYW1hIl0='),\n ],\n easyListDutch: [\n fromB64('I2FkdmVydGVudGll'),\n fromB64('I3ZpcEFkbWFya3RCYW5uZXJCbG9jaw=='),\n '.adstekst',\n fromB64('YVtocmVmXj0iaHR0cHM6Ly94bHR1YmUubmwvY2xpY2svIl0='),\n '#semilo-lrectangle',\n ],\n easyListGermany: [\n '#SSpotIMPopSlider',\n fromB64('LnNwb25zb3JsaW5rZ3J1ZW4='),\n fromB64('I3dlcmJ1bmdza3k='),\n fromB64('I3Jla2xhbWUtcmVjaHRzLW1pdHRl'),\n fromB64('YVtocmVmXj0iaHR0cHM6Ly9iZDc0Mi5jb20vIl0='),\n ],\n easyListItaly: [\n fromB64('LmJveF9hZHZfYW5udW5jaQ=='),\n '.sb-box-pubbliredazionale',\n fromB64('YVtocmVmXj0iaHR0cDovL2FmZmlsaWF6aW9uaWFkcy5zbmFpLml0LyJd'),\n fromB64('YVtocmVmXj0iaHR0cHM6Ly9hZHNlcnZlci5odG1sLml0LyJd'),\n fromB64('YVtocmVmXj0iaHR0cHM6Ly9hZmZpbGlhemlvbmlhZHMuc25haS5pdC8iXQ=='),\n ],\n easyListLithuania: [\n fromB64('LnJla2xhbW9zX3RhcnBhcw=='),\n fromB64('LnJla2xhbW9zX251b3JvZG9z'),\n fromB64('aW1nW2FsdD0iUmVrbGFtaW5pcyBza3lkZWxpcyJd'),\n fromB64('aW1nW2FsdD0iRGVkaWt1b3RpLmx0IHNlcnZlcmlhaSJd'),\n fromB64('aW1nW2FsdD0iSG9zdGluZ2FzIFNlcnZlcmlhaS5sdCJd'),\n ],\n estonian: [fromB64('QVtocmVmKj0iaHR0cDovL3BheTRyZXN1bHRzMjQuZXUiXQ==')],\n fanboyAnnoyances: ['#ac-lre-player', '.navigate-to-top', '#subscribe_popup', '.newsletter_holder', '#back-top'],\n fanboyAntiFacebook: ['.util-bar-module-firefly-visible'],\n fanboyEnhancedTrackers: [\n '.open.pushModal',\n '#issuem-leaky-paywall-articles-zero-remaining-nag',\n '#sovrn_container',\n 'div[class$=\"-hide\"][zoompage-fontsize][style=\"display: block;\"]',\n '.BlockNag__Card',\n ],\n fanboySocial: ['#FollowUs', '#meteored_share', '#social_follow', '.article-sharer', '.community__social-desc'],\n frellwitSwedish: [\n fromB64('YVtocmVmKj0iY2FzaW5vcHJvLnNlIl1bdGFyZ2V0PSJfYmxhbmsiXQ=='),\n fromB64('YVtocmVmKj0iZG9rdG9yLXNlLm9uZWxpbmsubWUiXQ=='),\n 'article.category-samarbete',\n fromB64('ZGl2LmhvbGlkQWRz'),\n 'ul.adsmodern',\n ],\n greekAdBlock: [\n fromB64('QVtocmVmKj0iYWRtYW4ub3RlbmV0LmdyL2NsaWNrPyJd'),\n fromB64('QVtocmVmKj0iaHR0cDovL2F4aWFiYW5uZXJzLmV4b2R1cy5nci8iXQ=='),\n fromB64('QVtocmVmKj0iaHR0cDovL2ludGVyYWN0aXZlLmZvcnRobmV0LmdyL2NsaWNrPyJd'),\n 'DIV.agores300',\n 'TABLE.advright',\n ],\n hungarian: [\n '#cemp_doboz',\n '.optimonk-iframe-container',\n fromB64('LmFkX19tYWlu'),\n fromB64('W2NsYXNzKj0iR29vZ2xlQWRzIl0='),\n '#hirdetesek_box',\n ],\n iDontCareAboutCookies: [\n '.alert-info[data-block-track*=\"CookieNotice\"]',\n '.ModuleTemplateCookieIndicator',\n '.o--cookies--container',\n '#cookies-policy-sticky',\n '#stickyCookieBar',\n ],\n icelandicAbp: [fromB64('QVtocmVmXj0iL2ZyYW1ld29yay9yZXNvdXJjZXMvZm9ybXMvYWRzLmFzcHgiXQ==')],\n latvian: [\n fromB64(\n 'YVtocmVmPSJodHRwOi8vd3d3LnNhbGlkemluaS5sdi8iXVtzdHlsZT0iZGlzcGxheTogYmxvY2s7IHdpZHRoOiAxMjBweDsgaGVpZ2h0O' +\n 'iA0MHB4OyBvdmVyZmxvdzogaGlkZGVuOyBwb3NpdGlvbjogcmVsYXRpdmU7Il0=',\n ),\n fromB64(\n 'YVtocmVmPSJodHRwOi8vd3d3LnNhbGlkemluaS5sdi8iXVtzdHlsZT0iZGlzcGxheTogYmxvY2s7IHdpZHRoOiA4OHB4OyBoZWlnaHQ6I' +\n 'DMxcHg7IG92ZXJmbG93OiBoaWRkZW47IHBvc2l0aW9uOiByZWxhdGl2ZTsiXQ==',\n ),\n ],\n listKr: [\n fromB64('YVtocmVmKj0iLy9hZC5wbGFuYnBsdXMuY28ua3IvIl0='),\n fromB64('I2xpdmVyZUFkV3JhcHBlcg=='),\n fromB64('YVtocmVmKj0iLy9hZHYuaW1hZHJlcC5jby5rci8iXQ=='),\n fromB64('aW5zLmZhc3R2aWV3LWFk'),\n '.revenue_unit_item.dable',\n ],\n listeAr: [\n fromB64('LmdlbWluaUxCMUFk'),\n '.right-and-left-sponsers',\n fromB64('YVtocmVmKj0iLmFmbGFtLmluZm8iXQ=='),\n fromB64('YVtocmVmKj0iYm9vcmFxLm9yZyJd'),\n fromB64('YVtocmVmKj0iZHViaXp6bGUuY29tL2FyLz91dG1fc291cmNlPSJd'),\n ],\n listeFr: [\n fromB64('YVtocmVmXj0iaHR0cDovL3Byb21vLnZhZG9yLmNvbS8iXQ=='),\n fromB64('I2FkY29udGFpbmVyX3JlY2hlcmNoZQ=='),\n fromB64('YVtocmVmKj0id2Vib3JhbWEuZnIvZmNnaS1iaW4vIl0='),\n '.site-pub-interstitiel',\n 'div[id^=\"crt-\"][data-criteo-id]',\n ],\n officialPolish: [\n '#ceneo-placeholder-ceneo-12',\n fromB64('W2hyZWZePSJodHRwczovL2FmZi5zZW5kaHViLnBsLyJd'),\n fromB64('YVtocmVmXj0iaHR0cDovL2Fkdm1hbmFnZXIudGVjaGZ1bi5wbC9yZWRpcmVjdC8iXQ=='),\n fromB64('YVtocmVmXj0iaHR0cDovL3d3dy50cml6ZXIucGwvP3V0bV9zb3VyY2UiXQ=='),\n fromB64('ZGl2I3NrYXBpZWNfYWQ='),\n ],\n ro: [\n fromB64('YVtocmVmXj0iLy9hZmZ0cmsuYWx0ZXgucm8vQ291bnRlci9DbGljayJd'),\n fromB64('YVtocmVmXj0iaHR0cHM6Ly9ibGFja2ZyaWRheXNhbGVzLnJvL3Ryay9zaG9wLyJd'),\n fromB64('YVtocmVmXj0iaHR0cHM6Ly9ldmVudC4ycGVyZm9ybWFudC5jb20vZXZlbnRzL2NsaWNrIl0='),\n fromB64('YVtocmVmXj0iaHR0cHM6Ly9sLnByb2ZpdHNoYXJlLnJvLyJd'),\n 'a[href^=\"/url/\"]',\n ],\n ruAd: [\n fromB64('YVtocmVmKj0iLy9mZWJyYXJlLnJ1LyJd'),\n fromB64('YVtocmVmKj0iLy91dGltZy5ydS8iXQ=='),\n fromB64('YVtocmVmKj0iOi8vY2hpa2lkaWtpLnJ1Il0='),\n '#pgeldiz',\n '.yandex-rtb-block',\n ],\n thaiAds: [\n 'a[href*=macau-uta-popup]',\n fromB64('I2Fkcy1nb29nbGUtbWlkZGxlX3JlY3RhbmdsZS1ncm91cA=='),\n fromB64('LmFkczMwMHM='),\n '.bumq',\n '.img-kosana',\n ],\n webAnnoyancesUltralist: [\n '#mod-social-share-2',\n '#social-tools',\n fromB64('LmN0cGwtZnVsbGJhbm5lcg=='),\n '.zergnet-recommend',\n '.yt.btn-link.btn-md.btn',\n ],\n }\n}\n\ntype Options = {\n debug?: boolean\n}\n\n/**\n * The order of the returned array means nothing (it's always sorted alphabetically).\n *\n * Notice that the source is slightly unstable.\n * Safari provides a 2-taps way to disable all content blockers on a page temporarily.\n * Also content blockers can be disabled permanently for a domain, but it requires 4 taps.\n * So empty array shouldn't be treated as \"no blockers\", it should be treated as \"no signal\".\n * If you are a website owner, don't make your visitors want to disable content blockers.\n */\nexport default async function getDomBlockers({ debug }: Options = {}): Promise {\n if (!isApplicable()) {\n return undefined\n }\n\n const filters = getFilters()\n const filterNames = Object.keys(filters) as Array\n const allSelectors = ([] as string[]).concat(...filterNames.map((filterName) => filters[filterName]))\n const blockedSelectors = await getBlockedSelectors(allSelectors)\n\n if (debug) {\n printDebug(filters, blockedSelectors)\n }\n\n const activeBlockers = filterNames.filter((filterName) => {\n const selectors = filters[filterName]\n const blockedCount = countTruthy(selectors.map((selector) => blockedSelectors[selector]))\n return blockedCount > selectors.length * 0.6\n })\n activeBlockers.sort()\n\n return activeBlockers\n}\n\nexport function isApplicable(): boolean {\n // Safari (desktop and mobile) and all Android browsers keep content blockers in both regular and private mode\n return isWebKit() || isAndroid()\n}\n\nexport async function getBlockedSelectors(selectors: readonly T[]): Promise<{ [K in T]?: true }> {\n const d = document\n const root = d.createElement('div')\n const elements = new Array(selectors.length)\n const blockedSelectors: { [K in T]?: true } = {} // Set() isn't used just in case somebody need older browser support\n\n forceShow(root)\n\n // First create all elements that can be blocked. If the DOM steps below are done in a single cycle,\n // browser will alternate tree modification and layout reading, that is very slow.\n for (let i = 0; i < selectors.length; ++i) {\n const element = selectorToElement(selectors[i])\n if (element.tagName === 'DIALOG') {\n ;(element as HTMLDialogElement).show()\n }\n const holder = d.createElement('div') // Protects from unwanted effects of `+` and `~` selectors of filters\n forceShow(holder)\n holder.appendChild(element)\n root.appendChild(holder)\n elements[i] = element\n }\n\n // document.body can be null while the page is loading\n while (!d.body) {\n await wait(50)\n }\n d.body.appendChild(root)\n\n await releaseEventLoop()\n\n try {\n // Then check which of the elements are blocked\n for (let i = 0; i < selectors.length; ++i) {\n if (!elements[i].offsetParent) {\n blockedSelectors[selectors[i]] = true\n }\n }\n } finally {\n // Then remove the elements\n root.parentNode?.removeChild(root)\n }\n\n return blockedSelectors\n}\n\nfunction forceShow(element: HTMLElement) {\n element.style.setProperty('visibility', 'hidden', 'important')\n element.style.setProperty('display', 'block', 'important')\n}\n\nfunction printDebug(filters: Filters, blockedSelectors: { [K in string]?: true }) {\n let message = 'DOM blockers debug:\\n```'\n for (const filterName of Object.keys(filters) as Array) {\n message += `\\n${filterName}:`\n for (const selector of filters[filterName]) {\n message += `\\n ${blockedSelectors[selector] ? '🚫' : '➡️'} ${selector}`\n }\n }\n // console.log is ok here because it's under a debug clause\n // eslint-disable-next-line no-console\n console.log(`${message}\\n\\`\\`\\``)\n}\n","/**\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/@media/inverted-colors\n */\nexport default function areColorsInverted(): boolean | undefined {\n if (doesMatch('inverted')) {\n return true\n }\n if (doesMatch('none')) {\n return false\n }\n return undefined\n}\n\nfunction doesMatch(value: string) {\n return matchMedia(`(inverted-colors: ${value})`).matches\n}\n","/**\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/@media/forced-colors\n */\nexport default function areColorsForced(): boolean | undefined {\n if (doesMatch('active')) {\n return true\n }\n if (doesMatch('none')) {\n return false\n }\n return undefined\n}\n\nfunction doesMatch(value: string) {\n return matchMedia(`(forced-colors: ${value})`).matches\n}\n","export const enum ContrastPreference {\n Less = -1,\n None = 0,\n More = 1,\n // \"Max\" can be added in future\n ForcedColors = 10,\n}\n\n/**\n * @see https://www.w3.org/TR/mediaqueries-5/#prefers-contrast\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/@media/prefers-contrast\n */\nexport default function getContrastPreference(): number | undefined {\n if (doesMatch('no-preference')) {\n return ContrastPreference.None\n }\n // The sources contradict on the keywords. Probably 'high' and 'low' will never be implemented.\n // Need to check it when all browsers implement the feature.\n if (doesMatch('high') || doesMatch('more')) {\n return ContrastPreference.More\n }\n if (doesMatch('low') || doesMatch('less')) {\n return ContrastPreference.Less\n }\n if (doesMatch('forced')) {\n return ContrastPreference.ForcedColors\n }\n return undefined\n}\n\nfunction doesMatch(value: string) {\n return matchMedia(`(prefers-contrast: ${value})`).matches\n}\n","/**\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/@media/prefers-reduced-motion\n */\nexport default function isMotionReduced(): boolean | undefined {\n if (doesMatch('reduce')) {\n return true\n }\n if (doesMatch('no-preference')) {\n return false\n }\n return undefined\n}\n\nfunction doesMatch(value: string) {\n return matchMedia(`(prefers-reduced-motion: ${value})`).matches\n}\n","/**\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/@media/prefers-reduced-transparency\n */\nexport default function isTransparencyReduced(): boolean | undefined {\n if (doesMatch('reduce')) {\n return true\n }\n if (doesMatch('no-preference')) {\n return false\n }\n return undefined\n}\n\nfunction doesMatch(value: string) {\n return matchMedia(`(prefers-reduced-transparency: ${value})`).matches\n}\n","/**\n * @see https://www.w3.org/TR/mediaqueries-5/#dynamic-range\n */\nexport default function isHDR(): boolean | undefined {\n if (doesMatch('high')) {\n return true\n }\n if (doesMatch('standard')) {\n return false\n }\n return undefined\n}\n\nfunction doesMatch(value: string) {\n return matchMedia(`(dynamic-range: ${value})`).matches\n}\n","const M = Math // To reduce the minified code size\nconst fallbackFn = () => 0\n\n/**\n * @see https://gitlab.torproject.org/legacy/trac/-/issues/13018\n * @see https://bugzilla.mozilla.org/show_bug.cgi?id=531915\n */\nexport default function getMathFingerprint(): Record {\n // Native operations\n const acos = M.acos || fallbackFn\n const acosh = M.acosh || fallbackFn\n const asin = M.asin || fallbackFn\n const asinh = M.asinh || fallbackFn\n const atanh = M.atanh || fallbackFn\n const atan = M.atan || fallbackFn\n const sin = M.sin || fallbackFn\n const sinh = M.sinh || fallbackFn\n const cos = M.cos || fallbackFn\n const cosh = M.cosh || fallbackFn\n const tan = M.tan || fallbackFn\n const tanh = M.tanh || fallbackFn\n const exp = M.exp || fallbackFn\n const expm1 = M.expm1 || fallbackFn\n const log1p = M.log1p || fallbackFn\n\n // Operation polyfills\n const powPI = (value: number) => M.pow(M.PI, value)\n const acoshPf = (value: number) => M.log(value + M.sqrt(value * value - 1))\n const asinhPf = (value: number) => M.log(value + M.sqrt(value * value + 1))\n const atanhPf = (value: number) => M.log((1 + value) / (1 - value)) / 2\n const sinhPf = (value: number) => M.exp(value) - 1 / M.exp(value) / 2\n const coshPf = (value: number) => (M.exp(value) + 1 / M.exp(value)) / 2\n const expm1Pf = (value: number) => M.exp(value) - 1\n const tanhPf = (value: number) => (M.exp(2 * value) - 1) / (M.exp(2 * value) + 1)\n const log1pPf = (value: number) => M.log(1 + value)\n\n // Note: constant values are empirical\n return {\n acos: acos(0.123124234234234242),\n acosh: acosh(1e308),\n acoshPf: acoshPf(1e154), // 1e308 will not work for polyfill\n asin: asin(0.123124234234234242),\n asinh: asinh(1),\n asinhPf: asinhPf(1),\n atanh: atanh(0.5),\n atanhPf: atanhPf(0.5),\n atan: atan(0.5),\n sin: sin(-1e300),\n sinh: sinh(1),\n sinhPf: sinhPf(1),\n cos: cos(10.000000000123),\n cosh: cosh(1),\n coshPf: coshPf(1),\n tan: tan(-1e300),\n tanh: tanh(1),\n tanhPf: tanhPf(1),\n exp: exp(1),\n expm1: expm1(1),\n expm1Pf: expm1Pf(1),\n log1p: log1p(10),\n log1pPf: log1pPf(10),\n powPI: powPI(-100),\n }\n}\n","import { isChromium, isWebKit } from '../utils/browser'\nimport { withIframe } from '../utils/dom'\nimport { MaybePromise } from '../utils/async'\n\ntype WritableCSSProperties = {\n [K in keyof CSSStyleDeclaration]: CSSStyleDeclaration[K] extends string ? K : never\n}[Extract]\n\ntype WritableCSSStyles = Partial>\n\ntype Preset = [style?: WritableCSSStyles, text?: string]\n\n/**\n * We use m or w because these two characters take up the maximum width.\n * Also there are a couple of ligatures.\n */\nconst defaultText = 'mmMwWLliI0fiflO&1'\n\n/**\n * Settings of text blocks to measure. The keys are random but persistent words.\n */\nexport const presets: Record = {\n /**\n * The default font. User can change it in desktop Chrome, desktop Firefox, IE 11,\n * Android Chrome (but only when the size is ≥ than the default) and Android Firefox.\n */\n default: [],\n /** OS font on macOS. User can change its size and weight. Applies after Safari restart. */\n apple: [{ font: '-apple-system-body' }],\n /** User can change it in desktop Chrome and desktop Firefox. */\n serif: [{ fontFamily: 'serif' }],\n /** User can change it in desktop Chrome and desktop Firefox. */\n sans: [{ fontFamily: 'sans-serif' }],\n /** User can change it in desktop Chrome and desktop Firefox. */\n mono: [{ fontFamily: 'monospace' }],\n /**\n * Check the smallest allowed font size. User can change it in desktop Chrome, desktop Firefox and desktop Safari.\n * The height can be 0 in Chrome on a retina display.\n */\n min: [{ fontSize: '1px' }],\n /** Tells one OS from another in desktop Chrome. */\n system: [{ fontFamily: 'system-ui' }],\n}\n\n/**\n * The result is a dictionary of the width of the text samples.\n * Heights aren't included because they give no extra entropy and are unstable.\n *\n * The result is very stable in IE 11, Edge 18 and Safari 14.\n * The result changes when the OS pixel density changes in Chromium 87. The real pixel density is required to solve,\n * but seems like it's impossible: https://stackoverflow.com/q/1713771/1118709.\n * The \"min\" and the \"mono\" (only on Windows) value may change when the page is zoomed in Firefox 87.\n */\nexport default function getFontPreferences(): Promise> {\n return withNaturalFonts((document, container) => {\n const elements: Record = {}\n const sizes: Record = {}\n\n // First create all elements to measure. If the DOM steps below are done in a single cycle,\n // browser will alternate tree modification and layout reading, that is very slow.\n for (const key of Object.keys(presets)) {\n const [style = {}, text = defaultText] = presets[key]\n\n const element = document.createElement('span')\n element.textContent = text\n element.style.whiteSpace = 'nowrap'\n\n for (const name of Object.keys(style) as Array) {\n const value = style[name]\n if (value !== undefined) {\n element.style[name] = value\n }\n }\n\n elements[key] = element\n container.append(document.createElement('br'), element)\n }\n\n // Then measure the created elements\n for (const key of Object.keys(presets)) {\n sizes[key] = elements[key].getBoundingClientRect().width\n }\n\n return sizes\n })\n}\n\n/**\n * Creates a DOM environment that provides the most natural font available, including Android OS font.\n * Measurements of the elements are zoom-independent.\n * Don't put a content to measure inside an absolutely positioned element.\n */\nfunction withNaturalFonts(\n action: (document: Document, container: HTMLElement) => MaybePromise,\n containerWidthPx = 4000,\n): Promise {\n /*\n * Requirements for Android Chrome to apply the system font size to a text inside an iframe:\n * - The iframe mustn't have a `display: none;` style;\n * - The text mustn't be positioned absolutely;\n * - The text block must be wide enough.\n * 2560px on some devices in portrait orientation for the biggest font size option (32px);\n * - There must be much enough text to form a few lines (I don't know the exact numbers);\n * - The text must have the `text-size-adjust: none` style. Otherwise the text will scale in \"Desktop site\" mode;\n *\n * Requirements for Android Firefox to apply the system font size to a text inside an iframe:\n * - The iframe document must have a header: ``.\n * The only way to set it is to use the `srcdoc` attribute of the iframe;\n * - The iframe content must get loaded before adding extra content with JavaScript;\n *\n * https://example.com as the iframe target always inherits Android font settings so it can be used as a reference.\n *\n * Observations on how page zoom affects the measurements:\n * - macOS Safari 11.1, 12.1, 13.1, 14.0: zoom reset + offsetWidth = 100% reliable;\n * - macOS Safari 11.1, 12.1, 13.1, 14.0: zoom reset + getBoundingClientRect = 100% reliable;\n * - macOS Safari 14.0: offsetWidth = 5% fluctuation;\n * - macOS Safari 14.0: getBoundingClientRect = 5% fluctuation;\n * - iOS Safari 9, 10, 11.0, 12.0: haven't found a way to zoom a page (pinch doesn't change layout);\n * - iOS Safari 13.1, 14.0: zoom reset + offsetWidth = 100% reliable;\n * - iOS Safari 13.1, 14.0: zoom reset + getBoundingClientRect = 100% reliable;\n * - iOS Safari 14.0: offsetWidth = 100% reliable;\n * - iOS Safari 14.0: getBoundingClientRect = 100% reliable;\n * - Chrome 42, 65, 80, 87: zoom 1/devicePixelRatio + offsetWidth = 1px fluctuation;\n * - Chrome 42, 65, 80, 87: zoom 1/devicePixelRatio + getBoundingClientRect = 100% reliable;\n * - Chrome 87: offsetWidth = 1px fluctuation;\n * - Chrome 87: getBoundingClientRect = 0.7px fluctuation;\n * - Firefox 48, 51: offsetWidth = 10% fluctuation;\n * - Firefox 48, 51: getBoundingClientRect = 10% fluctuation;\n * - Firefox 52, 53, 57, 62, 66, 67, 68, 71, 75, 80, 84: offsetWidth = width 100% reliable, height 10% fluctuation;\n * - Firefox 52, 53, 57, 62, 66, 67, 68, 71, 75, 80, 84: getBoundingClientRect = width 100% reliable, height 10%\n * fluctuation;\n * - Android Chrome 86: haven't found a way to zoom a page (pinch doesn't change layout);\n * - Android Firefox 84: font size in accessibility settings changes all the CSS sizes, but offsetWidth and\n * getBoundingClientRect keep measuring with regular units, so the size reflects the font size setting and doesn't\n * fluctuate;\n * - IE 11, Edge 18: zoom 1/devicePixelRatio + offsetWidth = 100% reliable;\n * - IE 11, Edge 18: zoom 1/devicePixelRatio + getBoundingClientRect = reflects the zoom level;\n * - IE 11, Edge 18: offsetWidth = 100% reliable;\n * - IE 11, Edge 18: getBoundingClientRect = 100% reliable;\n */\n return withIframe((_, iframeWindow) => {\n const iframeDocument = iframeWindow.document\n const iframeBody = iframeDocument.body\n\n const bodyStyle = iframeBody.style\n bodyStyle.width = `${containerWidthPx}px`\n bodyStyle.webkitTextSizeAdjust = bodyStyle.textSizeAdjust = 'none'\n\n // See the big comment above\n if (isChromium()) {\n iframeBody.style.zoom = `${1 / iframeWindow.devicePixelRatio}`\n } else if (isWebKit()) {\n iframeBody.style.zoom = 'reset'\n }\n\n // See the big comment above\n const linesOfText = iframeDocument.createElement('div')\n linesOfText.textContent = [...Array((containerWidthPx / 20) << 0)].map(() => 'word').join(' ')\n iframeBody.appendChild(linesOfText)\n\n return action(iframeDocument, iframeBody)\n }, '')\n}\n","import { isGecko } from '../utils/browser'\n\n// Types and constants are used instead of interfaces and enums to avoid this error in projects which use this library:\n// Exported variable '...' has or is using name '...' from external module \"...\" but cannot be named.\n\n/**\n * WebGL basic features\n */\ntype WebGlBasicsPayload = {\n version: string // WebGL 1.0 (OpenGL ES 2.0 Chromium)\n vendor: string // WebKit\n vendorUnmasked: string // Apple\n renderer: string // WebKit WebGL\n rendererUnmasked: string // Apple M1\n shadingLanguageVersion: string // WebGL GLSL ES 1.0 (OpenGL ES GLSL...\n}\n\n/**\n * WebGL extended features\n */\ntype WebGlExtensionsPayload = {\n contextAttributes: string[] // ['alpha=true', 'antialias=true...\n parameters: string[] // ['ACTIVE_TEXTURE(33984)', 'ALIASED_LINE_WID...\n shaderPrecisions: string[] // ['FRAGMENT_SHADER.LOW_FLOAT=127,127,23...\n extensions: string[] | null // ['ANGLE_instanced_arrays', 'EXT_blend_minmax', 'EXT_color...\n extensionParameters: string[] // ['COMPRESSED_RGB_S3TC_DXT1_EXT(33776)', 'COMPR...\n}\n\ntype CanvasContext = WebGLRenderingContext & { readonly canvas: HTMLCanvasElement }\n\ntype Options = {\n cache: {\n webgl?: {\n context: CanvasContext | undefined\n }\n }\n}\n\n/** WebGl context is not available */\nexport const STATUS_NO_GL_CONTEXT = -1\n/** WebGL context `getParameter` method is not a function */\nexport const STATUS_GET_PARAMETER_NOT_A_FUNCTION = -2\n\nexport type SpecialStatus = typeof STATUS_NO_GL_CONTEXT | typeof STATUS_GET_PARAMETER_NOT_A_FUNCTION\n\nconst validContextParameters = new Set([\n 10752, 2849, 2884, 2885, 2886, 2928, 2929, 2930, 2931, 2932, 2960, 2961, 2962, 2963, 2964, 2965, 2966, 2967, 2968,\n 2978, 3024, 3042, 3088, 3089, 3106, 3107, 32773, 32777, 32777, 32823, 32824, 32936, 32937, 32938, 32939, 32968, 32969,\n 32970, 32971, 3317, 33170, 3333, 3379, 3386, 33901, 33902, 34016, 34024, 34076, 3408, 3410, 3411, 3412, 3413, 3414,\n 3415, 34467, 34816, 34817, 34818, 34819, 34877, 34921, 34930, 35660, 35661, 35724, 35738, 35739, 36003, 36004, 36005,\n 36347, 36348, 36349, 37440, 37441, 37443, 7936, 7937, 7938,\n // SAMPLE_ALPHA_TO_COVERAGE (32926) and SAMPLE_COVERAGE (32928) are excluded because they trigger a console warning\n // in IE, Chrome ≤ 59 and Safari ≤ 13 and give no entropy.\n])\nconst validExtensionParams = new Set([\n 34047, // MAX_TEXTURE_MAX_ANISOTROPY_EXT\n 35723, // FRAGMENT_SHADER_DERIVATIVE_HINT_OES\n 36063, // MAX_COLOR_ATTACHMENTS_WEBGL\n 34852, // MAX_DRAW_BUFFERS_WEBGL\n 34853, // DRAW_BUFFER0_WEBGL\n 34854, // DRAW_BUFFER1_WEBGL\n 34229, // VERTEX_ARRAY_BINDING_OES\n 36392, // TIMESTAMP_EXT\n 36795, // GPU_DISJOINT_EXT\n 38449, // MAX_VIEWS_OVR\n])\nconst shaderTypes = ['FRAGMENT_SHADER', 'VERTEX_SHADER'] as const\nconst precisionTypes = ['LOW_FLOAT', 'MEDIUM_FLOAT', 'HIGH_FLOAT', 'LOW_INT', 'MEDIUM_INT', 'HIGH_INT'] as const\nconst rendererInfoExtensionName = 'WEBGL_debug_renderer_info'\n\n/**\n * Gets the basic and simple WebGL parameters\n */\nexport function getWebGlBasics({ cache }: Options): WebGlBasicsPayload | SpecialStatus {\n const gl = getWebGLContext(cache)\n if (!gl) {\n return STATUS_NO_GL_CONTEXT\n }\n\n if (!isValidParameterGetter(gl)) {\n return STATUS_GET_PARAMETER_NOT_A_FUNCTION\n }\n\n const debugExtension = shouldAvoidDebugRendererInfo() ? null : gl.getExtension(rendererInfoExtensionName)\n\n return {\n version: gl.getParameter(gl.VERSION)?.toString() || '',\n vendor: gl.getParameter(gl.VENDOR)?.toString() || '',\n vendorUnmasked: debugExtension ? gl.getParameter(debugExtension.UNMASKED_VENDOR_WEBGL)?.toString() : '',\n renderer: gl.getParameter(gl.RENDERER)?.toString() || '',\n rendererUnmasked: debugExtension ? gl.getParameter(debugExtension.UNMASKED_RENDERER_WEBGL)?.toString() : '',\n shadingLanguageVersion: gl.getParameter(gl.SHADING_LANGUAGE_VERSION)?.toString() || '',\n }\n}\n\n/**\n * Gets the advanced and massive WebGL parameters and extensions\n */\nexport function getWebGlExtensions({ cache }: Options): WebGlExtensionsPayload | SpecialStatus {\n const gl = getWebGLContext(cache)\n if (!gl) {\n return STATUS_NO_GL_CONTEXT\n }\n\n if (!isValidParameterGetter(gl)) {\n return STATUS_GET_PARAMETER_NOT_A_FUNCTION\n }\n\n const extensions = gl.getSupportedExtensions()\n const contextAttributes = gl.getContextAttributes()\n\n // Features\n const attributes: string[] = []\n const parameters: string[] = []\n const extensionParameters: string[] = []\n const shaderPrecisions: string[] = []\n\n // Context attributes\n if (contextAttributes) {\n for (const attributeName of Object.keys(contextAttributes) as (keyof WebGLContextAttributes)[]) {\n attributes.push(`${attributeName}=${contextAttributes[attributeName]}`)\n }\n }\n\n // Context parameters\n const constants = getConstantsFromPrototype(gl)\n for (const constant of constants) {\n const code = gl[constant] as number\n parameters.push(`${constant}=${code}${validContextParameters.has(code) ? `=${gl.getParameter(code)}` : ''}`)\n }\n\n // Extension parameters\n if (extensions) {\n for (const name of extensions) {\n if (name === rendererInfoExtensionName && shouldAvoidDebugRendererInfo()) {\n continue\n }\n\n const extension = gl.getExtension(name)\n if (!extension) {\n continue\n }\n\n for (const constant of getConstantsFromPrototype(extension)) {\n const code = extension[constant]\n extensionParameters.push(\n `${constant}=${code}${validExtensionParams.has(code) ? `=${gl.getParameter(code)}` : ''}`,\n )\n }\n }\n }\n\n // Shader precision\n for (const shaderType of shaderTypes) {\n for (const precisionType of precisionTypes) {\n const shaderPrecision = getShaderPrecision(gl, shaderType, precisionType)\n shaderPrecisions.push(`${shaderType}.${precisionType}=${shaderPrecision.join(',')}`)\n }\n }\n\n // Postprocess\n extensionParameters.sort()\n parameters.sort()\n\n return {\n contextAttributes: attributes,\n parameters: parameters,\n shaderPrecisions: shaderPrecisions,\n extensions: extensions,\n extensionParameters: extensionParameters,\n }\n}\n\n/**\n * This function usually takes the most time to execute in all the sources, therefore we cache its result.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function getWebGLContext(cache: Options['cache']) {\n if (cache.webgl) {\n return cache.webgl.context\n }\n\n const canvas = document.createElement('canvas')\n let context: CanvasContext | undefined\n\n canvas.addEventListener('webglCreateContextError', () => (context = undefined))\n\n for (const type of ['webgl', 'experimental-webgl']) {\n try {\n context = canvas.getContext(type) as CanvasContext\n } catch {\n // Ok, continue\n }\n if (context) {\n break\n }\n }\n\n cache.webgl = { context }\n return context\n}\n\n/**\n * https://developer.mozilla.org/en-US/docs/Web/API/WebGLShaderPrecisionFormat\n * https://developer.mozilla.org/en-US/docs/Web/API/WebGLRenderingContext/getShaderPrecisionFormat\n * https://www.khronos.org/registry/webgl/specs/latest/1.0/#5.12\n */\nfunction getShaderPrecision(\n gl: WebGLRenderingContext,\n shaderType: typeof shaderTypes[number],\n precisionType: typeof precisionTypes[number],\n) {\n const shaderPrecision = gl.getShaderPrecisionFormat(gl[shaderType], gl[precisionType])\n return shaderPrecision ? [shaderPrecision.rangeMin, shaderPrecision.rangeMax, shaderPrecision.precision] : []\n}\n\nfunction getConstantsFromPrototype(obj: K): Array> {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const keys = Object.keys((obj as any).__proto__) as Array\n return keys.filter(isConstantLike)\n}\n\nfunction isConstantLike(key: K): key is Extract {\n return typeof key === 'string' && !key.match(/[^A-Z0-9_x]/)\n}\n\n/**\n * Some browsers print a console warning when the WEBGL_debug_renderer_info extension is requested.\n * JS Agent aims to avoid printing messages to console, so we avoid this extension in that browsers.\n */\nexport function shouldAvoidDebugRendererInfo(): boolean {\n return isGecko()\n}\n\n/**\n * Some unknown browsers have no `getParameter` method\n */\nfunction isValidParameterGetter(gl: WebGLRenderingContext) {\n return typeof gl.getParameter === 'function'\n}\n","import { loadSources, SourcesToComponents } from '../utils/entropy_source'\nimport getAudioFingerprint from './audio'\nimport getFonts from './fonts'\nimport getPlugins from './plugins'\nimport getCanvasFingerprint from './canvas'\nimport getTouchSupport from './touch_support'\nimport getOsCpu from './os_cpu'\nimport getLanguages from './languages'\nimport getColorDepth from './color_depth'\nimport getDeviceMemory from './device_memory'\nimport getScreenResolution from './screen_resolution'\nimport getScreenFrame from './screen_frame'\nimport getHardwareConcurrency from './hardware_concurrency'\nimport getTimezone from './timezone'\nimport getSessionStorage from './session_storage'\nimport getLocalStorage from './local_storage'\nimport getIndexedDB from './indexed_db'\nimport getOpenDatabase from './open_database'\nimport getCpuClass from './cpu_class'\nimport getPlatform from './platform'\nimport getVendor from './vendor'\nimport getVendorFlavors from './vendor_flavors'\nimport areCookiesEnabled from './cookies_enabled'\nimport getDomBlockers from './dom_blockers'\nimport getColorGamut from './color_gamut'\nimport areColorsInverted from './inverted_colors'\nimport areColorsForced from './forced_colors'\nimport getMonochromeDepth from './monochrome'\nimport getContrastPreference from './contrast'\nimport isMotionReduced from './reduced_motion'\nimport isTransparencyReduced from './reduced_transparency'\nimport isHDR from './hdr'\nimport getMathFingerprint from './math'\nimport getFontPreferences from './font_preferences'\nimport isPdfViewerEnabled from './pdf_viewer_enabled'\nimport getArchitecture from './architecture'\nimport getApplePayState from './apple_pay'\nimport getPrivateClickMeasurement from './private_click_measurement'\nimport { getWebGlBasics, getWebGlExtensions } from './webgl'\n\n/**\n * The list of entropy sources used to make visitor identifiers.\n *\n * This value isn't restricted by Semantic Versioning, i.e. it may be changed without bumping minor or major version of\n * this package.\n *\n * Note: Rollup and Webpack are smart enough to remove unused properties of this object during tree-shaking, so there is\n * no need to export the sources individually.\n */\nexport const sources = {\n // READ FIRST:\n // See https://github.com/fingerprintjs/fingerprintjs/blob/master/contributing.md#how-to-make-an-entropy-source\n // to learn how entropy source works and how to make your own.\n\n // The sources run in this exact order.\n // The asynchronous sources are at the start to run in parallel with other sources.\n fonts: getFonts,\n domBlockers: getDomBlockers,\n fontPreferences: getFontPreferences,\n audio: getAudioFingerprint,\n screenFrame: getScreenFrame,\n canvas: getCanvasFingerprint,\n\n osCpu: getOsCpu,\n languages: getLanguages,\n colorDepth: getColorDepth,\n deviceMemory: getDeviceMemory,\n screenResolution: getScreenResolution,\n hardwareConcurrency: getHardwareConcurrency,\n timezone: getTimezone,\n sessionStorage: getSessionStorage,\n localStorage: getLocalStorage,\n indexedDB: getIndexedDB,\n openDatabase: getOpenDatabase,\n cpuClass: getCpuClass,\n platform: getPlatform,\n plugins: getPlugins,\n touchSupport: getTouchSupport,\n vendor: getVendor,\n vendorFlavors: getVendorFlavors,\n cookiesEnabled: areCookiesEnabled,\n colorGamut: getColorGamut,\n invertedColors: areColorsInverted,\n forcedColors: areColorsForced,\n monochrome: getMonochromeDepth,\n contrast: getContrastPreference,\n reducedMotion: isMotionReduced,\n reducedTransparency: isTransparencyReduced,\n hdr: isHDR,\n math: getMathFingerprint,\n pdfViewerEnabled: isPdfViewerEnabled,\n architecture: getArchitecture,\n applePay: getApplePayState,\n privateClickMeasurement: getPrivateClickMeasurement,\n\n // Some sources can affect other sources (e.g. WebGL can affect canvas), so it's important to run these sources\n // after other sources.\n webGlBasics: getWebGlBasics,\n webGlExtensions: getWebGlExtensions,\n}\n\n/**\n * List of components from the built-in entropy sources.\n *\n * Warning! This type is out of Semantic Versioning, i.e. may have incompatible changes within a major version. If you\n * want to avoid breaking changes, use `UnknownComponents` instead that is more generic but guarantees backward\n * compatibility within a major version. This is because browsers change constantly and therefore entropy sources have\n * to change too.\n */\nexport type BuiltinComponents = SourcesToComponents\n\nexport interface BuiltinSourceOptions {\n debug?: boolean\n cache: Record\n}\n\n/**\n * Loads the built-in entropy sources.\n * Returns a function that collects the entropy components to make the visitor identifier.\n */\nexport default function loadBuiltinSources(options: BuiltinSourceOptions): () => Promise {\n return loadSources(sources, options, [])\n}\n","export default function getOsCpu(): string | undefined {\n return navigator.oscpu\n}\n","import { isChromium, isChromium86OrNewer } from '../utils/browser'\n\nexport default function getLanguages(): string[][] {\n const n = navigator\n const result: string[][] = []\n\n const language = n.language || n.userLanguage || n.browserLanguage || n.systemLanguage\n if (language !== undefined) {\n result.push([language])\n }\n\n if (Array.isArray(n.languages)) {\n // Starting from Chromium 86, there is only a single value in `navigator.language` in Incognito mode:\n // the value of `navigator.language`. Therefore the value is ignored in this browser.\n if (!(isChromium() && isChromium86OrNewer())) {\n result.push(n.languages)\n }\n } else if (typeof n.languages === 'string') {\n const languages = n.languages as string\n if (languages) {\n result.push(languages.split(','))\n }\n }\n\n return result\n}\n","export default function getColorDepth(): number {\n return window.screen.colorDepth\n}\n","import { replaceNaN, toFloat } from '../utils/data'\n\nexport default function getDeviceMemory(): number | undefined {\n // `navigator.deviceMemory` is a string containing a number in some unidentified cases\n return replaceNaN(toFloat(navigator.deviceMemory), undefined)\n}\n","import { replaceNaN, toInt } from '../utils/data'\nimport { isSafariWebKit, isWebKit, isWebKit616OrNewer } from '../utils/browser'\n\ntype ScreenResolution = [number | null, number | null]\n\n/**\n * A version of the entropy source with stabilization to make it suitable for static fingerprinting.\n * The window resolution is always the document size in private mode of Safari 17,\n * so the window resolution is not used in Safari 17.\n */\nexport default function getScreenResolution(): ScreenResolution | undefined {\n if (isWebKit() && isWebKit616OrNewer() && isSafariWebKit()) {\n return undefined\n }\n\n return getUnstableScreenResolution()\n}\n\n/**\n * A version of the entropy source without stabilization.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function getUnstableScreenResolution(): ScreenResolution {\n const s = screen\n\n // Some browsers return screen resolution as strings, e.g. \"1200\", instead of a number, e.g. 1200.\n // I suspect it's done by certain plugins that randomize browser properties to prevent fingerprinting.\n // Some browsers even return screen resolution as not numbers.\n const parseDimension = (value: unknown) => replaceNaN(toInt(value), null)\n const dimensions = [parseDimension(s.width), parseDimension(s.height)] as ScreenResolution\n dimensions.sort().reverse()\n return dimensions\n}\n","import { replaceNaN, toInt } from '../utils/data'\n\nexport default function getHardwareConcurrency(): number | undefined {\n // sometimes hardware concurrency is a string\n return replaceNaN(toInt(navigator.hardwareConcurrency), undefined)\n}\n","import { toFloat } from '../utils/data'\n\nexport default function getTimezone(): string {\n const DateTimeFormat = window.Intl?.DateTimeFormat\n if (DateTimeFormat) {\n const timezone = new DateTimeFormat().resolvedOptions().timeZone\n if (timezone) {\n return timezone\n }\n }\n\n // For browsers that don't support timezone names\n // The minus is intentional because the JS offset is opposite to the real offset\n const offset = -getTimezoneOffset()\n return `UTC${offset >= 0 ? '+' : ''}${Math.abs(offset)}`\n}\n\nfunction getTimezoneOffset(): number {\n const currentYear = new Date().getFullYear()\n // The timezone offset may change over time due to daylight saving time (DST) shifts.\n // The non-DST timezone offset is used as the result timezone offset.\n // Since the DST season differs in the northern and the southern hemispheres,\n // both January and July timezones offsets are considered.\n return Math.max(\n // `getTimezoneOffset` returns a number as a string in some unidentified cases\n toFloat(new Date(currentYear, 0, 1).getTimezoneOffset()),\n toFloat(new Date(currentYear, 6, 1).getTimezoneOffset()),\n )\n}\n","export default function getSessionStorage(): boolean {\n try {\n return !!window.sessionStorage\n } catch (error) {\n /* SecurityError when referencing it means it exists */\n return true\n }\n}\n","// https://bugzilla.mozilla.org/show_bug.cgi?id=781447\nexport default function getLocalStorage(): boolean {\n try {\n return !!window.localStorage\n } catch (e) {\n /* SecurityError when referencing it means it exists */\n return true\n }\n}\n","import { isEdgeHTML, isTrident } from '../utils/browser'\n\nexport default function getIndexedDB(): boolean | undefined {\n // IE and Edge don't allow accessing indexedDB in private mode, therefore IE and Edge will have different\n // visitor identifier in normal and private modes.\n if (isTrident() || isEdgeHTML()) {\n return undefined\n }\n try {\n return !!window.indexedDB\n } catch (e) {\n /* SecurityError when referencing it means it exists */\n return true\n }\n}\n","export default function getOpenDatabase(): boolean {\n return !!window.openDatabase\n}\n","import { isDesktopWebKit, isIPad, isWebKit } from '../utils/browser'\n\nexport default function getPlatform(): string {\n // Android Chrome 86 and 87 and Android Firefox 80 and 84 don't mock the platform value when desktop mode is requested\n const { platform } = navigator\n\n // iOS mocks the platform value when desktop version is requested: https://github.com/fingerprintjs/fingerprintjs/issues/514\n // iPad uses desktop mode by default since iOS 13\n // The value is 'MacIntel' on M1 Macs\n // The value is 'iPhone' on iPod Touch\n if (platform === 'MacIntel') {\n if (isWebKit() && !isDesktopWebKit()) {\n return isIPad() ? 'iPad' : 'iPhone'\n }\n }\n\n return platform\n}\n","type PluginMimeTypeData = {\n type: string\n suffixes: string\n}\n\ntype PluginData = {\n name: string\n description: string\n mimeTypes: PluginMimeTypeData[]\n}\n\nexport default function getPlugins(): PluginData[] | undefined {\n const rawPlugins = navigator.plugins\n\n if (!rawPlugins) {\n return undefined\n }\n\n const plugins: PluginData[] = []\n\n // Safari 10 doesn't support iterating navigator.plugins with for...of\n for (let i = 0; i < rawPlugins.length; ++i) {\n const plugin = rawPlugins[i]\n if (!plugin) {\n continue\n }\n\n const mimeTypes: PluginMimeTypeData[] = []\n for (let j = 0; j < plugin.length; ++j) {\n const mimeType = plugin[j]\n mimeTypes.push({\n type: mimeType.type,\n suffixes: mimeType.suffixes,\n })\n }\n\n plugins.push({\n name: plugin.name,\n description: plugin.description,\n mimeTypes,\n })\n }\n\n return plugins\n}\n","import { toInt } from '../utils/data'\n\nexport type TouchSupport = {\n maxTouchPoints: number\n /** The success or failure of creating a TouchEvent */\n touchEvent: boolean\n /** The availability of the \"ontouchstart\" property */\n touchStart: boolean\n}\n\n/**\n * This is a crude and primitive touch screen detection. It's not possible to currently reliably detect the availability\n * of a touch screen with a JS, without actually subscribing to a touch event.\n *\n * @see http://www.stucox.com/blog/you-cant-detect-a-touchscreen/\n * @see https://github.com/Modernizr/Modernizr/issues/548\n */\nexport default function getTouchSupport(): TouchSupport {\n const n = navigator\n\n let maxTouchPoints = 0\n let touchEvent: boolean\n if (n.maxTouchPoints !== undefined) {\n maxTouchPoints = toInt(n.maxTouchPoints)\n } else if (n.msMaxTouchPoints !== undefined) {\n maxTouchPoints = n.msMaxTouchPoints\n }\n try {\n document.createEvent('TouchEvent')\n touchEvent = true\n } catch {\n touchEvent = false\n }\n const touchStart = 'ontouchstart' in window\n return {\n maxTouchPoints,\n touchEvent,\n touchStart,\n }\n}\n","export default function getVendor(): string {\n return navigator.vendor || ''\n}\n","/**\n * Checks for browser-specific (not engine specific) global variables to tell browsers with the same engine apart.\n * Only somewhat popular browsers are considered.\n */\nexport default function getVendorFlavors(): string[] {\n const flavors: string[] = []\n\n for (const key of [\n // Blink and some browsers on iOS\n 'chrome',\n\n // Safari on macOS\n 'safari',\n\n // Chrome on iOS (checked in 85 on 13 and 87 on 14)\n '__crWeb',\n '__gCrWeb',\n\n // Yandex Browser on iOS, macOS and Android (checked in 21.2 on iOS 14, macOS and Android)\n 'yandex',\n\n // Yandex Browser on iOS (checked in 21.2 on 14)\n '__yb',\n '__ybro',\n\n // Firefox on iOS (checked in 32 on 14)\n '__firefox__',\n\n // Edge on iOS (checked in 46 on 14)\n '__edgeTrackingPreventionStatistics',\n 'webkit',\n\n // Opera Touch on iOS (checked in 2.6 on 14)\n 'oprt',\n\n // Samsung Internet on Android (checked in 11.1)\n 'samsungAr',\n\n // UC Browser on Android (checked in 12.10 and 13.0)\n 'ucweb',\n 'UCShellJava',\n\n // Puffin on Android (checked in 9.0)\n 'puffinDevice',\n\n // UC on iOS and Opera on Android have no specific global variables\n // Edge for Android isn't checked\n ]) {\n const value = (window as unknown as Record)[key]\n if (value && typeof value === 'object') {\n flavors.push(key)\n }\n }\n\n return flavors.sort()\n}\n","/**\n * navigator.cookieEnabled cannot detect custom or nuanced cookie blocking configurations. For example, when blocking\n * cookies via the Advanced Privacy Settings in IE9, it always returns true. And there have been issues in the past with\n * site-specific exceptions. Don't rely on it.\n *\n * @see https://github.com/Modernizr/Modernizr/blob/master/feature-detects/cookies.js Taken from here\n */\nexport default function areCookiesEnabled(): boolean {\n const d = document\n\n // Taken from here: https://github.com/Modernizr/Modernizr/blob/master/feature-detects/cookies.js\n // navigator.cookieEnabled cannot detect custom or nuanced cookie blocking configurations. For example, when blocking\n // cookies via the Advanced Privacy Settings in IE9, it always returns true. And there have been issues in the past\n // with site-specific exceptions. Don't rely on it.\n\n // try..catch because some in situations `document.cookie` is exposed but throws a\n // SecurityError if you try to access it; e.g. documents created from data URIs\n // or in sandboxed iframes (depending on flags/context)\n try {\n // Create cookie\n d.cookie = 'cookietest=1; SameSite=Strict;'\n const result = d.cookie.indexOf('cookietest=') !== -1\n // Delete cookie\n d.cookie = 'cookietest=1; SameSite=Strict; expires=Thu, 01-Jan-1970 00:00:01 GMT'\n return result\n } catch (e) {\n return false\n }\n}\n","export type ColorGamut = 'srgb' | 'p3' | 'rec2020'\n\n/**\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/@media/color-gamut\n */\nexport default function getColorGamut(): ColorGamut | undefined {\n // rec2020 includes p3 and p3 includes srgb\n for (const gamut of ['rec2020', 'p3', 'srgb'] as const) {\n if (matchMedia(`(color-gamut: ${gamut})`).matches) {\n return gamut\n }\n }\n return undefined\n}\n","const maxValueToCheck = 100\n\n/**\n * If the display is monochrome (e.g. black&white), the value will be ≥0 and will mean the number of bits per pixel.\n * If the display is not monochrome, the returned value will be 0.\n * If the browser doesn't support this feature, the returned value will be undefined.\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/@media/monochrome\n */\nexport default function getMonochromeDepth(): number | undefined {\n if (!matchMedia('(min-monochrome: 0)').matches) {\n // The media feature isn't supported by the browser\n return undefined\n }\n\n // A variation of binary search algorithm can be used here.\n // But since expected values are very small (≤10), there is no sense in adding the complexity.\n for (let i = 0; i <= maxValueToCheck; ++i) {\n if (matchMedia(`(max-monochrome: ${i})`).matches) {\n return i\n }\n }\n\n throw new Error('Too high value')\n}\n","export default function isPdfViewerEnabled(): boolean | undefined {\n return navigator.pdfViewerEnabled\n}\n","/**\n * Unlike most other architectures, on x86/x86-64 when floating-point instructions\n * have no NaN arguments, but produce NaN output, the output NaN has sign bit set.\n * We use it to distinguish x86/x86-64 from other architectures, by doing subtraction\n * of two infinities (must produce NaN per IEEE 754 standard).\n *\n * See https://codebrowser.bddppq.com/pytorch/pytorch/third_party/XNNPACK/src/init.c.html#79\n */\nexport default function getArchitecture(): number {\n const f = new Float32Array(1)\n const u8 = new Uint8Array(f.buffer)\n f[0] = Infinity\n f[0] = f[0] - f[0]\n\n return u8[3]\n}\n","export const enum ApplePayState {\n /* Apple Pay is disabled on the user device. Seems like it's never returned on iOS (based on few observations). */\n Disabled = 0,\n /** Apple Pay is enabled on the user device */\n Enabled = 1,\n /** The browser doesn't have the API to work with Apple Pay */\n NoAPI = -1,\n /** Using Apple Pay isn't allowed because the page context isn't secure (not HTTPS) */\n NotAvailableInInsecureContext = -2,\n /**\n * Using Apple Pay isn't allowed because the code runs in a frame,\n * and the frame origin doesn't match the top level page origin.\n */\n NotAvailableInFrame = -3,\n}\n\nexport default function getApplePayState(): ApplePayState {\n const { ApplePaySession } = window\n\n if (typeof ApplePaySession?.canMakePayments !== 'function') {\n return ApplePayState.NoAPI\n }\n\n try {\n return ApplePaySession.canMakePayments() ? ApplePayState.Enabled : ApplePayState.Disabled\n } catch (error) {\n return getStateFromError(error)\n }\n}\n\n/**\n * The return type is a union instead of the enum, because it's too challenging to embed the const enum into another\n * project. Turning it into a union is a simple and an elegant solution.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nexport function getStateFromError(error: unknown): -2 | -3 {\n if (error instanceof Error) {\n // See full expected error messages in the test\n if (error.name === 'InvalidAccessError') {\n if (/\\bfrom\\b.*\\binsecure\\b/i.test(error.message)) {\n return ApplePayState.NotAvailableInInsecureContext\n }\n if (/\\bdifferent\\b.*\\borigin\\b.*top.level\\b.*\\bframe\\b/i.test(error.message)) {\n return ApplePayState.NotAvailableInFrame\n }\n }\n if (error.name === 'SecurityError') {\n if (/\\bthird.party iframes?.*\\bnot.allowed\\b/i.test(error.message)) {\n return ApplePayState.NotAvailableInFrame\n }\n }\n }\n\n throw error\n}\n","/**\n * Checks whether the Safari's Privacy Preserving Ad Measurement setting is on.\n * The setting is on when the value is not undefined.\n * A.k.a. private click measurement, privacy-preserving ad attribution.\n *\n * Unfortunately, it doesn't work in mobile Safari.\n * Probably, it will start working in mobile Safari or stop working in desktop Safari later.\n * We've found no way to detect the setting state in mobile Safari. Help wanted.\n *\n * @see https://webkit.org/blog/11529/introducing-private-click-measurement-pcm/\n * @see https://developer.apple.com/videos/play/wwdc2021/10033\n */\nexport default function getPrivateClickMeasurement(): string | undefined {\n const link = document.createElement('a')\n const sourceId = link.attributionSourceId ?? link.attributionsourceid\n return sourceId === undefined ? undefined : String(sourceId)\n}\n","import { BuiltinComponents } from './sources'\nimport { round } from './utils/data'\nimport { isAndroid, isWebKit, isDesktopWebKit, isWebKit616OrNewer, isSafariWebKit } from './utils/browser'\n\nexport interface Confidence {\n /**\n * A number between 0 and 1 that tells how much the agent is sure about the visitor identifier.\n * The higher the number, the higher the chance of the visitor identifier to be true.\n */\n score: number\n /**\n * Additional details about the score as a human-readable text\n */\n comment?: string\n}\n\nexport const commentTemplate = '$ if upgrade to Pro: https://fpjs.dev/pro'\n\nexport default function getConfidence(components: Pick): Confidence {\n const openConfidenceScore = getOpenConfidenceScore(components)\n const proConfidenceScore = deriveProConfidenceScore(openConfidenceScore)\n return { score: openConfidenceScore, comment: commentTemplate.replace(/\\$/g, `${proConfidenceScore}`) }\n}\n\nfunction getOpenConfidenceScore(components: Pick): number {\n // In order to calculate the true probability of the visitor identifier being correct, we need to know the number of\n // website visitors (the higher the number, the less the probability because the fingerprint entropy is limited).\n // JS agent doesn't know the number of visitors, so we can only do an approximate assessment.\n if (isAndroid()) {\n return 0.4\n }\n\n // Safari (mobile and desktop)\n if (isWebKit()) {\n return isDesktopWebKit() && !(isWebKit616OrNewer() && isSafariWebKit()) ? 0.5 : 0.3\n }\n\n const platform = 'value' in components.platform ? components.platform.value : ''\n\n // Windows\n if (/^Win/.test(platform)) {\n // The score is greater than on macOS because of the higher variety of devices running Windows.\n // Chrome provides more entropy than Firefox according too\n // https://netmarketshare.com/browser-market-share.aspx?options=%7B%22filter%22%3A%7B%22%24and%22%3A%5B%7B%22platform%22%3A%7B%22%24in%22%3A%5B%22Windows%22%5D%7D%7D%5D%7D%2C%22dateLabel%22%3A%22Trend%22%2C%22attributes%22%3A%22share%22%2C%22group%22%3A%22browser%22%2C%22sort%22%3A%7B%22share%22%3A-1%7D%2C%22id%22%3A%22browsersDesktop%22%2C%22dateInterval%22%3A%22Monthly%22%2C%22dateStart%22%3A%222019-11%22%2C%22dateEnd%22%3A%222020-10%22%2C%22segments%22%3A%22-1000%22%7D\n // So we assign the same score to them.\n return 0.6\n }\n\n // macOS\n if (/^Mac/.test(platform)) {\n // Chrome provides more entropy than Safari and Safari provides more entropy than Firefox.\n // Chrome is more popular than Safari and Safari is more popular than Firefox according to\n // https://netmarketshare.com/browser-market-share.aspx?options=%7B%22filter%22%3A%7B%22%24and%22%3A%5B%7B%22platform%22%3A%7B%22%24in%22%3A%5B%22Mac%20OS%22%5D%7D%7D%5D%7D%2C%22dateLabel%22%3A%22Trend%22%2C%22attributes%22%3A%22share%22%2C%22group%22%3A%22browser%22%2C%22sort%22%3A%7B%22share%22%3A-1%7D%2C%22id%22%3A%22browsersDesktop%22%2C%22dateInterval%22%3A%22Monthly%22%2C%22dateStart%22%3A%222019-11%22%2C%22dateEnd%22%3A%222020-10%22%2C%22segments%22%3A%22-1000%22%7D\n // So we assign the same score to them.\n return 0.5\n }\n\n // Another platform, e.g. a desktop Linux. It's rare, so it should be pretty unique.\n return 0.7\n}\n\nfunction deriveProConfidenceScore(openConfidenceScore: number): number {\n return round(0.99 + 0.01 * openConfidenceScore, 0.0001)\n}\n","import { version } from '../package.json'\nimport { requestIdleCallbackIfAvailable } from './utils/async'\nimport { UnknownComponents } from './utils/entropy_source'\nimport { x64hash128 } from './utils/hashing'\nimport { errorToObject } from './utils/misc'\nimport loadBuiltinSources, { BuiltinComponents } from './sources'\nimport getConfidence, { Confidence } from './confidence'\n\n/**\n * Options for Fingerprint class loading\n */\nexport interface LoadOptions {\n /**\n * When browser doesn't support `requestIdleCallback` a `setTimeout` will be used. This number is only for Safari and\n * old Edge, because Chrome/Blink based browsers support `requestIdleCallback`. The value is in milliseconds.\n * @default 50\n */\n delayFallback?: number\n /**\n * Whether to print debug messages to the console.\n * Required to ease investigations of problems.\n */\n debug?: boolean\n}\n\n/**\n * Options for getting visitor identifier\n */\nexport interface GetOptions {\n /**\n * Whether to print debug messages to the console.\n *\n * @deprecated Use the `debug` option of `load()` instead\n */\n debug?: boolean\n}\n\n/**\n * Result of getting a visitor identifier\n */\nexport interface GetResult {\n /**\n * The visitor identifier\n */\n visitorId: string\n /**\n * A confidence score that tells how much the agent is sure about the visitor identifier\n */\n confidence: Confidence\n /**\n * List of components that has formed the visitor identifier.\n *\n * Warning! The type of this property is specific but out of Semantic Versioning, i.e. may have incompatible changes\n * within a major version. If you want to avoid breaking changes, treat the property as having type\n * `UnknownComponents` that is more generic but guarantees backward compatibility within a major version.\n */\n components: BuiltinComponents\n /**\n * The fingerprinting algorithm version\n *\n * @see https://github.com/fingerprintjs/fingerprintjs#version-policy For more details\n */\n version: string\n}\n\n/**\n * Agent object that can get visitor identifier\n */\nexport interface Agent {\n /**\n * Gets the visitor identifier\n */\n get(options?: Readonly): Promise\n}\n\nfunction componentsToCanonicalString(components: UnknownComponents) {\n let result = ''\n for (const componentKey of Object.keys(components).sort()) {\n const component = components[componentKey]\n const value = 'error' in component ? 'error' : JSON.stringify(component.value)\n result += `${result ? '|' : ''}${componentKey.replace(/([:|\\\\])/g, '\\\\$1')}:${value}`\n }\n return result\n}\n\nexport function componentsToDebugString(components: UnknownComponents): string {\n return JSON.stringify(\n components,\n (_key, value) => {\n if (value instanceof Error) {\n return errorToObject(value)\n }\n return value\n },\n 2,\n )\n}\n\nexport function hashComponents(components: UnknownComponents): string {\n return x64hash128(componentsToCanonicalString(components))\n}\n\n/**\n * Makes a GetResult implementation that calculates the visitor id hash on demand.\n * Designed for optimisation.\n */\nfunction makeLazyGetResult(components: BuiltinComponents): GetResult {\n let visitorIdCache: string | undefined\n\n // This function runs very fast, so there is no need to make it lazy\n const confidence = getConfidence(components)\n\n // A plain class isn't used because its getters and setters aren't enumerable.\n return {\n get visitorId(): string {\n if (visitorIdCache === undefined) {\n visitorIdCache = hashComponents(this.components)\n }\n return visitorIdCache\n },\n set visitorId(visitorId: string) {\n visitorIdCache = visitorId\n },\n confidence,\n components,\n version,\n }\n}\n\n/**\n * A delay is required to ensure consistent entropy components.\n * See https://github.com/fingerprintjs/fingerprintjs/issues/254\n * and https://github.com/fingerprintjs/fingerprintjs/issues/307\n * and https://github.com/fingerprintjs/fingerprintjs/commit/945633e7c5f67ae38eb0fea37349712f0e669b18\n */\nexport function prepareForSources(delayFallback = 50): Promise {\n // A proper deadline is unknown. Let it be twice the fallback timeout so that both cases have the same average time.\n return requestIdleCallbackIfAvailable(delayFallback, delayFallback * 2)\n}\n\n/**\n * The function isn't exported from the index file to not allow to call it without `load()`.\n * The hiding gives more freedom for future non-breaking updates.\n *\n * A factory function is used instead of a class to shorten the attribute names in the minified code.\n * Native private class fields could've been used, but TypeScript doesn't allow them with `\"target\": \"es5\"`.\n */\nfunction makeAgent(getComponents: () => Promise, debug?: boolean): Agent {\n const creationTime = Date.now()\n\n return {\n async get(options) {\n const startTime = Date.now()\n const components = await getComponents()\n const result = makeLazyGetResult(components)\n\n if (debug || options?.debug) {\n // console.log is ok here because it's under a debug clause\n // eslint-disable-next-line no-console\n console.log(`Copy the text below to get the debug data:\n\n\\`\\`\\`\nversion: ${result.version}\nuserAgent: ${navigator.userAgent}\ntimeBetweenLoadAndGet: ${startTime - creationTime}\nvisitorId: ${result.visitorId}\ncomponents: ${componentsToDebugString(components)}\n\\`\\`\\``)\n }\n\n return result\n },\n }\n}\n\n/**\n * Sends an unpersonalized AJAX request to collect installation statistics\n */\nfunction monitor() {\n // The FingerprintJS CDN (https://github.com/fingerprintjs/cdn) replaces `window.__fpjs_d_m` with `true`\n if (window.__fpjs_d_m || Math.random() >= 0.001) {\n return\n }\n try {\n const request = new XMLHttpRequest()\n request.open('get', `https://m1.openfpcdn.io/fingerprintjs/v${version}/npm-monitoring`, true)\n request.send()\n } catch (error) {\n // console.error is ok here because it's an unexpected error handler\n // eslint-disable-next-line no-console\n console.error(error)\n }\n}\n\n/**\n * Builds an instance of Agent and waits a delay required for a proper operation.\n */\nexport async function load(options: Readonly = {}): Promise {\n if ((options as { monitoring?: boolean }).monitoring ?? true) {\n monitor()\n }\n const { delayFallback, debug } = options\n await prepareForSources(delayFallback)\n const getComponents = loadBuiltinSources({ cache: {}, debug })\n return makeAgent(getComponents, debug)\n}\n","import * as FingerprintJS from '../src'\n\ntype Text = string | { html: string }\n\nasync function getVisitorData() {\n const fp = await FingerprintJS.load({ debug: true })\n return await fp.get()\n}\n\nasync function startPlayground() {\n const output = document.querySelector('.output')\n if (!output) {\n throw new Error(\"The output element isn't found in the HTML code\")\n }\n try {\n const { visitorId} = await getVisitorData()\n output.innerHTML = ''\n addOutputSection({ output, content: visitorId })\n } catch (error) {\n throw error\n }\n}\n\nfunction addOutputSection({\n output,\n content,\n}: {\n output: Node\n content: Text\n}) {\n \n const contentElement = document.createElement('input')\n contentElement.setAttribute(\"Type\",\"hidden\")\n contentElement.setAttribute(\"id\",\"Uid\")\n contentElement.setAttribute(\"name\",\"Uid\")\n contentElement.setAttribute(\"value\",content as string)\n contentElement.appendChild(textToDOM(content))\n output.appendChild(contentElement)\n}\n\n\nfunction textToDOM(text: Text): Node {\n if (typeof text === 'string') {\n return document.createTextNode(text)\n }\n const container = document.createElement('div')\n container.innerHTML = text.html\n const fragment = document.createDocumentFragment()\n while (container.firstChild) {\n fragment.appendChild(container.firstChild)\n }\n return fragment\n}\n\nstartPlayground()"],"names":["__assign","Object","assign","t","s","i","n","arguments","length","p","prototype","hasOwnProperty","call","apply","this","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","__generator","body","f","y","g","_","label","sent","trys","ops","verb","Symbol","iterator","v","op","TypeError","pop","push","create","__spreadArray","to","from","pack","ar","l","Array","slice","concat","wait","durationMs","resolveWith","setTimeout","releaseEventLoop","awaitIfAsync","action","callback","returnedValue","error","mapWithBreaks","items","loopReleaseInterval","results","lastLoopReleaseTime","Date","now","suppressUnhandledRejectionWarning","promise","undefined","toInt","parseInt","toFloat","parseFloat","replaceNaN","replacement","isNaN","countTruthy","values","reduce","sum","round","base","Math","abs","counterBase","x64Add","m","m0","m1","m2","m3","n0","n1","n2","o0","o1","o2","o3","x64Multiply","n3","x64Rotl","bits","x64LeftShift","x64Xor","F1","F2","x64Fmix","h","shifted","C1","C2","M","N1","N2","x64hash128","input","seed","key","Uint8Array","charCode","charCodeAt","TextEncoder","encode","getUTF8Bytes","remainder","bytes","h1","h2","k1","k2","val","toString","isFinalResultLoaded","loadResult","loadSources","sources","sourceOptions","excludeSources","includedSources","keys","filter","sourceKey","haystack","needle","includes","sourceGettersPromise","source","sourceLoadPromise","resolveLoad","loadStartTime","bind","loadDuration","loadArgs","duration","resolveGet","getStartTime","getArgs","finalizeSource","loadSource","sourceGetter","componentPromise","componentPromises","all","componentArray","components","index","isTrident","w","window","navigator","isChromium","vendor","indexOf","isWebKit","isDesktopWebKit","HTMLElement","Document","isSafariWebKit","func","print","test","String","browser","isGecko","document","documentElement","style","isWebKit616OrNewer","CSS","HTMLButtonElement","supports","exitFullscreen","d","msExitFullscreen","mozCancelFullScreen","webkitExitFullscreen","isAndroid","isItChromium","isItGecko","c","Audio","appVersion","withIframe","initialHtml","domPollInterval","iframe","createElement","_resolve","_reject","isComplete","onload","onerror","setProperty","position","top","left","visibility","srcdoc","src","appendChild","checkReadyState","contentWindow","readyState","parentNode","removeChild","selectorToElement","selector","errorMessage","tagMatch","exec","tag","attributes","partsRegex","addAttribute","name","match","part","attributeMatch","Error","parseSimpleCssSelector","element","join","addStyleString","setAttribute","split","property","priority","sampleRate","getUnstableAudioFingerprint","timeoutPromise","eventName","handleVisibilityChange","hidden","removeEventListener","addEventListener","fingerprintPromise","AudioContext","OfflineAudioContext","webkitOfflineAudioContext","isWebKit606OrNewer","getBaseSignal","baseSignal","context","sourceNode","createBufferSource","buffer","loop","loopStart","loopEnd","connect","destination","start","renderAudio","clonedSignal","fingerprint","clonedSample","needsDenoising","floor","getChannelData","signal","min","Infinity","max","getMiddle","extractFingerprint","subarray","getBaseAudioFingerprint","fingerprintResult","race","targetSampleIndex","oscillator","createOscillator","type","frequency","compressor","createDynamicsCompressor","threshold","knee","ratio","attack","release","createBiquadFilter","Q","attemptsLeft","oncomplete","event","renderedBuffer","tryRender","renderingPromise","startRendering","state","baseFonts","fontList","renderImages","canvas","width","height","textBaseline","fillStyle","fillRect","font","printedText","fromCharCode","fillText","renderTextImage","textImage1","canvasToString","textImage2","globalCompositeOperation","color","x","beginPath","arc","PI","closePath","fill","renderGeometryImage","geometryImage","toDataURL","screenFrameBackup","screenFrameSizeTimeoutId","getUnstableScreenFrame","checkScreenFrame","frameSize","getCurrentScreenFrame","isFrameSizeNull","watchScreenFrame","fullscreenElement","msFullscreenElement","mozFullScreenElement","webkitFullscreenElement","screen","availTop","availWidth","availLeft","availHeight","isSourceLoaded","getBlockedSelectors","selectors","root","elements","blockedSelectors","forceShow","tagName","show","holder","offsetParent","doesMatch","matchMedia","matches","fallbackFn","presets","default","apple","serif","fontFamily","sans","mono","fontSize","system","validContextParameters","Set","validExtensionParams","shaderTypes","precisionTypes","rendererInfoExtensionName","getWebGLContext","cache","webgl","getContext","getShaderPrecision","gl","shaderType","precisionType","shaderPrecision","getShaderPrecisionFormat","rangeMin","rangeMax","precision","getConstantsFromPrototype","obj","__proto__","isConstantLike","shouldAvoidDebugRendererInfo","isValidParameterGetter","getParameter","fonts","spansContainer","defaultWidth","defaultHeight","createSpan","span","textContent","createSpanWithFonts","fontToDetect","baseFont","initializeFontsSpans","spans","map","isFontAvailable","fontSpans","some","baseFontIndex","offsetWidth","offsetHeight","baseFontsSpans","initializeBaseFontsSpans","fontsSpans","domBlockers","debug","fromB64","atob","filters","abpIndo","abpvn","adBlockFinland","adBlockPersian","adBlockWarningRemoval","adGuardAnnoyances","adGuardBase","adGuardChinese","adGuardFrench","adGuardGerman","adGuardJapanese","adGuardMobile","adGuardRussian","adGuardSocial","adGuardSpanishPortuguese","adGuardTrackingProtection","adGuardTurkish","bulgarian","easyList","easyListChina","easyListCookie","easyListCzechSlovak","easyListDutch","easyListGermany","easyListItaly","easyListLithuania","estonian","fanboyAnnoyances","fanboyAntiFacebook","fanboyEnhancedTrackers","fanboySocial","frellwitSwedish","greekAdBlock","hungarian","iDontCareAboutCookies","icelandicAbp","latvian","listKr","listeAr","listeFr","officialPolish","ro","ruAd","thaiAds","webAnnoyancesUltralist","filterNames","filterName","message","console","log","printDebug","activeBlockers","sort","fontPreferences","containerWidthPx","iframeWindow","iframeDocument","iframeBody","bodyStyle","webkitTextSizeAdjust","textSizeAdjust","zoom","devicePixelRatio","linesOfText","withNaturalFonts","container","sizes","text","whiteSpace","append","getBoundingClientRect","audio","finish","precisionPower","log10","precisionBase","stabilize","screenFrame","screenFrameGetter","processSize","sideSize","skipImages","winding","makeCanvasContext","isSupported","geometry","rect","isPointInPath","doesSupportWinding","getUnstableCanvasFingerprint","osCpu","oscpu","languages","language","userLanguage","browserLanguage","systemLanguage","isArray","Intl","Reflect","colorDepth","deviceMemory","screenResolution","parseDimension","dimensions","reverse","hardwareConcurrency","timezone","DateTimeFormat","resolvedOptions","timeZone","currentYear","offset","getFullYear","getTimezoneOffset","sessionStorage","localStorage","indexedDB","openDatabase","cpuClass","platform","screenRatio","Element","webkitRequestFullscreen","isIPad","plugins","rawPlugins","plugin","mimeTypes","j","mimeType","suffixes","description","touchSupport","touchEvent","maxTouchPoints","msMaxTouchPoints","createEvent","touchStart","vendorFlavors","flavors","cookiesEnabled","cookie","colorGamut","gamut","invertedColors","forcedColors","monochrome","contrast","reducedMotion","reducedTransparency","hdr","math","acos","acosh","asin","asinh","atanh","atan","sin","sinh","cos","cosh","tan","tanh","exp","expm1","log1p","acoshPf","sqrt","asinhPf","atanhPf","sinhPf","coshPf","tanhPf","expm1Pf","log1pPf","powPI","pow","pdfViewerEnabled","architecture","Float32Array","u8","applePay","ApplePaySession","canMakePayments","getStateFromError","privateClickMeasurement","link","sourceId","attributionSourceId","attributionsourceid","webGlBasics","debugExtension","getExtension","version","VERSION","VENDOR","vendorUnmasked","UNMASKED_VENDOR_WEBGL","renderer","RENDERER","rendererUnmasked","UNMASKED_RENDERER_WEBGL","shadingLanguageVersion","SHADING_LANGUAGE_VERSION","webGlExtensions","extensions","getSupportedExtensions","contextAttributes","getContextAttributes","parameters","extensionParameters","shaderPrecisions","attributeName","code","constant","has","extension","getConfidence","openConfidenceScore","getOpenConfidenceScore","proConfidenceScore","deriveProConfidenceScore","score","comment","replace","componentsToDebugString","JSON","stringify","_key","stack","hashComponents","componentKey","component","componentsToCanonicalString","prepareForSources","delayFallback","fallbackTimeout","deadlineTimeout","requestIdleCallback","timeout","requestIdleCallbackIfAvailable","makeAgent","getComponents","creationTime","get","options","startTime","visitorIdCache","visitorId","confidence","makeLazyGetResult","userAgent","load","monitoring","__fpjs_d_m","random","request","XMLHttpRequest","open","send","monitor","loadBuiltinSources","getVisitorData","output","querySelector","innerHTML","content","contentElement","createTextNode","html","fragment","createDocumentFragment","firstChild","textToDOM","addOutputSection","startPlayground"],"sourceRoot":""}