@metamask/snaps-execution-environments 7.0.0 → 7.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +14 -1
- package/dist/browserify/iframe/bundle.js +5 -5
- package/dist/browserify/node-process/bundle.js +4 -4
- package/dist/browserify/node-thread/bundle.js +4 -4
- package/dist/browserify/webview/index.html +5 -5
- package/dist/browserify/worker-executor/bundle.js +5 -5
- package/dist/browserify/worker-pool/bundle.js +5 -5
- package/dist/common/BaseSnapExecutor.cjs +30 -3
- package/dist/common/BaseSnapExecutor.cjs.map +1 -1
- package/dist/common/BaseSnapExecutor.d.cts.map +1 -1
- package/dist/common/BaseSnapExecutor.d.mts.map +1 -1
- package/dist/common/BaseSnapExecutor.mjs +30 -3
- package/dist/common/BaseSnapExecutor.mjs.map +1 -1
- package/dist/common/endowments/commonEndowmentFactory.cjs +1 -1
- package/dist/common/endowments/commonEndowmentFactory.cjs.map +1 -1
- package/dist/common/endowments/commonEndowmentFactory.d.cts.map +1 -1
- package/dist/common/endowments/commonEndowmentFactory.d.mts.map +1 -1
- package/dist/common/endowments/commonEndowmentFactory.mjs +1 -1
- package/dist/common/endowments/commonEndowmentFactory.mjs.map +1 -1
- package/dist/common/endowments/console.cjs.map +1 -1
- package/dist/common/endowments/console.d.cts.map +1 -1
- package/dist/common/endowments/console.d.mts.map +1 -1
- package/dist/common/endowments/console.mjs.map +1 -1
- package/dist/common/endowments/crypto.cjs +1 -1
- package/dist/common/endowments/crypto.cjs.map +1 -1
- package/dist/common/endowments/crypto.mjs +1 -1
- package/dist/common/endowments/crypto.mjs.map +1 -1
- package/dist/common/endowments/index.cjs +2 -2
- package/dist/common/endowments/index.cjs.map +1 -1
- package/dist/common/endowments/index.d.cts.map +1 -1
- package/dist/common/endowments/index.d.mts.map +1 -1
- package/dist/common/endowments/index.mjs +2 -2
- package/dist/common/endowments/index.mjs.map +1 -1
- package/dist/common/endowments/math.cjs +1 -1
- package/dist/common/endowments/math.cjs.map +1 -1
- package/dist/common/endowments/math.mjs +1 -1
- package/dist/common/endowments/math.mjs.map +1 -1
- package/dist/common/endowments/network.cjs.map +1 -1
- package/dist/common/endowments/network.d.cts.map +1 -1
- package/dist/common/endowments/network.d.mts.map +1 -1
- package/dist/common/endowments/network.mjs.map +1 -1
- package/dist/common/globalObject.cjs +2 -1
- package/dist/common/globalObject.cjs.map +1 -1
- package/dist/common/globalObject.d.cts.map +1 -1
- package/dist/common/globalObject.d.mts.map +1 -1
- package/dist/common/globalObject.mjs +2 -1
- package/dist/common/globalObject.mjs.map +1 -1
- package/dist/common/validation.cjs +2 -0
- package/dist/common/validation.cjs.map +1 -1
- package/dist/common/validation.d.cts +18 -2
- package/dist/common/validation.d.cts.map +1 -1
- package/dist/common/validation.d.mts +18 -2
- package/dist/common/validation.d.mts.map +1 -1
- package/dist/common/validation.mjs +2 -0
- package/dist/common/validation.mjs.map +1 -1
- package/dist/iframe/index.cjs +1 -1
- package/dist/iframe/index.cjs.map +1 -1
- package/dist/iframe/index.mjs +1 -1
- package/dist/iframe/index.mjs.map +1 -1
- package/dist/node-process/index.cjs +1 -1
- package/dist/node-process/index.cjs.map +1 -1
- package/dist/node-process/index.mjs +1 -1
- package/dist/node-process/index.mjs.map +1 -1
- package/dist/node-thread/index.cjs +1 -1
- package/dist/node-thread/index.cjs.map +1 -1
- package/dist/node-thread/index.mjs +1 -1
- package/dist/node-thread/index.mjs.map +1 -1
- package/dist/proxy/ProxySnapExecutor.cjs +1 -2
- package/dist/proxy/ProxySnapExecutor.cjs.map +1 -1
- package/dist/proxy/ProxySnapExecutor.mjs +1 -2
- package/dist/proxy/ProxySnapExecutor.mjs.map +1 -1
- package/dist/webview/WebViewExecutorStream.cjs +3 -0
- package/dist/webview/WebViewExecutorStream.cjs.map +1 -1
- package/dist/webview/WebViewExecutorStream.d.cts.map +1 -1
- package/dist/webview/WebViewExecutorStream.d.mts.map +1 -1
- package/dist/webview/WebViewExecutorStream.mjs +3 -0
- package/dist/webview/WebViewExecutorStream.mjs.map +1 -1
- package/dist/webview/index.cjs +1 -1
- package/dist/webview/index.cjs.map +1 -1
- package/dist/webview/index.mjs +1 -1
- package/dist/webview/index.mjs.map +1 -1
- package/dist/webworker/executor/index.cjs +1 -1
- package/dist/webworker/executor/index.cjs.map +1 -1
- package/dist/webworker/executor/index.mjs +1 -1
- package/dist/webworker/executor/index.mjs.map +1 -1
- package/dist/webworker/pool/index.cjs +1 -1
- package/dist/webworker/pool/index.cjs.map +1 -1
- package/dist/webworker/pool/index.mjs +1 -1
- package/dist/webworker/pool/index.mjs.map +1 -1
- package/package.json +12 -26
|
@@ -11,10 +11,9 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
11
11
|
};
|
|
12
12
|
var _ProxySnapExecutor_instances, _ProxySnapExecutor_stream, _ProxySnapExecutor_frameUrl, _ProxySnapExecutor_onData, _ProxySnapExecutor_initializeJob, _ProxySnapExecutor_terminateJob;
|
|
13
13
|
import { WindowPostMessageStream } from "@metamask/post-message-stream";
|
|
14
|
-
// eslint-disable-next-line import/no-extraneous-dependencies
|
|
15
|
-
import packageJson from "@metamask/snaps-execution-environments/package.json" with { type: "json" };
|
|
16
14
|
import { createWindow, logError } from "@metamask/snaps-utils";
|
|
17
15
|
import { assert } from "@metamask/utils";
|
|
16
|
+
import packageJson from "@metamask/snaps-execution-environments/package.json" with { type: "json" };
|
|
18
17
|
const IFRAME_URL = `https://execution.metamask.io/iframe/${packageJson.version}/index.html`;
|
|
19
18
|
/**
|
|
20
19
|
* A "proxy" snap executor that uses a level of indirection to execute snaps.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProxySnapExecutor.mjs","sourceRoot":"","sources":["../../src/proxy/ProxySnapExecutor.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,OAAO,EAAE,uBAAuB,EAAE,sCAAsC;AACxE,
|
|
1
|
+
{"version":3,"file":"ProxySnapExecutor.mjs","sourceRoot":"","sources":["../../src/proxy/ProxySnapExecutor.ts"],"names":[],"mappings":"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","sourcesContent":["import type { BasePostMessageStream } from '@metamask/post-message-stream';\nimport { WindowPostMessageStream } from '@metamask/post-message-stream';\nimport { createWindow, logError } from '@metamask/snaps-utils';\nimport type { JsonRpcRequest } from '@metamask/utils';\nimport { assert } from '@metamask/utils';\n\nimport packageJson from '@metamask/snaps-execution-environments/package.json';\n\ntype ExecutorJob = {\n id: string;\n window: Window;\n stream: WindowPostMessageStream;\n};\n\nconst IFRAME_URL = `https://execution.metamask.io/iframe/${packageJson.version}/index.html`;\n\n/**\n * A \"proxy\" snap executor that uses a level of indirection to execute snaps.\n *\n * Useful for multiple execution environments.\n *\n * This is not a traditional snap executor, as it does not execute snaps itself.\n * Instead, it creates an iframe window for each snap execution, and sends the\n * snap execution request to the iframe window. The iframe window is responsible\n * for executing the snap.\n *\n * This executor is persisted between snap executions. The executor essentially\n * acts as a proxy between the client and the iframe execution environment.\n */\nexport class ProxySnapExecutor {\n readonly #stream: BasePostMessageStream;\n\n readonly #frameUrl: string;\n\n readonly jobs: Record<string, ExecutorJob> = {};\n\n /**\n * Initialize the executor with the given stream. This is a wrapper around the\n * constructor.\n *\n * @param stream - The stream to use for communication.\n * @param frameUrl - An optional URL for the iframe to use.\n * @returns The initialized executor.\n */\n static initialize(stream: BasePostMessageStream, frameUrl = IFRAME_URL) {\n return new ProxySnapExecutor(stream, frameUrl);\n }\n\n constructor(stream: BasePostMessageStream, frameUrl: string) {\n this.#stream = stream;\n this.#stream.on('data', this.#onData.bind(this));\n this.#frameUrl = frameUrl;\n }\n\n /**\n * Handle an incoming message from a `ProxyExecutionService`. This\n * assumes that the message contains a `jobId` property, and a JSON-RPC\n * request in the `data` property.\n *\n * @param data - The message data.\n * @param data.data - The JSON-RPC request.\n * @param data.jobId - The job ID.\n */\n #onData(data: { data: JsonRpcRequest; jobId: string }) {\n const { jobId, data: request } = data;\n\n if (!this.jobs[jobId]) {\n // This ensures that a job is initialized before it is used. To avoid\n // code duplication, we call the `#onData` method again, which will\n // run the rest of the logic after initialization.\n this.#initializeJob(jobId)\n .then(() => {\n this.#onData(data);\n })\n .catch((error) => {\n logError('[Worker] Error initializing job:', error);\n });\n\n return;\n }\n\n // This is a method specific to the `OffscreenSnapExecutor`, as the service\n // itself does not have access to the iframes directly.\n if (request.method === 'terminateJob') {\n this.#terminateJob(jobId);\n return;\n }\n\n this.jobs[jobId].stream.write(request);\n }\n\n /**\n * Create a new iframe and set up a stream to communicate with it.\n *\n * @param jobId - The job ID.\n * @returns The executor job object.\n */\n async #initializeJob(jobId: string): Promise<ExecutorJob> {\n const window = await createWindow({ uri: this.#frameUrl, id: jobId });\n const jobStream = new WindowPostMessageStream({\n name: 'parent',\n target: 'child',\n targetWindow: window, // iframe's internal window\n targetOrigin: '*',\n });\n\n // Write messages from the iframe to the parent, wrapped with the job ID.\n jobStream.on('data', (data) => {\n this.#stream.write({ data, jobId });\n });\n\n this.jobs[jobId] = { id: jobId, window, stream: jobStream };\n return this.jobs[jobId];\n }\n\n /**\n * Terminate the job with the given ID. This will close the iframe and delete\n * the job from the internal job map.\n *\n * @param jobId - The job ID.\n */\n #terminateJob(jobId: string) {\n assert(this.jobs[jobId], `Job \"${jobId}\" not found.`);\n\n const iframe = document.getElementById(jobId);\n assert(iframe, `Iframe with ID \"${jobId}\" not found.`);\n\n iframe.remove();\n this.jobs[jobId].stream.destroy();\n delete this.jobs[jobId];\n }\n}\n"]}
|
|
@@ -55,6 +55,9 @@ class WebViewExecutorStream extends post_message_stream_1.BasePostMessageStream
|
|
|
55
55
|
data,
|
|
56
56
|
}));
|
|
57
57
|
}
|
|
58
|
+
// TODO: Either fix this lint violation or explain why it's necessary to
|
|
59
|
+
// ignore.
|
|
60
|
+
// eslint-disable-next-line no-restricted-syntax
|
|
58
61
|
_onMessage(event) {
|
|
59
62
|
if (!Array.isArray(event.data)) {
|
|
60
63
|
return;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WebViewExecutorStream.cjs","sourceRoot":"","sources":["../../src/webview/WebViewExecutorStream.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,uEAAsE;AACtE,uEAAgF;AAChF,2CAAgD;AAQhD,MAAa,qBAAsB,SAAQ,2CAAqB;IAO9D;;;;;;;;;;;;;OAaG;IAEH,YAAY,EAAE,IAAI,EAAE,MAAM,EAAE,YAAY,EAA6B;QACnE,KAAK,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"WebViewExecutorStream.cjs","sourceRoot":"","sources":["../../src/webview/WebViewExecutorStream.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,uEAAsE;AACtE,uEAAgF;AAChF,2CAAgD;AAQhD,MAAa,qBAAsB,SAAQ,2CAAqB;IAO9D;;;;;;;;;;;;;OAaG;IAEH,YAAY,EAAE,IAAI,EAAE,MAAM,EAAE,YAAY,EAA6B;QACnE,KAAK,EAAE,CAAC;QAtBD,8CAAM;QAEN,gDAAQ;QAER,sDAAc;QAoBrB,uBAAA,IAAI,+BAAS,IAAI,MAAA,CAAC;QAClB,uBAAA,IAAI,iCAAW,MAAM,MAAA,CAAC;QACtB,uBAAA,IAAI,uCAAiB,YAAY,MAAA,CAAC;QAElC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE7C,gCAAgC;QAChC,6DAA6D;QAC7D,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,UAAiB,EAAE,KAAK,CAAC,CAAC;QAElE,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED;;;OAGG;IAEO,YAAY,CAAC,IAAa;QAClC,uBAAA,IAAI,2CAAc,CAAC,WAAW,CAC5B,IAAI,CAAC,SAAS,CAAC;YACb,MAAM,EAAE,uBAAA,IAAI,qCAAQ;YACpB,IAAI;SACL,CAAC,CACH,CAAC;IACJ,CAAC;IAED,wEAAwE;IACxE,WAAW;IACX,gDAAgD;IACxC,UAAU,CAAC,KAAuB;QACxC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;YAC/B,OAAO;QACT,CAAC;QAED,MAAM,IAAI,GAAG,IAAA,qBAAa,EAAC,IAAI,UAAU,CAAC,KAAK,CAAC,IAAgB,CAAC,CAAC,CAAC;QACnE,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAEjC,gEAAgE;QAChE,0CAA0C;QAC1C,IAAI,CAAC,IAAA,4BAAoB,EAAC,OAAO,CAAC,IAAI,OAAO,CAAC,MAAM,KAAK,uBAAA,IAAI,mCAAM,EAAE,CAAC;YACpE,OAAO;QACT,CAAC;QAED,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED,QAAQ;QACN,gCAAgC;QAChC,6DAA6D;QAC7D,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,UAAiB,EAAE,KAAK,CAAC,CAAC;IACvE,CAAC;CACF;AA7ED,sDA6EC","sourcesContent":["import type { PostMessageEvent } from '@metamask/post-message-stream';\nimport { BasePostMessageStream } from '@metamask/post-message-stream';\nimport { isValidStreamMessage } from '@metamask/post-message-stream/dist/utils';\nimport { bytesToString } from '@metamask/utils';\n\ntype WebViewExecutorStreamArgs = {\n name: string;\n target: string;\n targetWindow: Window['ReactNativeWebView'];\n};\n\nexport class WebViewExecutorStream extends BasePostMessageStream {\n readonly #name;\n\n readonly #target;\n\n readonly #targetWindow;\n\n /**\n * A special post-message-stream to be used by the WebView executor.\n *\n * This stream is different in a few ways:\n * - It expects data to be base64 encoded\n * - It stringifies the data it posts\n * - It does less validation of origins\n *\n * @param args - Options bag.\n * @param args.name - The name of the stream. Used to differentiate between\n * multiple streams sharing the same window object. child:WebView\n * @param args.target - The name of the stream to exchange messages with. parent:rnside\n * @param args.targetWindow - The window object of the target stream.\n */\n\n constructor({ name, target, targetWindow }: WebViewExecutorStreamArgs) {\n super();\n\n this.#name = name;\n this.#target = target;\n this.#targetWindow = targetWindow;\n\n this._onMessage = this._onMessage.bind(this);\n\n // This method is already bound.\n // eslint-disable-next-line @typescript-eslint/unbound-method\n window.addEventListener('message', this._onMessage as any, false);\n\n this._handshake();\n }\n\n /**\n * Webview needs to receive strings only on postMessage. That's the main difference between this and the original window post message stream.\n * Reference: https://github.com/react-native-webview/react-native-webview/blob/master/docs/Guide.md?plain=1#L471\n */\n\n protected _postMessage(data: unknown): void {\n this.#targetWindow.postMessage(\n JSON.stringify({\n target: this.#target,\n data,\n }),\n );\n }\n\n // TODO: Either fix this lint violation or explain why it's necessary to\n // ignore.\n // eslint-disable-next-line no-restricted-syntax\n private _onMessage(event: PostMessageEvent): void {\n if (!Array.isArray(event.data)) {\n return;\n }\n\n const json = bytesToString(new Uint8Array(event.data as number[]));\n const message = JSON.parse(json);\n\n // Notice that we don't check targetWindow or targetOrigin here.\n // This doesn't seem possible to do in RN.\n if (!isValidStreamMessage(message) || message.target !== this.#name) {\n return;\n }\n\n this._onData(message.data);\n }\n\n _destroy() {\n // This method is already bound.\n // eslint-disable-next-line @typescript-eslint/unbound-method\n window.removeEventListener('message', this._onMessage as any, false);\n }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WebViewExecutorStream.d.cts","sourceRoot":"","sources":["../../src/webview/WebViewExecutorStream.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,sCAAsC;AAItE,KAAK,yBAAyB,GAAG;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,YAAY,EAAE,MAAM,CAAC,oBAAoB,CAAC,CAAC;CAC5C,CAAC;AAEF,qBAAa,qBAAsB,SAAQ,qBAAqB;;IAO9D;;;;;;;;;;;;;OAaG;gBAES,EAAE,IAAI,EAAE,MAAM,EAAE,YAAY,EAAE,EAAE,yBAAyB;IAgBrE;;;OAGG;IAEH,SAAS,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI;
|
|
1
|
+
{"version":3,"file":"WebViewExecutorStream.d.cts","sourceRoot":"","sources":["../../src/webview/WebViewExecutorStream.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,sCAAsC;AAItE,KAAK,yBAAyB,GAAG;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,YAAY,EAAE,MAAM,CAAC,oBAAoB,CAAC,CAAC;CAC5C,CAAC;AAEF,qBAAa,qBAAsB,SAAQ,qBAAqB;;IAO9D;;;;;;;;;;;;;OAaG;gBAES,EAAE,IAAI,EAAE,MAAM,EAAE,YAAY,EAAE,EAAE,yBAAyB;IAgBrE;;;OAGG;IAEH,SAAS,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI;IAY3C,OAAO,CAAC,UAAU;IAiBlB,QAAQ;CAKT"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WebViewExecutorStream.d.mts","sourceRoot":"","sources":["../../src/webview/WebViewExecutorStream.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,sCAAsC;AAItE,KAAK,yBAAyB,GAAG;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,YAAY,EAAE,MAAM,CAAC,oBAAoB,CAAC,CAAC;CAC5C,CAAC;AAEF,qBAAa,qBAAsB,SAAQ,qBAAqB;;IAO9D;;;;;;;;;;;;;OAaG;gBAES,EAAE,IAAI,EAAE,MAAM,EAAE,YAAY,EAAE,EAAE,yBAAyB;IAgBrE;;;OAGG;IAEH,SAAS,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI;
|
|
1
|
+
{"version":3,"file":"WebViewExecutorStream.d.mts","sourceRoot":"","sources":["../../src/webview/WebViewExecutorStream.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,sCAAsC;AAItE,KAAK,yBAAyB,GAAG;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,YAAY,EAAE,MAAM,CAAC,oBAAoB,CAAC,CAAC;CAC5C,CAAC;AAEF,qBAAa,qBAAsB,SAAQ,qBAAqB;;IAO9D;;;;;;;;;;;;;OAaG;gBAES,EAAE,IAAI,EAAE,MAAM,EAAE,YAAY,EAAE,EAAE,yBAAyB;IAgBrE;;;OAGG;IAEH,SAAS,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI;IAY3C,OAAO,CAAC,UAAU;IAiBlB,QAAQ;CAKT"}
|
|
@@ -52,6 +52,9 @@ export class WebViewExecutorStream extends BasePostMessageStream {
|
|
|
52
52
|
data,
|
|
53
53
|
}));
|
|
54
54
|
}
|
|
55
|
+
// TODO: Either fix this lint violation or explain why it's necessary to
|
|
56
|
+
// ignore.
|
|
57
|
+
// eslint-disable-next-line no-restricted-syntax
|
|
55
58
|
_onMessage(event) {
|
|
56
59
|
if (!Array.isArray(event.data)) {
|
|
57
60
|
return;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WebViewExecutorStream.mjs","sourceRoot":"","sources":["../../src/webview/WebViewExecutorStream.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,OAAO,EAAE,qBAAqB,EAAE,sCAAsC;AACtE,OAAO,EAAE,oBAAoB,EAAE,oDAAiD;AAChF,OAAO,EAAE,aAAa,EAAE,wBAAwB;AAQhD,MAAM,OAAO,qBAAsB,SAAQ,qBAAqB;IAO9D;;;;;;;;;;;;;OAaG;IAEH,YAAY,EAAE,IAAI,EAAE,MAAM,EAAE,YAAY,EAA6B;QACnE,KAAK,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"WebViewExecutorStream.mjs","sourceRoot":"","sources":["../../src/webview/WebViewExecutorStream.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,OAAO,EAAE,qBAAqB,EAAE,sCAAsC;AACtE,OAAO,EAAE,oBAAoB,EAAE,oDAAiD;AAChF,OAAO,EAAE,aAAa,EAAE,wBAAwB;AAQhD,MAAM,OAAO,qBAAsB,SAAQ,qBAAqB;IAO9D;;;;;;;;;;;;;OAaG;IAEH,YAAY,EAAE,IAAI,EAAE,MAAM,EAAE,YAAY,EAA6B;QACnE,KAAK,EAAE,CAAC;QAtBD,8CAAM;QAEN,gDAAQ;QAER,sDAAc;QAoBrB,uBAAA,IAAI,+BAAS,IAAI,MAAA,CAAC;QAClB,uBAAA,IAAI,iCAAW,MAAM,MAAA,CAAC;QACtB,uBAAA,IAAI,uCAAiB,YAAY,MAAA,CAAC;QAElC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE7C,gCAAgC;QAChC,6DAA6D;QAC7D,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,UAAiB,EAAE,KAAK,CAAC,CAAC;QAElE,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED;;;OAGG;IAEO,YAAY,CAAC,IAAa;QAClC,uBAAA,IAAI,2CAAc,CAAC,WAAW,CAC5B,IAAI,CAAC,SAAS,CAAC;YACb,MAAM,EAAE,uBAAA,IAAI,qCAAQ;YACpB,IAAI;SACL,CAAC,CACH,CAAC;IACJ,CAAC;IAED,wEAAwE;IACxE,WAAW;IACX,gDAAgD;IACxC,UAAU,CAAC,KAAuB;QACxC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;YAC/B,OAAO;QACT,CAAC;QAED,MAAM,IAAI,GAAG,aAAa,CAAC,IAAI,UAAU,CAAC,KAAK,CAAC,IAAgB,CAAC,CAAC,CAAC;QACnE,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAEjC,gEAAgE;QAChE,0CAA0C;QAC1C,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC,MAAM,KAAK,uBAAA,IAAI,mCAAM,EAAE,CAAC;YACpE,OAAO;QACT,CAAC;QAED,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED,QAAQ;QACN,gCAAgC;QAChC,6DAA6D;QAC7D,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,UAAiB,EAAE,KAAK,CAAC,CAAC;IACvE,CAAC;CACF","sourcesContent":["import type { PostMessageEvent } from '@metamask/post-message-stream';\nimport { BasePostMessageStream } from '@metamask/post-message-stream';\nimport { isValidStreamMessage } from '@metamask/post-message-stream/dist/utils';\nimport { bytesToString } from '@metamask/utils';\n\ntype WebViewExecutorStreamArgs = {\n name: string;\n target: string;\n targetWindow: Window['ReactNativeWebView'];\n};\n\nexport class WebViewExecutorStream extends BasePostMessageStream {\n readonly #name;\n\n readonly #target;\n\n readonly #targetWindow;\n\n /**\n * A special post-message-stream to be used by the WebView executor.\n *\n * This stream is different in a few ways:\n * - It expects data to be base64 encoded\n * - It stringifies the data it posts\n * - It does less validation of origins\n *\n * @param args - Options bag.\n * @param args.name - The name of the stream. Used to differentiate between\n * multiple streams sharing the same window object. child:WebView\n * @param args.target - The name of the stream to exchange messages with. parent:rnside\n * @param args.targetWindow - The window object of the target stream.\n */\n\n constructor({ name, target, targetWindow }: WebViewExecutorStreamArgs) {\n super();\n\n this.#name = name;\n this.#target = target;\n this.#targetWindow = targetWindow;\n\n this._onMessage = this._onMessage.bind(this);\n\n // This method is already bound.\n // eslint-disable-next-line @typescript-eslint/unbound-method\n window.addEventListener('message', this._onMessage as any, false);\n\n this._handshake();\n }\n\n /**\n * Webview needs to receive strings only on postMessage. That's the main difference between this and the original window post message stream.\n * Reference: https://github.com/react-native-webview/react-native-webview/blob/master/docs/Guide.md?plain=1#L471\n */\n\n protected _postMessage(data: unknown): void {\n this.#targetWindow.postMessage(\n JSON.stringify({\n target: this.#target,\n data,\n }),\n );\n }\n\n // TODO: Either fix this lint violation or explain why it's necessary to\n // ignore.\n // eslint-disable-next-line no-restricted-syntax\n private _onMessage(event: PostMessageEvent): void {\n if (!Array.isArray(event.data)) {\n return;\n }\n\n const json = bytesToString(new Uint8Array(event.data as number[]));\n const message = JSON.parse(json);\n\n // Notice that we don't check targetWindow or targetOrigin here.\n // This doesn't seem possible to do in RN.\n if (!isValidStreamMessage(message) || message.target !== this.#name) {\n return;\n }\n\n this._onData(message.data);\n }\n\n _destroy() {\n // This method is already bound.\n // eslint-disable-next-line @typescript-eslint/unbound-method\n window.removeEventListener('message', this._onMessage as any, false);\n }\n}\n"]}
|
package/dist/webview/index.cjs
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const WebViewExecutorStream_1 = require("./WebViewExecutorStream.cjs");
|
|
3
4
|
const lockdown_events_1 = require("../common/lockdown/lockdown-events.cjs");
|
|
4
5
|
const lockdown_more_1 = require("../common/lockdown/lockdown-more.cjs");
|
|
5
6
|
const IFrameSnapExecutor_1 = require("../iframe/IFrameSnapExecutor.cjs");
|
|
6
|
-
const WebViewExecutorStream_1 = require("./WebViewExecutorStream.cjs");
|
|
7
7
|
// Lockdown is already applied in LavaMoat
|
|
8
8
|
(0, lockdown_more_1.executeLockdownMore)();
|
|
9
9
|
(0, lockdown_events_1.executeLockdownEvents)();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","sourceRoot":"","sources":["../../src/webview/index.ts"],"names":[],"mappings":";;AAAA,4EAA2E;AAC3E,wEAAuE;AACvE,yEAAkE;
|
|
1
|
+
{"version":3,"file":"index.cjs","sourceRoot":"","sources":["../../src/webview/index.ts"],"names":[],"mappings":";;AAAA,uEAAgE;AAChE,4EAA2E;AAC3E,wEAAuE;AACvE,yEAAkE;AAElE,0CAA0C;AAC1C,IAAA,mCAAmB,GAAE,CAAC;AACtB,IAAA,uCAAqB,GAAE,CAAC;AAExB,MAAM,YAAY,GAAG,IAAI,6CAAqB,CAAC;IAC7C,IAAI,EAAE,OAAO,EAAE,UAAU;IACzB,MAAM,EAAE,QAAQ,EAAE,SAAS;IAC3B,YAAY,EAAE,MAAM,CAAC,kBAAkB;CACxC,CAAC,CAAC;AAEH,uCAAkB,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC","sourcesContent":["import { WebViewExecutorStream } from './WebViewExecutorStream';\nimport { executeLockdownEvents } from '../common/lockdown/lockdown-events';\nimport { executeLockdownMore } from '../common/lockdown/lockdown-more';\nimport { IFrameSnapExecutor } from '../iframe/IFrameSnapExecutor';\n\n// Lockdown is already applied in LavaMoat\nexecuteLockdownMore();\nexecuteLockdownEvents();\n\nconst parentStream = new WebViewExecutorStream({\n name: 'child', // webview\n target: 'parent', // rnside\n targetWindow: window.ReactNativeWebView,\n});\n\nIFrameSnapExecutor.initialize(parentStream);\n"]}
|
package/dist/webview/index.mjs
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
+
import { WebViewExecutorStream } from "./WebViewExecutorStream.mjs";
|
|
1
2
|
import { executeLockdownEvents } from "../common/lockdown/lockdown-events.mjs";
|
|
2
3
|
import { executeLockdownMore } from "../common/lockdown/lockdown-more.mjs";
|
|
3
4
|
import { IFrameSnapExecutor } from "../iframe/IFrameSnapExecutor.mjs";
|
|
4
|
-
import { WebViewExecutorStream } from "./WebViewExecutorStream.mjs";
|
|
5
5
|
// Lockdown is already applied in LavaMoat
|
|
6
6
|
executeLockdownMore();
|
|
7
7
|
executeLockdownEvents();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sourceRoot":"","sources":["../../src/webview/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,+CAA2C;AAC3E,OAAO,EAAE,mBAAmB,EAAE,6CAAyC;AACvE,OAAO,EAAE,kBAAkB,EAAE,yCAAqC;
|
|
1
|
+
{"version":3,"file":"index.mjs","sourceRoot":"","sources":["../../src/webview/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,oCAAgC;AAChE,OAAO,EAAE,qBAAqB,EAAE,+CAA2C;AAC3E,OAAO,EAAE,mBAAmB,EAAE,6CAAyC;AACvE,OAAO,EAAE,kBAAkB,EAAE,yCAAqC;AAElE,0CAA0C;AAC1C,mBAAmB,EAAE,CAAC;AACtB,qBAAqB,EAAE,CAAC;AAExB,MAAM,YAAY,GAAG,IAAI,qBAAqB,CAAC;IAC7C,IAAI,EAAE,OAAO,EAAE,UAAU;IACzB,MAAM,EAAE,QAAQ,EAAE,SAAS;IAC3B,YAAY,EAAE,MAAM,CAAC,kBAAkB;CACxC,CAAC,CAAC;AAEH,kBAAkB,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC","sourcesContent":["import { WebViewExecutorStream } from './WebViewExecutorStream';\nimport { executeLockdownEvents } from '../common/lockdown/lockdown-events';\nimport { executeLockdownMore } from '../common/lockdown/lockdown-more';\nimport { IFrameSnapExecutor } from '../iframe/IFrameSnapExecutor';\n\n// Lockdown is already applied in LavaMoat\nexecuteLockdownMore();\nexecuteLockdownEvents();\n\nconst parentStream = new WebViewExecutorStream({\n name: 'child', // webview\n target: 'parent', // rnside\n targetWindow: window.ReactNativeWebView,\n});\n\nIFrameSnapExecutor.initialize(parentStream);\n"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const WebWorkerSnapExecutor_1 = require("./WebWorkerSnapExecutor.cjs");
|
|
3
4
|
const lockdown_events_1 = require("../../common/lockdown/lockdown-events.cjs");
|
|
4
5
|
const lockdown_more_1 = require("../../common/lockdown/lockdown-more.cjs");
|
|
5
|
-
const WebWorkerSnapExecutor_1 = require("./WebWorkerSnapExecutor.cjs");
|
|
6
6
|
// Lockdown is already applied in LavaMoat
|
|
7
7
|
(0, lockdown_more_1.executeLockdownMore)();
|
|
8
8
|
(0, lockdown_events_1.executeLockdownEvents)();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","sourceRoot":"","sources":["../../../src/webworker/executor/index.ts"],"names":[],"mappings":";;AAAA,+EAA8E;AAC9E,2EAA0E;
|
|
1
|
+
{"version":3,"file":"index.cjs","sourceRoot":"","sources":["../../../src/webworker/executor/index.ts"],"names":[],"mappings":";;AAAA,uEAAgE;AAChE,+EAA8E;AAC9E,2EAA0E;AAE1E,0CAA0C;AAC1C,IAAA,mCAAmB,GAAE,CAAC;AACtB,IAAA,uCAAqB,GAAE,CAAC;AAExB,6CAAqB,CAAC,UAAU,EAAE,CAAC","sourcesContent":["import { WebWorkerSnapExecutor } from './WebWorkerSnapExecutor';\nimport { executeLockdownEvents } from '../../common/lockdown/lockdown-events';\nimport { executeLockdownMore } from '../../common/lockdown/lockdown-more';\n\n// Lockdown is already applied in LavaMoat\nexecuteLockdownMore();\nexecuteLockdownEvents();\n\nWebWorkerSnapExecutor.initialize();\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
+
import { WebWorkerSnapExecutor } from "./WebWorkerSnapExecutor.mjs";
|
|
1
2
|
import { executeLockdownEvents } from "../../common/lockdown/lockdown-events.mjs";
|
|
2
3
|
import { executeLockdownMore } from "../../common/lockdown/lockdown-more.mjs";
|
|
3
|
-
import { WebWorkerSnapExecutor } from "./WebWorkerSnapExecutor.mjs";
|
|
4
4
|
// Lockdown is already applied in LavaMoat
|
|
5
5
|
executeLockdownMore();
|
|
6
6
|
executeLockdownEvents();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sourceRoot":"","sources":["../../../src/webworker/executor/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,
|
|
1
|
+
{"version":3,"file":"index.mjs","sourceRoot":"","sources":["../../../src/webworker/executor/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,oCAAgC;AAChE,OAAO,EAAE,qBAAqB,EAAE,kDAA8C;AAC9E,OAAO,EAAE,mBAAmB,EAAE,gDAA4C;AAE1E,0CAA0C;AAC1C,mBAAmB,EAAE,CAAC;AACtB,qBAAqB,EAAE,CAAC;AAExB,qBAAqB,CAAC,UAAU,EAAE,CAAC","sourcesContent":["import { WebWorkerSnapExecutor } from './WebWorkerSnapExecutor';\nimport { executeLockdownEvents } from '../../common/lockdown/lockdown-events';\nimport { executeLockdownMore } from '../../common/lockdown/lockdown-more';\n\n// Lockdown is already applied in LavaMoat\nexecuteLockdownMore();\nexecuteLockdownEvents();\n\nWebWorkerSnapExecutor.initialize();\n"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const WebWorkerPool_1 = require("./WebWorkerPool.cjs");
|
|
3
4
|
const lockdown_events_1 = require("../../common/lockdown/lockdown-events.cjs");
|
|
4
5
|
const lockdown_more_1 = require("../../common/lockdown/lockdown-more.cjs");
|
|
5
|
-
const WebWorkerPool_1 = require("./WebWorkerPool.cjs");
|
|
6
6
|
// Lockdown is already applied in LavaMoat
|
|
7
7
|
(0, lockdown_more_1.executeLockdownMore)();
|
|
8
8
|
(0, lockdown_events_1.executeLockdownEvents)();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","sourceRoot":"","sources":["../../../src/webworker/pool/index.ts"],"names":[],"mappings":";;AAAA,+EAA8E;AAC9E,2EAA0E;
|
|
1
|
+
{"version":3,"file":"index.cjs","sourceRoot":"","sources":["../../../src/webworker/pool/index.ts"],"names":[],"mappings":";;AAAA,uDAAgD;AAChD,+EAA8E;AAC9E,2EAA0E;AAE1E,0CAA0C;AAC1C,IAAA,mCAAmB,GAAE,CAAC;AACtB,IAAA,uCAAqB,GAAE,CAAC;AAExB,6BAAa,CAAC,UAAU,EAAE,CAAC","sourcesContent":["import { WebWorkerPool } from './WebWorkerPool';\nimport { executeLockdownEvents } from '../../common/lockdown/lockdown-events';\nimport { executeLockdownMore } from '../../common/lockdown/lockdown-more';\n\n// Lockdown is already applied in LavaMoat\nexecuteLockdownMore();\nexecuteLockdownEvents();\n\nWebWorkerPool.initialize();\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
+
import { WebWorkerPool } from "./WebWorkerPool.mjs";
|
|
1
2
|
import { executeLockdownEvents } from "../../common/lockdown/lockdown-events.mjs";
|
|
2
3
|
import { executeLockdownMore } from "../../common/lockdown/lockdown-more.mjs";
|
|
3
|
-
import { WebWorkerPool } from "./WebWorkerPool.mjs";
|
|
4
4
|
// Lockdown is already applied in LavaMoat
|
|
5
5
|
executeLockdownMore();
|
|
6
6
|
executeLockdownEvents();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sourceRoot":"","sources":["../../../src/webworker/pool/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.mjs","sourceRoot":"","sources":["../../../src/webworker/pool/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,4BAAwB;AAChD,OAAO,EAAE,qBAAqB,EAAE,kDAA8C;AAC9E,OAAO,EAAE,mBAAmB,EAAE,gDAA4C;AAE1E,0CAA0C;AAC1C,mBAAmB,EAAE,CAAC;AACtB,qBAAqB,EAAE,CAAC;AAExB,aAAa,CAAC,UAAU,EAAE,CAAC","sourcesContent":["import { WebWorkerPool } from './WebWorkerPool';\nimport { executeLockdownEvents } from '../../common/lockdown/lockdown-events';\nimport { executeLockdownMore } from '../../common/lockdown/lockdown-more';\n\n// Lockdown is already applied in LavaMoat\nexecuteLockdownMore();\nexecuteLockdownEvents();\n\nWebWorkerPool.initialize();\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@metamask/snaps-execution-environments",
|
|
3
|
-
"version": "7.
|
|
3
|
+
"version": "7.1.0",
|
|
4
4
|
"description": "Snap sandbox environments for executing SES javascript",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"MetaMask",
|
|
@@ -50,9 +50,9 @@
|
|
|
50
50
|
"lint": "yarn lint:eslint && yarn lint:misc --check && yarn changelog:validate && yarn lint:dependencies",
|
|
51
51
|
"lint:ci": "yarn lint",
|
|
52
52
|
"lint:dependencies": "depcheck",
|
|
53
|
-
"lint:eslint": "eslint . --cache
|
|
53
|
+
"lint:eslint": "eslint . --cache",
|
|
54
54
|
"lint:fix": "yarn lint:eslint --fix && yarn lint:misc --write",
|
|
55
|
-
"lint:misc": "prettier --no-error-on-unmatched-pattern --
|
|
55
|
+
"lint:misc": "prettier --no-error-on-unmatched-pattern --log-level warn \"**/*.json\" \"**/*.md\" \"**/*.html\" \"!CHANGELOG.md\" --ignore-path ./.prettierignore",
|
|
56
56
|
"publish:preview": "yarn npm publish --tag preview",
|
|
57
57
|
"since-latest-release": "../../scripts/since-latest-release.sh",
|
|
58
58
|
"start": "node scripts/start.js",
|
|
@@ -67,13 +67,13 @@
|
|
|
67
67
|
"@metamask/json-rpc-engine": "^10.0.2",
|
|
68
68
|
"@metamask/object-multiplex": "^2.1.0",
|
|
69
69
|
"@metamask/post-message-stream": "^9.0.0",
|
|
70
|
-
"@metamask/providers": "^
|
|
70
|
+
"@metamask/providers": "^21.0.0",
|
|
71
71
|
"@metamask/rpc-errors": "^7.0.2",
|
|
72
|
-
"@metamask/snaps-sdk": "^6.
|
|
73
|
-
"@metamask/snaps-utils": "^9.
|
|
72
|
+
"@metamask/snaps-sdk": "^6.20.0",
|
|
73
|
+
"@metamask/snaps-utils": "^9.1.0",
|
|
74
74
|
"@metamask/superstruct": "^3.1.0",
|
|
75
75
|
"@metamask/utils": "^11.2.0",
|
|
76
|
-
"nanoid": "^3.
|
|
76
|
+
"nanoid": "^3.3.10",
|
|
77
77
|
"readable-stream": "^3.6.2"
|
|
78
78
|
},
|
|
79
79
|
"devDependencies": {
|
|
@@ -85,19 +85,13 @@
|
|
|
85
85
|
"@lavamoat/allow-scripts": "^3.0.4",
|
|
86
86
|
"@lavamoat/lavapack": "^6.1.1",
|
|
87
87
|
"@lavamoat/lavatube": "^1.0.0",
|
|
88
|
-
"@metamask/auto-changelog": "^
|
|
89
|
-
"@metamask/eslint-config": "^12.1.0",
|
|
90
|
-
"@metamask/eslint-config-jest": "^12.1.0",
|
|
91
|
-
"@metamask/eslint-config-nodejs": "^12.1.0",
|
|
92
|
-
"@metamask/eslint-config-typescript": "^12.1.0",
|
|
88
|
+
"@metamask/auto-changelog": "^4.1.0",
|
|
93
89
|
"@swc/core": "1.3.78",
|
|
94
90
|
"@swc/jest": "^0.2.26",
|
|
95
91
|
"@ts-bridge/cli": "^0.6.1",
|
|
96
92
|
"@types/express": "^4.17.17",
|
|
97
93
|
"@types/jest": "^27.5.1",
|
|
98
94
|
"@types/node": "18.14.2",
|
|
99
|
-
"@typescript-eslint/eslint-plugin": "^5.42.1",
|
|
100
|
-
"@typescript-eslint/parser": "^6.21.0",
|
|
101
95
|
"@wdio/browser-runner": "^8.19.0",
|
|
102
96
|
"@wdio/cli": "^8.19.0",
|
|
103
97
|
"@wdio/globals": "^8.19.0",
|
|
@@ -109,15 +103,8 @@
|
|
|
109
103
|
"browserify": "^17.0.0",
|
|
110
104
|
"deepmerge": "^4.2.2",
|
|
111
105
|
"depcheck": "^1.4.7",
|
|
112
|
-
"esbuild": "^0.
|
|
113
|
-
"eslint": "^
|
|
114
|
-
"eslint-config-prettier": "^8.5.0",
|
|
115
|
-
"eslint-plugin-import": "^2.26.0",
|
|
116
|
-
"eslint-plugin-jest": "^27.1.5",
|
|
117
|
-
"eslint-plugin-jsdoc": "^41.1.2",
|
|
118
|
-
"eslint-plugin-n": "^15.7.0",
|
|
119
|
-
"eslint-plugin-prettier": "^4.2.1",
|
|
120
|
-
"eslint-plugin-promise": "^6.1.1",
|
|
106
|
+
"esbuild": "^0.25.1",
|
|
107
|
+
"eslint": "^9.11.0",
|
|
121
108
|
"expect-webdriverio": "^4.4.1",
|
|
122
109
|
"istanbul-lib-coverage": "^3.2.0",
|
|
123
110
|
"istanbul-lib-report": "^3.0.0",
|
|
@@ -128,15 +115,14 @@
|
|
|
128
115
|
"jest-silent-reporter": "^0.6.0",
|
|
129
116
|
"lavamoat": "^8.0.4",
|
|
130
117
|
"lavamoat-browserify": "^17.0.5",
|
|
131
|
-
"prettier": "^
|
|
132
|
-
"prettier-plugin-packagejson": "^2.5.2",
|
|
118
|
+
"prettier": "^3.3.3",
|
|
133
119
|
"rimraf": "^4.1.2",
|
|
134
120
|
"serve-handler": "^6.1.5",
|
|
135
121
|
"ses": "^1.1.0",
|
|
136
122
|
"terser": "^5.17.7",
|
|
137
123
|
"ts-node": "^10.9.1",
|
|
138
124
|
"typescript": "~5.3.3",
|
|
139
|
-
"vite": "^
|
|
125
|
+
"vite": "^6.2.3",
|
|
140
126
|
"vite-tsconfig-paths": "^4.0.5",
|
|
141
127
|
"wdio-chromedriver-service": "^8.1.1",
|
|
142
128
|
"wdio-geckodriver-service": "^5.0.2",
|