@metamask/snaps-execution-environments 4.0.1 → 5.0.1
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 +15 -1
- package/dist/browserify/iframe/bundle.js +4 -4
- package/dist/browserify/node-process/bundle.js +3 -3
- package/dist/browserify/node-thread/bundle.js +3 -3
- package/dist/browserify/webview/bundle.js +4 -4
- package/dist/browserify/worker-executor/bundle.js +4 -4
- package/dist/browserify/worker-pool/bundle.js +4 -4
- package/dist/chunk-2VA6RAEE.js +30 -0
- package/dist/chunk-2VA6RAEE.js.map +1 -0
- package/dist/chunk-3JCT4MWT.js +108 -0
- package/dist/chunk-3JCT4MWT.js.map +1 -0
- package/dist/chunk-3Y4ZRKNE.js +33 -0
- package/dist/chunk-3Y4ZRKNE.js.map +1 -0
- package/dist/chunk-44XYIN4N.js +86 -0
- package/dist/chunk-44XYIN4N.js.map +1 -0
- package/dist/chunk-4CGJF3BT.mjs +262 -0
- package/dist/chunk-4CGJF3BT.mjs.map +1 -0
- package/dist/chunk-4XRZLEKU.js +49 -0
- package/dist/chunk-4XRZLEKU.js.map +1 -0
- package/dist/chunk-53ZULHPK.mjs +16 -0
- package/dist/chunk-53ZULHPK.mjs.map +1 -0
- package/dist/chunk-5DEV3QQU.mjs +12 -0
- package/dist/chunk-5DEV3QQU.mjs.map +1 -0
- package/dist/chunk-5FG5IBYT.mjs +33 -0
- package/dist/chunk-5FG5IBYT.mjs.map +1 -0
- package/dist/chunk-5STN3QCA.js +183 -0
- package/dist/chunk-5STN3QCA.js.map +1 -0
- package/dist/chunk-7AJWXSDQ.mjs +73 -0
- package/dist/chunk-7AJWXSDQ.mjs.map +1 -0
- package/dist/chunk-ACK2JBSO.mjs +49 -0
- package/dist/chunk-ACK2JBSO.mjs.map +1 -0
- package/dist/chunk-B3JZNNZD.js +48 -0
- package/dist/chunk-B3JZNNZD.js.map +1 -0
- package/dist/chunk-BCBKEUCG.mjs +38 -0
- package/dist/chunk-BCBKEUCG.mjs.map +1 -0
- package/dist/chunk-BTEAZZKP.mjs +24 -0
- package/dist/chunk-BTEAZZKP.mjs.map +1 -0
- package/dist/chunk-CV5LC4PP.js +24 -0
- package/dist/chunk-CV5LC4PP.js.map +1 -0
- package/dist/chunk-CWCVTRNZ.mjs +48 -0
- package/dist/chunk-CWCVTRNZ.mjs.map +1 -0
- package/dist/chunk-CWIFVPLR.js +262 -0
- package/dist/chunk-CWIFVPLR.js.map +1 -0
- package/dist/chunk-DFPM46ZF.js +147 -0
- package/dist/chunk-DFPM46ZF.js.map +1 -0
- package/dist/chunk-DLLLH5HN.js +26 -0
- package/dist/chunk-DLLLH5HN.js.map +1 -0
- package/dist/chunk-DTF6YTIS.js +484 -0
- package/dist/chunk-DTF6YTIS.js.map +1 -0
- package/dist/chunk-ERB7OLAB.mjs +86 -0
- package/dist/chunk-ERB7OLAB.mjs.map +1 -0
- package/dist/chunk-EXN2TFDJ.js +38 -0
- package/dist/chunk-EXN2TFDJ.js.map +1 -0
- package/dist/chunk-F37LPBJS.js +33 -0
- package/dist/chunk-F37LPBJS.js.map +1 -0
- package/dist/chunk-FOEAIF5U.js +16 -0
- package/dist/chunk-FOEAIF5U.js.map +1 -0
- package/dist/chunk-HGLRZZ56.js +32 -0
- package/dist/chunk-HGLRZZ56.js.map +1 -0
- package/dist/chunk-HKHW6TTX.js +49 -0
- package/dist/chunk-HKHW6TTX.js.map +1 -0
- package/dist/chunk-HWS4QSOC.mjs +16 -0
- package/dist/chunk-HWS4QSOC.mjs.map +1 -0
- package/dist/chunk-I5G4YFHM.js +73 -0
- package/dist/chunk-I5G4YFHM.js.map +1 -0
- package/dist/chunk-IX5S3V47.mjs +26 -0
- package/dist/chunk-IX5S3V47.mjs.map +1 -0
- package/dist/chunk-JW3JHJ7S.js +45 -0
- package/dist/chunk-JW3JHJ7S.js.map +1 -0
- package/dist/chunk-LO5ORVRC.js +16 -0
- package/dist/chunk-LO5ORVRC.js.map +1 -0
- package/dist/chunk-MCXWFCGV.js +1 -0
- package/dist/chunk-MCXWFCGV.js.map +1 -0
- package/dist/chunk-MIWGLICQ.mjs +108 -0
- package/dist/chunk-MIWGLICQ.mjs.map +1 -0
- package/dist/chunk-MM6ZSW4E.mjs +81 -0
- package/dist/chunk-MM6ZSW4E.mjs.map +1 -0
- package/dist/chunk-MOXNHXPG.js +67 -0
- package/dist/chunk-MOXNHXPG.js.map +1 -0
- package/dist/chunk-MS2LQQYH.js +38 -0
- package/dist/chunk-MS2LQQYH.js.map +1 -0
- package/dist/chunk-MXNMMTJW.mjs +51 -0
- package/dist/chunk-MXNMMTJW.mjs.map +1 -0
- package/dist/chunk-OBT45IWW.js +92 -0
- package/dist/chunk-OBT45IWW.js.map +1 -0
- package/dist/chunk-OCNPLHS2.js +51 -0
- package/dist/chunk-OCNPLHS2.js.map +1 -0
- package/dist/chunk-OLASO3O4.js +81 -0
- package/dist/chunk-OLASO3O4.js.map +1 -0
- package/dist/chunk-PTCQ2I47.mjs +147 -0
- package/dist/chunk-PTCQ2I47.mjs.map +1 -0
- package/dist/chunk-Q42NNJFY.mjs +32 -0
- package/dist/chunk-Q42NNJFY.mjs.map +1 -0
- package/dist/chunk-QJB4J7WL.mjs +67 -0
- package/dist/chunk-QJB4J7WL.mjs.map +1 -0
- package/dist/chunk-QVIHE3WB.mjs +484 -0
- package/dist/chunk-QVIHE3WB.mjs.map +1 -0
- package/dist/chunk-QZC2X6NG.js +44 -0
- package/dist/chunk-QZC2X6NG.js.map +1 -0
- package/dist/chunk-RZNKZRAD.js +40 -0
- package/dist/chunk-RZNKZRAD.js.map +1 -0
- package/dist/chunk-S7257EN3.mjs +49 -0
- package/dist/chunk-S7257EN3.mjs.map +1 -0
- package/dist/chunk-TSEAPB7L.mjs +1 -0
- package/dist/chunk-TSEAPB7L.mjs.map +1 -0
- package/dist/chunk-UOPIRTJX.mjs +44 -0
- package/dist/chunk-UOPIRTJX.mjs.map +1 -0
- package/dist/chunk-USHNZDGV.mjs +33 -0
- package/dist/chunk-USHNZDGV.mjs.map +1 -0
- package/dist/chunk-V76DI2XM.mjs +183 -0
- package/dist/chunk-V76DI2XM.mjs.map +1 -0
- package/dist/chunk-VKFZ4EB5.mjs +40 -0
- package/dist/chunk-VKFZ4EB5.mjs.map +1 -0
- package/dist/chunk-W7EDURT5.mjs +92 -0
- package/dist/chunk-W7EDURT5.mjs.map +1 -0
- package/dist/chunk-WV3CXIKN.mjs +147 -0
- package/dist/chunk-WV3CXIKN.mjs.map +1 -0
- package/dist/chunk-Y7MVNOPY.mjs +45 -0
- package/dist/chunk-Y7MVNOPY.mjs.map +1 -0
- package/dist/chunk-YRZVIDCF.mjs +38 -0
- package/dist/chunk-YRZVIDCF.mjs.map +1 -0
- package/dist/chunk-Z4WSS7YZ.js +147 -0
- package/dist/chunk-Z4WSS7YZ.js.map +1 -0
- package/dist/chunk-Z7BOREC4.js +12 -0
- package/dist/chunk-Z7BOREC4.js.map +1 -0
- package/dist/chunk-ZNTCZK7J.mjs +30 -0
- package/dist/chunk-ZNTCZK7J.mjs.map +1 -0
- package/dist/common/BaseSnapExecutor.js +26 -0
- package/dist/common/BaseSnapExecutor.js.map +1 -0
- package/dist/common/BaseSnapExecutor.mjs +26 -0
- package/dist/common/BaseSnapExecutor.mjs.map +1 -0
- package/dist/common/commands.js +11 -0
- package/dist/common/commands.js.map +1 -0
- package/dist/common/commands.mjs +11 -0
- package/dist/common/commands.mjs.map +1 -0
- package/dist/common/endowments/commonEndowmentFactory.js +20 -0
- package/dist/common/endowments/commonEndowmentFactory.js.map +1 -0
- package/dist/common/endowments/commonEndowmentFactory.mjs +20 -0
- package/dist/common/endowments/commonEndowmentFactory.mjs.map +1 -0
- package/dist/common/endowments/console.js +13 -0
- package/dist/common/endowments/console.js.map +1 -0
- package/dist/common/endowments/console.mjs +13 -0
- package/dist/common/endowments/console.mjs.map +1 -0
- package/dist/common/endowments/crypto.js +11 -0
- package/dist/common/endowments/crypto.js.map +1 -0
- package/dist/common/endowments/crypto.mjs +11 -0
- package/dist/common/endowments/crypto.mjs.map +1 -0
- package/dist/common/endowments/date.js +9 -0
- package/dist/common/endowments/date.js.map +1 -0
- package/dist/common/endowments/date.mjs +9 -0
- package/dist/common/endowments/date.mjs.map +1 -0
- package/dist/common/endowments/index.js +21 -0
- package/dist/common/endowments/index.js.map +1 -0
- package/dist/common/endowments/index.mjs +21 -0
- package/dist/common/endowments/index.mjs.map +1 -0
- package/dist/common/endowments/interval.js +8 -0
- package/dist/common/endowments/interval.js.map +1 -0
- package/dist/common/endowments/interval.mjs +8 -0
- package/dist/common/endowments/interval.mjs.map +1 -0
- package/dist/common/endowments/math.js +10 -0
- package/dist/common/endowments/math.js.map +1 -0
- package/dist/common/endowments/math.mjs +10 -0
- package/dist/common/endowments/math.mjs.map +1 -0
- package/dist/common/endowments/network.js +10 -0
- package/dist/common/endowments/network.js.map +1 -0
- package/dist/common/endowments/network.mjs +10 -0
- package/dist/common/endowments/network.mjs.map +1 -0
- package/dist/common/endowments/textDecoder.js +8 -0
- package/dist/common/endowments/textDecoder.js.map +1 -0
- package/dist/common/endowments/textDecoder.mjs +8 -0
- package/dist/common/endowments/textDecoder.mjs.map +1 -0
- package/dist/common/endowments/textEncoder.js +8 -0
- package/dist/common/endowments/textEncoder.js.map +1 -0
- package/dist/common/endowments/textEncoder.mjs +8 -0
- package/dist/common/endowments/textEncoder.mjs.map +1 -0
- package/dist/common/endowments/timeout.js +8 -0
- package/dist/common/endowments/timeout.js.map +1 -0
- package/dist/common/endowments/timeout.mjs +8 -0
- package/dist/common/endowments/timeout.mjs.map +1 -0
- package/dist/common/globalEvents.js +11 -0
- package/dist/common/globalEvents.js.map +1 -0
- package/dist/common/globalEvents.mjs +11 -0
- package/dist/common/globalEvents.mjs.map +1 -0
- package/dist/common/globalObject.js +10 -0
- package/dist/common/globalObject.js.map +1 -0
- package/dist/common/globalObject.mjs +10 -0
- package/dist/common/globalObject.mjs.map +1 -0
- package/dist/common/lockdown/lockdown-events.js +8 -0
- package/dist/common/lockdown/lockdown-events.js.map +1 -0
- package/dist/common/lockdown/lockdown-events.mjs +8 -0
- package/dist/common/lockdown/lockdown-events.mjs.map +1 -0
- package/dist/common/lockdown/lockdown-more.js +8 -0
- package/dist/common/lockdown/lockdown-more.js.map +1 -0
- package/dist/common/lockdown/lockdown-more.mjs +8 -0
- package/dist/common/lockdown/lockdown-more.mjs.map +1 -0
- package/dist/common/lockdown/lockdown.js +22 -0
- package/dist/common/lockdown/lockdown.js.map +1 -0
- package/dist/common/lockdown/lockdown.mjs +22 -0
- package/dist/common/lockdown/lockdown.mjs.map +1 -0
- package/dist/common/sortParams.js +8 -0
- package/dist/common/sortParams.js.map +1 -0
- package/dist/common/sortParams.mjs +8 -0
- package/dist/common/sortParams.mjs.map +1 -0
- package/dist/common/utils.js +21 -0
- package/dist/common/utils.js.map +1 -0
- package/dist/common/utils.mjs +21 -0
- package/dist/common/utils.mjs.map +1 -0
- package/dist/common/validation.js +38 -0
- package/dist/common/validation.js.map +1 -0
- package/dist/common/validation.mjs +38 -0
- package/dist/common/validation.mjs.map +1 -0
- package/dist/globals.d.js +1 -0
- package/dist/globals.d.js.map +1 -0
- package/dist/globals.d.mjs +1 -0
- package/dist/globals.d.mjs.map +1 -0
- package/dist/iframe/IFrameSnapExecutor.js +27 -0
- package/dist/iframe/IFrameSnapExecutor.js.map +1 -0
- package/dist/iframe/IFrameSnapExecutor.mjs +27 -0
- package/dist/iframe/IFrameSnapExecutor.mjs.map +1 -0
- package/dist/iframe/index.js +35 -0
- package/dist/iframe/index.js.map +1 -0
- package/dist/iframe/index.mjs +35 -0
- package/dist/iframe/index.mjs.map +1 -0
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +9 -0
- package/dist/index.mjs.map +1 -0
- package/dist/logging.js +8 -0
- package/dist/logging.js.map +1 -0
- package/dist/logging.mjs +8 -0
- package/dist/logging.mjs.map +1 -0
- package/dist/node-process/ChildProcessSnapExecutor.js +27 -0
- package/dist/node-process/ChildProcessSnapExecutor.js.map +1 -0
- package/dist/node-process/ChildProcessSnapExecutor.mjs +27 -0
- package/dist/node-process/ChildProcessSnapExecutor.mjs.map +1 -0
- package/dist/node-process/index.js +31 -0
- package/dist/node-process/index.js.map +1 -0
- package/dist/node-process/index.mjs +31 -0
- package/dist/node-process/index.mjs.map +1 -0
- package/dist/node-thread/ThreadSnapExecutor.js +27 -0
- package/dist/node-thread/ThreadSnapExecutor.js.map +1 -0
- package/dist/node-thread/ThreadSnapExecutor.mjs +27 -0
- package/dist/node-thread/ThreadSnapExecutor.mjs.map +1 -0
- package/dist/node-thread/index.js +31 -0
- package/dist/node-thread/index.js.map +1 -0
- package/dist/node-thread/index.mjs +31 -0
- package/dist/node-thread/index.mjs.map +1 -0
- package/dist/proxy/ProxySnapExecutor.js +8 -0
- package/dist/proxy/ProxySnapExecutor.js.map +1 -0
- package/dist/proxy/ProxySnapExecutor.mjs +8 -0
- package/dist/proxy/ProxySnapExecutor.mjs.map +1 -0
- package/dist/proxy/index.js +9 -0
- package/dist/proxy/index.js.map +1 -0
- package/dist/proxy/index.mjs +9 -0
- package/dist/proxy/index.mjs.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/dist/types/common/utils.d.ts +7 -0
- package/dist/types/vendor/global.d.js +1 -0
- package/dist/types/vendor/global.d.js.map +1 -0
- package/dist/types/vendor/global.d.mjs +1 -0
- package/dist/types/vendor/global.d.mjs.map +1 -0
- package/dist/types/vendor/readable-stream.d.js +1 -0
- package/dist/types/vendor/readable-stream.d.js.map +1 -0
- package/dist/types/vendor/readable-stream.d.mjs +1 -0
- package/dist/types/vendor/readable-stream.d.mjs.map +1 -0
- package/dist/webview/WebViewExecutorStream.js +8 -0
- package/dist/webview/WebViewExecutorStream.js.map +1 -0
- package/dist/webview/WebViewExecutorStream.mjs +8 -0
- package/dist/webview/WebViewExecutorStream.mjs.map +1 -0
- package/dist/webview/index.js +26 -0
- package/dist/webview/index.js.map +1 -0
- package/dist/webview/index.mjs +26 -0
- package/dist/webview/index.mjs.map +1 -0
- package/dist/webworker/executor/WebWorkerSnapExecutor.js +27 -0
- package/dist/webworker/executor/WebWorkerSnapExecutor.js.map +1 -0
- package/dist/webworker/executor/WebWorkerSnapExecutor.mjs +27 -0
- package/dist/webworker/executor/WebWorkerSnapExecutor.mjs.map +1 -0
- package/dist/webworker/executor/index.js +35 -0
- package/dist/webworker/executor/index.js.map +1 -0
- package/dist/webworker/executor/index.mjs +35 -0
- package/dist/webworker/executor/index.mjs.map +1 -0
- package/dist/webworker/pool/WebWorkerPool.js +8 -0
- package/dist/webworker/pool/WebWorkerPool.js.map +1 -0
- package/dist/webworker/pool/WebWorkerPool.mjs +8 -0
- package/dist/webworker/pool/WebWorkerPool.mjs.map +1 -0
- package/dist/webworker/pool/index.js +16 -0
- package/dist/webworker/pool/index.js.map +1 -0
- package/dist/webworker/pool/index.mjs +16 -0
- package/dist/webworker/pool/index.mjs.map +1 -0
- package/package.json +25 -18
- package/dist/cjs/common/BaseSnapExecutor.js +0 -496
- package/dist/cjs/common/BaseSnapExecutor.js.map +0 -1
- package/dist/cjs/common/commands.js +0 -102
- package/dist/cjs/common/commands.js.map +0 -1
- package/dist/cjs/common/endowments/commonEndowmentFactory.js +0 -147
- package/dist/cjs/common/endowments/commonEndowmentFactory.js.map +0 -1
- package/dist/cjs/common/endowments/console.js +0 -134
- package/dist/cjs/common/endowments/console.js.map +0 -1
- package/dist/cjs/common/endowments/crypto.js +0 -44
- package/dist/cjs/common/endowments/crypto.js.map +0 -1
- package/dist/cjs/common/endowments/date.js +0 -53
- package/dist/cjs/common/endowments/date.js.map +0 -1
- package/dist/cjs/common/endowments/index.js +0 -93
- package/dist/cjs/common/endowments/index.js.map +0 -1
- package/dist/cjs/common/endowments/interval.js +0 -62
- package/dist/cjs/common/endowments/interval.js.map +0 -1
- package/dist/cjs/common/endowments/math.js +0 -67
- package/dist/cjs/common/endowments/math.js.map +0 -1
- package/dist/cjs/common/endowments/network.js +0 -303
- package/dist/cjs/common/endowments/network.js.map +0 -1
- package/dist/cjs/common/endowments/textDecoder.js +0 -28
- package/dist/cjs/common/endowments/textDecoder.js.map +0 -1
- package/dist/cjs/common/endowments/textEncoder.js +0 -28
- package/dist/cjs/common/endowments/textEncoder.js.map +0 -1
- package/dist/cjs/common/endowments/timeout.js +0 -64
- package/dist/cjs/common/endowments/timeout.js.map +0 -1
- package/dist/cjs/common/globalEvents.js +0 -40
- package/dist/cjs/common/globalEvents.js.map +0 -1
- package/dist/cjs/common/globalObject.js +0 -53
- package/dist/cjs/common/globalObject.js.map +0 -1
- package/dist/cjs/common/lockdown/lockdown-events.js +0 -74
- package/dist/cjs/common/lockdown/lockdown-events.js.map +0 -1
- package/dist/cjs/common/lockdown/lockdown-more.js +0 -73
- package/dist/cjs/common/lockdown/lockdown-more.js.map +0 -1
- package/dist/cjs/common/lockdown/lockdown.js +0 -30
- package/dist/cjs/common/lockdown/lockdown.js.map +0 -1
- package/dist/cjs/common/sortParams.js +0 -26
- package/dist/cjs/common/sortParams.js.map +0 -1
- package/dist/cjs/common/utils.js +0 -128
- package/dist/cjs/common/utils.js.map +0 -1
- package/dist/cjs/common/validation.js +0 -149
- package/dist/cjs/common/validation.js.map +0 -1
- package/dist/cjs/iframe/IFrameSnapExecutor.js +0 -50
- package/dist/cjs/iframe/IFrameSnapExecutor.js.map +0 -1
- package/dist/cjs/iframe/index.js +0 -13
- package/dist/cjs/iframe/index.js.map +0 -1
- package/dist/cjs/index.js +0 -20
- package/dist/cjs/index.js.map +0 -1
- package/dist/cjs/logging.js +0 -15
- package/dist/cjs/logging.js.map +0 -1
- package/dist/cjs/node-process/ChildProcessSnapExecutor.js +0 -39
- package/dist/cjs/node-process/ChildProcessSnapExecutor.js.map +0 -1
- package/dist/cjs/node-process/index.js +0 -11
- package/dist/cjs/node-process/index.js.map +0 -1
- package/dist/cjs/node-thread/ThreadSnapExecutor.js +0 -39
- package/dist/cjs/node-thread/ThreadSnapExecutor.js.map +0 -1
- package/dist/cjs/node-thread/index.js +0 -11
- package/dist/cjs/node-thread/index.js.map +0 -1
- package/dist/cjs/proxy/ProxySnapExecutor.js +0 -183
- package/dist/cjs/proxy/ProxySnapExecutor.js.map +0 -1
- package/dist/cjs/proxy/index.js +0 -20
- package/dist/cjs/proxy/index.js.map +0 -1
- package/dist/cjs/webview/WebViewExecutorStream.js +0 -121
- package/dist/cjs/webview/WebViewExecutorStream.js.map +0 -1
- package/dist/cjs/webview/index.js +0 -19
- package/dist/cjs/webview/index.js.map +0 -1
- package/dist/cjs/webworker/executor/WebWorkerSnapExecutor.js +0 -45
- package/dist/cjs/webworker/executor/WebWorkerSnapExecutor.js.map +0 -1
- package/dist/cjs/webworker/executor/index.js +0 -13
- package/dist/cjs/webworker/executor/index.js.map +0 -1
- package/dist/cjs/webworker/pool/WebWorkerPool.js +0 -248
- package/dist/cjs/webworker/pool/WebWorkerPool.js.map +0 -1
- package/dist/cjs/webworker/pool/index.js +0 -13
- package/dist/cjs/webworker/pool/index.js.map +0 -1
- package/dist/esm/common/BaseSnapExecutor.js +0 -486
- package/dist/esm/common/BaseSnapExecutor.js.map +0 -1
- package/dist/esm/common/commands.js +0 -101
- package/dist/esm/common/commands.js.map +0 -1
- package/dist/esm/common/endowments/commonEndowmentFactory.js +0 -132
- package/dist/esm/common/endowments/commonEndowmentFactory.js.map +0 -1
- package/dist/esm/common/endowments/console.js +0 -116
- package/dist/esm/common/endowments/console.js.map +0 -1
- package/dist/esm/common/endowments/crypto.js +0 -26
- package/dist/esm/common/endowments/crypto.js.map +0 -1
- package/dist/esm/common/endowments/date.js +0 -43
- package/dist/esm/common/endowments/date.js.map +0 -1
- package/dist/esm/common/endowments/index.js +0 -92
- package/dist/esm/common/endowments/index.js.map +0 -1
- package/dist/esm/common/endowments/interval.js +0 -52
- package/dist/esm/common/endowments/interval.js.map +0 -1
- package/dist/esm/common/endowments/math.js +0 -57
- package/dist/esm/common/endowments/math.js.map +0 -1
- package/dist/esm/common/endowments/network.js +0 -293
- package/dist/esm/common/endowments/network.js.map +0 -1
- package/dist/esm/common/endowments/textDecoder.js +0 -18
- package/dist/esm/common/endowments/textDecoder.js.map +0 -1
- package/dist/esm/common/endowments/textEncoder.js +0 -18
- package/dist/esm/common/endowments/textEncoder.js.map +0 -1
- package/dist/esm/common/endowments/timeout.js +0 -54
- package/dist/esm/common/endowments/timeout.js.map +0 -1
- package/dist/esm/common/globalEvents.js +0 -36
- package/dist/esm/common/globalEvents.js.map +0 -1
- package/dist/esm/common/globalObject.js +0 -36
- package/dist/esm/common/globalObject.js.map +0 -1
- package/dist/esm/common/lockdown/lockdown-events.js +0 -66
- package/dist/esm/common/lockdown/lockdown-events.js.map +0 -1
- package/dist/esm/common/lockdown/lockdown-more.js +0 -82
- package/dist/esm/common/lockdown/lockdown-more.js.map +0 -1
- package/dist/esm/common/lockdown/lockdown.js +0 -24
- package/dist/esm/common/lockdown/lockdown.js.map +0 -1
- package/dist/esm/common/sortParams.js +0 -29
- package/dist/esm/common/sortParams.js.map +0 -1
- package/dist/esm/common/utils.js +0 -128
- package/dist/esm/common/utils.js.map +0 -1
- package/dist/esm/common/validation.js +0 -127
- package/dist/esm/common/validation.js.map +0 -1
- package/dist/esm/iframe/IFrameSnapExecutor.js +0 -35
- package/dist/esm/iframe/IFrameSnapExecutor.js.map +0 -1
- package/dist/esm/iframe/index.js +0 -9
- package/dist/esm/iframe/index.js.map +0 -1
- package/dist/esm/index.js +0 -3
- package/dist/esm/index.js.map +0 -1
- package/dist/esm/logging.js +0 -10
- package/dist/esm/logging.js.map +0 -1
- package/dist/esm/node-process/ChildProcessSnapExecutor.js +0 -24
- package/dist/esm/node-process/ChildProcessSnapExecutor.js.map +0 -1
- package/dist/esm/node-process/index.js +0 -7
- package/dist/esm/node-process/index.js.map +0 -1
- package/dist/esm/node-thread/ThreadSnapExecutor.js +0 -24
- package/dist/esm/node-thread/ThreadSnapExecutor.js.map +0 -1
- package/dist/esm/node-thread/index.js +0 -7
- package/dist/esm/node-thread/index.js.map +0 -1
- package/dist/esm/proxy/ProxySnapExecutor.js +0 -181
- package/dist/esm/proxy/ProxySnapExecutor.js.map +0 -1
- package/dist/esm/proxy/index.js +0 -3
- package/dist/esm/proxy/index.js.map +0 -1
- package/dist/esm/webview/WebViewExecutorStream.js +0 -111
- package/dist/esm/webview/WebViewExecutorStream.js.map +0 -1
- package/dist/esm/webview/index.js +0 -15
- package/dist/esm/webview/index.js.map +0 -1
- package/dist/esm/webworker/executor/WebWorkerSnapExecutor.js +0 -30
- package/dist/esm/webworker/executor/WebWorkerSnapExecutor.js.map +0 -1
- package/dist/esm/webworker/executor/index.js +0 -9
- package/dist/esm/webworker/executor/index.js.map +0 -1
- package/dist/esm/webworker/pool/WebWorkerPool.js +0 -245
- package/dist/esm/webworker/pool/WebWorkerPool.js.map +0 -1
- package/dist/esm/webworker/pool/index.js +0 -9
- package/dist/esm/webworker/pool/index.js.map +0 -1
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
2
|
+
|
|
3
|
+
var _chunkDTF6YTISjs = require('./chunk-DTF6YTIS.js');
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
var _chunkZ7BOREC4js = require('./chunk-Z7BOREC4.js');
|
|
7
|
+
|
|
8
|
+
// src/node-process/ChildProcessSnapExecutor.ts
|
|
9
|
+
var _objectmultiplex = require('@metamask/object-multiplex'); var _objectmultiplex2 = _interopRequireDefault(_objectmultiplex);
|
|
10
|
+
var _postmessagestream = require('@metamask/post-message-stream');
|
|
11
|
+
var _snapsutils = require('@metamask/snaps-utils');
|
|
12
|
+
var _readablestream = require('readable-stream');
|
|
13
|
+
var ChildProcessSnapExecutor = class _ChildProcessSnapExecutor extends _chunkDTF6YTISjs.BaseSnapExecutor {
|
|
14
|
+
static initialize() {
|
|
15
|
+
_chunkZ7BOREC4js.log.call(void 0, "Worker: Connecting to parent.");
|
|
16
|
+
const parentStream = new (0, _postmessagestream.ProcessMessageStream)();
|
|
17
|
+
const mux = new (0, _objectmultiplex2.default)();
|
|
18
|
+
_readablestream.pipeline.call(void 0, parentStream, mux, parentStream, (error) => {
|
|
19
|
+
if (error) {
|
|
20
|
+
_snapsutils.logError.call(void 0, `Parent stream failure, closing worker.`, error);
|
|
21
|
+
}
|
|
22
|
+
self.close();
|
|
23
|
+
});
|
|
24
|
+
const commandStream = mux.createStream(_snapsutils.SNAP_STREAM_NAMES.COMMAND);
|
|
25
|
+
const rpcStream = mux.createStream(_snapsutils.SNAP_STREAM_NAMES.JSON_RPC);
|
|
26
|
+
return new _ChildProcessSnapExecutor(commandStream, rpcStream);
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
exports.ChildProcessSnapExecutor = ChildProcessSnapExecutor;
|
|
33
|
+
//# sourceMappingURL=chunk-F37LPBJS.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/node-process/ChildProcessSnapExecutor.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAO,qBAAqB;AAC5B,SAAS,4BAA4B;AACrC,SAAS,UAAU,yBAAyB;AAC5C,SAAS,gBAAgB;AAKlB,IAAM,2BAAN,MAAM,kCAAiC,iBAAiB;AAAA,EAC7D,OAAO,aAAa;AAClB,QAAI,+BAA+B;AAEnC,UAAM,eAAe,IAAI,qBAAqB;AAC9C,UAAM,MAAM,IAAI,gBAAgB;AAChC,aAAS,cAAc,KAAY,cAAc,CAAC,UAAU;AAC1D,UAAI,OAAO;AACT,iBAAS,0CAA0C,KAAK;AAAA,MAC1D;AACA,WAAK,MAAM;AAAA,IACb,CAAC;AAED,UAAM,gBAAgB,IAAI,aAAa,kBAAkB,OAAO;AAChE,UAAM,YAAY,IAAI,aAAa,kBAAkB,QAAQ;AAC7D,WAAO,IAAI,0BAAyB,eAAe,SAAS;AAAA,EAC9D;AACF","sourcesContent":["import ObjectMultiplex from '@metamask/object-multiplex';\nimport { ProcessMessageStream } from '@metamask/post-message-stream';\nimport { logError, SNAP_STREAM_NAMES } from '@metamask/snaps-utils';\nimport { pipeline } from 'readable-stream';\n\nimport { BaseSnapExecutor } from '../common/BaseSnapExecutor';\nimport { log } from '../logging';\n\nexport class ChildProcessSnapExecutor extends BaseSnapExecutor {\n static initialize() {\n log('Worker: Connecting to parent.');\n\n const parentStream = new ProcessMessageStream();\n const mux = new ObjectMultiplex();\n pipeline(parentStream, mux as any, parentStream, (error) => {\n if (error) {\n logError(`Parent stream failure, closing worker.`, error);\n }\n self.close();\n });\n\n const commandStream = mux.createStream(SNAP_STREAM_NAMES.COMMAND);\n const rpcStream = mux.createStream(SNAP_STREAM_NAMES.JSON_RPC) as any;\n return new ChildProcessSnapExecutor(commandStream, rpcStream);\n }\n}\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});// src/common/endowments/textDecoder.ts
|
|
2
|
+
var createTextDecoder = () => {
|
|
3
|
+
return {
|
|
4
|
+
TextDecoder: harden(TextDecoder)
|
|
5
|
+
};
|
|
6
|
+
};
|
|
7
|
+
var endowmentModule = {
|
|
8
|
+
names: ["TextDecoder"],
|
|
9
|
+
factory: createTextDecoder
|
|
10
|
+
};
|
|
11
|
+
var textDecoder_default = endowmentModule;
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
exports.textDecoder_default = textDecoder_default;
|
|
16
|
+
//# sourceMappingURL=chunk-FOEAIF5U.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/common/endowments/textDecoder.ts"],"names":[],"mappings":";AAKA,IAAM,oBAAoB,MAAM;AAC9B,SAAO;AAAA,IACL,aAAa,OAAO,WAAW;AAAA,EACjC;AACF;AAEA,IAAM,kBAAkB;AAAA,EACtB,OAAO,CAAC,aAAa;AAAA,EACrB,SAAS;AACX;AACA,IAAO,sBAAQ","sourcesContent":["/**\n * Creates TextDecoder function hardened by SES.\n *\n * @returns An object with the attenuated `TextDecoder` function.\n */\nconst createTextDecoder = () => {\n return {\n TextDecoder: harden(TextDecoder),\n } as const;\n};\n\nconst endowmentModule = {\n names: ['TextDecoder'] as const,\n factory: createTextDecoder,\n};\nexport default endowmentModule;\n"]}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
|
+
|
|
3
|
+
var _chunkDLLLH5HNjs = require('./chunk-DLLLH5HN.js');
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
var _chunkEXN2TFDJjs = require('./chunk-EXN2TFDJ.js');
|
|
7
|
+
|
|
8
|
+
// src/common/endowments/crypto.ts
|
|
9
|
+
var createCrypto = () => {
|
|
10
|
+
if ("crypto" in _chunkDLLLH5HNjs.rootRealmGlobal && typeof _chunkDLLLH5HNjs.rootRealmGlobal.crypto === "object" && "SubtleCrypto" in _chunkDLLLH5HNjs.rootRealmGlobal && typeof _chunkDLLLH5HNjs.rootRealmGlobal.SubtleCrypto === "function") {
|
|
11
|
+
return {
|
|
12
|
+
crypto: harden(_chunkDLLLH5HNjs.rootRealmGlobal.crypto),
|
|
13
|
+
SubtleCrypto: harden(_chunkDLLLH5HNjs.rootRealmGlobal.SubtleCrypto)
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
const crypto = _chunkEXN2TFDJjs.__require.call(void 0, "crypto").webcrypto;
|
|
17
|
+
return {
|
|
18
|
+
crypto: harden(crypto),
|
|
19
|
+
SubtleCrypto: harden(crypto.subtle.constructor)
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
var endowmentModule = {
|
|
23
|
+
names: ["crypto", "SubtleCrypto"],
|
|
24
|
+
factory: createCrypto
|
|
25
|
+
};
|
|
26
|
+
var crypto_default = endowmentModule;
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
exports.createCrypto = createCrypto; exports.crypto_default = crypto_default;
|
|
32
|
+
//# sourceMappingURL=chunk-HGLRZZ56.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/common/endowments/crypto.ts"],"names":[],"mappings":";;;;;;;;AAEO,IAAM,eAAe,MAAM;AAChC,MACE,YAAY,mBACZ,OAAO,gBAAgB,WAAW,YAClC,kBAAkB,mBAClB,OAAO,gBAAgB,iBAAiB,YACxC;AACA,WAAO;AAAA,MACL,QAAQ,OAAO,gBAAgB,MAAM;AAAA,MACrC,cAAc,OAAO,gBAAgB,YAAY;AAAA,IACnD;AAAA,EACF;AAIA,QAAM,SAAS,UAAQ,QAAQ,EAAE;AACjC,SAAO;AAAA,IACL,QAAQ,OAAO,MAAM;AAAA,IACrB,cAAc,OAAO,OAAO,OAAO,WAAW;AAAA,EAChD;AACF;AAEA,IAAM,kBAAkB;AAAA,EACtB,OAAO,CAAC,UAAU,cAAc;AAAA,EAChC,SAAS;AACX;AACA,IAAO,iBAAQ","sourcesContent":["import { rootRealmGlobal } from '../globalObject';\n\nexport const createCrypto = () => {\n if (\n 'crypto' in rootRealmGlobal &&\n typeof rootRealmGlobal.crypto === 'object' &&\n 'SubtleCrypto' in rootRealmGlobal &&\n typeof rootRealmGlobal.SubtleCrypto === 'function'\n ) {\n return {\n crypto: harden(rootRealmGlobal.crypto),\n SubtleCrypto: harden(rootRealmGlobal.SubtleCrypto),\n };\n }\n // For now, we expose the experimental webcrypto API for Node.js execution environments\n // TODO: Figure out if this is enough long-term or if we should use a polyfill.\n /* eslint-disable-next-line @typescript-eslint/no-require-imports, @typescript-eslint/no-var-requires, n/global-require */\n const crypto = require('crypto').webcrypto;\n return {\n crypto: harden(crypto),\n SubtleCrypto: harden(crypto.subtle.constructor),\n } as const;\n};\n\nconst endowmentModule = {\n names: ['crypto', 'SubtleCrypto'] as const,\n factory: createCrypto,\n};\nexport default endowmentModule;\n"]}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});// src/common/endowments/interval.ts
|
|
2
|
+
var _rpcerrors = require('@metamask/rpc-errors');
|
|
3
|
+
var MINIMUM_INTERVAL = 10;
|
|
4
|
+
var createInterval = () => {
|
|
5
|
+
const registeredHandles = /* @__PURE__ */ new Map();
|
|
6
|
+
const _setInterval = (handler, timeout) => {
|
|
7
|
+
if (typeof handler !== "function") {
|
|
8
|
+
throw _rpcerrors.rpcErrors.invalidInput(
|
|
9
|
+
`The interval handler must be a function. Received: ${typeof handler}.`
|
|
10
|
+
);
|
|
11
|
+
}
|
|
12
|
+
harden(handler);
|
|
13
|
+
const handle = Object.freeze(/* @__PURE__ */ Object.create(null));
|
|
14
|
+
const platformHandle = setInterval(
|
|
15
|
+
handler,
|
|
16
|
+
Math.max(MINIMUM_INTERVAL, timeout ?? 0)
|
|
17
|
+
);
|
|
18
|
+
registeredHandles.set(handle, platformHandle);
|
|
19
|
+
return handle;
|
|
20
|
+
};
|
|
21
|
+
const _clearInterval = (handle) => {
|
|
22
|
+
harden(handle);
|
|
23
|
+
const platformHandle = registeredHandles.get(handle);
|
|
24
|
+
if (platformHandle !== void 0) {
|
|
25
|
+
clearInterval(platformHandle);
|
|
26
|
+
registeredHandles.delete(handle);
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
const teardownFunction = () => {
|
|
30
|
+
for (const handle of registeredHandles.keys()) {
|
|
31
|
+
_clearInterval(handle);
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
return {
|
|
35
|
+
setInterval: harden(_setInterval),
|
|
36
|
+
clearInterval: harden(_clearInterval),
|
|
37
|
+
teardownFunction
|
|
38
|
+
};
|
|
39
|
+
};
|
|
40
|
+
var endowmentModule = {
|
|
41
|
+
names: ["setInterval", "clearInterval"],
|
|
42
|
+
factory: createInterval
|
|
43
|
+
};
|
|
44
|
+
var interval_default = endowmentModule;
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
exports.interval_default = interval_default;
|
|
49
|
+
//# sourceMappingURL=chunk-HKHW6TTX.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/common/endowments/interval.ts"],"names":[],"mappings":";AAAA,SAAS,iBAAiB;AAE1B,IAAM,mBAAmB;AAYzB,IAAM,iBAAiB,MAAM;AAC3B,QAAM,oBAAoB,oBAAI,IAAsB;AAEpD,QAAM,eAAe,CAAC,SAAuB,YAA8B;AACzE,QAAI,OAAO,YAAY,YAAY;AACjC,YAAM,UAAU;AAAA,QACd,sDAAsD,OAAO,OAAO;AAAA,MACtE;AAAA,IACF;AACA,WAAO,OAAO;AACd,UAAM,SAAS,OAAO,OAAO,uBAAO,OAAO,IAAI,CAAC;AAChD,UAAM,iBAAiB;AAAA,MACrB;AAAA,MACA,KAAK,IAAI,kBAAkB,WAAW,CAAC;AAAA,IACzC;AACA,sBAAkB,IAAI,QAAQ,cAAc;AAC5C,WAAO;AAAA,EACT;AAEA,QAAM,iBAAiB,CAAC,WAA0B;AAChD,WAAO,MAAM;AACb,UAAM,iBAAiB,kBAAkB,IAAI,MAAM;AACnD,QAAI,mBAAmB,QAAW;AAChC,oBAAc,cAAqB;AACnC,wBAAkB,OAAO,MAAM;AAAA,IACjC;AAAA,EACF;AAEA,QAAM,mBAAmB,MAAY;AACnC,eAAW,UAAU,kBAAkB,KAAK,GAAG;AAC7C,qBAAe,MAAM;AAAA,IACvB;AAAA,EACF;AAEA,SAAO;AAAA,IACL,aAAa,OAAO,YAAY;AAAA,IAChC,eAAe,OAAO,cAAc;AAAA,IACpC;AAAA,EACF;AACF;AAEA,IAAM,kBAAkB;AAAA,EACtB,OAAO,CAAC,eAAe,eAAe;AAAA,EACtC,SAAS;AACX;AACA,IAAO,mBAAQ","sourcesContent":["import { rpcErrors } from '@metamask/rpc-errors';\n\nconst MINIMUM_INTERVAL = 10;\n\n/**\n * Creates a pair of `setInterval` and `clearInterval` functions attenuated such\n * that:\n * - `setInterval` throws if its \"handler\" parameter is not a function.\n * - `clearInterval` only clears timeouts created by its sibling `setInterval`,\n * or else no-ops.\n *\n * @returns An object with the attenuated `setInterval` and `clearInterval`\n * functions.\n */\nconst createInterval = () => {\n const registeredHandles = new Map<unknown, unknown>();\n\n const _setInterval = (handler: TimerHandler, timeout?: number): unknown => {\n if (typeof handler !== 'function') {\n throw rpcErrors.invalidInput(\n `The interval handler must be a function. Received: ${typeof handler}.`,\n );\n }\n harden(handler);\n const handle = Object.freeze(Object.create(null));\n const platformHandle = setInterval(\n handler,\n Math.max(MINIMUM_INTERVAL, timeout ?? 0),\n );\n registeredHandles.set(handle, platformHandle);\n return handle;\n };\n\n const _clearInterval = (handle: unknown): void => {\n harden(handle);\n const platformHandle = registeredHandles.get(handle);\n if (platformHandle !== undefined) {\n clearInterval(platformHandle as any);\n registeredHandles.delete(handle);\n }\n };\n\n const teardownFunction = (): void => {\n for (const handle of registeredHandles.keys()) {\n _clearInterval(handle);\n }\n };\n\n return {\n setInterval: harden(_setInterval),\n clearInterval: harden(_clearInterval),\n teardownFunction,\n } as const;\n};\n\nconst endowmentModule = {\n names: ['setInterval', 'clearInterval'] as const,\n factory: createInterval,\n};\nexport default endowmentModule;\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
// src/common/endowments/textEncoder.ts
|
|
2
|
+
var createTextEncoder = () => {
|
|
3
|
+
return {
|
|
4
|
+
TextEncoder: harden(TextEncoder)
|
|
5
|
+
};
|
|
6
|
+
};
|
|
7
|
+
var endowmentModule = {
|
|
8
|
+
names: ["TextEncoder"],
|
|
9
|
+
factory: createTextEncoder
|
|
10
|
+
};
|
|
11
|
+
var textEncoder_default = endowmentModule;
|
|
12
|
+
|
|
13
|
+
export {
|
|
14
|
+
textEncoder_default
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=chunk-HWS4QSOC.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/common/endowments/textEncoder.ts"],"sourcesContent":["/**\n * Creates TextEncoder function hardened by SES.\n *\n * @returns An object with the attenuated `TextEncoder` function.\n */\nconst createTextEncoder = () => {\n return {\n TextEncoder: harden(TextEncoder),\n } as const;\n};\n\nconst endowmentModule = {\n names: ['TextEncoder'] as const,\n factory: createTextEncoder,\n};\nexport default endowmentModule;\n"],"mappings":";AAKA,IAAM,oBAAoB,MAAM;AAC9B,SAAO;AAAA,IACL,aAAa,OAAO,WAAW;AAAA,EACjC;AACF;AAEA,IAAM,kBAAkB;AAAA,EACtB,OAAO,CAAC,aAAa;AAAA,EACrB,SAAS;AACX;AACA,IAAO,sBAAQ;","names":[]}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
var _chunkEXN2TFDJjs = require('./chunk-EXN2TFDJ.js');
|
|
6
|
+
|
|
7
|
+
// src/webview/WebViewExecutorStream.ts
|
|
8
|
+
var _postmessagestream = require('@metamask/post-message-stream');
|
|
9
|
+
var _utils = require('@metamask/post-message-stream/dist/utils');
|
|
10
|
+
var _utils3 = require('@metamask/utils');
|
|
11
|
+
var _name, _target, _targetWindow;
|
|
12
|
+
var WebViewExecutorStream = class extends _postmessagestream.BasePostMessageStream {
|
|
13
|
+
/**
|
|
14
|
+
* A special post-message-stream to be used by the WebView executor.
|
|
15
|
+
*
|
|
16
|
+
* This stream is different in a few ways:
|
|
17
|
+
* - It expects data to be base64 encoded
|
|
18
|
+
* - It stringifies the data it posts
|
|
19
|
+
* - It does less validation of origins
|
|
20
|
+
*
|
|
21
|
+
* @param args - Options bag.
|
|
22
|
+
* @param args.name - The name of the stream. Used to differentiate between
|
|
23
|
+
* multiple streams sharing the same window object. child:WebView
|
|
24
|
+
* @param args.target - The name of the stream to exchange messages with. parent:rnside
|
|
25
|
+
* @param args.targetWindow - The window object of the target stream.
|
|
26
|
+
*/
|
|
27
|
+
constructor({ name, target, targetWindow }) {
|
|
28
|
+
super();
|
|
29
|
+
_chunkEXN2TFDJjs.__privateAdd.call(void 0, this, _name, void 0);
|
|
30
|
+
_chunkEXN2TFDJjs.__privateAdd.call(void 0, this, _target, void 0);
|
|
31
|
+
_chunkEXN2TFDJjs.__privateAdd.call(void 0, this, _targetWindow, void 0);
|
|
32
|
+
_chunkEXN2TFDJjs.__privateSet.call(void 0, this, _name, name);
|
|
33
|
+
_chunkEXN2TFDJjs.__privateSet.call(void 0, this, _target, target);
|
|
34
|
+
_chunkEXN2TFDJjs.__privateSet.call(void 0, this, _targetWindow, targetWindow);
|
|
35
|
+
this._onMessage = this._onMessage.bind(this);
|
|
36
|
+
window.addEventListener("message", this._onMessage, false);
|
|
37
|
+
this._handshake();
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Webview needs to receive strings only on postMessage. That's the main difference between this and the original window post message stream.
|
|
41
|
+
* Reference: https://github.com/react-native-webview/react-native-webview/blob/master/docs/Guide.md?plain=1#L471
|
|
42
|
+
*/
|
|
43
|
+
_postMessage(data) {
|
|
44
|
+
_chunkEXN2TFDJjs.__privateGet.call(void 0, this, _targetWindow).postMessage(
|
|
45
|
+
JSON.stringify({
|
|
46
|
+
target: _chunkEXN2TFDJjs.__privateGet.call(void 0, this, _target),
|
|
47
|
+
data
|
|
48
|
+
})
|
|
49
|
+
);
|
|
50
|
+
}
|
|
51
|
+
_onMessage(event) {
|
|
52
|
+
if (typeof event.data !== "string") {
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
const bytes = _utils3.base64ToBytes.call(void 0, event.data);
|
|
56
|
+
const message = JSON.parse(_utils3.bytesToString.call(void 0, bytes));
|
|
57
|
+
if (!_utils.isValidStreamMessage.call(void 0, message) || message.target !== _chunkEXN2TFDJjs.__privateGet.call(void 0, this, _name)) {
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
this._onData(message.data);
|
|
61
|
+
}
|
|
62
|
+
_destroy() {
|
|
63
|
+
window.removeEventListener("message", this._onMessage, false);
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
_name = new WeakMap();
|
|
67
|
+
_target = new WeakMap();
|
|
68
|
+
_targetWindow = new WeakMap();
|
|
69
|
+
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
exports.WebViewExecutorStream = WebViewExecutorStream;
|
|
73
|
+
//# sourceMappingURL=chunk-I5G4YFHM.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/webview/WebViewExecutorStream.ts"],"names":[],"mappings":";;;;;;;AACA,SAAS,6BAA6B;AACtC,SAAS,4BAA4B;AACrC,SAAS,eAAe,qBAAqB;AAH7C;AAWO,IAAM,wBAAN,cAAoC,sBAAsB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAsB/D,YAAY,EAAE,MAAM,QAAQ,aAAa,GAA8B;AACrE,UAAM;AAtBR;AAEA;AAEA;AAoBE,uBAAK,OAAQ;AACb,uBAAK,SAAU;AACf,uBAAK,eAAgB;AAErB,SAAK,aAAa,KAAK,WAAW,KAAK,IAAI;AAI3C,WAAO,iBAAiB,WAAW,KAAK,YAAmB,KAAK;AAEhE,SAAK,WAAW;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA,EAOU,aAAa,MAAqB;AAC1C,uBAAK,eAAc;AAAA,MACjB,KAAK,UAAU;AAAA,QACb,QAAQ,mBAAK;AAAA,QACb;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AAAA,EAEQ,WAAW,OAA+B;AAChD,QAAI,OAAO,MAAM,SAAS,UAAU;AAClC;AAAA,IACF;AAEA,UAAM,QAAQ,cAAc,MAAM,IAAI;AACtC,UAAM,UAAU,KAAK,MAAM,cAAc,KAAK,CAAC;AAI/C,QAAI,CAAC,qBAAqB,OAAO,KAAK,QAAQ,WAAW,mBAAK,QAAO;AACnE;AAAA,IACF;AAEA,SAAK,QAAQ,QAAQ,IAAI;AAAA,EAC3B;AAAA,EAEA,WAAW;AAGT,WAAO,oBAAoB,WAAW,KAAK,YAAmB,KAAK;AAAA,EACrE;AACF;AAzEE;AAEA;AAEA","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 { base64ToBytes, 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 #name;\n\n #target;\n\n #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 private _onMessage(event: PostMessageEvent): void {\n if (typeof event.data !== 'string') {\n return;\n }\n\n const bytes = base64ToBytes(event.data);\n const message = JSON.parse(bytesToString(bytes));\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"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
// src/common/globalObject.ts
|
|
2
|
+
var _rootRealmGlobal;
|
|
3
|
+
var _rootRealmGlobalName;
|
|
4
|
+
if (typeof globalThis !== "undefined") {
|
|
5
|
+
_rootRealmGlobal = globalThis;
|
|
6
|
+
_rootRealmGlobalName = "globalThis" /* globalThis */;
|
|
7
|
+
} else if (typeof self !== "undefined") {
|
|
8
|
+
_rootRealmGlobal = self;
|
|
9
|
+
_rootRealmGlobalName = "self" /* self */;
|
|
10
|
+
} else if (typeof window !== "undefined") {
|
|
11
|
+
_rootRealmGlobal = window;
|
|
12
|
+
_rootRealmGlobalName = "window" /* window */;
|
|
13
|
+
} else if (typeof global !== "undefined") {
|
|
14
|
+
_rootRealmGlobal = global;
|
|
15
|
+
_rootRealmGlobalName = "global" /* global */;
|
|
16
|
+
} else {
|
|
17
|
+
throw new Error("Unknown realm type; failed to identify global object.");
|
|
18
|
+
}
|
|
19
|
+
var rootRealmGlobal = _rootRealmGlobal;
|
|
20
|
+
var rootRealmGlobalName = _rootRealmGlobalName;
|
|
21
|
+
|
|
22
|
+
export {
|
|
23
|
+
rootRealmGlobal,
|
|
24
|
+
rootRealmGlobalName
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=chunk-IX5S3V47.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/common/globalObject.ts"],"sourcesContent":["enum GlobalObjectNames {\n // The globalThis entry is incorrectly identified as shadowing the global\n // globalThis.\n /* eslint-disable @typescript-eslint/naming-convention */\n // eslint-disable-next-line @typescript-eslint/no-shadow\n globalThis = 'globalThis',\n global = 'global',\n self = 'self',\n window = 'window',\n /* eslint-enable @typescript-eslint/naming-convention */\n}\n\nlet _rootRealmGlobal: typeof globalThis;\nlet _rootRealmGlobalName: string;\n\n/* istanbul ignore next */\n/* eslint-disable no-negated-condition */\nif (typeof globalThis !== 'undefined') {\n _rootRealmGlobal = globalThis;\n _rootRealmGlobalName = GlobalObjectNames.globalThis;\n} else if (typeof self !== 'undefined') {\n _rootRealmGlobal = self;\n _rootRealmGlobalName = GlobalObjectNames.self;\n} else if (typeof window !== 'undefined') {\n _rootRealmGlobal = window;\n _rootRealmGlobalName = GlobalObjectNames.window;\n} else if (typeof global !== 'undefined') {\n _rootRealmGlobal = global;\n _rootRealmGlobalName = GlobalObjectNames.global;\n} else {\n throw new Error('Unknown realm type; failed to identify global object.');\n}\n/* eslint-enable no-negated-condition */\n\n/**\n * A platform-agnostic alias for the root realm global object.\n */\nconst rootRealmGlobal = _rootRealmGlobal;\n\n/**\n * The string literal corresponding to the name of the root realm global object.\n */\nconst rootRealmGlobalName = _rootRealmGlobalName;\n\nexport { rootRealmGlobal, rootRealmGlobalName };\n"],"mappings":";AAYA,IAAI;AACJ,IAAI;AAIJ,IAAI,OAAO,eAAe,aAAa;AACrC,qBAAmB;AACnB,yBAAuB;AACzB,WAAW,OAAO,SAAS,aAAa;AACtC,qBAAmB;AACnB,yBAAuB;AACzB,WAAW,OAAO,WAAW,aAAa;AACxC,qBAAmB;AACnB,yBAAuB;AACzB,WAAW,OAAO,WAAW,aAAa;AACxC,qBAAmB;AACnB,yBAAuB;AACzB,OAAO;AACL,QAAM,IAAI,MAAM,uDAAuD;AACzE;AAMA,IAAM,kBAAkB;AAKxB,IAAM,sBAAsB;","names":[]}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
2
|
+
|
|
3
|
+
var _chunkDTF6YTISjs = require('./chunk-DTF6YTIS.js');
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
var _chunkZ7BOREC4js = require('./chunk-Z7BOREC4.js');
|
|
7
|
+
|
|
8
|
+
// src/iframe/IFrameSnapExecutor.ts
|
|
9
|
+
var _objectmultiplex = require('@metamask/object-multiplex'); var _objectmultiplex2 = _interopRequireDefault(_objectmultiplex);
|
|
10
|
+
var _postmessagestream = require('@metamask/post-message-stream');
|
|
11
|
+
var _snapsutils = require('@metamask/snaps-utils');
|
|
12
|
+
var _readablestream = require('readable-stream');
|
|
13
|
+
var IFrameSnapExecutor = class _IFrameSnapExecutor extends _chunkDTF6YTISjs.BaseSnapExecutor {
|
|
14
|
+
/**
|
|
15
|
+
* Initialize the IFrameSnapExecutor. This creates a post message stream from
|
|
16
|
+
* and to the parent window, for two-way communication with the iframe.
|
|
17
|
+
*
|
|
18
|
+
* @param stream - The stream to use for communication.
|
|
19
|
+
* @returns An instance of `IFrameSnapExecutor`, with the initialized post
|
|
20
|
+
* message streams.
|
|
21
|
+
*/
|
|
22
|
+
static initialize(stream = new (0, _postmessagestream.WindowPostMessageStream)({
|
|
23
|
+
name: "child",
|
|
24
|
+
target: "parent",
|
|
25
|
+
targetWindow: self.parent,
|
|
26
|
+
targetOrigin: "*"
|
|
27
|
+
})) {
|
|
28
|
+
_chunkZ7BOREC4js.log.call(void 0, "Worker: Connecting to parent.");
|
|
29
|
+
const mux = new (0, _objectmultiplex2.default)();
|
|
30
|
+
_readablestream.pipeline.call(void 0, stream, mux, stream, (error) => {
|
|
31
|
+
if (error) {
|
|
32
|
+
_snapsutils.logError.call(void 0, `Parent stream failure, closing worker.`, error);
|
|
33
|
+
}
|
|
34
|
+
self.close();
|
|
35
|
+
});
|
|
36
|
+
const commandStream = mux.createStream(_snapsutils.SNAP_STREAM_NAMES.COMMAND);
|
|
37
|
+
const rpcStream = mux.createStream(_snapsutils.SNAP_STREAM_NAMES.JSON_RPC);
|
|
38
|
+
return new _IFrameSnapExecutor(commandStream, rpcStream);
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
exports.IFrameSnapExecutor = IFrameSnapExecutor;
|
|
45
|
+
//# sourceMappingURL=chunk-JW3JHJ7S.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/iframe/IFrameSnapExecutor.ts"],"names":[],"mappings":";;;;;;;;AAAA,OAAO,qBAAqB;AAE5B,SAAS,+BAA+B;AACxC,SAAS,UAAU,yBAAyB;AAC5C,SAAS,gBAAgB;AAKlB,IAAM,qBAAN,MAAM,4BAA2B,iBAAiB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASvD,OAAO,WACL,SAAgC,IAAI,wBAAwB;AAAA,IAC1D,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,cAAc,KAAK;AAAA,IACnB,cAAc;AAAA,EAChB,CAAC,GACD;AACA,QAAI,+BAA+B;AAEnC,UAAM,MAAM,IAAI,gBAAgB;AAChC,aAAS,QAAQ,KAAK,QAAQ,CAAC,UAAU;AACvC,UAAI,OAAO;AACT,iBAAS,0CAA0C,KAAK;AAAA,MAC1D;AACA,WAAK,MAAM;AAAA,IACb,CAAC;AAED,UAAM,gBAAgB,IAAI,aAAa,kBAAkB,OAAO;AAChE,UAAM,YAAY,IAAI,aAAa,kBAAkB,QAAQ;AAE7D,WAAO,IAAI,oBAAmB,eAAe,SAAS;AAAA,EACxD;AACF","sourcesContent":["import ObjectMultiplex from '@metamask/object-multiplex';\nimport type { BasePostMessageStream } from '@metamask/post-message-stream';\nimport { WindowPostMessageStream } from '@metamask/post-message-stream';\nimport { logError, SNAP_STREAM_NAMES } from '@metamask/snaps-utils';\nimport { pipeline } from 'readable-stream';\n\nimport { BaseSnapExecutor } from '../common/BaseSnapExecutor';\nimport { log } from '../logging';\n\nexport class IFrameSnapExecutor extends BaseSnapExecutor {\n /**\n * Initialize the IFrameSnapExecutor. This creates a post message stream from\n * and to the parent window, for two-way communication with the iframe.\n *\n * @param stream - The stream to use for communication.\n * @returns An instance of `IFrameSnapExecutor`, with the initialized post\n * message streams.\n */\n static initialize(\n stream: BasePostMessageStream = new WindowPostMessageStream({\n name: 'child',\n target: 'parent',\n targetWindow: self.parent,\n targetOrigin: '*',\n }),\n ) {\n log('Worker: Connecting to parent.');\n\n const mux = new ObjectMultiplex();\n pipeline(stream, mux, stream, (error) => {\n if (error) {\n logError(`Parent stream failure, closing worker.`, error);\n }\n self.close();\n });\n\n const commandStream = mux.createStream(SNAP_STREAM_NAMES.COMMAND);\n const rpcStream = mux.createStream(SNAP_STREAM_NAMES.JSON_RPC);\n\n return new IFrameSnapExecutor(commandStream, rpcStream);\n }\n}\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});// src/common/endowments/textEncoder.ts
|
|
2
|
+
var createTextEncoder = () => {
|
|
3
|
+
return {
|
|
4
|
+
TextEncoder: harden(TextEncoder)
|
|
5
|
+
};
|
|
6
|
+
};
|
|
7
|
+
var endowmentModule = {
|
|
8
|
+
names: ["TextEncoder"],
|
|
9
|
+
factory: createTextEncoder
|
|
10
|
+
};
|
|
11
|
+
var textEncoder_default = endowmentModule;
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
exports.textEncoder_default = textEncoder_default;
|
|
16
|
+
//# sourceMappingURL=chunk-LO5ORVRC.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/common/endowments/textEncoder.ts"],"names":[],"mappings":";AAKA,IAAM,oBAAoB,MAAM;AAC9B,SAAO;AAAA,IACL,aAAa,OAAO,WAAW;AAAA,EACjC;AACF;AAEA,IAAM,kBAAkB;AAAA,EACtB,OAAO,CAAC,aAAa;AAAA,EACrB,SAAS;AACX;AACA,IAAO,sBAAQ","sourcesContent":["/**\n * Creates TextEncoder function hardened by SES.\n *\n * @returns An object with the attenuated `TextEncoder` function.\n */\nconst createTextEncoder = () => {\n return {\n TextEncoder: harden(TextEncoder),\n } as const;\n};\n\nconst endowmentModule = {\n names: ['TextEncoder'] as const,\n factory: createTextEncoder,\n};\nexport default endowmentModule;\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";//# sourceMappingURL=chunk-MCXWFCGV.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":""}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import {
|
|
2
|
+
__privateAdd,
|
|
3
|
+
__privateGet,
|
|
4
|
+
__privateMethod,
|
|
5
|
+
__privateSet
|
|
6
|
+
} from "./chunk-YRZVIDCF.mjs";
|
|
7
|
+
|
|
8
|
+
// src/proxy/ProxySnapExecutor.ts
|
|
9
|
+
import { WindowPostMessageStream } from "@metamask/post-message-stream";
|
|
10
|
+
import packageJson from "@metamask/snaps-execution-environments/package.json";
|
|
11
|
+
import { createWindow, logError } from "@metamask/snaps-utils";
|
|
12
|
+
import { assert } from "@metamask/utils";
|
|
13
|
+
var IFRAME_URL = `https://execution.metamask.io/iframe/${packageJson.version}/index.html`;
|
|
14
|
+
var _stream, _frameUrl, _onData, onData_fn, _initializeJob, initializeJob_fn, _terminateJob, terminateJob_fn;
|
|
15
|
+
var _ProxySnapExecutor = class _ProxySnapExecutor {
|
|
16
|
+
constructor(stream, frameUrl) {
|
|
17
|
+
/**
|
|
18
|
+
* Handle an incoming message from a `ProxyExecutionService`. This
|
|
19
|
+
* assumes that the message contains a `jobId` property, and a JSON-RPC
|
|
20
|
+
* request in the `data` property.
|
|
21
|
+
*
|
|
22
|
+
* @param data - The message data.
|
|
23
|
+
* @param data.data - The JSON-RPC request.
|
|
24
|
+
* @param data.jobId - The job ID.
|
|
25
|
+
*/
|
|
26
|
+
__privateAdd(this, _onData);
|
|
27
|
+
/**
|
|
28
|
+
* Create a new iframe and set up a stream to communicate with it.
|
|
29
|
+
*
|
|
30
|
+
* @param jobId - The job ID.
|
|
31
|
+
*/
|
|
32
|
+
__privateAdd(this, _initializeJob);
|
|
33
|
+
/**
|
|
34
|
+
* Terminate the job with the given ID. This will close the iframe and delete
|
|
35
|
+
* the job from the internal job map.
|
|
36
|
+
*
|
|
37
|
+
* @param jobId - The job ID.
|
|
38
|
+
*/
|
|
39
|
+
__privateAdd(this, _terminateJob);
|
|
40
|
+
__privateAdd(this, _stream, void 0);
|
|
41
|
+
__privateAdd(this, _frameUrl, void 0);
|
|
42
|
+
this.jobs = {};
|
|
43
|
+
__privateSet(this, _stream, stream);
|
|
44
|
+
__privateGet(this, _stream).on("data", __privateMethod(this, _onData, onData_fn).bind(this));
|
|
45
|
+
__privateSet(this, _frameUrl, frameUrl);
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Initialize the executor with the given stream. This is a wrapper around the
|
|
49
|
+
* constructor.
|
|
50
|
+
*
|
|
51
|
+
* @param stream - The stream to use for communication.
|
|
52
|
+
* @param frameUrl - An optional URL for the iframe to use.
|
|
53
|
+
* @returns The initialized executor.
|
|
54
|
+
*/
|
|
55
|
+
static initialize(stream, frameUrl = IFRAME_URL) {
|
|
56
|
+
return new _ProxySnapExecutor(stream, frameUrl);
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
_stream = new WeakMap();
|
|
60
|
+
_frameUrl = new WeakMap();
|
|
61
|
+
_onData = new WeakSet();
|
|
62
|
+
onData_fn = function(data) {
|
|
63
|
+
const { jobId, data: request } = data;
|
|
64
|
+
if (!this.jobs[jobId]) {
|
|
65
|
+
__privateMethod(this, _initializeJob, initializeJob_fn).call(this, jobId).then(() => {
|
|
66
|
+
__privateMethod(this, _onData, onData_fn).call(this, data);
|
|
67
|
+
}).catch((error) => {
|
|
68
|
+
logError("[Worker] Error initializing job:", error);
|
|
69
|
+
});
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
if (request.method === "terminateJob") {
|
|
73
|
+
__privateMethod(this, _terminateJob, terminateJob_fn).call(this, jobId);
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
this.jobs[jobId].stream.write(request);
|
|
77
|
+
};
|
|
78
|
+
_initializeJob = new WeakSet();
|
|
79
|
+
initializeJob_fn = async function(jobId) {
|
|
80
|
+
const window = await createWindow(__privateGet(this, _frameUrl), jobId);
|
|
81
|
+
const jobStream = new WindowPostMessageStream({
|
|
82
|
+
name: "parent",
|
|
83
|
+
target: "child",
|
|
84
|
+
targetWindow: window,
|
|
85
|
+
// iframe's internal window
|
|
86
|
+
targetOrigin: "*"
|
|
87
|
+
});
|
|
88
|
+
jobStream.on("data", (data) => {
|
|
89
|
+
__privateGet(this, _stream).write({ data, jobId });
|
|
90
|
+
});
|
|
91
|
+
this.jobs[jobId] = { id: jobId, window, stream: jobStream };
|
|
92
|
+
return this.jobs[jobId];
|
|
93
|
+
};
|
|
94
|
+
_terminateJob = new WeakSet();
|
|
95
|
+
terminateJob_fn = function(jobId) {
|
|
96
|
+
assert(this.jobs[jobId], `Job "${jobId}" not found.`);
|
|
97
|
+
const iframe = document.getElementById(jobId);
|
|
98
|
+
assert(iframe, `Iframe with ID "${jobId}" not found.`);
|
|
99
|
+
iframe.remove();
|
|
100
|
+
this.jobs[jobId].stream.destroy();
|
|
101
|
+
delete this.jobs[jobId];
|
|
102
|
+
};
|
|
103
|
+
var ProxySnapExecutor = _ProxySnapExecutor;
|
|
104
|
+
|
|
105
|
+
export {
|
|
106
|
+
ProxySnapExecutor
|
|
107
|
+
};
|
|
108
|
+
//# sourceMappingURL=chunk-MIWGLICQ.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/proxy/ProxySnapExecutor.ts"],"sourcesContent":["import type { BasePostMessageStream } from '@metamask/post-message-stream';\nimport { WindowPostMessageStream } from '@metamask/post-message-stream';\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport packageJson from '@metamask/snaps-execution-environments/package.json';\nimport { createWindow, logError } from '@metamask/snaps-utils';\nimport type { JsonRpcRequest } from '@metamask/utils';\nimport { assert } from '@metamask/utils';\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 */\n async #initializeJob(jobId: string): Promise<ExecutorJob> {\n const window = await createWindow(this.#frameUrl, 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"],"mappings":";;;;;;;;AACA,SAAS,+BAA+B;AAExC,OAAO,iBAAiB;AACxB,SAAS,cAAc,gBAAgB;AAEvC,SAAS,cAAc;AAQvB,IAAM,aAAa,wCAAwC,YAAY,OAAO;AAd9E;AA6BO,IAAM,qBAAN,MAAM,mBAAkB;AAAA,EAmB7B,YAAY,QAA+B,UAAkB;AAe7D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAiCA;AAAA;AAAA;AAAA;AAAA;AAAA,uBAAM;AAwBN;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA1FA,uBAAS,SAAT;AAEA,uBAAS,WAAT;AAEA,SAAS,OAAoC,CAAC;AAe5C,uBAAK,SAAU;AACf,uBAAK,SAAQ,GAAG,QAAQ,sBAAK,oBAAQ,KAAK,IAAI,CAAC;AAC/C,uBAAK,WAAY;AAAA,EACnB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EARA,OAAO,WAAW,QAA+B,WAAW,YAAY;AACtE,WAAO,IAAI,mBAAkB,QAAQ,QAAQ;AAAA,EAC/C;AAoFF;AApGW;AAEA;AA+BT;AAAA,YAAO,SAAC,MAA+C;AACrD,QAAM,EAAE,OAAO,MAAM,QAAQ,IAAI;AAEjC,MAAI,CAAC,KAAK,KAAK,KAAK,GAAG;AAIrB,0BAAK,kCAAL,WAAoB,OACjB,KAAK,MAAM;AACV,4BAAK,oBAAL,WAAa;AAAA,IACf,CAAC,EACA,MAAM,CAAC,UAAU;AAChB,eAAS,oCAAoC,KAAK;AAAA,IACpD,CAAC;AAEH;AAAA,EACF;AAIA,MAAI,QAAQ,WAAW,gBAAgB;AACrC,0BAAK,gCAAL,WAAmB;AACnB;AAAA,EACF;AAEA,OAAK,KAAK,KAAK,EAAE,OAAO,MAAM,OAAO;AACvC;AAOM;AAAA,mBAAc,eAAC,OAAqC;AACxD,QAAM,SAAS,MAAM,aAAa,mBAAK,YAAW,KAAK;AACvD,QAAM,YAAY,IAAI,wBAAwB;AAAA,IAC5C,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,cAAc;AAAA;AAAA,IACd,cAAc;AAAA,EAChB,CAAC;AAGD,YAAU,GAAG,QAAQ,CAAC,SAAS;AAC7B,uBAAK,SAAQ,MAAM,EAAE,MAAM,MAAM,CAAC;AAAA,EACpC,CAAC;AAED,OAAK,KAAK,KAAK,IAAI,EAAE,IAAI,OAAO,QAAQ,QAAQ,UAAU;AAC1D,SAAO,KAAK,KAAK,KAAK;AACxB;AAQA;AAAA,kBAAa,SAAC,OAAe;AAC3B,SAAO,KAAK,KAAK,KAAK,GAAG,QAAQ,KAAK,cAAc;AAEpD,QAAM,SAAS,SAAS,eAAe,KAAK;AAC5C,SAAO,QAAQ,mBAAmB,KAAK,cAAc;AAErD,SAAO,OAAO;AACd,OAAK,KAAK,KAAK,EAAE,OAAO,QAAQ;AAChC,SAAO,KAAK,KAAK,KAAK;AACxB;AApGK,IAAM,oBAAN;","names":[]}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import {
|
|
2
|
+
assertIsOnNameLookupRequestArguments,
|
|
3
|
+
assertIsOnSignatureRequestArguments,
|
|
4
|
+
assertIsOnTransactionRequestArguments,
|
|
5
|
+
assertIsOnUserInputRequestArguments
|
|
6
|
+
} from "./chunk-WV3CXIKN.mjs";
|
|
7
|
+
|
|
8
|
+
// src/common/commands.ts
|
|
9
|
+
import { HandlerType } from "@metamask/snaps-utils";
|
|
10
|
+
import { assertExhaustive } from "@metamask/utils";
|
|
11
|
+
function getHandlerArguments(origin, handler, request) {
|
|
12
|
+
switch (handler) {
|
|
13
|
+
case HandlerType.OnTransaction: {
|
|
14
|
+
assertIsOnTransactionRequestArguments(request.params);
|
|
15
|
+
const { transaction, chainId, transactionOrigin } = request.params;
|
|
16
|
+
return {
|
|
17
|
+
transaction,
|
|
18
|
+
chainId,
|
|
19
|
+
transactionOrigin
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
case HandlerType.OnSignature: {
|
|
23
|
+
assertIsOnSignatureRequestArguments(request.params);
|
|
24
|
+
const { signature, signatureOrigin } = request.params;
|
|
25
|
+
return { signature, signatureOrigin };
|
|
26
|
+
}
|
|
27
|
+
case HandlerType.OnNameLookup: {
|
|
28
|
+
assertIsOnNameLookupRequestArguments(request.params);
|
|
29
|
+
const { chainId, domain, address } = request.params;
|
|
30
|
+
return domain ? {
|
|
31
|
+
chainId,
|
|
32
|
+
domain
|
|
33
|
+
} : {
|
|
34
|
+
chainId,
|
|
35
|
+
address
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
case HandlerType.OnRpcRequest:
|
|
39
|
+
case HandlerType.OnKeyringRequest:
|
|
40
|
+
return { origin, request };
|
|
41
|
+
case HandlerType.OnCronjob:
|
|
42
|
+
case HandlerType.OnInstall:
|
|
43
|
+
case HandlerType.OnUpdate:
|
|
44
|
+
return { request };
|
|
45
|
+
case HandlerType.OnHomePage:
|
|
46
|
+
return {};
|
|
47
|
+
case HandlerType.OnUserInput: {
|
|
48
|
+
assertIsOnUserInputRequestArguments(request.params);
|
|
49
|
+
const { id, event } = request.params;
|
|
50
|
+
return { id, event };
|
|
51
|
+
}
|
|
52
|
+
default:
|
|
53
|
+
return assertExhaustive(handler);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
function getCommandMethodImplementations(startSnap, invokeSnap, onTerminate) {
|
|
57
|
+
return {
|
|
58
|
+
ping: async () => Promise.resolve("OK"),
|
|
59
|
+
terminate: async () => {
|
|
60
|
+
onTerminate();
|
|
61
|
+
return Promise.resolve("OK");
|
|
62
|
+
},
|
|
63
|
+
executeSnap: async (snapId, sourceCode, endowments) => {
|
|
64
|
+
await startSnap(snapId, sourceCode, endowments);
|
|
65
|
+
return "OK";
|
|
66
|
+
},
|
|
67
|
+
snapRpc: async (target, handler, origin, request) => {
|
|
68
|
+
return await invokeSnap(
|
|
69
|
+
target,
|
|
70
|
+
handler,
|
|
71
|
+
getHandlerArguments(origin, handler, request)
|
|
72
|
+
) ?? null;
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
export {
|
|
78
|
+
getHandlerArguments,
|
|
79
|
+
getCommandMethodImplementations
|
|
80
|
+
};
|
|
81
|
+
//# sourceMappingURL=chunk-MM6ZSW4E.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/common/commands.ts"],"sourcesContent":["import { HandlerType } from '@metamask/snaps-utils';\nimport { assertExhaustive } from '@metamask/utils';\n\nimport type { InvokeSnap, InvokeSnapArgs } from './BaseSnapExecutor';\nimport type {\n ExecuteSnap,\n JsonRpcRequestWithoutId,\n Ping,\n PossibleLookupRequestArgs,\n SnapRpc,\n Terminate,\n} from './validation';\nimport {\n assertIsOnTransactionRequestArguments,\n assertIsOnSignatureRequestArguments,\n assertIsOnNameLookupRequestArguments,\n assertIsOnUserInputRequestArguments,\n} from './validation';\n\nexport type CommandMethodsMapping = {\n ping: Ping;\n terminate: Terminate;\n executeSnap: ExecuteSnap;\n snapRpc: SnapRpc;\n};\n\n/**\n * Formats the arguments for the given handler.\n *\n * @param origin - The origin of the request.\n * @param handler - The handler to pass the request to.\n * @param request - The request object.\n * @returns The formatted arguments.\n */\nexport function getHandlerArguments(\n origin: string,\n handler: HandlerType,\n request: JsonRpcRequestWithoutId,\n): InvokeSnapArgs {\n // `request` is already validated by the time this function is called.\n\n switch (handler) {\n case HandlerType.OnTransaction: {\n assertIsOnTransactionRequestArguments(request.params);\n\n const { transaction, chainId, transactionOrigin } = request.params;\n return {\n transaction,\n chainId,\n transactionOrigin,\n };\n }\n case HandlerType.OnSignature: {\n assertIsOnSignatureRequestArguments(request.params);\n\n const { signature, signatureOrigin } = request.params;\n return { signature, signatureOrigin };\n }\n case HandlerType.OnNameLookup: {\n assertIsOnNameLookupRequestArguments(request.params);\n\n // TS complains that domain/address are not part of the type\n // casting here as we've already validated the request args in the above step.\n const { chainId, domain, address } =\n request.params as unknown as PossibleLookupRequestArgs;\n\n return domain\n ? {\n chainId,\n domain,\n }\n : {\n chainId,\n address,\n };\n }\n case HandlerType.OnRpcRequest:\n case HandlerType.OnKeyringRequest:\n return { origin, request };\n\n case HandlerType.OnCronjob:\n case HandlerType.OnInstall:\n case HandlerType.OnUpdate:\n return { request };\n\n case HandlerType.OnHomePage:\n return {};\n case HandlerType.OnUserInput: {\n assertIsOnUserInputRequestArguments(request.params);\n\n const { id, event } = request.params;\n return { id, event };\n }\n\n default:\n return assertExhaustive(handler);\n }\n}\n\n/**\n * Gets an object mapping internal, \"command\" JSON-RPC method names to their\n * implementations.\n *\n * @param startSnap - A function that starts a snap.\n * @param invokeSnap - A function that invokes the RPC method handler of a\n * snap.\n * @param onTerminate - A function that will be called when this executor is\n * terminated in order to handle cleanup tasks.\n * @returns An object containing the \"command\" method implementations.\n */\nexport function getCommandMethodImplementations(\n startSnap: (...args: Parameters<ExecuteSnap>) => Promise<void>,\n invokeSnap: InvokeSnap,\n onTerminate: () => void,\n): CommandMethodsMapping {\n return {\n ping: async () => Promise.resolve('OK'),\n terminate: async () => {\n onTerminate();\n return Promise.resolve('OK');\n },\n\n executeSnap: async (snapId, sourceCode, endowments) => {\n await startSnap(snapId, sourceCode, endowments);\n return 'OK';\n },\n\n snapRpc: async (target, handler, origin, request) => {\n return (\n (await invokeSnap(\n target,\n handler,\n getHandlerArguments(origin, handler, request),\n )) ?? null\n );\n },\n };\n}\n"],"mappings":";;;;;;;;AAAA,SAAS,mBAAmB;AAC5B,SAAS,wBAAwB;AAiC1B,SAAS,oBACd,QACA,SACA,SACgB;AAGhB,UAAQ,SAAS;AAAA,IACf,KAAK,YAAY,eAAe;AAC9B,4CAAsC,QAAQ,MAAM;AAEpD,YAAM,EAAE,aAAa,SAAS,kBAAkB,IAAI,QAAQ;AAC5D,aAAO;AAAA,QACL;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAAA,IACF;AAAA,IACA,KAAK,YAAY,aAAa;AAC5B,0CAAoC,QAAQ,MAAM;AAElD,YAAM,EAAE,WAAW,gBAAgB,IAAI,QAAQ;AAC/C,aAAO,EAAE,WAAW,gBAAgB;AAAA,IACtC;AAAA,IACA,KAAK,YAAY,cAAc;AAC7B,2CAAqC,QAAQ,MAAM;AAInD,YAAM,EAAE,SAAS,QAAQ,QAAQ,IAC/B,QAAQ;AAEV,aAAO,SACH;AAAA,QACE;AAAA,QACA;AAAA,MACF,IACA;AAAA,QACE;AAAA,QACA;AAAA,MACF;AAAA,IACN;AAAA,IACA,KAAK,YAAY;AAAA,IACjB,KAAK,YAAY;AACf,aAAO,EAAE,QAAQ,QAAQ;AAAA,IAE3B,KAAK,YAAY;AAAA,IACjB,KAAK,YAAY;AAAA,IACjB,KAAK,YAAY;AACf,aAAO,EAAE,QAAQ;AAAA,IAEnB,KAAK,YAAY;AACf,aAAO,CAAC;AAAA,IACV,KAAK,YAAY,aAAa;AAC5B,0CAAoC,QAAQ,MAAM;AAElD,YAAM,EAAE,IAAI,MAAM,IAAI,QAAQ;AAC9B,aAAO,EAAE,IAAI,MAAM;AAAA,IACrB;AAAA,IAEA;AACE,aAAO,iBAAiB,OAAO;AAAA,EACnC;AACF;AAaO,SAAS,gCACd,WACA,YACA,aACuB;AACvB,SAAO;AAAA,IACL,MAAM,YAAY,QAAQ,QAAQ,IAAI;AAAA,IACtC,WAAW,YAAY;AACrB,kBAAY;AACZ,aAAO,QAAQ,QAAQ,IAAI;AAAA,IAC7B;AAAA,IAEA,aAAa,OAAO,QAAQ,YAAY,eAAe;AACrD,YAAM,UAAU,QAAQ,YAAY,UAAU;AAC9C,aAAO;AAAA,IACT;AAAA,IAEA,SAAS,OAAO,QAAQ,SAAS,QAAQ,YAAY;AACnD,aACG,MAAM;AAAA,QACL;AAAA,QACA;AAAA,QACA,oBAAoB,QAAQ,SAAS,OAAO;AAAA,MAC9C,KAAM;AAAA,IAEV;AAAA,EACF;AACF;","names":[]}
|