@metamask/snaps-execution-environments 6.6.2 → 6.7.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.
Files changed (526) hide show
  1. package/CHANGELOG.md +18 -1
  2. package/dist/common/BaseSnapExecutor.cjs +436 -0
  3. package/dist/common/BaseSnapExecutor.cjs.map +1 -0
  4. package/dist/{types/common/BaseSnapExecutor.d.ts → common/BaseSnapExecutor.d.cts} +8 -6
  5. package/dist/common/BaseSnapExecutor.d.cts.map +1 -0
  6. package/dist/common/BaseSnapExecutor.d.mts +70 -0
  7. package/dist/common/BaseSnapExecutor.d.mts.map +1 -0
  8. package/dist/common/BaseSnapExecutor.mjs +430 -24
  9. package/dist/common/BaseSnapExecutor.mjs.map +1 -1
  10. package/dist/common/commands.cjs +95 -0
  11. package/dist/common/commands.cjs.map +1 -0
  12. package/dist/{types/common/commands.d.ts → common/commands.d.cts} +5 -4
  13. package/dist/common/commands.d.cts.map +1 -0
  14. package/dist/common/commands.d.mts +31 -0
  15. package/dist/common/commands.d.mts.map +1 -0
  16. package/dist/common/commands.mjs +89 -10
  17. package/dist/common/commands.mjs.map +1 -1
  18. package/dist/common/endowments/commonEndowmentFactory.cjs +76 -0
  19. package/dist/common/endowments/commonEndowmentFactory.cjs.map +1 -0
  20. package/dist/{types/common/endowments/commonEndowmentFactory.d.ts → common/endowments/commonEndowmentFactory.d.cts} +5 -4
  21. package/dist/common/endowments/commonEndowmentFactory.d.cts.map +1 -0
  22. package/dist/common/endowments/commonEndowmentFactory.d.mts +26 -0
  23. package/dist/common/endowments/commonEndowmentFactory.d.mts.map +1 -0
  24. package/dist/common/endowments/commonEndowmentFactory.mjs +69 -18
  25. package/dist/common/endowments/commonEndowmentFactory.mjs.map +1 -1
  26. package/dist/common/endowments/console.cjs +103 -0
  27. package/dist/common/endowments/console.cjs.map +1 -0
  28. package/dist/{types/common/endowments/console.d.ts → common/endowments/console.d.cts} +2 -1
  29. package/dist/common/endowments/console.d.cts.map +1 -0
  30. package/dist/common/endowments/console.d.mts +46 -0
  31. package/dist/common/endowments/console.d.mts.map +1 -0
  32. package/dist/common/endowments/console.mjs +98 -11
  33. package/dist/common/endowments/console.mjs.map +1 -1
  34. package/dist/common/endowments/crypto.cjs +30 -0
  35. package/dist/common/endowments/crypto.cjs.map +1 -0
  36. package/dist/{types/common/endowments/crypto.d.ts → common/endowments/crypto.d.cts} +1 -0
  37. package/dist/common/endowments/crypto.d.cts.map +1 -0
  38. package/dist/common/endowments/crypto.d.mts +13 -0
  39. package/dist/common/endowments/crypto.d.mts.map +1 -0
  40. package/dist/common/endowments/crypto.mjs +26 -9
  41. package/dist/common/endowments/crypto.mjs.map +1 -1
  42. package/dist/common/endowments/date.cjs +39 -0
  43. package/dist/common/endowments/date.cjs.map +1 -0
  44. package/dist/{types/common/endowments/date.d.ts → common/endowments/date.d.cts} +1 -0
  45. package/dist/common/endowments/date.d.cts.map +1 -0
  46. package/dist/common/endowments/date.d.mts +16 -0
  47. package/dist/common/endowments/date.d.mts.map +1 -0
  48. package/dist/common/endowments/date.mjs +35 -7
  49. package/dist/common/endowments/date.mjs.map +1 -1
  50. package/dist/common/endowments/index.cjs +93 -0
  51. package/dist/common/endowments/index.cjs.map +1 -0
  52. package/dist/{types/common/endowments/index.d.ts → common/endowments/index.d.cts} +4 -3
  53. package/dist/common/endowments/index.d.cts.map +1 -0
  54. package/dist/common/endowments/index.d.mts +29 -0
  55. package/dist/common/endowments/index.d.mts.map +1 -0
  56. package/dist/common/endowments/index.mjs +85 -20
  57. package/dist/common/endowments/index.mjs.map +1 -1
  58. package/dist/common/endowments/interval.cjs +51 -0
  59. package/dist/common/endowments/interval.cjs.map +1 -0
  60. package/dist/{types/common/endowments/interval.d.ts → common/endowments/interval.d.cts} +1 -0
  61. package/dist/common/endowments/interval.d.cts.map +1 -0
  62. package/dist/common/endowments/interval.d.mts +10 -0
  63. package/dist/common/endowments/interval.d.mts.map +1 -0
  64. package/dist/common/endowments/interval.mjs +47 -6
  65. package/dist/common/endowments/interval.mjs.map +1 -1
  66. package/dist/common/endowments/math.cjs +54 -0
  67. package/dist/common/endowments/math.cjs.map +1 -0
  68. package/dist/{types/common/endowments/math.d.ts → common/endowments/math.d.cts} +1 -0
  69. package/dist/common/endowments/math.d.cts.map +1 -0
  70. package/dist/common/endowments/math.d.mts +61 -0
  71. package/dist/common/endowments/math.d.mts.map +1 -0
  72. package/dist/common/endowments/math.mjs +50 -8
  73. package/dist/common/endowments/math.mjs.map +1 -1
  74. package/dist/common/endowments/network.cjs +255 -0
  75. package/dist/common/endowments/network.cjs.map +1 -0
  76. package/dist/{types/common/endowments/network.d.ts → common/endowments/network.d.cts} +4 -2
  77. package/dist/common/endowments/network.d.cts.map +1 -0
  78. package/dist/common/endowments/network.d.mts +25 -0
  79. package/dist/common/endowments/network.d.mts.map +1 -0
  80. package/dist/common/endowments/network.mjs +251 -8
  81. package/dist/common/endowments/network.mjs.map +1 -1
  82. package/dist/common/endowments/textDecoder.cjs +18 -0
  83. package/dist/common/endowments/textDecoder.cjs.map +1 -0
  84. package/dist/{types/common/endowments/textDecoder.d.ts → common/endowments/textDecoder.d.cts} +1 -0
  85. package/dist/common/endowments/textDecoder.d.cts.map +1 -0
  86. package/dist/common/endowments/textDecoder.d.mts +11 -0
  87. package/dist/common/endowments/textDecoder.d.mts.map +1 -0
  88. package/dist/common/endowments/textDecoder.mjs +14 -6
  89. package/dist/common/endowments/textDecoder.mjs.map +1 -1
  90. package/dist/common/endowments/textEncoder.cjs +18 -0
  91. package/dist/common/endowments/textEncoder.cjs.map +1 -0
  92. package/dist/{types/common/endowments/textEncoder.d.ts → common/endowments/textEncoder.d.cts} +1 -0
  93. package/dist/common/endowments/textEncoder.d.cts.map +1 -0
  94. package/dist/common/endowments/textEncoder.d.mts +11 -0
  95. package/dist/common/endowments/textEncoder.d.mts.map +1 -0
  96. package/dist/common/endowments/textEncoder.mjs +14 -6
  97. package/dist/common/endowments/textEncoder.mjs.map +1 -1
  98. package/dist/common/endowments/timeout.cjs +53 -0
  99. package/dist/common/endowments/timeout.cjs.map +1 -0
  100. package/dist/{types/common/endowments/timeout.d.ts → common/endowments/timeout.d.cts} +1 -0
  101. package/dist/common/endowments/timeout.d.cts.map +1 -0
  102. package/dist/common/endowments/timeout.d.mts +10 -0
  103. package/dist/common/endowments/timeout.d.mts.map +1 -0
  104. package/dist/common/endowments/timeout.mjs +49 -6
  105. package/dist/common/endowments/timeout.mjs.map +1 -1
  106. package/dist/common/globalEvents.cjs +48 -0
  107. package/dist/common/globalEvents.cjs.map +1 -0
  108. package/dist/{types/common/globalEvents.d.ts → common/globalEvents.d.cts} +1 -0
  109. package/dist/common/globalEvents.d.cts.map +1 -0
  110. package/dist/common/globalEvents.d.mts +21 -0
  111. package/dist/common/globalEvents.d.mts.map +1 -0
  112. package/dist/common/globalEvents.mjs +42 -10
  113. package/dist/common/globalEvents.mjs.map +1 -1
  114. package/dist/common/globalObject.cjs +50 -0
  115. package/dist/common/globalObject.cjs.map +1 -0
  116. package/dist/{types/common/globalObject.d.ts → common/globalObject.d.cts} +1 -0
  117. package/dist/common/globalObject.d.cts.map +1 -0
  118. package/dist/common/globalObject.d.mts +10 -0
  119. package/dist/common/globalObject.d.mts.map +1 -0
  120. package/dist/common/globalObject.mjs +45 -9
  121. package/dist/common/globalObject.mjs.map +1 -1
  122. package/dist/common/lockdown/lockdown-events.cjs +60 -0
  123. package/dist/common/lockdown/lockdown-events.cjs.map +1 -0
  124. package/dist/{types/common/lockdown/lockdown-events.d.ts → common/lockdown/lockdown-events.d.cts} +1 -0
  125. package/dist/common/lockdown/lockdown-events.d.cts.map +1 -0
  126. package/dist/common/lockdown/lockdown-events.d.mts +5 -0
  127. package/dist/common/lockdown/lockdown-events.d.mts.map +1 -0
  128. package/dist/common/lockdown/lockdown-events.mjs +55 -7
  129. package/dist/common/lockdown/lockdown-events.mjs.map +1 -1
  130. package/dist/common/lockdown/lockdown-more.cjs +89 -0
  131. package/dist/common/lockdown/lockdown-more.cjs.map +1 -0
  132. package/dist/{types/common/lockdown/lockdown-more.d.ts → common/lockdown/lockdown-more.d.cts} +1 -0
  133. package/dist/common/lockdown/lockdown-more.d.cts.map +1 -0
  134. package/dist/common/lockdown/lockdown-more.d.mts +23 -0
  135. package/dist/common/lockdown/lockdown-more.d.mts.map +1 -0
  136. package/dist/common/lockdown/lockdown-more.mjs +84 -7
  137. package/dist/common/lockdown/lockdown-more.mjs.map +1 -1
  138. package/dist/common/lockdown/lockdown.cjs +29 -0
  139. package/dist/common/lockdown/lockdown.cjs.map +1 -0
  140. package/dist/{types/common/lockdown/lockdown.d.ts → common/lockdown/lockdown.d.cts} +1 -0
  141. package/dist/common/lockdown/lockdown.d.cts.map +1 -0
  142. package/dist/common/lockdown/lockdown.d.mts +8 -0
  143. package/dist/common/lockdown/lockdown.d.mts.map +1 -0
  144. package/dist/common/lockdown/lockdown.mjs +22 -19
  145. package/dist/common/lockdown/lockdown.mjs.map +1 -1
  146. package/dist/common/sortParams.cjs +35 -0
  147. package/dist/common/sortParams.cjs.map +1 -0
  148. package/dist/{types/common/sortParams.d.ts → common/sortParams.d.cts} +2 -1
  149. package/dist/common/sortParams.d.cts.map +1 -0
  150. package/dist/common/sortParams.d.mts +17 -0
  151. package/dist/common/sortParams.d.mts.map +1 -0
  152. package/dist/common/sortParams.mjs +29 -6
  153. package/dist/common/sortParams.mjs.map +1 -1
  154. package/dist/common/utils.cjs +156 -0
  155. package/dist/common/utils.cjs.map +1 -0
  156. package/dist/{types/common/utils.d.ts → common/utils.d.cts} +2 -1
  157. package/dist/common/utils.d.cts.map +1 -0
  158. package/dist/common/utils.d.mts +50 -0
  159. package/dist/common/utils.d.mts.map +1 -0
  160. package/dist/common/utils.mjs +146 -20
  161. package/dist/common/utils.mjs.map +1 -1
  162. package/dist/common/validation.cjs +137 -0
  163. package/dist/common/validation.cjs.map +1 -0
  164. package/dist/{types/common/validation.d.ts → common/validation.d.cts} +37 -36
  165. package/dist/common/validation.d.cts.map +1 -0
  166. package/dist/common/validation.d.mts +199 -0
  167. package/dist/common/validation.d.mts.map +1 -0
  168. package/dist/common/validation.mjs +127 -37
  169. package/dist/common/validation.mjs.map +1 -1
  170. package/dist/iframe/IFrameSnapExecutor.cjs +42 -0
  171. package/dist/iframe/IFrameSnapExecutor.cjs.map +1 -0
  172. package/dist/{types/iframe/IFrameSnapExecutor.d.ts → iframe/IFrameSnapExecutor.d.cts} +3 -2
  173. package/dist/iframe/IFrameSnapExecutor.d.cts.map +1 -0
  174. package/dist/iframe/IFrameSnapExecutor.d.mts +14 -0
  175. package/dist/iframe/IFrameSnapExecutor.d.mts.map +1 -0
  176. package/dist/iframe/IFrameSnapExecutor.mjs +42 -26
  177. package/dist/iframe/IFrameSnapExecutor.mjs.map +1 -1
  178. package/dist/iframe/index.cjs +10 -0
  179. package/dist/iframe/index.cjs.map +1 -0
  180. package/dist/iframe/index.d.cts +2 -0
  181. package/dist/iframe/index.d.cts.map +1 -0
  182. package/dist/iframe/index.d.mts +2 -0
  183. package/dist/iframe/index.d.mts.map +1 -0
  184. package/dist/iframe/index.mjs +4 -31
  185. package/dist/iframe/index.mjs.map +1 -1
  186. package/dist/index.cjs +18 -0
  187. package/dist/index.cjs.map +1 -0
  188. package/dist/index.d.cts +2 -0
  189. package/dist/index.d.cts.map +1 -0
  190. package/dist/index.d.mts +2 -0
  191. package/dist/index.d.mts.map +1 -0
  192. package/dist/index.mjs +1 -8
  193. package/dist/index.mjs.map +1 -1
  194. package/dist/logging.cjs +13 -0
  195. package/dist/logging.cjs.map +1 -0
  196. package/dist/{types/logging.d.ts → logging.d.cts} +1 -0
  197. package/dist/logging.d.cts.map +1 -0
  198. package/dist/logging.d.mts +9 -0
  199. package/dist/logging.d.mts.map +1 -0
  200. package/dist/logging.mjs +9 -7
  201. package/dist/logging.mjs.map +1 -1
  202. package/dist/node-process/ChildProcessSnapExecutor.cjs +30 -0
  203. package/dist/node-process/ChildProcessSnapExecutor.cjs.map +1 -0
  204. package/dist/{types/node-process/ChildProcessSnapExecutor.d.ts → node-process/ChildProcessSnapExecutor.d.cts} +2 -1
  205. package/dist/node-process/ChildProcessSnapExecutor.d.cts.map +1 -0
  206. package/dist/node-process/ChildProcessSnapExecutor.d.mts +5 -0
  207. package/dist/node-process/ChildProcessSnapExecutor.d.mts.map +1 -0
  208. package/dist/node-process/ChildProcessSnapExecutor.mjs +30 -26
  209. package/dist/node-process/ChildProcessSnapExecutor.mjs.map +1 -1
  210. package/dist/node-process/index.cjs +8 -0
  211. package/dist/node-process/index.cjs.map +1 -0
  212. package/dist/node-process/index.d.cts +2 -0
  213. package/dist/node-process/index.d.cts.map +1 -0
  214. package/dist/node-process/index.d.mts +2 -0
  215. package/dist/node-process/index.d.mts.map +1 -0
  216. package/dist/node-process/index.mjs +3 -28
  217. package/dist/node-process/index.mjs.map +1 -1
  218. package/dist/node-thread/ThreadSnapExecutor.cjs +30 -0
  219. package/dist/node-thread/ThreadSnapExecutor.cjs.map +1 -0
  220. package/dist/node-thread/ThreadSnapExecutor.d.cts +5 -0
  221. package/dist/node-thread/ThreadSnapExecutor.d.cts.map +1 -0
  222. package/dist/node-thread/ThreadSnapExecutor.d.mts +5 -0
  223. package/dist/node-thread/ThreadSnapExecutor.d.mts.map +1 -0
  224. package/dist/node-thread/ThreadSnapExecutor.mjs +30 -26
  225. package/dist/node-thread/ThreadSnapExecutor.mjs.map +1 -1
  226. package/dist/node-thread/index.cjs +8 -0
  227. package/dist/node-thread/index.cjs.map +1 -0
  228. package/dist/node-thread/index.d.cts +2 -0
  229. package/dist/node-thread/index.d.cts.map +1 -0
  230. package/dist/node-thread/index.d.mts +2 -0
  231. package/dist/node-thread/index.d.mts.map +1 -0
  232. package/dist/node-thread/index.mjs +3 -28
  233. package/dist/node-thread/index.mjs.map +1 -1
  234. package/dist/proxy/ProxySnapExecutor.cjs +112 -0
  235. package/dist/proxy/ProxySnapExecutor.cjs.map +1 -0
  236. package/dist/{types/proxy/ProxySnapExecutor.d.ts → proxy/ProxySnapExecutor.d.cts} +4 -3
  237. package/dist/proxy/ProxySnapExecutor.d.cts.map +1 -0
  238. package/dist/proxy/ProxySnapExecutor.d.mts +36 -0
  239. package/dist/proxy/ProxySnapExecutor.d.mts.map +1 -0
  240. package/dist/proxy/ProxySnapExecutor.mjs +104 -6
  241. package/dist/proxy/ProxySnapExecutor.mjs.map +1 -1
  242. package/dist/proxy/index.cjs +18 -0
  243. package/dist/proxy/index.cjs.map +1 -0
  244. package/dist/proxy/index.d.cts +2 -0
  245. package/dist/proxy/index.d.cts.map +1 -0
  246. package/dist/proxy/index.d.mts +2 -0
  247. package/dist/proxy/index.d.mts.map +1 -0
  248. package/dist/proxy/index.mjs +1 -8
  249. package/dist/proxy/index.mjs.map +1 -1
  250. package/dist/webview/WebViewExecutorStream.cjs +79 -0
  251. package/dist/webview/WebViewExecutorStream.cjs.map +1 -0
  252. package/dist/{types/webview/WebViewExecutorStream.d.ts → webview/WebViewExecutorStream.d.cts} +3 -2
  253. package/dist/webview/WebViewExecutorStream.d.cts.map +1 -0
  254. package/dist/webview/WebViewExecutorStream.d.mts +33 -0
  255. package/dist/webview/WebViewExecutorStream.d.mts.map +1 -0
  256. package/dist/webview/WebViewExecutorStream.mjs +74 -6
  257. package/dist/webview/WebViewExecutorStream.mjs.map +1 -1
  258. package/dist/webview/index.cjs +16 -0
  259. package/dist/webview/index.cjs.map +1 -0
  260. package/dist/webview/index.d.cts +2 -0
  261. package/dist/webview/index.d.cts.map +1 -0
  262. package/dist/webview/index.d.mts +2 -0
  263. package/dist/webview/index.d.mts.map +1 -0
  264. package/dist/webview/index.mjs +9 -21
  265. package/dist/webview/index.mjs.map +1 -1
  266. package/dist/webworker/executor/WebWorkerSnapExecutor.cjs +37 -0
  267. package/dist/webworker/executor/WebWorkerSnapExecutor.cjs.map +1 -0
  268. package/dist/{types/webworker/executor/WebWorkerSnapExecutor.d.ts → webworker/executor/WebWorkerSnapExecutor.d.cts} +3 -2
  269. package/dist/webworker/executor/WebWorkerSnapExecutor.d.cts.map +1 -0
  270. package/dist/webworker/executor/WebWorkerSnapExecutor.d.mts +14 -0
  271. package/dist/webworker/executor/WebWorkerSnapExecutor.d.mts.map +1 -0
  272. package/dist/webworker/executor/WebWorkerSnapExecutor.mjs +37 -26
  273. package/dist/webworker/executor/WebWorkerSnapExecutor.mjs.map +1 -1
  274. package/dist/webworker/executor/index.cjs +10 -0
  275. package/dist/webworker/executor/index.cjs.map +1 -0
  276. package/dist/webworker/executor/index.d.cts +2 -0
  277. package/dist/webworker/executor/index.d.cts.map +1 -0
  278. package/dist/webworker/executor/index.d.mts +2 -0
  279. package/dist/webworker/executor/index.d.mts.map +1 -0
  280. package/dist/webworker/executor/index.mjs +4 -31
  281. package/dist/webworker/executor/index.mjs.map +1 -1
  282. package/dist/webworker/pool/WebWorkerPool.cjs +168 -0
  283. package/dist/webworker/pool/WebWorkerPool.cjs.map +1 -0
  284. package/dist/{types/webworker/pool/WebWorkerPool.d.ts → webworker/pool/WebWorkerPool.d.cts} +4 -3
  285. package/dist/webworker/pool/WebWorkerPool.d.cts.map +1 -0
  286. package/dist/webworker/pool/WebWorkerPool.d.mts +24 -0
  287. package/dist/webworker/pool/WebWorkerPool.d.mts.map +1 -0
  288. package/dist/webworker/pool/WebWorkerPool.mjs +163 -6
  289. package/dist/webworker/pool/WebWorkerPool.mjs.map +1 -1
  290. package/dist/webworker/pool/index.cjs +10 -0
  291. package/dist/webworker/pool/index.cjs.map +1 -0
  292. package/dist/webworker/pool/index.d.cts +2 -0
  293. package/dist/webworker/pool/index.d.cts.map +1 -0
  294. package/dist/webworker/pool/index.d.mts +2 -0
  295. package/dist/webworker/pool/index.d.mts.map +1 -0
  296. package/dist/webworker/pool/index.mjs +4 -12
  297. package/dist/webworker/pool/index.mjs.map +1 -1
  298. package/package.json +21 -18
  299. package/dist/browserify/iframe/bundle.js +0 -9
  300. package/dist/browserify/iframe/index.html +0 -13394
  301. package/dist/browserify/node-process/bundle.js +0 -13390
  302. package/dist/browserify/node-thread/bundle.js +0 -13390
  303. package/dist/browserify/webview/index.html +0 -13402
  304. package/dist/browserify/worker-executor/bundle.js +0 -13392
  305. package/dist/browserify/worker-pool/bundle.js +0 -9
  306. package/dist/browserify/worker-pool/index.html +0 -13394
  307. package/dist/chunk-2VA6RAEE.js +0 -30
  308. package/dist/chunk-2VA6RAEE.js.map +0 -1
  309. package/dist/chunk-3JCT4MWT.js +0 -108
  310. package/dist/chunk-3JCT4MWT.js.map +0 -1
  311. package/dist/chunk-46LW37FK.js +0 -144
  312. package/dist/chunk-46LW37FK.js.map +0 -1
  313. package/dist/chunk-4COIRXF5.js +0 -86
  314. package/dist/chunk-4COIRXF5.js.map +0 -1
  315. package/dist/chunk-4XRZLEKU.js +0 -49
  316. package/dist/chunk-4XRZLEKU.js.map +0 -1
  317. package/dist/chunk-53ZULHPK.mjs +0 -16
  318. package/dist/chunk-53ZULHPK.mjs.map +0 -1
  319. package/dist/chunk-5DEV3QQU.mjs +0 -12
  320. package/dist/chunk-5DEV3QQU.mjs.map +0 -1
  321. package/dist/chunk-5LGIS4VY.js +0 -33
  322. package/dist/chunk-5LGIS4VY.js.map +0 -1
  323. package/dist/chunk-5STN3QCA.js +0 -183
  324. package/dist/chunk-5STN3QCA.js.map +0 -1
  325. package/dist/chunk-75RCH4ZX.mjs +0 -151
  326. package/dist/chunk-75RCH4ZX.mjs.map +0 -1
  327. package/dist/chunk-7AJWXSDQ.mjs +0 -73
  328. package/dist/chunk-7AJWXSDQ.mjs.map +0 -1
  329. package/dist/chunk-7MMUJJQ2.js +0 -151
  330. package/dist/chunk-7MMUJJQ2.js.map +0 -1
  331. package/dist/chunk-BCBKEUCG.mjs +0 -38
  332. package/dist/chunk-BCBKEUCG.mjs.map +0 -1
  333. package/dist/chunk-BTEAZZKP.mjs +0 -24
  334. package/dist/chunk-BTEAZZKP.mjs.map +0 -1
  335. package/dist/chunk-BVRVUIJB.mjs +0 -67
  336. package/dist/chunk-BVRVUIJB.mjs.map +0 -1
  337. package/dist/chunk-CV5LC4PP.js +0 -24
  338. package/dist/chunk-CV5LC4PP.js.map +0 -1
  339. package/dist/chunk-DAG7NWEU.mjs +0 -33
  340. package/dist/chunk-DAG7NWEU.mjs.map +0 -1
  341. package/dist/chunk-DKDTGAFK.js +0 -67
  342. package/dist/chunk-DKDTGAFK.js.map +0 -1
  343. package/dist/chunk-DLLLH5HN.js +0 -26
  344. package/dist/chunk-DLLLH5HN.js.map +0 -1
  345. package/dist/chunk-EXN2TFDJ.js +0 -38
  346. package/dist/chunk-EXN2TFDJ.js.map +0 -1
  347. package/dist/chunk-FJT65CXB.js +0 -472
  348. package/dist/chunk-FJT65CXB.js.map +0 -1
  349. package/dist/chunk-FOEAIF5U.js +0 -16
  350. package/dist/chunk-FOEAIF5U.js.map +0 -1
  351. package/dist/chunk-FUPEJT7B.js +0 -82
  352. package/dist/chunk-FUPEJT7B.js.map +0 -1
  353. package/dist/chunk-HCJZG6W7.mjs +0 -45
  354. package/dist/chunk-HCJZG6W7.mjs.map +0 -1
  355. package/dist/chunk-HGLRZZ56.js +0 -32
  356. package/dist/chunk-HGLRZZ56.js.map +0 -1
  357. package/dist/chunk-HL2TTKF3.mjs +0 -144
  358. package/dist/chunk-HL2TTKF3.mjs.map +0 -1
  359. package/dist/chunk-HWS4QSOC.mjs +0 -16
  360. package/dist/chunk-HWS4QSOC.mjs.map +0 -1
  361. package/dist/chunk-HXKBUIYS.js +0 -262
  362. package/dist/chunk-HXKBUIYS.js.map +0 -1
  363. package/dist/chunk-I5G4YFHM.js +0 -73
  364. package/dist/chunk-I5G4YFHM.js.map +0 -1
  365. package/dist/chunk-IX5S3V47.mjs +0 -26
  366. package/dist/chunk-IX5S3V47.mjs.map +0 -1
  367. package/dist/chunk-JOT5JH42.js +0 -52
  368. package/dist/chunk-JOT5JH42.js.map +0 -1
  369. package/dist/chunk-KEAB7ZVV.js +0 -50
  370. package/dist/chunk-KEAB7ZVV.js.map +0 -1
  371. package/dist/chunk-LAKWJYBO.js +0 -33
  372. package/dist/chunk-LAKWJYBO.js.map +0 -1
  373. package/dist/chunk-LO5ORVRC.js +0 -16
  374. package/dist/chunk-LO5ORVRC.js.map +0 -1
  375. package/dist/chunk-MCXWFCGV.js +0 -1
  376. package/dist/chunk-MCXWFCGV.js.map +0 -1
  377. package/dist/chunk-MIWGLICQ.mjs +0 -108
  378. package/dist/chunk-MIWGLICQ.mjs.map +0 -1
  379. package/dist/chunk-MMYM63NH.mjs +0 -82
  380. package/dist/chunk-MMYM63NH.mjs.map +0 -1
  381. package/dist/chunk-MS2LQQYH.js +0 -38
  382. package/dist/chunk-MS2LQQYH.js.map +0 -1
  383. package/dist/chunk-MXNMMTJW.mjs +0 -51
  384. package/dist/chunk-MXNMMTJW.mjs.map +0 -1
  385. package/dist/chunk-OBT45IWW.js +0 -92
  386. package/dist/chunk-OBT45IWW.js.map +0 -1
  387. package/dist/chunk-OCNPLHS2.js +0 -51
  388. package/dist/chunk-OCNPLHS2.js.map +0 -1
  389. package/dist/chunk-ODICKSGZ.mjs +0 -86
  390. package/dist/chunk-ODICKSGZ.mjs.map +0 -1
  391. package/dist/chunk-OIN7VU4G.mjs +0 -33
  392. package/dist/chunk-OIN7VU4G.mjs.map +0 -1
  393. package/dist/chunk-Q42NNJFY.mjs +0 -32
  394. package/dist/chunk-Q42NNJFY.mjs.map +0 -1
  395. package/dist/chunk-Q42WB3ZO.js +0 -40
  396. package/dist/chunk-Q42WB3ZO.js.map +0 -1
  397. package/dist/chunk-QZC2X6NG.js +0 -44
  398. package/dist/chunk-QZC2X6NG.js.map +0 -1
  399. package/dist/chunk-S5NWI5Z7.mjs +0 -50
  400. package/dist/chunk-S5NWI5Z7.mjs.map +0 -1
  401. package/dist/chunk-S7257EN3.mjs +0 -49
  402. package/dist/chunk-S7257EN3.mjs.map +0 -1
  403. package/dist/chunk-TSEAPB7L.mjs +0 -1
  404. package/dist/chunk-TSEAPB7L.mjs.map +0 -1
  405. package/dist/chunk-TZAPZE45.mjs +0 -472
  406. package/dist/chunk-TZAPZE45.mjs.map +0 -1
  407. package/dist/chunk-UOPIRTJX.mjs +0 -44
  408. package/dist/chunk-UOPIRTJX.mjs.map +0 -1
  409. package/dist/chunk-V76DI2XM.mjs +0 -183
  410. package/dist/chunk-V76DI2XM.mjs.map +0 -1
  411. package/dist/chunk-VFQ5CRZS.mjs +0 -40
  412. package/dist/chunk-VFQ5CRZS.mjs.map +0 -1
  413. package/dist/chunk-W7EDURT5.mjs +0 -92
  414. package/dist/chunk-W7EDURT5.mjs.map +0 -1
  415. package/dist/chunk-WZDVTU5C.js +0 -45
  416. package/dist/chunk-WZDVTU5C.js.map +0 -1
  417. package/dist/chunk-XPCW7TKM.mjs +0 -262
  418. package/dist/chunk-XPCW7TKM.mjs.map +0 -1
  419. package/dist/chunk-Y7AK2VVC.mjs +0 -52
  420. package/dist/chunk-Y7AK2VVC.mjs.map +0 -1
  421. package/dist/chunk-YRZVIDCF.mjs +0 -38
  422. package/dist/chunk-YRZVIDCF.mjs.map +0 -1
  423. package/dist/chunk-Z7BOREC4.js +0 -12
  424. package/dist/chunk-Z7BOREC4.js.map +0 -1
  425. package/dist/chunk-ZNTCZK7J.mjs +0 -30
  426. package/dist/chunk-ZNTCZK7J.mjs.map +0 -1
  427. package/dist/common/BaseSnapExecutor.js +0 -26
  428. package/dist/common/BaseSnapExecutor.js.map +0 -1
  429. package/dist/common/commands.js +0 -11
  430. package/dist/common/commands.js.map +0 -1
  431. package/dist/common/endowments/commonEndowmentFactory.js +0 -20
  432. package/dist/common/endowments/commonEndowmentFactory.js.map +0 -1
  433. package/dist/common/endowments/console.js +0 -13
  434. package/dist/common/endowments/console.js.map +0 -1
  435. package/dist/common/endowments/crypto.js +0 -11
  436. package/dist/common/endowments/crypto.js.map +0 -1
  437. package/dist/common/endowments/date.js +0 -9
  438. package/dist/common/endowments/date.js.map +0 -1
  439. package/dist/common/endowments/index.js +0 -21
  440. package/dist/common/endowments/index.js.map +0 -1
  441. package/dist/common/endowments/interval.js +0 -8
  442. package/dist/common/endowments/interval.js.map +0 -1
  443. package/dist/common/endowments/math.js +0 -10
  444. package/dist/common/endowments/math.js.map +0 -1
  445. package/dist/common/endowments/network.js +0 -10
  446. package/dist/common/endowments/network.js.map +0 -1
  447. package/dist/common/endowments/textDecoder.js +0 -8
  448. package/dist/common/endowments/textDecoder.js.map +0 -1
  449. package/dist/common/endowments/textEncoder.js +0 -8
  450. package/dist/common/endowments/textEncoder.js.map +0 -1
  451. package/dist/common/endowments/timeout.js +0 -8
  452. package/dist/common/endowments/timeout.js.map +0 -1
  453. package/dist/common/globalEvents.js +0 -11
  454. package/dist/common/globalEvents.js.map +0 -1
  455. package/dist/common/globalObject.js +0 -10
  456. package/dist/common/globalObject.js.map +0 -1
  457. package/dist/common/lockdown/lockdown-events.js +0 -8
  458. package/dist/common/lockdown/lockdown-events.js.map +0 -1
  459. package/dist/common/lockdown/lockdown-more.js +0 -8
  460. package/dist/common/lockdown/lockdown-more.js.map +0 -1
  461. package/dist/common/lockdown/lockdown.js +0 -22
  462. package/dist/common/lockdown/lockdown.js.map +0 -1
  463. package/dist/common/sortParams.js +0 -8
  464. package/dist/common/sortParams.js.map +0 -1
  465. package/dist/common/utils.js +0 -21
  466. package/dist/common/utils.js.map +0 -1
  467. package/dist/common/validation.js +0 -38
  468. package/dist/common/validation.js.map +0 -1
  469. package/dist/globals.d.js +0 -1
  470. package/dist/globals.d.js.map +0 -1
  471. package/dist/globals.d.mjs +0 -1
  472. package/dist/globals.d.mjs.map +0 -1
  473. package/dist/iframe/IFrameSnapExecutor.js +0 -27
  474. package/dist/iframe/IFrameSnapExecutor.js.map +0 -1
  475. package/dist/iframe/index.js +0 -35
  476. package/dist/iframe/index.js.map +0 -1
  477. package/dist/index.js +0 -9
  478. package/dist/index.js.map +0 -1
  479. package/dist/logging.js +0 -8
  480. package/dist/logging.js.map +0 -1
  481. package/dist/node-process/ChildProcessSnapExecutor.js +0 -27
  482. package/dist/node-process/ChildProcessSnapExecutor.js.map +0 -1
  483. package/dist/node-process/index.js +0 -31
  484. package/dist/node-process/index.js.map +0 -1
  485. package/dist/node-thread/ThreadSnapExecutor.js +0 -27
  486. package/dist/node-thread/ThreadSnapExecutor.js.map +0 -1
  487. package/dist/node-thread/index.js +0 -31
  488. package/dist/node-thread/index.js.map +0 -1
  489. package/dist/proxy/ProxySnapExecutor.js +0 -8
  490. package/dist/proxy/ProxySnapExecutor.js.map +0 -1
  491. package/dist/proxy/index.js +0 -9
  492. package/dist/proxy/index.js.map +0 -1
  493. package/dist/tsconfig.build.tsbuildinfo +0 -1
  494. package/dist/types/iframe/index.d.ts +0 -1
  495. package/dist/types/index.d.ts +0 -1
  496. package/dist/types/node-process/index.d.ts +0 -1
  497. package/dist/types/node-thread/ThreadSnapExecutor.d.ts +0 -4
  498. package/dist/types/node-thread/index.d.ts +0 -1
  499. package/dist/types/proxy/index.d.ts +0 -1
  500. package/dist/types/vendor/global.d.js +0 -1
  501. package/dist/types/vendor/global.d.js.map +0 -1
  502. package/dist/types/vendor/global.d.mjs +0 -1
  503. package/dist/types/vendor/global.d.mjs.map +0 -1
  504. package/dist/types/vendor/providers.d.js +0 -1
  505. package/dist/types/vendor/providers.d.js.map +0 -1
  506. package/dist/types/vendor/providers.d.mjs +0 -1
  507. package/dist/types/vendor/providers.d.mjs.map +0 -1
  508. package/dist/types/vendor/readable-stream.d.js +0 -1
  509. package/dist/types/vendor/readable-stream.d.js.map +0 -1
  510. package/dist/types/vendor/readable-stream.d.mjs +0 -1
  511. package/dist/types/vendor/readable-stream.d.mjs.map +0 -1
  512. package/dist/types/webview/index.d.ts +0 -1
  513. package/dist/types/webworker/executor/index.d.ts +0 -1
  514. package/dist/types/webworker/pool/index.d.ts +0 -1
  515. package/dist/webview/WebViewExecutorStream.js +0 -8
  516. package/dist/webview/WebViewExecutorStream.js.map +0 -1
  517. package/dist/webview/index.js +0 -26
  518. package/dist/webview/index.js.map +0 -1
  519. package/dist/webworker/executor/WebWorkerSnapExecutor.js +0 -27
  520. package/dist/webworker/executor/WebWorkerSnapExecutor.js.map +0 -1
  521. package/dist/webworker/executor/index.js +0 -35
  522. package/dist/webworker/executor/index.js.map +0 -1
  523. package/dist/webworker/pool/WebWorkerPool.js +0 -8
  524. package/dist/webworker/pool/WebWorkerPool.js.map +0 -1
  525. package/dist/webworker/pool/index.js +0 -16
  526. package/dist/webworker/pool/index.js.map +0 -1
@@ -1,27 +1,31 @@
1
- import {
2
- ThreadSnapExecutor
3
- } from "../chunk-OIN7VU4G.mjs";
4
- import "../chunk-TZAPZE45.mjs";
5
- import "../chunk-BVRVUIJB.mjs";
6
- import "../chunk-ODICKSGZ.mjs";
7
- import "../chunk-S5NWI5Z7.mjs";
8
- import "../chunk-BCBKEUCG.mjs";
9
- import "../chunk-XPCW7TKM.mjs";
10
- import "../chunk-53ZULHPK.mjs";
11
- import "../chunk-HWS4QSOC.mjs";
12
- import "../chunk-Y7AK2VVC.mjs";
13
- import "../chunk-W7EDURT5.mjs";
14
- import "../chunk-Q42NNJFY.mjs";
15
- import "../chunk-UOPIRTJX.mjs";
16
- import "../chunk-HL2TTKF3.mjs";
17
- import "../chunk-5DEV3QQU.mjs";
18
- import "../chunk-MMYM63NH.mjs";
19
- import "../chunk-75RCH4ZX.mjs";
20
- import "../chunk-ZNTCZK7J.mjs";
21
- import "../chunk-IX5S3V47.mjs";
22
- import "../chunk-BTEAZZKP.mjs";
23
- import "../chunk-YRZVIDCF.mjs";
24
- export {
25
- ThreadSnapExecutor
26
- };
1
+ function $importDefault(module) {
2
+ if (module?.__esModule) {
3
+ return module.default;
4
+ }
5
+ return module;
6
+ }
7
+ import $ObjectMultiplex from "@metamask/object-multiplex";
8
+ const ObjectMultiplex = $importDefault($ObjectMultiplex);
9
+ import $metamaskpostmessagestream from "@metamask/post-message-stream";
10
+ const { ThreadMessageStream } = $metamaskpostmessagestream;
11
+ import { logError, SNAP_STREAM_NAMES } from "@metamask/snaps-utils";
12
+ import { pipeline } from "readable-stream";
13
+ import { BaseSnapExecutor } from "../common/BaseSnapExecutor.mjs";
14
+ import { log } from "../logging.mjs";
15
+ export class ThreadSnapExecutor extends BaseSnapExecutor {
16
+ static initialize() {
17
+ log('Worker: Connecting to parent.');
18
+ const parentStream = new ThreadMessageStream();
19
+ const mux = new ObjectMultiplex();
20
+ pipeline(parentStream, mux, parentStream, (error) => {
21
+ if (error) {
22
+ logError(`Parent stream failure, closing worker.`, error);
23
+ }
24
+ self.close();
25
+ });
26
+ const commandStream = mux.createStream(SNAP_STREAM_NAMES.COMMAND);
27
+ const rpcStream = mux.createStream(SNAP_STREAM_NAMES.JSON_RPC);
28
+ return new ThreadSnapExecutor(commandStream, rpcStream);
29
+ }
30
+ }
27
31
  //# sourceMappingURL=ThreadSnapExecutor.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
1
+ {"version":3,"file":"ThreadSnapExecutor.mjs","sourceRoot":"","sources":["../../src/node-thread/ThreadSnapExecutor.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,gBAAe,mCAAmC;;;;AAEzD,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,8BAA8B;AACpE,OAAO,EAAE,QAAQ,EAAE,wBAAwB;AAE3C,OAAO,EAAE,gBAAgB,EAAE,uCAAmC;AAC9D,OAAO,EAAE,GAAG,EAAE,uBAAmB;AAEjC,MAAM,OAAO,kBAAmB,SAAQ,gBAAgB;IACtD,MAAM,CAAC,UAAU;QACf,GAAG,CAAC,+BAA+B,CAAC,CAAC;QAErC,MAAM,YAAY,GAAG,IAAI,mBAAmB,EAAE,CAAC;QAC/C,MAAM,GAAG,GAAG,IAAI,eAAe,EAAE,CAAC;QAClC,QAAQ,CAAC,YAAY,EAAE,GAAU,EAAE,YAAY,EAAE,CAAC,KAAK,EAAE,EAAE;YACzD,IAAI,KAAK,EAAE,CAAC;gBACV,QAAQ,CAAC,wCAAwC,EAAE,KAAK,CAAC,CAAC;YAC5D,CAAC;YACD,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC,CAAC,CAAC;QAEH,MAAM,aAAa,GAAG,GAAG,CAAC,YAAY,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAClE,MAAM,SAAS,GAAG,GAAG,CAAC,YAAY,CAAC,iBAAiB,CAAC,QAAQ,CAAQ,CAAC;QACtE,OAAO,IAAI,kBAAkB,CAAC,aAAa,EAAE,SAAS,CAAC,CAAC;IAC1D,CAAC;CACF","sourcesContent":["import ObjectMultiplex from '@metamask/object-multiplex';\nimport { ThreadMessageStream } 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 ThreadSnapExecutor extends BaseSnapExecutor {\n static initialize() {\n log('Worker: Connecting to parent.');\n\n const parentStream = new ThreadMessageStream();\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 ThreadSnapExecutor(commandStream, rpcStream);\n }\n}\n"]}
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const lockdown_more_1 = require("../common/lockdown/lockdown-more.cjs");
4
+ const ThreadSnapExecutor_1 = require("./ThreadSnapExecutor.cjs");
5
+ // Lockdown is already applied in LavaMoat
6
+ (0, lockdown_more_1.executeLockdownMore)();
7
+ ThreadSnapExecutor_1.ThreadSnapExecutor.initialize();
8
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sourceRoot":"","sources":["../../src/node-thread/index.ts"],"names":[],"mappings":";;AAAA,wEAAuE;AACvE,iEAA0D;AAE1D,0CAA0C;AAC1C,IAAA,mCAAmB,GAAE,CAAC;AAEtB,uCAAkB,CAAC,UAAU,EAAE,CAAC","sourcesContent":["import { executeLockdownMore } from '../common/lockdown/lockdown-more';\nimport { ThreadSnapExecutor } from './ThreadSnapExecutor';\n\n// Lockdown is already applied in LavaMoat\nexecuteLockdownMore();\n\nThreadSnapExecutor.initialize();\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.cts","sourceRoot":"","sources":["../../src/node-thread/index.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.mts","sourceRoot":"","sources":["../../src/node-thread/index.ts"],"names":[],"mappings":""}
@@ -1,31 +1,6 @@
1
- import {
2
- executeLockdownMore
3
- } from "../chunk-MXNMMTJW.mjs";
4
- import {
5
- ThreadSnapExecutor
6
- } from "../chunk-OIN7VU4G.mjs";
7
- import "../chunk-TZAPZE45.mjs";
8
- import "../chunk-BVRVUIJB.mjs";
9
- import "../chunk-ODICKSGZ.mjs";
10
- import "../chunk-S5NWI5Z7.mjs";
11
- import "../chunk-BCBKEUCG.mjs";
12
- import "../chunk-XPCW7TKM.mjs";
13
- import "../chunk-53ZULHPK.mjs";
14
- import "../chunk-HWS4QSOC.mjs";
15
- import "../chunk-Y7AK2VVC.mjs";
16
- import "../chunk-W7EDURT5.mjs";
17
- import "../chunk-Q42NNJFY.mjs";
18
- import "../chunk-UOPIRTJX.mjs";
19
- import "../chunk-HL2TTKF3.mjs";
20
- import "../chunk-5DEV3QQU.mjs";
21
- import "../chunk-MMYM63NH.mjs";
22
- import "../chunk-75RCH4ZX.mjs";
23
- import "../chunk-ZNTCZK7J.mjs";
24
- import "../chunk-IX5S3V47.mjs";
25
- import "../chunk-BTEAZZKP.mjs";
26
- import "../chunk-YRZVIDCF.mjs";
27
-
28
- // src/node-thread/index.ts
1
+ import { executeLockdownMore } from "../common/lockdown/lockdown-more.mjs";
2
+ import { ThreadSnapExecutor } from "./ThreadSnapExecutor.mjs";
3
+ // Lockdown is already applied in LavaMoat
29
4
  executeLockdownMore();
30
5
  ThreadSnapExecutor.initialize();
31
6
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/node-thread/index.ts"],"sourcesContent":["import { executeLockdownMore } from '../common/lockdown/lockdown-more';\nimport { ThreadSnapExecutor } from './ThreadSnapExecutor';\n\n// Lockdown is already applied in LavaMoat\nexecuteLockdownMore();\n\nThreadSnapExecutor.initialize();\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,oBAAoB;AAEpB,mBAAmB,WAAW;","names":[]}
1
+ {"version":3,"file":"index.mjs","sourceRoot":"","sources":["../../src/node-thread/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,6CAAyC;AACvE,OAAO,EAAE,kBAAkB,EAAE,iCAA6B;AAE1D,0CAA0C;AAC1C,mBAAmB,EAAE,CAAC;AAEtB,kBAAkB,CAAC,UAAU,EAAE,CAAC","sourcesContent":["import { executeLockdownMore } from '../common/lockdown/lockdown-more';\nimport { ThreadSnapExecutor } from './ThreadSnapExecutor';\n\n// Lockdown is already applied in LavaMoat\nexecuteLockdownMore();\n\nThreadSnapExecutor.initialize();\n"]}
@@ -0,0 +1,112 @@
1
+ "use strict";
2
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
3
+ if (kind === "m") throw new TypeError("Private method is not writable");
4
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
5
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
6
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
7
+ };
8
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
9
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
10
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
11
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
12
+ };
13
+ var __importDefault = (this && this.__importDefault) || function (mod) {
14
+ return (mod && mod.__esModule) ? mod : { "default": mod };
15
+ };
16
+ var _ProxySnapExecutor_instances, _ProxySnapExecutor_stream, _ProxySnapExecutor_frameUrl, _ProxySnapExecutor_onData, _ProxySnapExecutor_initializeJob, _ProxySnapExecutor_terminateJob;
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ exports.ProxySnapExecutor = void 0;
19
+ const post_message_stream_1 = require("@metamask/post-message-stream");
20
+ // eslint-disable-next-line import/no-extraneous-dependencies
21
+ const package_json_1 = __importDefault(require("@metamask/snaps-execution-environments/package.json"));
22
+ const snaps_utils_1 = require("@metamask/snaps-utils");
23
+ const utils_1 = require("@metamask/utils");
24
+ const IFRAME_URL = `https://execution.metamask.io/iframe/${package_json_1.default.version}/index.html`;
25
+ /**
26
+ * A "proxy" snap executor that uses a level of indirection to execute snaps.
27
+ *
28
+ * Useful for multiple execution environments.
29
+ *
30
+ * This is not a traditional snap executor, as it does not execute snaps itself.
31
+ * Instead, it creates an iframe window for each snap execution, and sends the
32
+ * snap execution request to the iframe window. The iframe window is responsible
33
+ * for executing the snap.
34
+ *
35
+ * This executor is persisted between snap executions. The executor essentially
36
+ * acts as a proxy between the client and the iframe execution environment.
37
+ */
38
+ class ProxySnapExecutor {
39
+ /**
40
+ * Initialize the executor with the given stream. This is a wrapper around the
41
+ * constructor.
42
+ *
43
+ * @param stream - The stream to use for communication.
44
+ * @param frameUrl - An optional URL for the iframe to use.
45
+ * @returns The initialized executor.
46
+ */
47
+ static initialize(stream, frameUrl = IFRAME_URL) {
48
+ return new ProxySnapExecutor(stream, frameUrl);
49
+ }
50
+ constructor(stream, frameUrl) {
51
+ _ProxySnapExecutor_instances.add(this);
52
+ _ProxySnapExecutor_stream.set(this, void 0);
53
+ _ProxySnapExecutor_frameUrl.set(this, void 0);
54
+ this.jobs = {};
55
+ __classPrivateFieldSet(this, _ProxySnapExecutor_stream, stream, "f");
56
+ __classPrivateFieldGet(this, _ProxySnapExecutor_stream, "f").on('data', __classPrivateFieldGet(this, _ProxySnapExecutor_instances, "m", _ProxySnapExecutor_onData).bind(this));
57
+ __classPrivateFieldSet(this, _ProxySnapExecutor_frameUrl, frameUrl, "f");
58
+ }
59
+ }
60
+ exports.ProxySnapExecutor = ProxySnapExecutor;
61
+ _ProxySnapExecutor_stream = new WeakMap(), _ProxySnapExecutor_frameUrl = new WeakMap(), _ProxySnapExecutor_instances = new WeakSet(), _ProxySnapExecutor_onData = function _ProxySnapExecutor_onData(data) {
62
+ const { jobId, data: request } = data;
63
+ if (!this.jobs[jobId]) {
64
+ // This ensures that a job is initialized before it is used. To avoid
65
+ // code duplication, we call the `#onData` method again, which will
66
+ // run the rest of the logic after initialization.
67
+ __classPrivateFieldGet(this, _ProxySnapExecutor_instances, "m", _ProxySnapExecutor_initializeJob).call(this, jobId)
68
+ .then(() => {
69
+ __classPrivateFieldGet(this, _ProxySnapExecutor_instances, "m", _ProxySnapExecutor_onData).call(this, data);
70
+ })
71
+ .catch((error) => {
72
+ (0, snaps_utils_1.logError)('[Worker] Error initializing job:', error);
73
+ });
74
+ return;
75
+ }
76
+ // This is a method specific to the `OffscreenSnapExecutor`, as the service
77
+ // itself does not have access to the iframes directly.
78
+ if (request.method === 'terminateJob') {
79
+ __classPrivateFieldGet(this, _ProxySnapExecutor_instances, "m", _ProxySnapExecutor_terminateJob).call(this, jobId);
80
+ return;
81
+ }
82
+ this.jobs[jobId].stream.write(request);
83
+ }, _ProxySnapExecutor_initializeJob =
84
+ /**
85
+ * Create a new iframe and set up a stream to communicate with it.
86
+ *
87
+ * @param jobId - The job ID.
88
+ * @returns The executor job object.
89
+ */
90
+ async function _ProxySnapExecutor_initializeJob(jobId) {
91
+ const window = await (0, snaps_utils_1.createWindow)(__classPrivateFieldGet(this, _ProxySnapExecutor_frameUrl, "f"), jobId);
92
+ const jobStream = new post_message_stream_1.WindowPostMessageStream({
93
+ name: 'parent',
94
+ target: 'child',
95
+ targetWindow: window, // iframe's internal window
96
+ targetOrigin: '*',
97
+ });
98
+ // Write messages from the iframe to the parent, wrapped with the job ID.
99
+ jobStream.on('data', (data) => {
100
+ __classPrivateFieldGet(this, _ProxySnapExecutor_stream, "f").write({ data, jobId });
101
+ });
102
+ this.jobs[jobId] = { id: jobId, window, stream: jobStream };
103
+ return this.jobs[jobId];
104
+ }, _ProxySnapExecutor_terminateJob = function _ProxySnapExecutor_terminateJob(jobId) {
105
+ (0, utils_1.assert)(this.jobs[jobId], `Job "${jobId}" not found.`);
106
+ const iframe = document.getElementById(jobId);
107
+ (0, utils_1.assert)(iframe, `Iframe with ID "${jobId}" not found.`);
108
+ iframe.remove();
109
+ this.jobs[jobId].stream.destroy();
110
+ delete this.jobs[jobId];
111
+ };
112
+ //# sourceMappingURL=ProxySnapExecutor.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProxySnapExecutor.cjs","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';\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 * @returns The executor job object.\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"]}
@@ -1,6 +1,6 @@
1
- import type { BasePostMessageStream } from '@metamask/post-message-stream';
2
- import { WindowPostMessageStream } from '@metamask/post-message-stream';
3
- declare type ExecutorJob = {
1
+ import type { BasePostMessageStream } from "@metamask/post-message-stream";
2
+ import { WindowPostMessageStream } from "@metamask/post-message-stream";
3
+ type ExecutorJob = {
4
4
  id: string;
5
5
  window: Window;
6
6
  stream: WindowPostMessageStream;
@@ -33,3 +33,4 @@ export declare class ProxySnapExecutor {
33
33
  constructor(stream: BasePostMessageStream, frameUrl: string);
34
34
  }
35
35
  export {};
36
+ //# sourceMappingURL=ProxySnapExecutor.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProxySnapExecutor.d.cts","sourceRoot":"","sources":["../../src/proxy/ProxySnapExecutor.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,sCAAsC;AAC3E,OAAO,EAAE,uBAAuB,EAAE,sCAAsC;AAOxE,KAAK,WAAW,GAAG;IACjB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,uBAAuB,CAAC;CACjC,CAAC;AAIF;;;;;;;;;;;;GAYG;AACH,qBAAa,iBAAiB;;IAK5B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,CAAM;IAEhD;;;;;;;OAOG;IACH,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,qBAAqB,EAAE,QAAQ,SAAa;gBAI1D,MAAM,EAAE,qBAAqB,EAAE,QAAQ,EAAE,MAAM;CAmF5D"}
@@ -0,0 +1,36 @@
1
+ import type { BasePostMessageStream } from "@metamask/post-message-stream";
2
+ import { WindowPostMessageStream } from "@metamask/post-message-stream";
3
+ type ExecutorJob = {
4
+ id: string;
5
+ window: Window;
6
+ stream: WindowPostMessageStream;
7
+ };
8
+ /**
9
+ * A "proxy" snap executor that uses a level of indirection to execute snaps.
10
+ *
11
+ * Useful for multiple execution environments.
12
+ *
13
+ * This is not a traditional snap executor, as it does not execute snaps itself.
14
+ * Instead, it creates an iframe window for each snap execution, and sends the
15
+ * snap execution request to the iframe window. The iframe window is responsible
16
+ * for executing the snap.
17
+ *
18
+ * This executor is persisted between snap executions. The executor essentially
19
+ * acts as a proxy between the client and the iframe execution environment.
20
+ */
21
+ export declare class ProxySnapExecutor {
22
+ #private;
23
+ readonly jobs: Record<string, ExecutorJob>;
24
+ /**
25
+ * Initialize the executor with the given stream. This is a wrapper around the
26
+ * constructor.
27
+ *
28
+ * @param stream - The stream to use for communication.
29
+ * @param frameUrl - An optional URL for the iframe to use.
30
+ * @returns The initialized executor.
31
+ */
32
+ static initialize(stream: BasePostMessageStream, frameUrl?: string): ProxySnapExecutor;
33
+ constructor(stream: BasePostMessageStream, frameUrl: string);
34
+ }
35
+ export {};
36
+ //# sourceMappingURL=ProxySnapExecutor.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProxySnapExecutor.d.mts","sourceRoot":"","sources":["../../src/proxy/ProxySnapExecutor.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,sCAAsC;AAC3E,OAAO,EAAE,uBAAuB,EAAE,sCAAsC;AAOxE,KAAK,WAAW,GAAG;IACjB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,uBAAuB,CAAC;CACjC,CAAC;AAIF;;;;;;;;;;;;GAYG;AACH,qBAAa,iBAAiB;;IAK5B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,CAAM;IAEhD;;;;;;;OAOG;IACH,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,qBAAqB,EAAE,QAAQ,SAAa;gBAI1D,MAAM,EAAE,qBAAqB,EAAE,QAAQ,EAAE,MAAM;CAmF5D"}
@@ -1,8 +1,106 @@
1
- import {
2
- ProxySnapExecutor
3
- } from "../chunk-MIWGLICQ.mjs";
4
- import "../chunk-YRZVIDCF.mjs";
5
- export {
6
- ProxySnapExecutor
1
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
2
+ if (kind === "m") throw new TypeError("Private method is not writable");
3
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
4
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
5
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
6
+ };
7
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
8
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
9
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
10
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
11
+ };
12
+ var _ProxySnapExecutor_instances, _ProxySnapExecutor_stream, _ProxySnapExecutor_frameUrl, _ProxySnapExecutor_onData, _ProxySnapExecutor_initializeJob, _ProxySnapExecutor_terminateJob;
13
+ import $metamaskpostmessagestream from "@metamask/post-message-stream";
14
+ const { WindowPostMessageStream } = $metamaskpostmessagestream;
15
+ // eslint-disable-next-line import/no-extraneous-dependencies
16
+ import packageJson from "@metamask/snaps-execution-environments/package.json" with { type: "json" };
17
+ import { createWindow, logError } from "@metamask/snaps-utils";
18
+ import { assert } from "@metamask/utils";
19
+ const IFRAME_URL = `https://execution.metamask.io/iframe/${packageJson.version}/index.html`;
20
+ /**
21
+ * A "proxy" snap executor that uses a level of indirection to execute snaps.
22
+ *
23
+ * Useful for multiple execution environments.
24
+ *
25
+ * This is not a traditional snap executor, as it does not execute snaps itself.
26
+ * Instead, it creates an iframe window for each snap execution, and sends the
27
+ * snap execution request to the iframe window. The iframe window is responsible
28
+ * for executing the snap.
29
+ *
30
+ * This executor is persisted between snap executions. The executor essentially
31
+ * acts as a proxy between the client and the iframe execution environment.
32
+ */
33
+ export class ProxySnapExecutor {
34
+ /**
35
+ * Initialize the executor with the given stream. This is a wrapper around the
36
+ * constructor.
37
+ *
38
+ * @param stream - The stream to use for communication.
39
+ * @param frameUrl - An optional URL for the iframe to use.
40
+ * @returns The initialized executor.
41
+ */
42
+ static initialize(stream, frameUrl = IFRAME_URL) {
43
+ return new ProxySnapExecutor(stream, frameUrl);
44
+ }
45
+ constructor(stream, frameUrl) {
46
+ _ProxySnapExecutor_instances.add(this);
47
+ _ProxySnapExecutor_stream.set(this, void 0);
48
+ _ProxySnapExecutor_frameUrl.set(this, void 0);
49
+ this.jobs = {};
50
+ __classPrivateFieldSet(this, _ProxySnapExecutor_stream, stream, "f");
51
+ __classPrivateFieldGet(this, _ProxySnapExecutor_stream, "f").on('data', __classPrivateFieldGet(this, _ProxySnapExecutor_instances, "m", _ProxySnapExecutor_onData).bind(this));
52
+ __classPrivateFieldSet(this, _ProxySnapExecutor_frameUrl, frameUrl, "f");
53
+ }
54
+ }
55
+ _ProxySnapExecutor_stream = new WeakMap(), _ProxySnapExecutor_frameUrl = new WeakMap(), _ProxySnapExecutor_instances = new WeakSet(), _ProxySnapExecutor_onData = function _ProxySnapExecutor_onData(data) {
56
+ const { jobId, data: request } = data;
57
+ if (!this.jobs[jobId]) {
58
+ // This ensures that a job is initialized before it is used. To avoid
59
+ // code duplication, we call the `#onData` method again, which will
60
+ // run the rest of the logic after initialization.
61
+ __classPrivateFieldGet(this, _ProxySnapExecutor_instances, "m", _ProxySnapExecutor_initializeJob).call(this, jobId)
62
+ .then(() => {
63
+ __classPrivateFieldGet(this, _ProxySnapExecutor_instances, "m", _ProxySnapExecutor_onData).call(this, data);
64
+ })
65
+ .catch((error) => {
66
+ logError('[Worker] Error initializing job:', error);
67
+ });
68
+ return;
69
+ }
70
+ // This is a method specific to the `OffscreenSnapExecutor`, as the service
71
+ // itself does not have access to the iframes directly.
72
+ if (request.method === 'terminateJob') {
73
+ __classPrivateFieldGet(this, _ProxySnapExecutor_instances, "m", _ProxySnapExecutor_terminateJob).call(this, jobId);
74
+ return;
75
+ }
76
+ this.jobs[jobId].stream.write(request);
77
+ }, _ProxySnapExecutor_initializeJob =
78
+ /**
79
+ * Create a new iframe and set up a stream to communicate with it.
80
+ *
81
+ * @param jobId - The job ID.
82
+ * @returns The executor job object.
83
+ */
84
+ async function _ProxySnapExecutor_initializeJob(jobId) {
85
+ const window = await createWindow(__classPrivateFieldGet(this, _ProxySnapExecutor_frameUrl, "f"), jobId);
86
+ const jobStream = new WindowPostMessageStream({
87
+ name: 'parent',
88
+ target: 'child',
89
+ targetWindow: window, // iframe's internal window
90
+ targetOrigin: '*',
91
+ });
92
+ // Write messages from the iframe to the parent, wrapped with the job ID.
93
+ jobStream.on('data', (data) => {
94
+ __classPrivateFieldGet(this, _ProxySnapExecutor_stream, "f").write({ data, jobId });
95
+ });
96
+ this.jobs[jobId] = { id: jobId, window, stream: jobStream };
97
+ return this.jobs[jobId];
98
+ }, _ProxySnapExecutor_terminateJob = function _ProxySnapExecutor_terminateJob(jobId) {
99
+ assert(this.jobs[jobId], `Job "${jobId}" not found.`);
100
+ const iframe = document.getElementById(jobId);
101
+ assert(iframe, `Iframe with ID "${jobId}" not found.`);
102
+ iframe.remove();
103
+ this.jobs[jobId].stream.destroy();
104
+ delete this.jobs[jobId];
7
105
  };
8
106
  //# sourceMappingURL=ProxySnapExecutor.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
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';\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 * @returns The executor job object.\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"]}
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./ProxySnapExecutor.cjs"), exports);
18
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sourceRoot":"","sources":["../../src/proxy/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0DAAoC","sourcesContent":["export * from './ProxySnapExecutor';\n"]}
@@ -0,0 +1,2 @@
1
+ export * from "./ProxySnapExecutor.cjs";
2
+ //# sourceMappingURL=index.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.cts","sourceRoot":"","sources":["../../src/proxy/index.ts"],"names":[],"mappings":"AAAA,wCAAoC"}
@@ -0,0 +1,2 @@
1
+ export * from "./ProxySnapExecutor.mjs";
2
+ //# sourceMappingURL=index.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.mts","sourceRoot":"","sources":["../../src/proxy/index.ts"],"names":[],"mappings":"AAAA,wCAAoC"}
@@ -1,9 +1,2 @@
1
- import "../chunk-TSEAPB7L.mjs";
2
- import {
3
- ProxySnapExecutor
4
- } from "../chunk-MIWGLICQ.mjs";
5
- import "../chunk-YRZVIDCF.mjs";
6
- export {
7
- ProxySnapExecutor
8
- };
1
+ export * from "./ProxySnapExecutor.mjs";
9
2
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
1
+ {"version":3,"file":"index.mjs","sourceRoot":"","sources":["../../src/proxy/index.ts"],"names":[],"mappings":"AAAA,wCAAoC","sourcesContent":["export * from './ProxySnapExecutor';\n"]}
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
3
+ if (kind === "m") throw new TypeError("Private method is not writable");
4
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
5
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
6
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
7
+ };
8
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
9
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
10
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
11
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
12
+ };
13
+ var _WebViewExecutorStream_name, _WebViewExecutorStream_target, _WebViewExecutorStream_targetWindow;
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.WebViewExecutorStream = void 0;
16
+ const post_message_stream_1 = require("@metamask/post-message-stream");
17
+ const utils_1 = require("@metamask/post-message-stream/dist/utils.js");
18
+ const utils_2 = require("@metamask/utils");
19
+ class WebViewExecutorStream extends post_message_stream_1.BasePostMessageStream {
20
+ /**
21
+ * A special post-message-stream to be used by the WebView executor.
22
+ *
23
+ * This stream is different in a few ways:
24
+ * - It expects data to be base64 encoded
25
+ * - It stringifies the data it posts
26
+ * - It does less validation of origins
27
+ *
28
+ * @param args - Options bag.
29
+ * @param args.name - The name of the stream. Used to differentiate between
30
+ * multiple streams sharing the same window object. child:WebView
31
+ * @param args.target - The name of the stream to exchange messages with. parent:rnside
32
+ * @param args.targetWindow - The window object of the target stream.
33
+ */
34
+ constructor({ name, target, targetWindow }) {
35
+ super();
36
+ _WebViewExecutorStream_name.set(this, void 0);
37
+ _WebViewExecutorStream_target.set(this, void 0);
38
+ _WebViewExecutorStream_targetWindow.set(this, void 0);
39
+ __classPrivateFieldSet(this, _WebViewExecutorStream_name, name, "f");
40
+ __classPrivateFieldSet(this, _WebViewExecutorStream_target, target, "f");
41
+ __classPrivateFieldSet(this, _WebViewExecutorStream_targetWindow, targetWindow, "f");
42
+ this._onMessage = this._onMessage.bind(this);
43
+ // This method is already bound.
44
+ // eslint-disable-next-line @typescript-eslint/unbound-method
45
+ window.addEventListener('message', this._onMessage, false);
46
+ this._handshake();
47
+ }
48
+ /**
49
+ * Webview needs to receive strings only on postMessage. That's the main difference between this and the original window post message stream.
50
+ * Reference: https://github.com/react-native-webview/react-native-webview/blob/master/docs/Guide.md?plain=1#L471
51
+ */
52
+ _postMessage(data) {
53
+ __classPrivateFieldGet(this, _WebViewExecutorStream_targetWindow, "f").postMessage(JSON.stringify({
54
+ target: __classPrivateFieldGet(this, _WebViewExecutorStream_target, "f"),
55
+ data,
56
+ }));
57
+ }
58
+ _onMessage(event) {
59
+ if (typeof event.data !== 'string') {
60
+ return;
61
+ }
62
+ const bytes = (0, utils_2.base64ToBytes)(event.data);
63
+ const message = JSON.parse((0, utils_2.bytesToString)(bytes));
64
+ // Notice that we don't check targetWindow or targetOrigin here.
65
+ // This doesn't seem possible to do in RN.
66
+ if (!(0, utils_1.isValidStreamMessage)(message) || message.target !== __classPrivateFieldGet(this, _WebViewExecutorStream_name, "f")) {
67
+ return;
68
+ }
69
+ this._onData(message.data);
70
+ }
71
+ _destroy() {
72
+ // This method is already bound.
73
+ // eslint-disable-next-line @typescript-eslint/unbound-method
74
+ window.removeEventListener('message', this._onMessage, false);
75
+ }
76
+ }
77
+ exports.WebViewExecutorStream = WebViewExecutorStream;
78
+ _WebViewExecutorStream_name = new WeakMap(), _WebViewExecutorStream_target = new WeakMap(), _WebViewExecutorStream_targetWindow = new WeakMap();
79
+ //# sourceMappingURL=WebViewExecutorStream.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WebViewExecutorStream.cjs","sourceRoot":"","sources":["../../src/webview/WebViewExecutorStream.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,uEAAsE;AACtE,uEAAgF;AAChF,2CAA+D;AAQ/D,MAAa,qBAAsB,SAAQ,2CAAqB;IAO9D;;;;;;;;;;;;;OAaG;IAEH,YAAY,EAAE,IAAI,EAAE,MAAM,EAAE,YAAY,EAA6B;QACnE,KAAK,EAAE,CAAC;QAtBV,8CAAM;QAEN,gDAAQ;QAER,sDAAc;QAoBZ,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;IAEO,UAAU,CAAC,KAAuB;QACxC,IAAI,OAAO,KAAK,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YACnC,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAG,IAAA,qBAAa,EAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACxC,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAA,qBAAa,EAAC,KAAK,CAAC,CAAC,CAAC;QAEjD,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;AA1ED,sDA0EC","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"]}
@@ -1,5 +1,5 @@
1
- import { BasePostMessageStream } from '@metamask/post-message-stream';
2
- declare type WebViewExecutorStreamArgs = {
1
+ import { BasePostMessageStream } from "@metamask/post-message-stream";
2
+ type WebViewExecutorStreamArgs = {
3
3
  name: string;
4
4
  target: string;
5
5
  targetWindow: Window['ReactNativeWebView'];
@@ -30,3 +30,4 @@ export declare class WebViewExecutorStream extends BasePostMessageStream {
30
30
  _destroy(): void;
31
31
  }
32
32
  export {};
33
+ //# sourceMappingURL=WebViewExecutorStream.d.cts.map