@wener/utils 1.1.16 → 1.1.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (87) hide show
  1. package/dist/cjs/index.cjs +5 -5
  2. package/dist/cjs/index.cjs.map +1 -1
  3. package/dist/cjs/server.cjs +1 -1
  4. package/dist/cjs/server.cjs.map +1 -1
  5. package/dist/esm/index.js +11 -11
  6. package/dist/esm/index.js.map +1 -1
  7. package/dist/esm/server.js +1 -1
  8. package/dist/esm/server.js.map +1 -1
  9. package/dist/system/index.js +5 -5
  10. package/dist/system/index.js.map +1 -1
  11. package/dist/system/server.js +1 -1
  12. package/dist/system/server.js.map +1 -1
  13. package/lib/asyncs/createLazyPromise.js.map +1 -1
  14. package/lib/browsers/download.js.map +1 -1
  15. package/lib/browsers/getFileFromDataTransfer.js.map +1 -1
  16. package/lib/browsers/loaders.js.map +1 -1
  17. package/lib/crypto/getNodeCrypto.js.map +1 -1
  18. package/lib/crypto/getRandomValues.js.map +1 -1
  19. package/lib/crypto/pem/pem.js.map +1 -1
  20. package/lib/crypto/ulid.js +4 -1
  21. package/lib/crypto/ulid.js.map +1 -1
  22. package/lib/fetch/dumpRequest.js.map +1 -1
  23. package/lib/fetch/dumpResponse.js.map +1 -1
  24. package/lib/i18n/createTranslate.js.map +1 -1
  25. package/lib/io/ArrayBuffers.js +142 -164
  26. package/lib/io/ArrayBuffers.js.map +1 -1
  27. package/lib/io/Buffer.js +5 -6
  28. package/lib/io/Buffer.js.map +1 -1
  29. package/lib/libs/ms.js.map +1 -1
  30. package/lib/modules/parseModuleId.js.map +1 -1
  31. package/lib/server.js +8 -5
  32. package/lib/server.js.map +1 -1
  33. package/lib/servers/crypto/md5.js +8 -0
  34. package/lib/servers/crypto/md5.js.map +1 -0
  35. package/lib/servers/fetch/createFetchWithProxy.js.map +1 -0
  36. package/lib/servers/fetch/createFetchWithProxyByUndici.js.map +1 -0
  37. package/lib/servers/fetch/createFetchWithRetry.js +70 -0
  38. package/lib/servers/fetch/createFetchWithRetry.js.map +1 -0
  39. package/lib/servers/getPackageDir.js +18 -0
  40. package/lib/servers/getPackageDir.js.map +1 -0
  41. package/lib/servers/polyfill/polyfillBrowser.js.map +1 -0
  42. package/lib/servers/{polyfillCrypto.js → polyfill/polyfillCrypto.js} +1 -1
  43. package/lib/servers/polyfill/polyfillCrypto.js.map +1 -0
  44. package/lib/servers/polyfill/polyfillFetch.js.map +1 -0
  45. package/lib/servers/{polyfillJsDom.js → polyfill/polyfillJsDom.js} +1 -1
  46. package/lib/servers/polyfill/polyfillJsDom.js.map +1 -0
  47. package/lib/strings/formatBytes.js.map +1 -1
  48. package/lib/validations/isUUID.js +1 -1
  49. package/lib/validations/isUUID.js.map +1 -1
  50. package/lib/validations/parseTimestamp.js.map +1 -1
  51. package/package.json +6 -9
  52. package/src/crypto/hashing.test.ts +4 -1
  53. package/src/crypto/md5.d.ts +1 -0
  54. package/src/crypto/md5.js +44 -0
  55. package/src/crypto/ulid.test.ts +14 -1
  56. package/src/crypto/ulid.ts +5 -2
  57. package/src/fetch/types.ts +1 -1
  58. package/src/langs/hashCode.ts +37 -0
  59. package/src/logging/Logger.ts +6 -6
  60. package/src/logging/slog.test.ts +8 -0
  61. package/src/logging/slog.ts +100 -0
  62. package/src/maths/clamp.ts +1 -0
  63. package/src/server.ts +9 -5
  64. package/src/servers/crypto/md5.ts +5 -0
  65. package/src/servers/{createFetchWithProxyByNodeFetch.ts → fetch/createFetchWithProxyByNodeFetch.ts} +2 -2
  66. package/src/servers/{createFetchWithProxyByUndici.ts → fetch/createFetchWithProxyByUndici.ts} +3 -2
  67. package/src/servers/fetch/createFetchWithRetry.ts +95 -0
  68. package/src/servers/getPackageDir.ts +16 -0
  69. package/src/servers/{polyfillCrypto.ts → polyfill/polyfillCrypto.ts} +1 -1
  70. package/src/servers/{polyfillFetch.ts → polyfill/polyfillFetch.ts} +1 -1
  71. package/src/servers/{polyfillJsDom.ts → polyfill/polyfillJsDom.ts} +1 -1
  72. package/src/servers/{polyfillWebSocket.ts → polyfill/polyfillWebSocket.ts} +2 -2
  73. package/src/validations/isUUID.test.ts +14 -0
  74. package/src/validations/isUUID.ts +2 -2
  75. package/lib/servers/createFetchWithProxy.js.map +0 -1
  76. package/lib/servers/createFetchWithProxyByUndici.js.map +0 -1
  77. package/lib/servers/polyfillBrowser.js.map +0 -1
  78. package/lib/servers/polyfillCrypto.js.map +0 -1
  79. package/lib/servers/polyfillFetch.js.map +0 -1
  80. package/lib/servers/polyfillJsDom.js.map +0 -1
  81. /package/lib/servers/{createFetchWithProxy.js → fetch/createFetchWithProxy.js} +0 -0
  82. /package/lib/servers/{createFetchWithProxyByUndici.js → fetch/createFetchWithProxyByUndici.js} +0 -0
  83. /package/lib/servers/{polyfillBrowser.js → polyfill/polyfillBrowser.js} +0 -0
  84. /package/lib/servers/{polyfillFetch.js → polyfill/polyfillFetch.js} +0 -0
  85. /package/src/servers/{createFetchWithProxy.ts → fetch/createFetchWithProxy.ts} +0 -0
  86. /package/src/servers/{polyfillBrowser.test.ts → polyfill/polyfillBrowser.test.ts} +0 -0
  87. /package/src/servers/{polyfillBrowser.ts → polyfill/polyfillBrowser.ts} +0 -0
@@ -0,0 +1,95 @@
1
+ import { FetchLike } from '../../fetch';
2
+ import { getGlobalThis } from '../../isomorphics/getGlobalThis';
3
+
4
+ type RequestDelayFunction = (attempt: number, error: Error | null, response: Response | null) => number;
5
+ type RequestRetryOnFunction = (
6
+ attempt: number,
7
+ error: Error | null,
8
+ response: Response | null,
9
+ ) => boolean | Promise<boolean>;
10
+
11
+ export interface FetchWithRetryOptions {
12
+ fetch?: FetchLike;
13
+ retries?: number;
14
+ retryDelay?: number | RequestDelayFunction;
15
+ retryOn?: number[] | RequestRetryOnFunction;
16
+ }
17
+
18
+ export function createFetchWithRetry({
19
+ fetch = getGlobalThis().fetch,
20
+ retries = 3,
21
+ retryDelay = 1000,
22
+ retryOn = [],
23
+ }: FetchWithRetryOptions = {}): FetchLike {
24
+ // https://github.com/jonbern/fetch-retry/blob/master/index.js
25
+
26
+ return function fetchRetry(input: string | Request, init?: RequestInit) {
27
+ return new Promise(function (resolve, reject) {
28
+ var wrappedFetch = function (attempt: number) {
29
+ // As of node 18, this is no longer needed since node comes with native support for fetch:
30
+ /* istanbul ignore next */
31
+ var _input = typeof Request !== 'undefined' && input instanceof Request ? input.clone() : input;
32
+ fetch(_input, init)
33
+ .then(function (response) {
34
+ if (Array.isArray(retryOn) && retryOn.indexOf(response.status) === -1) {
35
+ resolve(response);
36
+ } else if (typeof retryOn === 'function') {
37
+ try {
38
+ return Promise.resolve(retryOn(attempt, null, response))
39
+ .then(function (retryOnResponse) {
40
+ if (retryOnResponse) {
41
+ retry(attempt, null, response);
42
+ } else {
43
+ resolve(response);
44
+ }
45
+ })
46
+ .catch(reject);
47
+ } catch (error) {
48
+ reject(error);
49
+ }
50
+ } else {
51
+ if (attempt < retries) {
52
+ retry(attempt, null, response);
53
+ } else {
54
+ resolve(response);
55
+ }
56
+ }
57
+ return;
58
+ })
59
+ .catch(function (error) {
60
+ if (typeof retryOn === 'function') {
61
+ try {
62
+ // eslint-disable-next-line no-undef
63
+ Promise.resolve(retryOn(attempt, error, null))
64
+ .then(function (retryOnResponse) {
65
+ if (retryOnResponse) {
66
+ retry(attempt, error, null);
67
+ } else {
68
+ reject(error);
69
+ }
70
+ })
71
+ .catch(function (error) {
72
+ reject(error);
73
+ });
74
+ } catch (error) {
75
+ reject(error);
76
+ }
77
+ } else if (attempt < retries) {
78
+ retry(attempt, error, null);
79
+ } else {
80
+ reject(error);
81
+ }
82
+ });
83
+ };
84
+
85
+ function retry(attempt: number, error: any, response: Response | null) {
86
+ let delay = typeof retryDelay === 'function' ? retryDelay(attempt, error, response) : retryDelay;
87
+ setTimeout(function () {
88
+ wrappedFetch(++attempt);
89
+ }, delay);
90
+ }
91
+
92
+ wrappedFetch(0);
93
+ });
94
+ };
95
+ }
@@ -0,0 +1,16 @@
1
+ import fs from 'node:fs';
2
+ import path from 'node:path';
3
+ import { fileURLToPath } from 'node:url';
4
+
5
+ const __filename = fileURLToPath(import.meta.url);
6
+ const __dirname = path.dirname(__filename);
7
+
8
+ export function getPackageDir(currentDir: string = __dirname) {
9
+ while (!fs.existsSync(path.join(currentDir, 'package.json'))) {
10
+ currentDir = path.resolve(currentDir, '..');
11
+ if (currentDir === '/') {
12
+ return undefined;
13
+ }
14
+ }
15
+ return currentDir;
16
+ }
@@ -1,4 +1,4 @@
1
- import { getGlobalThis } from '../isomorphics/getGlobalThis';
1
+ import { getGlobalThis } from '../../isomorphics/getGlobalThis';
2
2
 
3
3
  export async function polyfillCrypto() {
4
4
  const globalThis = getGlobalThis();
@@ -1,4 +1,4 @@
1
- import type { MaybePromise } from '../asyncs/MaybePromise';
1
+ import type { MaybePromise } from '../../asyncs/MaybePromise';
2
2
 
3
3
  export function polyfillFetch(nodeFetch: typeof import('node-fetch')): boolean;
4
4
  export function polyfillFetch(nodeFetch?: undefined): Promise<boolean>;
@@ -1,5 +1,5 @@
1
1
  import type { ConstructorOptions, ResourceLoaderConstructorOptions } from 'jsdom';
2
- import { getGlobalThis } from '../isomorphics/getGlobalThis';
2
+ import { getGlobalThis } from '../../isomorphics/getGlobalThis';
3
3
 
4
4
  export async function polyfillJsDom() {
5
5
  if (typeof window !== 'undefined') {
@@ -1,5 +1,5 @@
1
- import type { MaybePromise } from '../asyncs/MaybePromise';
2
- import { getGlobalThis } from '../isomorphics/getGlobalThis';
1
+ import type { MaybePromise } from '../../asyncs/MaybePromise';
2
+ import { getGlobalThis } from '../../isomorphics/getGlobalThis';
3
3
 
4
4
  export function polyfillWebSocket(ws: any): boolean;
5
5
  export function polyfillWebSocket(ws?: undefined): Promise<boolean>;
@@ -0,0 +1,14 @@
1
+ import { expect, test } from 'vitest';
2
+ import { randomUUID } from '../crypto/randomUUID';
3
+ import { isUUID } from './isUUID';
4
+
5
+ test('isUUID', () => {
6
+ for (const [a, b] of [
7
+ [undefined, false],
8
+ [null, false],
9
+ ['', false],
10
+ [randomUUID(), true],
11
+ ] as const) {
12
+ expect(isUUID(a), `${a} -> ${b}`).toEqual(b);
13
+ }
14
+ });
@@ -1,3 +1,3 @@
1
- export function isUUID(str: string) {
2
- return /^[0-9a-f]{8}-[0-9a-f]{4}-4[0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i.test(str);
1
+ export function isUUID(str: string | undefined | null) {
2
+ return Boolean(str) && /^[0-9a-f]{8}-[0-9a-f]{4}-4[0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i.test(String(str));
3
3
  }
@@ -1 +0,0 @@
1
- {"version":3,"file":"createFetchWithProxy.js","sources":["../../src/servers/createFetchWithProxy.ts"],"sourcesContent":["import { createFetchWithProxyByUndici } from './createFetchWithProxyByUndici';\n\nexport const createFetchWithProxy = createFetchWithProxyByUndici;\n"],"names":[],"mappings":";;AAEO,MAAM,oBAAuB,GAAA;;;;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"createFetchWithProxyByUndici.js","sources":["../../src/servers/createFetchWithProxyByUndici.ts"],"sourcesContent":["import { MaybePromise } from '../asyncs/MaybePromise';\nimport { FetchLike } from '../fetch';\n\nexport function createFetchWithProxyByUndici({\n proxy,\n token: _token,\n fetch,\n undici,\n}: {\n proxy?: string;\n token?: string;\n fetch?: FetchLike;\n undici?: MaybePromise<{ fetch: any; ProxyAgent: any }>;\n} = {}): FetchLike {\n if (!proxy) {\n return fetch || globalThis.fetch;\n }\n let agent: any;\n // https://github.com/nodejs/undici/blob/main/docs/best-practices/proxy.md\n return async (...args) => {\n const init = (args[1] ||= {}) as RequestInit & {\n duplex?: string;\n dispatcher?: any;\n };\n {\n const body = init.body;\n if (typeof body === 'object' && body && (body instanceof ReadableStream || Symbol.asyncIterator in body)) {\n // request.duplex must be set if request.body is ReadableStream or Async Iterables\n init.duplex ||= 'half';\n }\n }\n if (!agent) {\n let uri = proxy;\n let token = _token;\n {\n let u: URL | undefined;\n try {\n u = new URL(proxy);\n } catch (e) {}\n if (!token && u && (u.username || u.password)) {\n token = `Basic ${btoa(`${u.username || ''}:${u.password}`)}`;\n u.username = '';\n u.password = '';\n uri = u.toString();\n }\n }\n // if in next use 'next/dist/compiled/undici'\n undici ||= import('undici');\n const mod = await undici;\n const ProxyAgent = mod.ProxyAgent as new (_: any) => any;\n fetch ||= mod.fetch as FetchLike;\n // https://github.com/nodejs/undici/blob/main/docs/api/ProxyAgent.md\n agent = new ProxyAgent({\n uri,\n token,\n });\n // https://github.com/nodejs/node/issues/43187#issuecomment-1134634174\n // (global as any)[Symbol.for('undici.globalDispatcher.1')] = agent;\n }\n init.dispatcher = agent;\n return await fetch!(...args);\n };\n}\n"],"names":[],"mappings":"AAGO,SAAS,4BAA6B,CAAA;AAAA,EAC3C,KAAA;AAAA,EACA,KAAO,EAAA,MAAA;AAAA,EACP,KAAA;AAAA,EACA,MAAA;AACF,CAAA,GAKI,EAAe,EAAA;AACjB,EAAA,IAAI,CAAC,KAAO,EAAA;AACV,IAAA,OAAO,SAAS,UAAW,CAAA,KAAA,CAAA;AAAA,GAC7B;AACA,EAAI,IAAA,KAAA,CAAA;AAEJ,EAAA,OAAO,UAAU,IAAS,KAAA;AACxB,IAAM,MAAA,IAAA,GAAQ,sBAAY,EAAC,CAAA,CAAA;AAI3B,IAAA;AACE,MAAA,MAAM,OAAO,IAAK,CAAA,IAAA,CAAA;AAClB,MAAI,IAAA,OAAO,SAAS,QAAY,IAAA,IAAA,KAAS,gBAAgB,cAAkB,IAAA,MAAA,CAAO,iBAAiB,IAAO,CAAA,EAAA;AAExG,QAAK,IAAA,CAAA,MAAA,KAAL,KAAK,MAAW,GAAA,MAAA,CAAA,CAAA;AAAA,OAClB;AAAA,KACF;AACA,IAAA,IAAI,CAAC,KAAO,EAAA;AACV,MAAA,IAAI,GAAM,GAAA,KAAA,CAAA;AACV,MAAA,IAAI,KAAQ,GAAA,MAAA,CAAA;AACZ,MAAA;AACE,QAAI,IAAA,CAAA,CAAA;AACJ,QAAI,IAAA;AACF,UAAI,CAAA,GAAA,IAAI,IAAI,KAAK,CAAA,CAAA;AAAA,iBACV,CAAP,EAAA;AAAA,SAAW;AACb,QAAA,IAAI,CAAC,KAAS,IAAA,CAAA,KAAM,CAAE,CAAA,QAAA,IAAY,EAAE,QAAW,CAAA,EAAA;AAC7C,UAAA,KAAA,GAAQ,SAAS,IAAK,CAAA,CAAA,EAAG,EAAE,QAAY,IAAA,EAAA,CAAA,CAAA,EAAM,EAAE,QAAU,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA;AACzD,UAAA,CAAA,CAAE,QAAW,GAAA,EAAA,CAAA;AACb,UAAA,CAAA,CAAE,QAAW,GAAA,EAAA,CAAA;AACb,UAAA,GAAA,GAAM,EAAE,QAAS,EAAA,CAAA;AAAA,SACnB;AAAA,OACF;AAEA,MAAA,MAAA,KAAA,MAAA,GAAW,OAAO,QAAQ,CAAA,CAAA,CAAA;AAC1B,MAAA,MAAM,MAAM,MAAM,MAAA,CAAA;AAClB,MAAA,MAAM,aAAa,GAAI,CAAA,UAAA,CAAA;AACvB,MAAA,KAAA,KAAA,KAAA,GAAU,GAAI,CAAA,KAAA,CAAA,CAAA;AAEd,MAAA,KAAA,GAAQ,IAAI,UAAW,CAAA;AAAA,QACrB,GAAA;AAAA,QACA,KAAA;AAAA,OACD,CAAA,CAAA;AAAA,KAGH;AACA,IAAA,IAAA,CAAK,UAAa,GAAA,KAAA,CAAA;AAClB,IAAO,OAAA,MAAM,KAAO,CAAA,GAAG,IAAI,CAAA,CAAA;AAAA,GAC7B,CAAA;AACF;;;;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"polyfillBrowser.js","sources":["../../src/servers/polyfillBrowser.ts"],"sourcesContent":["import { polyfillCrypto } from './polyfillCrypto';\nimport { polyfillFetch } from './polyfillFetch';\nimport { polyfillJsDom } from './polyfillJsDom';\n\n/**\n * Polyfills the browser environment with the necessary APIs for the server.\n * Currently, this includes:\n * - `window`\n * - `document`\n * - `fetch`\n * - `crypto`\n */\nexport async function polyfillBrowser() {\n await polyfillCrypto();\n await polyfillFetch();\n await polyfillJsDom();\n}\n"],"names":[],"mappings":";;;;AAYA,eAAsB,eAAkB,GAAA;AACtC,EAAA,MAAM,cAAe,EAAA,CAAA;AACrB,EAAA,MAAM,aAAc,EAAA,CAAA;AACpB,EAAA,MAAM,aAAc,EAAA,CAAA;AACtB;;;;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"polyfillCrypto.js","sources":["../../src/servers/polyfillCrypto.ts"],"sourcesContent":["import { getGlobalThis } from '../isomorphics/getGlobalThis';\n\nexport async function polyfillCrypto() {\n const globalThis = getGlobalThis();\n if ('crypto' in globalThis) {\n return false;\n }\n (globalThis as any).crypto = (await import('node:crypto')).webcrypto as Crypto;\n return true;\n}\n"],"names":[],"mappings":";;AAEA,eAAsB,cAAiB,GAAA;AACrC,EAAA,MAAM,aAAa,aAAc,EAAA,CAAA;AACjC,EAAA,IAAI,YAAY,UAAY,EAAA;AAC1B,IAAO,OAAA,KAAA,CAAA;AAAA,GACT;AACA,EAAC,UAAmB,CAAA,MAAA,GAAA,CAAU,MAAM,OAAO,aAAa,CAAG,EAAA,SAAA,CAAA;AAC3D,EAAO,OAAA,IAAA,CAAA;AACT;;;;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"polyfillFetch.js","sources":["../../src/servers/polyfillFetch.ts"],"sourcesContent":["import type { MaybePromise } from '../asyncs/MaybePromise';\n\nexport function polyfillFetch(nodeFetch: typeof import('node-fetch')): boolean;\nexport function polyfillFetch(nodeFetch?: undefined): Promise<boolean>;\nexport function polyfillFetch(nodeFetch?: typeof import('node-fetch')): MaybePromise<boolean> {\n if ('fetch' in globalThis) {\n return false;\n }\n // sync mode\n if (nodeFetch) {\n const { default: fetch, Response, Headers, Request, AbortError, FetchError, FormData, Blob, File } = nodeFetch;\n Object.assign(globalThis, {\n fetch,\n Response,\n Headers,\n Request,\n AbortError,\n FetchError,\n FormData,\n Blob,\n File,\n });\n // abort controller\n return true;\n }\n return import('node-fetch').then((v) => polyfillFetch(v));\n}\n"],"names":[],"mappings":"AAIO,SAAS,cAAc,SAAgE,EAAA;AAC5F,EAAA,IAAI,WAAW,UAAY,EAAA;AACzB,IAAO,OAAA,KAAA,CAAA;AAAA,GACT;AAEA,EAAA,IAAI,SAAW,EAAA;AACb,IAAM,MAAA,EAAE,OAAS,EAAA,KAAA,EAAO,QAAU,EAAA,OAAA,EAAS,OAAS,EAAA,UAAA,EAAY,UAAY,EAAA,QAAA,EAAU,IAAM,EAAA,IAAA,EAAS,GAAA,SAAA,CAAA;AACrG,IAAA,MAAA,CAAO,OAAO,UAAY,EAAA;AAAA,MACxB,KAAA;AAAA,MACA,QAAA;AAAA,MACA,OAAA;AAAA,MACA,OAAA;AAAA,MACA,UAAA;AAAA,MACA,UAAA;AAAA,MACA,QAAA;AAAA,MACA,IAAA;AAAA,MACA,IAAA;AAAA,KACD,CAAA,CAAA;AAED,IAAO,OAAA,IAAA,CAAA;AAAA,GACT;AACA,EAAO,OAAA,OAAO,YAAY,CAAE,CAAA,IAAA,CAAK,CAAC,CAAM,KAAA,aAAA,CAAc,CAAC,CAAC,CAAA,CAAA;AAC1D;;;;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"polyfillJsDom.js","sources":["../../src/servers/polyfillJsDom.ts"],"sourcesContent":["import type { ConstructorOptions, ResourceLoaderConstructorOptions } from 'jsdom';\nimport { getGlobalThis } from '../isomorphics/getGlobalThis';\n\nexport async function polyfillJsDom() {\n if (typeof window !== 'undefined') {\n return false;\n }\n\n const globalThis = getGlobalThis();\n\n const { ResourceLoader, JSDOM } = await import('jsdom');\n\n // https://github.com/lukechilds/window/blob/master/src/index.js\n // eslint-disable-next-line @typescript-eslint/no-extraneous-class\n class Window {\n constructor(opts: ResourceLoaderConstructorOptions & ConstructorOptions = {}) {\n const { proxy, strictSSL, userAgent, ...jsdomOpts } = opts;\n const resources = new ResourceLoader({\n proxy,\n strictSSL,\n userAgent,\n });\n return new JSDOM(\n '',\n Object.assign(jsdomOpts, {\n resources,\n }),\n ).window;\n }\n }\n\n // https://github.com/lukechilds/browser-env/blob/master/src/index.js\n // Default jsdom config.\n // These settings must override any custom settings to make sure we can iterate\n // over the window object.\n const defaultJsdomConfig = {\n // features: {\n // FetchExternalResources: false,\n // ProcessExternalResources: false,\n // },\n };\n // IIFE executed on import to return an array of global Node.js properties that\n // conflict with global browser properties.\n const protectedProperties = (() =>\n Object.getOwnPropertyNames(new Window(defaultJsdomConfig)).filter(\n (prop) => typeof globalThis[prop as keyof typeof globalThis] !== 'undefined',\n ))();\n\n function installEnv(...args: any[]) {\n // Sets up global browser environment\n // Extract options from args\n const properties = args.filter((arg: any) => Array.isArray(arg))[0];\n const userJsdomConfig = args.filter((arg: any) => !Array.isArray(arg))[0];\n\n // Create window object\n const window = new Window(Object.assign({}, userJsdomConfig, defaultJsdomConfig));\n\n // Get all global browser properties\n Object.getOwnPropertyNames(window)\n\n // Remove protected properties\n .filter((prop) => !protectedProperties.includes(prop))\n\n // If we're only applying specific required properties remove everything else\n .filter((prop) => !(properties && properties.indexOf(prop) === -1))\n .filter((prop) => {\n switch (prop) {\n case 'undefined':\n return false;\n }\n return true;\n })\n\n // Copy what's left to the Node.js global scope\n .forEach((prop) => {\n // console.debug(`define globalThis.${prop}`);\n Object.defineProperty(globalThis, prop, {\n configurable: true,\n get: () => window[prop as keyof Window] as any,\n });\n });\n\n return window;\n }\n\n installEnv({ url: 'http://localhost' });\n return true;\n}\n"],"names":["window"],"mappings":";;AAGA,eAAsB,aAAgB,GAAA;AACpC,EAAI,IAAA,OAAO,WAAW,WAAa,EAAA;AACjC,IAAO,OAAA,KAAA,CAAA;AAAA,GACT;AAEA,EAAA,MAAM,aAAa,aAAc,EAAA,CAAA;AAEjC,EAAA,MAAM,EAAE,cAAgB,EAAA,KAAA,EAAU,GAAA,MAAM,OAAO,OAAO,CAAA,CAAA;AAItD,EAAA,MAAM,MAAO,CAAA;AAAA,IACX,WAAA,CAAY,IAA8D,GAAA,EAAI,EAAA;AAC5E,MAAA,MAAM,EAAE,KAAO,EAAA,SAAA,EAAW,SAAW,EAAA,GAAG,WAAc,GAAA,IAAA,CAAA;AACtD,MAAM,MAAA,SAAA,GAAY,IAAI,cAAe,CAAA;AAAA,QACnC,KAAA;AAAA,QACA,SAAA;AAAA,QACA,SAAA;AAAA,OACD,CAAA,CAAA;AACD,MAAA,OAAO,IAAI,KAAA;AAAA,QACT,EAAA;AAAA,QACA,MAAA,CAAO,OAAO,SAAW,EAAA;AAAA,UACvB,SAAA;AAAA,SACD,CAAA;AAAA,OACD,CAAA,MAAA,CAAA;AAAA,KACJ;AAAA,GACF;AAMA,EAAA,MAAM,kBAAqB,GAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAK3B,CAAA;AAGA,EAAM,MAAA,mBAAA,GAAA,CAAuB,MAC3B,MAAO,CAAA,mBAAA,CAAoB,IAAI,MAAO,CAAA,kBAAkB,CAAC,CAAE,CAAA,MAAA;AAAA,IACzD,CAAC,IAAA,KAAS,OAAO,UAAA,CAAW,IAA+B,CAAM,KAAA,WAAA;AAAA,GAChE,GAAA,CAAA;AAEL,EAAA,SAAS,cAAc,IAAa,EAAA;AAGlC,IAAM,MAAA,UAAA,GAAa,IAAK,CAAA,MAAA,CAAO,CAAC,GAAA,KAAa,MAAM,OAAQ,CAAA,GAAG,CAAC,CAAA,CAAE,CAAC,CAAA,CAAA;AAClE,IAAM,MAAA,eAAA,GAAkB,IAAK,CAAA,MAAA,CAAO,CAAC,GAAA,KAAa,CAAC,KAAA,CAAM,OAAQ,CAAA,GAAG,CAAC,CAAA,CAAE,CAAC,CAAA,CAAA;AAGxE,IAAMA,MAAAA,OAAAA,GAAS,IAAI,MAAO,CAAA,MAAA,CAAO,OAAO,EAAC,EAAG,eAAiB,EAAA,kBAAkB,CAAC,CAAA,CAAA;AAGhF,IAAO,MAAA,CAAA,mBAAA,CAAoBA,OAAM,CAAA,CAG9B,MAAO,CAAA,CAAC,SAAS,CAAC,mBAAA,CAAoB,QAAS,CAAA,IAAI,CAAC,CAAA,CAGpD,OAAO,CAAC,IAAA,KAAS,EAAE,UAAA,IAAc,UAAW,CAAA,OAAA,CAAQ,IAAI,CAAA,KAAM,CAAG,CAAA,CAAA,CAAA,CACjE,MAAO,CAAA,CAAC,IAAS,KAAA;AAChB,MAAA,QAAQ,IAAM;AAAA,QACZ,KAAK,WAAA;AACH,UAAO,OAAA,KAAA,CAAA;AAAA,OACX;AACA,MAAO,OAAA,IAAA,CAAA;AAAA,KACR,CAAA,CAGA,OAAQ,CAAA,CAAC,IAAS,KAAA;AAEjB,MAAO,MAAA,CAAA,cAAA,CAAe,YAAY,IAAM,EAAA;AAAA,QACtC,YAAc,EAAA,IAAA;AAAA,QACd,GAAA,EAAK,MAAMA,OAAAA,CAAO,IAAoB,CAAA;AAAA,OACvC,CAAA,CAAA;AAAA,KACF,CAAA,CAAA;AAEH,IAAOA,OAAAA,OAAAA,CAAAA;AAAA,GACT;AAEA,EAAW,UAAA,CAAA,EAAE,GAAK,EAAA,kBAAA,EAAoB,CAAA,CAAA;AACtC,EAAO,OAAA,IAAA,CAAA;AACT;;;;"}