@metamask/snaps-utils 8.0.1 → 8.1.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 (975) hide show
  1. package/CHANGELOG.md +21 -1
  2. package/dist/array.cjs +17 -0
  3. package/dist/array.cjs.map +1 -0
  4. package/dist/array.d.cts +11 -0
  5. package/dist/array.d.cts.map +1 -0
  6. package/dist/array.d.mts +11 -0
  7. package/dist/array.d.mts.map +1 -0
  8. package/dist/array.mjs +12 -7
  9. package/dist/array.mjs.map +1 -1
  10. package/dist/auxiliary-files.cjs +39 -0
  11. package/dist/auxiliary-files.cjs.map +1 -0
  12. package/dist/auxiliary-files.d.cts +17 -0
  13. package/dist/auxiliary-files.d.cts.map +1 -0
  14. package/dist/auxiliary-files.d.mts +17 -0
  15. package/dist/auxiliary-files.d.mts.map +1 -0
  16. package/dist/auxiliary-files.mjs +33 -14
  17. package/dist/auxiliary-files.mjs.map +1 -1
  18. package/dist/base64.cjs +38 -0
  19. package/dist/base64.cjs.map +1 -0
  20. package/dist/base64.d.cts +16 -0
  21. package/dist/base64.d.cts.map +1 -0
  22. package/dist/base64.d.mts +16 -0
  23. package/dist/base64.d.mts.map +1 -0
  24. package/dist/base64.mjs +32 -12
  25. package/dist/base64.mjs.map +1 -1
  26. package/dist/bytes.cjs +22 -0
  27. package/dist/bytes.cjs.map +1 -0
  28. package/dist/bytes.d.cts +9 -0
  29. package/dist/bytes.d.cts.map +1 -0
  30. package/dist/bytes.d.mts +9 -0
  31. package/dist/bytes.d.mts.map +1 -0
  32. package/dist/bytes.mjs +17 -9
  33. package/dist/bytes.mjs.map +1 -1
  34. package/dist/caveats.cjs +51 -0
  35. package/dist/caveats.cjs.map +1 -0
  36. package/dist/caveats.d.cts +47 -0
  37. package/dist/caveats.d.cts.map +1 -0
  38. package/dist/caveats.d.mts +47 -0
  39. package/dist/caveats.d.mts.map +1 -0
  40. package/dist/caveats.mjs +47 -7
  41. package/dist/caveats.mjs.map +1 -1
  42. package/dist/checksum.cjs +49 -0
  43. package/dist/checksum.cjs.map +1 -0
  44. package/dist/checksum.d.cts +22 -0
  45. package/dist/checksum.d.cts.map +1 -0
  46. package/dist/checksum.d.mts +22 -0
  47. package/dist/checksum.d.mts.map +1 -0
  48. package/dist/checksum.mjs +43 -12
  49. package/dist/checksum.mjs.map +1 -1
  50. package/dist/constants.cjs +8 -0
  51. package/dist/constants.cjs.map +1 -0
  52. package/dist/constants.d.cts +2 -0
  53. package/dist/constants.d.cts.map +1 -0
  54. package/dist/constants.d.mts +2 -0
  55. package/dist/constants.d.mts.map +1 -0
  56. package/dist/constants.mjs +4 -7
  57. package/dist/constants.mjs.map +1 -1
  58. package/dist/cronjob.cjs +70 -0
  59. package/dist/cronjob.cjs.map +1 -0
  60. package/dist/cronjob.d.cts +90 -0
  61. package/dist/cronjob.d.cts.map +1 -0
  62. package/dist/cronjob.d.mts +90 -0
  63. package/dist/cronjob.d.mts.map +1 -0
  64. package/dist/cronjob.mjs +64 -19
  65. package/dist/cronjob.mjs.map +1 -1
  66. package/dist/deep-clone.cjs +9 -0
  67. package/dist/deep-clone.cjs.map +1 -0
  68. package/dist/deep-clone.d.cts +2 -0
  69. package/dist/deep-clone.d.cts.map +1 -0
  70. package/dist/deep-clone.d.mts +2 -0
  71. package/dist/deep-clone.d.mts.map +1 -0
  72. package/dist/deep-clone.mjs +9 -7
  73. package/dist/deep-clone.mjs.map +1 -1
  74. package/dist/default-endowments.cjs +42 -0
  75. package/dist/default-endowments.cjs.map +1 -0
  76. package/dist/default-endowments.d.cts +5 -0
  77. package/dist/default-endowments.d.cts.map +1 -0
  78. package/dist/default-endowments.d.mts +5 -0
  79. package/dist/default-endowments.d.mts.map +1 -0
  80. package/dist/default-endowments.mjs +38 -7
  81. package/dist/default-endowments.mjs.map +1 -1
  82. package/dist/derivation-paths.cjs +215 -0
  83. package/dist/derivation-paths.cjs.map +1 -0
  84. package/dist/derivation-paths.d.cts +25 -0
  85. package/dist/derivation-paths.d.cts.map +1 -0
  86. package/dist/derivation-paths.d.mts +25 -0
  87. package/dist/derivation-paths.d.mts.map +1 -0
  88. package/dist/derivation-paths.mjs +206 -12
  89. package/dist/derivation-paths.mjs.map +1 -1
  90. package/dist/entropy.cjs +8 -0
  91. package/dist/entropy.cjs.map +1 -0
  92. package/dist/entropy.d.cts +4 -0
  93. package/dist/entropy.d.cts.map +1 -0
  94. package/dist/entropy.d.mts +4 -0
  95. package/dist/entropy.d.mts.map +1 -0
  96. package/dist/entropy.mjs +4 -9
  97. package/dist/entropy.mjs.map +1 -1
  98. package/dist/errors.cjs +189 -0
  99. package/dist/errors.cjs.map +1 -0
  100. package/dist/errors.d.cts +85 -0
  101. package/dist/errors.d.cts.map +1 -0
  102. package/dist/errors.d.mts +85 -0
  103. package/dist/errors.d.mts.map +1 -0
  104. package/dist/errors.mjs +179 -18
  105. package/dist/errors.mjs.map +1 -1
  106. package/dist/eval-worker.cjs +42 -0
  107. package/dist/eval-worker.cjs.map +1 -0
  108. package/dist/eval-worker.d.cts +2 -0
  109. package/dist/eval-worker.d.cts.map +1 -0
  110. package/dist/eval-worker.d.mts +2 -0
  111. package/dist/eval-worker.d.mts.map +1 -0
  112. package/dist/eval-worker.mjs +28 -31
  113. package/dist/eval-worker.mjs.map +1 -1
  114. package/dist/eval.cjs +54 -0
  115. package/dist/eval.cjs.map +1 -0
  116. package/dist/eval.d.cts +17 -0
  117. package/dist/eval.d.cts.map +1 -0
  118. package/dist/eval.d.mts +17 -0
  119. package/dist/eval.d.mts.map +1 -0
  120. package/dist/eval.mjs +66 -16
  121. package/dist/eval.mjs.map +1 -1
  122. package/dist/fs.cjs +159 -0
  123. package/dist/fs.cjs.map +1 -0
  124. package/dist/fs.d.cts +70 -0
  125. package/dist/fs.d.cts.map +1 -0
  126. package/dist/fs.d.mts +70 -0
  127. package/dist/fs.d.mts.map +1 -0
  128. package/dist/fs.mjs +144 -27
  129. package/dist/fs.mjs.map +1 -1
  130. package/dist/handler-types.cjs +18 -0
  131. package/dist/handler-types.cjs.map +1 -0
  132. package/dist/handler-types.d.cts +35 -0
  133. package/dist/handler-types.d.cts.map +1 -0
  134. package/dist/handler-types.d.mts +35 -0
  135. package/dist/handler-types.d.mts.map +1 -0
  136. package/dist/handler-types.mjs +14 -9
  137. package/dist/handler-types.mjs.map +1 -1
  138. package/dist/handlers.cjs +119 -0
  139. package/dist/handlers.cjs.map +1 -0
  140. package/dist/handlers.d.cts +750 -0
  141. package/dist/handlers.d.cts.map +1 -0
  142. package/dist/handlers.d.mts +750 -0
  143. package/dist/handlers.d.mts.map +1 -0
  144. package/dist/handlers.mjs +114 -33
  145. package/dist/handlers.mjs.map +1 -1
  146. package/dist/icon.cjs +58 -0
  147. package/dist/icon.cjs.map +1 -0
  148. package/dist/icon.d.cts +20 -0
  149. package/dist/icon.d.cts.map +1 -0
  150. package/dist/icon.d.mts +20 -0
  151. package/dist/icon.d.mts.map +1 -0
  152. package/dist/icon.mjs +52 -14
  153. package/dist/icon.mjs.map +1 -1
  154. package/dist/iframe.cjs +54 -0
  155. package/dist/iframe.cjs.map +1 -0
  156. package/dist/iframe.d.cts +12 -0
  157. package/dist/iframe.d.cts.map +1 -0
  158. package/dist/iframe.d.mts +12 -0
  159. package/dist/iframe.d.mts.map +1 -0
  160. package/dist/iframe.mjs +49 -7
  161. package/dist/iframe.mjs.map +1 -1
  162. package/dist/iframe.test.browser.cjs +15 -0
  163. package/dist/iframe.test.browser.cjs.map +1 -0
  164. package/dist/iframe.test.browser.d.cts +2 -0
  165. package/dist/iframe.test.browser.d.cts.map +1 -0
  166. package/dist/iframe.test.browser.d.mts +2 -0
  167. package/dist/iframe.test.browser.d.mts.map +1 -0
  168. package/dist/iframe.test.browser.mjs +13 -0
  169. package/dist/iframe.test.browser.mjs.map +1 -0
  170. package/dist/index.cjs +49 -0
  171. package/dist/index.cjs.map +1 -0
  172. package/dist/index.d.cts +33 -0
  173. package/dist/index.d.cts.map +1 -0
  174. package/dist/index.d.mts +33 -0
  175. package/dist/index.d.mts.map +1 -0
  176. package/dist/index.executionenv.cjs +25 -0
  177. package/dist/index.executionenv.cjs.map +1 -0
  178. package/dist/index.executionenv.d.cts +8 -0
  179. package/dist/index.executionenv.d.cts.map +1 -0
  180. package/dist/index.executionenv.d.mts +8 -0
  181. package/dist/index.executionenv.d.mts.map +1 -0
  182. package/dist/index.executionenv.mjs +8 -127
  183. package/dist/index.executionenv.mjs.map +1 -1
  184. package/dist/index.mjs +32 -397
  185. package/dist/index.mjs.map +1 -1
  186. package/dist/json-rpc.cjs +135 -0
  187. package/dist/json-rpc.cjs.map +1 -0
  188. package/dist/json-rpc.d.cts +56 -0
  189. package/dist/json-rpc.d.cts.map +1 -0
  190. package/dist/json-rpc.d.mts +56 -0
  191. package/dist/json-rpc.d.mts.map +1 -0
  192. package/dist/json-rpc.mjs +127 -17
  193. package/dist/json-rpc.mjs.map +1 -1
  194. package/dist/json.cjs +34 -0
  195. package/dist/json.cjs.map +1 -0
  196. package/dist/json.d.cts +23 -0
  197. package/dist/json.d.cts.map +1 -0
  198. package/dist/json.d.mts +23 -0
  199. package/dist/json.d.mts.map +1 -0
  200. package/dist/json.mjs +28 -9
  201. package/dist/json.mjs.map +1 -1
  202. package/dist/localization.cjs +128 -0
  203. package/dist/localization.cjs.map +1 -0
  204. package/dist/localization.d.cts +146 -0
  205. package/dist/localization.d.cts.map +1 -0
  206. package/dist/localization.d.mts +146 -0
  207. package/dist/localization.d.mts.map +1 -0
  208. package/dist/localization.mjs +119 -22
  209. package/dist/localization.mjs.map +1 -1
  210. package/dist/logging.cjs +67 -0
  211. package/dist/logging.cjs.map +1 -0
  212. package/dist/logging.d.cts +50 -0
  213. package/dist/logging.d.cts.map +1 -0
  214. package/dist/logging.d.mts +50 -0
  215. package/dist/logging.d.mts.map +1 -0
  216. package/dist/logging.mjs +60 -13
  217. package/dist/logging.mjs.map +1 -1
  218. package/dist/manifest/index.cjs +18 -0
  219. package/dist/manifest/index.cjs.map +1 -0
  220. package/dist/manifest/index.d.cts +2 -0
  221. package/dist/manifest/index.d.cts.map +1 -0
  222. package/dist/manifest/index.d.mts +2 -0
  223. package/dist/manifest/index.d.mts.map +1 -0
  224. package/dist/manifest/index.mjs +1 -64
  225. package/dist/manifest/index.mjs.map +1 -1
  226. package/dist/manifest/manifest.cjs +267 -0
  227. package/dist/manifest/manifest.cjs.map +1 -0
  228. package/dist/manifest/manifest.d.cts +100 -0
  229. package/dist/manifest/manifest.d.cts.map +1 -0
  230. package/dist/manifest/manifest.d.mts +100 -0
  231. package/dist/manifest/manifest.d.mts.map +1 -0
  232. package/dist/manifest/manifest.mjs +252 -57
  233. package/dist/manifest/manifest.mjs.map +1 -1
  234. package/dist/manifest/node.cjs +19 -0
  235. package/dist/manifest/node.cjs.map +1 -0
  236. package/dist/manifest/node.d.cts +3 -0
  237. package/dist/manifest/node.d.cts.map +1 -0
  238. package/dist/manifest/node.d.mts +3 -0
  239. package/dist/manifest/node.d.mts.map +1 -0
  240. package/dist/manifest/node.mjs +2 -105
  241. package/dist/manifest/node.mjs.map +1 -1
  242. package/dist/manifest/validation.cjs +194 -0
  243. package/dist/manifest/validation.cjs.map +1 -0
  244. package/dist/manifest/validation.d.cts +254 -0
  245. package/dist/manifest/validation.d.cts.map +1 -0
  246. package/dist/manifest/validation.d.mts +254 -0
  247. package/dist/manifest/validation.d.mts.map +1 -0
  248. package/dist/manifest/validation.mjs +186 -63
  249. package/dist/manifest/validation.mjs.map +1 -1
  250. package/dist/manifest/validator-types.cjs +3 -0
  251. package/dist/manifest/validator-types.cjs.map +1 -0
  252. package/dist/manifest/validator-types.d.cts +35 -0
  253. package/dist/manifest/validator-types.d.cts.map +1 -0
  254. package/dist/manifest/validator-types.d.mts +35 -0
  255. package/dist/manifest/validator-types.d.mts.map +1 -0
  256. package/dist/manifest/validator-types.mjs +1 -0
  257. package/dist/manifest/validator-types.mjs.map +1 -1
  258. package/dist/manifest/validator.cjs +109 -0
  259. package/dist/manifest/validator.cjs.map +1 -0
  260. package/dist/manifest/validator.d.cts +24 -0
  261. package/dist/manifest/validator.d.cts.map +1 -0
  262. package/dist/manifest/validator.d.mts +24 -0
  263. package/dist/manifest/validator.d.mts.map +1 -0
  264. package/dist/manifest/validator.mjs +79 -42
  265. package/dist/manifest/validator.mjs.map +1 -1
  266. package/dist/manifest/validators/checksum.cjs +23 -0
  267. package/dist/manifest/validators/checksum.cjs.map +1 -0
  268. package/dist/manifest/validators/checksum.d.cts +6 -0
  269. package/dist/manifest/validators/checksum.d.cts.map +1 -0
  270. package/dist/manifest/validators/checksum.d.mts +6 -0
  271. package/dist/manifest/validators/checksum.d.mts.map +1 -0
  272. package/dist/manifest/validators/checksum.mjs +18 -13
  273. package/dist/manifest/validators/checksum.mjs.map +1 -1
  274. package/dist/manifest/validators/expected-files.cjs +24 -0
  275. package/dist/manifest/validators/expected-files.cjs.map +1 -0
  276. package/dist/manifest/validators/expected-files.d.cts +6 -0
  277. package/dist/manifest/validators/expected-files.d.cts.map +1 -0
  278. package/dist/manifest/validators/expected-files.d.mts +6 -0
  279. package/dist/manifest/validators/expected-files.d.mts.map +1 -0
  280. package/dist/manifest/validators/expected-files.mjs +19 -7
  281. package/dist/manifest/validators/expected-files.mjs.map +1 -1
  282. package/dist/manifest/validators/icon-declared.cjs +15 -0
  283. package/dist/manifest/validators/icon-declared.cjs.map +1 -0
  284. package/dist/manifest/validators/icon-declared.d.cts +6 -0
  285. package/dist/manifest/validators/icon-declared.d.cts.map +1 -0
  286. package/dist/manifest/validators/icon-declared.d.mts +6 -0
  287. package/dist/manifest/validators/icon-declared.d.mts.map +1 -0
  288. package/dist/manifest/validators/icon-declared.mjs +10 -6
  289. package/dist/manifest/validators/icon-declared.mjs.map +1 -1
  290. package/dist/manifest/validators/icon-dimensions.cjs +20 -0
  291. package/dist/manifest/validators/icon-dimensions.cjs.map +1 -0
  292. package/dist/manifest/validators/icon-dimensions.d.cts +6 -0
  293. package/dist/manifest/validators/icon-dimensions.d.cts.map +1 -0
  294. package/dist/manifest/validators/icon-dimensions.d.mts +6 -0
  295. package/dist/manifest/validators/icon-dimensions.d.mts.map +1 -0
  296. package/dist/manifest/validators/icon-dimensions.mjs +15 -8
  297. package/dist/manifest/validators/icon-dimensions.mjs.map +1 -1
  298. package/dist/manifest/validators/icon-missing.cjs +16 -0
  299. package/dist/manifest/validators/icon-missing.cjs.map +1 -0
  300. package/dist/manifest/validators/icon-missing.d.cts +6 -0
  301. package/dist/manifest/validators/icon-missing.d.cts.map +1 -0
  302. package/dist/manifest/validators/icon-missing.d.mts +6 -0
  303. package/dist/manifest/validators/icon-missing.d.mts.map +1 -0
  304. package/dist/manifest/validators/icon-missing.mjs +11 -6
  305. package/dist/manifest/validators/icon-missing.mjs.map +1 -1
  306. package/dist/manifest/validators/index.cjs +31 -0
  307. package/dist/manifest/validators/index.cjs.map +1 -0
  308. package/dist/manifest/validators/index.d.cts +15 -0
  309. package/dist/manifest/validators/index.d.cts.map +1 -0
  310. package/dist/manifest/validators/index.d.mts +15 -0
  311. package/dist/manifest/validators/index.d.mts.map +1 -0
  312. package/dist/manifest/validators/index.mjs +14 -79
  313. package/dist/manifest/validators/index.mjs.map +1 -1
  314. package/dist/manifest/validators/is-localization-file.cjs +23 -0
  315. package/dist/manifest/validators/is-localization-file.cjs.map +1 -0
  316. package/dist/manifest/validators/is-localization-file.d.cts +6 -0
  317. package/dist/manifest/validators/is-localization-file.d.cts.map +1 -0
  318. package/dist/manifest/validators/is-localization-file.d.mts +6 -0
  319. package/dist/manifest/validators/is-localization-file.d.mts.map +1 -0
  320. package/dist/manifest/validators/is-localization-file.mjs +18 -10
  321. package/dist/manifest/validators/is-localization-file.mjs.map +1 -1
  322. package/dist/manifest/validators/is-package-json.cjs +24 -0
  323. package/dist/manifest/validators/is-package-json.cjs.map +1 -0
  324. package/dist/manifest/validators/is-package-json.d.cts +6 -0
  325. package/dist/manifest/validators/is-package-json.d.cts.map +1 -0
  326. package/dist/manifest/validators/is-package-json.d.mts +6 -0
  327. package/dist/manifest/validators/is-package-json.d.mts.map +1 -0
  328. package/dist/manifest/validators/is-package-json.mjs +19 -9
  329. package/dist/manifest/validators/is-package-json.mjs.map +1 -1
  330. package/dist/manifest/validators/is-snap-icon.cjs +24 -0
  331. package/dist/manifest/validators/is-snap-icon.cjs.map +1 -0
  332. package/dist/manifest/validators/is-snap-icon.d.cts +6 -0
  333. package/dist/manifest/validators/is-snap-icon.d.cts.map +1 -0
  334. package/dist/manifest/validators/is-snap-icon.d.mts +6 -0
  335. package/dist/manifest/validators/is-snap-icon.d.mts.map +1 -0
  336. package/dist/manifest/validators/is-snap-icon.mjs +19 -8
  337. package/dist/manifest/validators/is-snap-icon.mjs.map +1 -1
  338. package/dist/manifest/validators/is-snap-manifest.cjs +25 -0
  339. package/dist/manifest/validators/is-snap-manifest.cjs.map +1 -0
  340. package/dist/manifest/validators/is-snap-manifest.d.cts +6 -0
  341. package/dist/manifest/validators/is-snap-manifest.d.cts.map +1 -0
  342. package/dist/manifest/validators/is-snap-manifest.d.mts +6 -0
  343. package/dist/manifest/validators/is-snap-manifest.d.mts.map +1 -0
  344. package/dist/manifest/validators/is-snap-manifest.mjs +20 -21
  345. package/dist/manifest/validators/is-snap-manifest.mjs.map +1 -1
  346. package/dist/manifest/validators/manifest-localization.cjs +30 -0
  347. package/dist/manifest/validators/manifest-localization.cjs.map +1 -0
  348. package/dist/manifest/validators/manifest-localization.d.cts +6 -0
  349. package/dist/manifest/validators/manifest-localization.d.cts.map +1 -0
  350. package/dist/manifest/validators/manifest-localization.d.mts +6 -0
  351. package/dist/manifest/validators/manifest-localization.d.mts.map +1 -0
  352. package/dist/manifest/validators/manifest-localization.mjs +25 -8
  353. package/dist/manifest/validators/manifest-localization.mjs.map +1 -1
  354. package/dist/manifest/validators/package-json-recommended-fields.cjs +18 -0
  355. package/dist/manifest/validators/package-json-recommended-fields.cjs.map +1 -0
  356. package/dist/manifest/validators/package-json-recommended-fields.d.cts +6 -0
  357. package/dist/manifest/validators/package-json-recommended-fields.d.cts.map +1 -0
  358. package/dist/manifest/validators/package-json-recommended-fields.d.mts +6 -0
  359. package/dist/manifest/validators/package-json-recommended-fields.d.mts.map +1 -0
  360. package/dist/manifest/validators/package-json-recommended-fields.mjs +13 -6
  361. package/dist/manifest/validators/package-json-recommended-fields.mjs.map +1 -1
  362. package/dist/manifest/validators/package-name-match.cjs +21 -0
  363. package/dist/manifest/validators/package-name-match.cjs.map +1 -0
  364. package/dist/manifest/validators/package-name-match.d.cts +6 -0
  365. package/dist/manifest/validators/package-name-match.d.cts.map +1 -0
  366. package/dist/manifest/validators/package-name-match.d.mts +6 -0
  367. package/dist/manifest/validators/package-name-match.d.mts.map +1 -0
  368. package/dist/manifest/validators/package-name-match.mjs +16 -7
  369. package/dist/manifest/validators/package-name-match.mjs.map +1 -1
  370. package/dist/manifest/validators/repository-match.cjs +29 -0
  371. package/dist/manifest/validators/repository-match.cjs.map +1 -0
  372. package/dist/manifest/validators/repository-match.d.cts +6 -0
  373. package/dist/manifest/validators/repository-match.d.cts.map +1 -0
  374. package/dist/manifest/validators/repository-match.d.mts +6 -0
  375. package/dist/manifest/validators/repository-match.d.mts.map +1 -0
  376. package/dist/manifest/validators/repository-match.mjs +28 -8
  377. package/dist/manifest/validators/repository-match.mjs.map +1 -1
  378. package/dist/manifest/validators/version-match.cjs +21 -0
  379. package/dist/manifest/validators/version-match.cjs.map +1 -0
  380. package/dist/manifest/validators/version-match.d.cts +6 -0
  381. package/dist/manifest/validators/version-match.d.cts.map +1 -0
  382. package/dist/manifest/validators/version-match.d.mts +6 -0
  383. package/dist/manifest/validators/version-match.d.mts.map +1 -0
  384. package/dist/manifest/validators/version-match.mjs +16 -7
  385. package/dist/manifest/validators/version-match.mjs.map +1 -1
  386. package/dist/mock.cjs +113 -0
  387. package/dist/mock.cjs.map +1 -0
  388. package/dist/mock.d.cts +15 -0
  389. package/dist/mock.d.cts.map +1 -0
  390. package/dist/mock.d.mts +15 -0
  391. package/dist/mock.d.mts.map +1 -0
  392. package/dist/mock.mjs +103 -11
  393. package/dist/mock.mjs.map +1 -1
  394. package/dist/namespace.cjs +136 -0
  395. package/dist/namespace.cjs.map +1 -0
  396. package/dist/namespace.d.cts +130 -0
  397. package/dist/namespace.d.cts.map +1 -0
  398. package/dist/namespace.d.mts +130 -0
  399. package/dist/namespace.d.mts.map +1 -0
  400. package/dist/namespace.mjs +125 -43
  401. package/dist/namespace.mjs.map +1 -1
  402. package/dist/node.cjs +25 -0
  403. package/dist/node.cjs.map +1 -0
  404. package/dist/node.d.cts +8 -0
  405. package/dist/node.d.cts.map +1 -0
  406. package/dist/node.d.mts +8 -0
  407. package/dist/node.d.mts.map +1 -0
  408. package/dist/node.mjs +8 -475
  409. package/dist/node.mjs.map +1 -1
  410. package/dist/path.cjs +21 -0
  411. package/dist/path.cjs.map +1 -0
  412. package/dist/path.d.cts +8 -0
  413. package/dist/path.d.cts.map +1 -0
  414. package/dist/path.d.mts +8 -0
  415. package/dist/path.d.mts.map +1 -0
  416. package/dist/path.mjs +16 -7
  417. package/dist/path.mjs.map +1 -1
  418. package/dist/post-process.cjs +339 -0
  419. package/dist/post-process.cjs.map +1 -0
  420. package/dist/post-process.d.cts +72 -0
  421. package/dist/post-process.d.cts.map +1 -0
  422. package/dist/post-process.d.mts +72 -0
  423. package/dist/post-process.d.mts.map +1 -0
  424. package/dist/post-process.mjs +335 -9
  425. package/dist/post-process.mjs.map +1 -1
  426. package/dist/promise.cjs +3 -0
  427. package/dist/promise.cjs.map +1 -0
  428. package/dist/promise.d.cts +2 -0
  429. package/dist/promise.d.cts.map +1 -0
  430. package/dist/promise.d.mts +2 -0
  431. package/dist/promise.d.mts.map +1 -0
  432. package/dist/promise.mjs +1 -1
  433. package/dist/promise.mjs.map +1 -1
  434. package/dist/snaps.cjs +207 -0
  435. package/dist/snaps.cjs.map +1 -0
  436. package/dist/snaps.d.cts +174 -0
  437. package/dist/snaps.d.cts.map +1 -0
  438. package/dist/snaps.d.mts +174 -0
  439. package/dist/snaps.d.mts.map +1 -0
  440. package/dist/snaps.mjs +200 -45
  441. package/dist/snaps.mjs.map +1 -1
  442. package/dist/strings.cjs +15 -0
  443. package/dist/strings.cjs.map +1 -0
  444. package/dist/strings.d.cts +9 -0
  445. package/dist/strings.d.cts.map +1 -0
  446. package/dist/strings.d.mts +9 -0
  447. package/dist/strings.d.mts.map +1 -0
  448. package/dist/strings.mjs +10 -7
  449. package/dist/strings.mjs.map +1 -1
  450. package/dist/structs.cjs +316 -0
  451. package/dist/structs.cjs.map +1 -0
  452. package/dist/structs.d.cts +181 -0
  453. package/dist/structs.d.cts.map +1 -0
  454. package/dist/structs.d.mts +181 -0
  455. package/dist/structs.d.mts.map +1 -0
  456. package/dist/structs.mjs +300 -32
  457. package/dist/structs.mjs.map +1 -1
  458. package/dist/svg.cjs +49 -0
  459. package/dist/svg.cjs.map +1 -0
  460. package/dist/svg.d.cts +15 -0
  461. package/dist/svg.d.cts.map +1 -0
  462. package/dist/svg.d.mts +15 -0
  463. package/dist/svg.d.mts.map +1 -0
  464. package/dist/svg.mjs +43 -9
  465. package/dist/svg.mjs.map +1 -1
  466. package/dist/types.cjs +64 -0
  467. package/dist/types.cjs.map +1 -0
  468. package/dist/types.d.cts +104 -0
  469. package/dist/types.d.cts.map +1 -0
  470. package/dist/types.d.mts +104 -0
  471. package/dist/types.d.mts.map +1 -0
  472. package/dist/types.mjs +58 -21
  473. package/dist/types.mjs.map +1 -1
  474. package/dist/ui.cjs +405 -0
  475. package/dist/ui.cjs.map +1 -0
  476. package/dist/ui.d.cts +93 -0
  477. package/dist/ui.d.cts.map +1 -0
  478. package/dist/ui.d.mts +93 -0
  479. package/dist/ui.d.mts.map +1 -0
  480. package/dist/ui.mjs +391 -23
  481. package/dist/ui.mjs.map +1 -1
  482. package/dist/validation.cjs +23 -0
  483. package/dist/validation.cjs.map +1 -0
  484. package/dist/validation.d.cts +9 -0
  485. package/dist/validation.d.cts.map +1 -0
  486. package/dist/validation.d.mts +9 -0
  487. package/dist/validation.d.mts.map +1 -0
  488. package/dist/validation.mjs +18 -26
  489. package/dist/validation.mjs.map +1 -1
  490. package/dist/versions.cjs +44 -0
  491. package/dist/versions.cjs.map +1 -0
  492. package/dist/versions.d.cts +22 -0
  493. package/dist/versions.d.cts.map +1 -0
  494. package/dist/versions.d.mts +22 -0
  495. package/dist/versions.d.mts.map +1 -0
  496. package/dist/versions.mjs +38 -11
  497. package/dist/versions.mjs.map +1 -1
  498. package/dist/virtual-file/VirtualFile.cjs +75 -0
  499. package/dist/virtual-file/VirtualFile.cjs.map +1 -0
  500. package/dist/virtual-file/VirtualFile.d.cts +35 -0
  501. package/dist/virtual-file/VirtualFile.d.cts.map +1 -0
  502. package/dist/virtual-file/VirtualFile.d.mts +35 -0
  503. package/dist/virtual-file/VirtualFile.d.mts.map +1 -0
  504. package/dist/virtual-file/VirtualFile.mjs +70 -8
  505. package/dist/virtual-file/VirtualFile.mjs.map +1 -1
  506. package/dist/virtual-file/index.cjs +18 -0
  507. package/dist/virtual-file/index.cjs.map +1 -0
  508. package/dist/virtual-file/index.d.cts +2 -0
  509. package/dist/virtual-file/index.d.cts.map +1 -0
  510. package/dist/virtual-file/index.d.mts +2 -0
  511. package/dist/virtual-file/index.d.mts.map +1 -0
  512. package/dist/virtual-file/index.mjs +1 -9
  513. package/dist/virtual-file/index.mjs.map +1 -1
  514. package/dist/virtual-file/node.cjs +19 -0
  515. package/dist/virtual-file/node.cjs.map +1 -0
  516. package/dist/virtual-file/node.d.cts +3 -0
  517. package/dist/virtual-file/node.d.cts.map +1 -0
  518. package/dist/virtual-file/node.d.mts +3 -0
  519. package/dist/virtual-file/node.d.mts.map +1 -0
  520. package/dist/virtual-file/node.mjs +2 -16
  521. package/dist/virtual-file/node.mjs.map +1 -1
  522. package/dist/virtual-file/toVirtualFile.cjs +31 -0
  523. package/dist/virtual-file/toVirtualFile.cjs.map +1 -0
  524. package/dist/virtual-file/toVirtualFile.d.cts +24 -0
  525. package/dist/virtual-file/toVirtualFile.d.cts.map +1 -0
  526. package/dist/virtual-file/toVirtualFile.d.mts +24 -0
  527. package/dist/virtual-file/toVirtualFile.d.mts.map +1 -0
  528. package/dist/virtual-file/toVirtualFile.mjs +25 -11
  529. package/dist/virtual-file/toVirtualFile.mjs.map +1 -1
  530. package/package.json +36 -24
  531. package/dist/array.js +0 -8
  532. package/dist/array.js.map +0 -1
  533. package/dist/auxiliary-files.js +0 -15
  534. package/dist/auxiliary-files.js.map +0 -1
  535. package/dist/base64.js +0 -13
  536. package/dist/base64.js.map +0 -1
  537. package/dist/bytes.js +0 -10
  538. package/dist/bytes.js.map +0 -1
  539. package/dist/caveats.js +0 -8
  540. package/dist/caveats.js.map +0 -1
  541. package/dist/checksum.js +0 -13
  542. package/dist/checksum.js.map +0 -1
  543. package/dist/chunk-37EUH3KZ.js +0 -293
  544. package/dist/chunk-37EUH3KZ.js.map +0 -1
  545. package/dist/chunk-3N27GIUS.mjs +0 -229
  546. package/dist/chunk-3N27GIUS.mjs.map +0 -1
  547. package/dist/chunk-3OXW5H4F.js +0 -30
  548. package/dist/chunk-3OXW5H4F.js.map +0 -1
  549. package/dist/chunk-3RFGTBEP.js +0 -151
  550. package/dist/chunk-3RFGTBEP.js.map +0 -1
  551. package/dist/chunk-3RUWAMJT.mjs +0 -31
  552. package/dist/chunk-3RUWAMJT.mjs.map +0 -1
  553. package/dist/chunk-3S4INAGA.mjs +0 -18
  554. package/dist/chunk-3S4INAGA.mjs.map +0 -1
  555. package/dist/chunk-44VFHYJO.js +0 -249
  556. package/dist/chunk-44VFHYJO.js.map +0 -1
  557. package/dist/chunk-4AA3TKRJ.mjs +0 -153
  558. package/dist/chunk-4AA3TKRJ.mjs.map +0 -1
  559. package/dist/chunk-4BGZ2CHC.mjs +0 -22
  560. package/dist/chunk-4BGZ2CHC.mjs.map +0 -1
  561. package/dist/chunk-4CMD46B2.js +0 -1
  562. package/dist/chunk-4CMD46B2.js.map +0 -1
  563. package/dist/chunk-4RYTYEUQ.mjs +0 -33
  564. package/dist/chunk-4RYTYEUQ.mjs.map +0 -1
  565. package/dist/chunk-4ZJOU3LR.js +0 -71
  566. package/dist/chunk-4ZJOU3LR.js.map +0 -1
  567. package/dist/chunk-53QXTM77.js +0 -229
  568. package/dist/chunk-53QXTM77.js.map +0 -1
  569. package/dist/chunk-5FTBWYCW.mjs +0 -27
  570. package/dist/chunk-5FTBWYCW.mjs.map +0 -1
  571. package/dist/chunk-5MABKEV7.mjs +0 -66
  572. package/dist/chunk-5MABKEV7.mjs.map +0 -1
  573. package/dist/chunk-5R7UF7KM.mjs +0 -21
  574. package/dist/chunk-5R7UF7KM.mjs.map +0 -1
  575. package/dist/chunk-5UAPBOKO.js +0 -37
  576. package/dist/chunk-5UAPBOKO.js.map +0 -1
  577. package/dist/chunk-5WKQI22S.js +0 -7
  578. package/dist/chunk-5WKQI22S.js.map +0 -1
  579. package/dist/chunk-63OXILAY.mjs +0 -69
  580. package/dist/chunk-63OXILAY.mjs.map +0 -1
  581. package/dist/chunk-6ATNGN44.js +0 -300
  582. package/dist/chunk-6ATNGN44.js.map +0 -1
  583. package/dist/chunk-6HXIPMBN.js +0 -103
  584. package/dist/chunk-6HXIPMBN.js.map +0 -1
  585. package/dist/chunk-6YJWU77L.js +0 -19
  586. package/dist/chunk-6YJWU77L.js.map +0 -1
  587. package/dist/chunk-7HLSXEHK.mjs +0 -300
  588. package/dist/chunk-7HLSXEHK.mjs.map +0 -1
  589. package/dist/chunk-7LG4D4XA.mjs +0 -20
  590. package/dist/chunk-7LG4D4XA.mjs.map +0 -1
  591. package/dist/chunk-7P62OIGX.js +0 -69
  592. package/dist/chunk-7P62OIGX.js.map +0 -1
  593. package/dist/chunk-7T7FYH77.mjs +0 -37
  594. package/dist/chunk-7T7FYH77.mjs.map +0 -1
  595. package/dist/chunk-7VJ2BOVU.js +0 -15
  596. package/dist/chunk-7VJ2BOVU.js.map +0 -1
  597. package/dist/chunk-A3RRMELT.mjs +0 -1
  598. package/dist/chunk-A3RRMELT.mjs.map +0 -1
  599. package/dist/chunk-AMW2VJ3N.js +0 -32
  600. package/dist/chunk-AMW2VJ3N.js.map +0 -1
  601. package/dist/chunk-ANYNWSCA.mjs +0 -104
  602. package/dist/chunk-ANYNWSCA.mjs.map +0 -1
  603. package/dist/chunk-AOGVLPQZ.js +0 -18
  604. package/dist/chunk-AOGVLPQZ.js.map +0 -1
  605. package/dist/chunk-AS5P6JRP.mjs +0 -9
  606. package/dist/chunk-AS5P6JRP.mjs.map +0 -1
  607. package/dist/chunk-ASZWZ7JT.js +0 -20
  608. package/dist/chunk-ASZWZ7JT.js.map +0 -1
  609. package/dist/chunk-B5GNTDE2.js +0 -109
  610. package/dist/chunk-B5GNTDE2.js.map +0 -1
  611. package/dist/chunk-BGSO2GQC.mjs +0 -41
  612. package/dist/chunk-BGSO2GQC.mjs.map +0 -1
  613. package/dist/chunk-BPK5BH7K.js +0 -27
  614. package/dist/chunk-BPK5BH7K.js.map +0 -1
  615. package/dist/chunk-CJK7DDV2.mjs +0 -109
  616. package/dist/chunk-CJK7DDV2.mjs.map +0 -1
  617. package/dist/chunk-CPG2UGAA.js +0 -25
  618. package/dist/chunk-CPG2UGAA.js.map +0 -1
  619. package/dist/chunk-DE22V5AO.mjs +0 -53
  620. package/dist/chunk-DE22V5AO.mjs.map +0 -1
  621. package/dist/chunk-DEQUNIME.js +0 -53
  622. package/dist/chunk-DEQUNIME.js.map +0 -1
  623. package/dist/chunk-DKO64Y4H.mjs +0 -27
  624. package/dist/chunk-DKO64Y4H.mjs.map +0 -1
  625. package/dist/chunk-E3BDBG6T.js +0 -20
  626. package/dist/chunk-E3BDBG6T.js.map +0 -1
  627. package/dist/chunk-EFRPCO3C.js +0 -1
  628. package/dist/chunk-EFRPCO3C.js.map +0 -1
  629. package/dist/chunk-EVHDXNOC.mjs +0 -35
  630. package/dist/chunk-EVHDXNOC.mjs.map +0 -1
  631. package/dist/chunk-EYWMVDCD.mjs +0 -25
  632. package/dist/chunk-EYWMVDCD.mjs.map +0 -1
  633. package/dist/chunk-FA4QIZH6.js +0 -1
  634. package/dist/chunk-FA4QIZH6.js.map +0 -1
  635. package/dist/chunk-FBZ5SU7X.js +0 -189
  636. package/dist/chunk-FBZ5SU7X.js.map +0 -1
  637. package/dist/chunk-GIVJAZ2Q.mjs +0 -248
  638. package/dist/chunk-GIVJAZ2Q.mjs.map +0 -1
  639. package/dist/chunk-GJAVOB7B.js +0 -24
  640. package/dist/chunk-GJAVOB7B.js.map +0 -1
  641. package/dist/chunk-GXSTPU7D.mjs +0 -293
  642. package/dist/chunk-GXSTPU7D.mjs.map +0 -1
  643. package/dist/chunk-HY4W6BUH.mjs +0 -24
  644. package/dist/chunk-HY4W6BUH.mjs.map +0 -1
  645. package/dist/chunk-HYF7Q6VY.mjs +0 -1
  646. package/dist/chunk-HYF7Q6VY.mjs.map +0 -1
  647. package/dist/chunk-I2SWLZ34.js +0 -30
  648. package/dist/chunk-I2SWLZ34.js.map +0 -1
  649. package/dist/chunk-IELPPZJP.mjs +0 -189
  650. package/dist/chunk-IELPPZJP.mjs.map +0 -1
  651. package/dist/chunk-IJX3CXOY.js +0 -9
  652. package/dist/chunk-IJX3CXOY.js.map +0 -1
  653. package/dist/chunk-IPUL74MZ.mjs +0 -30
  654. package/dist/chunk-IPUL74MZ.mjs.map +0 -1
  655. package/dist/chunk-IV3FSWZ7.mjs +0 -9
  656. package/dist/chunk-IV3FSWZ7.mjs.map +0 -1
  657. package/dist/chunk-IVDERT5W.js +0 -22
  658. package/dist/chunk-IVDERT5W.js.map +0 -1
  659. package/dist/chunk-JETPRED3.js +0 -248
  660. package/dist/chunk-JETPRED3.js.map +0 -1
  661. package/dist/chunk-JI5NQ2C3.mjs +0 -1
  662. package/dist/chunk-JI5NQ2C3.mjs.map +0 -1
  663. package/dist/chunk-JJTIVHFX.mjs +0 -38
  664. package/dist/chunk-JJTIVHFX.mjs.map +0 -1
  665. package/dist/chunk-L2DHOOBX.js +0 -33
  666. package/dist/chunk-L2DHOOBX.js.map +0 -1
  667. package/dist/chunk-LEKZPKS2.js +0 -21
  668. package/dist/chunk-LEKZPKS2.js.map +0 -1
  669. package/dist/chunk-LHQP7CUJ.mjs +0 -107
  670. package/dist/chunk-LHQP7CUJ.mjs.map +0 -1
  671. package/dist/chunk-LOJA2ZS4.js +0 -107
  672. package/dist/chunk-LOJA2ZS4.js.map +0 -1
  673. package/dist/chunk-LQSEBGOX.js +0 -34
  674. package/dist/chunk-LQSEBGOX.js.map +0 -1
  675. package/dist/chunk-MDOG3S4V.mjs +0 -34
  676. package/dist/chunk-MDOG3S4V.mjs.map +0 -1
  677. package/dist/chunk-MFGLB75H.mjs +0 -22
  678. package/dist/chunk-MFGLB75H.mjs.map +0 -1
  679. package/dist/chunk-MKFQAXRF.js +0 -21
  680. package/dist/chunk-MKFQAXRF.js.map +0 -1
  681. package/dist/chunk-MQURBEO4.mjs +0 -16
  682. package/dist/chunk-MQURBEO4.mjs.map +0 -1
  683. package/dist/chunk-MWAZGSRO.js +0 -75
  684. package/dist/chunk-MWAZGSRO.js.map +0 -1
  685. package/dist/chunk-N2JAYIUP.mjs +0 -75
  686. package/dist/chunk-N2JAYIUP.mjs.map +0 -1
  687. package/dist/chunk-N4MA537G.js +0 -22
  688. package/dist/chunk-N4MA537G.js.map +0 -1
  689. package/dist/chunk-N5HVDE3P.mjs +0 -30
  690. package/dist/chunk-N5HVDE3P.mjs.map +0 -1
  691. package/dist/chunk-N722KRZW.js +0 -41
  692. package/dist/chunk-N722KRZW.js.map +0 -1
  693. package/dist/chunk-NNYGTNHP.mjs +0 -1
  694. package/dist/chunk-NNYGTNHP.mjs.map +0 -1
  695. package/dist/chunk-NSVVZNSD.mjs +0 -183
  696. package/dist/chunk-NSVVZNSD.mjs.map +0 -1
  697. package/dist/chunk-NUCLSR2G.js +0 -8
  698. package/dist/chunk-NUCLSR2G.js.map +0 -1
  699. package/dist/chunk-OBN2WDFU.js +0 -38
  700. package/dist/chunk-OBN2WDFU.js.map +0 -1
  701. package/dist/chunk-P252LKUT.mjs +0 -9
  702. package/dist/chunk-P252LKUT.mjs.map +0 -1
  703. package/dist/chunk-PAOTMYIM.mjs +0 -69
  704. package/dist/chunk-PAOTMYIM.mjs.map +0 -1
  705. package/dist/chunk-PJMEJVOB.mjs +0 -29
  706. package/dist/chunk-PJMEJVOB.mjs.map +0 -1
  707. package/dist/chunk-PLBSSUVY.js +0 -29
  708. package/dist/chunk-PLBSSUVY.js.map +0 -1
  709. package/dist/chunk-PLNIERDY.js +0 -34
  710. package/dist/chunk-PLNIERDY.js.map +0 -1
  711. package/dist/chunk-PO5BBHHX.mjs +0 -22
  712. package/dist/chunk-PO5BBHHX.mjs.map +0 -1
  713. package/dist/chunk-PTOH2SVI.mjs +0 -55
  714. package/dist/chunk-PTOH2SVI.mjs.map +0 -1
  715. package/dist/chunk-PZF4KWU2.mjs +0 -151
  716. package/dist/chunk-PZF4KWU2.mjs.map +0 -1
  717. package/dist/chunk-QD3LTING.js +0 -34
  718. package/dist/chunk-QD3LTING.js.map +0 -1
  719. package/dist/chunk-QGCNQRIQ.js +0 -35
  720. package/dist/chunk-QGCNQRIQ.js.map +0 -1
  721. package/dist/chunk-QYPLUMB7.mjs +0 -249
  722. package/dist/chunk-QYPLUMB7.mjs.map +0 -1
  723. package/dist/chunk-RAZ7XG4Z.mjs +0 -1
  724. package/dist/chunk-RAZ7XG4Z.mjs.map +0 -1
  725. package/dist/chunk-RNMJQSVQ.js +0 -69
  726. package/dist/chunk-RNMJQSVQ.js.map +0 -1
  727. package/dist/chunk-RRFKK45V.mjs +0 -15
  728. package/dist/chunk-RRFKK45V.mjs.map +0 -1
  729. package/dist/chunk-S3BWTUTZ.js +0 -31
  730. package/dist/chunk-S3BWTUTZ.js.map +0 -1
  731. package/dist/chunk-SKKANJ45.mjs +0 -19
  732. package/dist/chunk-SKKANJ45.mjs.map +0 -1
  733. package/dist/chunk-SPCIIRSB.mjs +0 -7
  734. package/dist/chunk-SPCIIRSB.mjs.map +0 -1
  735. package/dist/chunk-SRMDDOVO.mjs +0 -20
  736. package/dist/chunk-SRMDDOVO.mjs.map +0 -1
  737. package/dist/chunk-SYYDKPK3.js +0 -15
  738. package/dist/chunk-SYYDKPK3.js.map +0 -1
  739. package/dist/chunk-T2VA4YJE.js +0 -104
  740. package/dist/chunk-T2VA4YJE.js.map +0 -1
  741. package/dist/chunk-T3VM5YXY.js +0 -1
  742. package/dist/chunk-T3VM5YXY.js.map +0 -1
  743. package/dist/chunk-T3YY4JIJ.js +0 -9
  744. package/dist/chunk-T3YY4JIJ.js.map +0 -1
  745. package/dist/chunk-T5ZOOZ46.js +0 -22
  746. package/dist/chunk-T5ZOOZ46.js.map +0 -1
  747. package/dist/chunk-TAMKWZ4E.js +0 -183
  748. package/dist/chunk-TAMKWZ4E.js.map +0 -1
  749. package/dist/chunk-TFP64TMV.js +0 -1
  750. package/dist/chunk-TFP64TMV.js.map +0 -1
  751. package/dist/chunk-TYWGZIOF.mjs +0 -34
  752. package/dist/chunk-TYWGZIOF.mjs.map +0 -1
  753. package/dist/chunk-UAINMOUU.js +0 -18
  754. package/dist/chunk-UAINMOUU.js.map +0 -1
  755. package/dist/chunk-UNNEBOL4.mjs +0 -15
  756. package/dist/chunk-UNNEBOL4.mjs.map +0 -1
  757. package/dist/chunk-UW74NLTC.mjs +0 -18
  758. package/dist/chunk-UW74NLTC.mjs.map +0 -1
  759. package/dist/chunk-VBYSWMSU.js +0 -66
  760. package/dist/chunk-VBYSWMSU.js.map +0 -1
  761. package/dist/chunk-VEPYH26P.js +0 -27
  762. package/dist/chunk-VEPYH26P.js.map +0 -1
  763. package/dist/chunk-VIAHMNTA.mjs +0 -34
  764. package/dist/chunk-VIAHMNTA.mjs.map +0 -1
  765. package/dist/chunk-VWLBM7XM.js +0 -1
  766. package/dist/chunk-VWLBM7XM.js.map +0 -1
  767. package/dist/chunk-W7A3BYUP.mjs +0 -1
  768. package/dist/chunk-W7A3BYUP.mjs.map +0 -1
  769. package/dist/chunk-W7KRIAIX.js +0 -55
  770. package/dist/chunk-W7KRIAIX.js.map +0 -1
  771. package/dist/chunk-X2GGUOMY.js +0 -153
  772. package/dist/chunk-X2GGUOMY.js.map +0 -1
  773. package/dist/chunk-X3UZCGO5.mjs +0 -103
  774. package/dist/chunk-X3UZCGO5.mjs.map +0 -1
  775. package/dist/chunk-XF2AZMWG.mjs +0 -32
  776. package/dist/chunk-XF2AZMWG.mjs.map +0 -1
  777. package/dist/chunk-XWYJQWHG.js +0 -56
  778. package/dist/chunk-XWYJQWHG.js.map +0 -1
  779. package/dist/chunk-XZ7362GQ.mjs +0 -63
  780. package/dist/chunk-XZ7362GQ.mjs.map +0 -1
  781. package/dist/chunk-XZNJFDBF.mjs +0 -21
  782. package/dist/chunk-XZNJFDBF.mjs.map +0 -1
  783. package/dist/chunk-YJHQZFR4.mjs +0 -71
  784. package/dist/chunk-YJHQZFR4.mjs.map +0 -1
  785. package/dist/chunk-YL2EHYAA.js +0 -16
  786. package/dist/chunk-YL2EHYAA.js.map +0 -1
  787. package/dist/chunk-Z2JQNSVL.mjs +0 -8
  788. package/dist/chunk-Z2JQNSVL.mjs.map +0 -1
  789. package/dist/chunk-ZT3KKTS2.js +0 -9
  790. package/dist/chunk-ZT3KKTS2.js.map +0 -1
  791. package/dist/constants.js +0 -8
  792. package/dist/constants.js.map +0 -1
  793. package/dist/cronjob.js +0 -20
  794. package/dist/cronjob.js.map +0 -1
  795. package/dist/deep-clone.js +0 -8
  796. package/dist/deep-clone.js.map +0 -1
  797. package/dist/default-endowments.js +0 -8
  798. package/dist/default-endowments.js.map +0 -1
  799. package/dist/derivation-paths.js +0 -13
  800. package/dist/derivation-paths.js.map +0 -1
  801. package/dist/entropy.js +0 -10
  802. package/dist/entropy.js.map +0 -1
  803. package/dist/errors.js +0 -20
  804. package/dist/errors.js.map +0 -1
  805. package/dist/eval-worker.js +0 -43
  806. package/dist/eval-worker.js.map +0 -1
  807. package/dist/eval.js +0 -17
  808. package/dist/eval.js.map +0 -1
  809. package/dist/fs.js +0 -28
  810. package/dist/fs.js.map +0 -1
  811. package/dist/handler-types.js +0 -10
  812. package/dist/handler-types.js.map +0 -1
  813. package/dist/handlers.js +0 -35
  814. package/dist/handlers.js.map +0 -1
  815. package/dist/icon.js +0 -15
  816. package/dist/icon.js.map +0 -1
  817. package/dist/iframe.js +0 -8
  818. package/dist/iframe.js.map +0 -1
  819. package/dist/index.executionenv.js +0 -128
  820. package/dist/index.executionenv.js.map +0 -1
  821. package/dist/index.js +0 -398
  822. package/dist/index.js.map +0 -1
  823. package/dist/json-rpc.js +0 -18
  824. package/dist/json-rpc.js.map +0 -1
  825. package/dist/json.js +0 -10
  826. package/dist/json.js.map +0 -1
  827. package/dist/localization.js +0 -23
  828. package/dist/localization.js.map +0 -1
  829. package/dist/logging.js +0 -14
  830. package/dist/logging.js.map +0 -1
  831. package/dist/manifest/index.js +0 -65
  832. package/dist/manifest/index.js.map +0 -1
  833. package/dist/manifest/manifest.js +0 -59
  834. package/dist/manifest/manifest.js.map +0 -1
  835. package/dist/manifest/node.js +0 -106
  836. package/dist/manifest/node.js.map +0 -1
  837. package/dist/manifest/validation.js +0 -64
  838. package/dist/manifest/validation.js.map +0 -1
  839. package/dist/manifest/validator-types.js +0 -1
  840. package/dist/manifest/validator-types.js.map +0 -1
  841. package/dist/manifest/validator.js +0 -44
  842. package/dist/manifest/validator.js.map +0 -1
  843. package/dist/manifest/validators/checksum.js +0 -15
  844. package/dist/manifest/validators/checksum.js.map +0 -1
  845. package/dist/manifest/validators/expected-files.js +0 -9
  846. package/dist/manifest/validators/expected-files.js.map +0 -1
  847. package/dist/manifest/validators/icon-declared.js +0 -8
  848. package/dist/manifest/validators/icon-declared.js.map +0 -1
  849. package/dist/manifest/validators/icon-dimensions.js +0 -10
  850. package/dist/manifest/validators/icon-dimensions.js.map +0 -1
  851. package/dist/manifest/validators/icon-missing.js +0 -8
  852. package/dist/manifest/validators/icon-missing.js.map +0 -1
  853. package/dist/manifest/validators/index.js +0 -80
  854. package/dist/manifest/validators/index.js.map +0 -1
  855. package/dist/manifest/validators/is-localization-file.js +0 -12
  856. package/dist/manifest/validators/is-localization-file.js.map +0 -1
  857. package/dist/manifest/validators/is-package-json.js +0 -11
  858. package/dist/manifest/validators/is-package-json.js.map +0 -1
  859. package/dist/manifest/validators/is-snap-icon.js +0 -10
  860. package/dist/manifest/validators/is-snap-icon.js.map +0 -1
  861. package/dist/manifest/validators/is-snap-manifest.js +0 -23
  862. package/dist/manifest/validators/is-snap-manifest.js.map +0 -1
  863. package/dist/manifest/validators/manifest-localization.js +0 -10
  864. package/dist/manifest/validators/manifest-localization.js.map +0 -1
  865. package/dist/manifest/validators/package-json-recommended-fields.js +0 -8
  866. package/dist/manifest/validators/package-json-recommended-fields.js.map +0 -1
  867. package/dist/manifest/validators/package-name-match.js +0 -9
  868. package/dist/manifest/validators/package-name-match.js.map +0 -1
  869. package/dist/manifest/validators/repository-match.js +0 -10
  870. package/dist/manifest/validators/repository-match.js.map +0 -1
  871. package/dist/manifest/validators/version-match.js +0 -9
  872. package/dist/manifest/validators/version-match.js.map +0 -1
  873. package/dist/mock.js +0 -13
  874. package/dist/mock.js.map +0 -1
  875. package/dist/namespace.js +0 -44
  876. package/dist/namespace.js.map +0 -1
  877. package/dist/node.js +0 -476
  878. package/dist/node.js.map +0 -1
  879. package/dist/path.js +0 -8
  880. package/dist/path.js.map +0 -1
  881. package/dist/post-process.js +0 -10
  882. package/dist/post-process.js.map +0 -1
  883. package/dist/promise.js +0 -2
  884. package/dist/promise.js.map +0 -1
  885. package/dist/snaps.js +0 -46
  886. package/dist/snaps.js.map +0 -1
  887. package/dist/strings.js +0 -8
  888. package/dist/strings.js.map +0 -1
  889. package/dist/structs.js +0 -33
  890. package/dist/structs.js.map +0 -1
  891. package/dist/svg.js +0 -10
  892. package/dist/svg.js.map +0 -1
  893. package/dist/tsconfig.build.tsbuildinfo +0 -1
  894. package/dist/types/array.d.ts +0 -10
  895. package/dist/types/auxiliary-files.d.ts +0 -16
  896. package/dist/types/base64.d.ts +0 -15
  897. package/dist/types/bytes.d.ts +0 -8
  898. package/dist/types/caveats.d.ts +0 -46
  899. package/dist/types/checksum.d.ts +0 -21
  900. package/dist/types/constants.d.ts +0 -1
  901. package/dist/types/cronjob.d.ts +0 -89
  902. package/dist/types/deep-clone.d.ts +0 -1
  903. package/dist/types/default-endowments.d.ts +0 -4
  904. package/dist/types/derivation-paths.d.ts +0 -24
  905. package/dist/types/entropy.d.ts +0 -3
  906. package/dist/types/errors.d.ts +0 -84
  907. package/dist/types/eval-worker.d.ts +0 -1
  908. package/dist/types/eval.d.ts +0 -16
  909. package/dist/types/fs.d.ts +0 -69
  910. package/dist/types/handler-types.d.ts +0 -34
  911. package/dist/types/handlers.d.ts +0 -749
  912. package/dist/types/icon.d.ts +0 -19
  913. package/dist/types/iframe.d.ts +0 -11
  914. package/dist/types/iframe.test.browser.d.ts +0 -1
  915. package/dist/types/index.d.ts +0 -32
  916. package/dist/types/index.executionenv.d.ts +0 -7
  917. package/dist/types/json-rpc.d.ts +0 -55
  918. package/dist/types/json.d.ts +0 -22
  919. package/dist/types/localization.d.ts +0 -145
  920. package/dist/types/logging.d.ts +0 -49
  921. package/dist/types/manifest/index.d.ts +0 -1
  922. package/dist/types/manifest/manifest.d.ts +0 -98
  923. package/dist/types/manifest/node.d.ts +0 -2
  924. package/dist/types/manifest/validation.d.ts +0 -253
  925. package/dist/types/manifest/validator-types.d.ts +0 -34
  926. package/dist/types/manifest/validator.d.ts +0 -22
  927. package/dist/types/manifest/validators/checksum.d.ts +0 -5
  928. package/dist/types/manifest/validators/expected-files.d.ts +0 -5
  929. package/dist/types/manifest/validators/icon-declared.d.ts +0 -5
  930. package/dist/types/manifest/validators/icon-dimensions.d.ts +0 -5
  931. package/dist/types/manifest/validators/icon-missing.d.ts +0 -5
  932. package/dist/types/manifest/validators/index.d.ts +0 -14
  933. package/dist/types/manifest/validators/is-localization-file.d.ts +0 -5
  934. package/dist/types/manifest/validators/is-package-json.d.ts +0 -5
  935. package/dist/types/manifest/validators/is-snap-icon.d.ts +0 -5
  936. package/dist/types/manifest/validators/is-snap-manifest.d.ts +0 -5
  937. package/dist/types/manifest/validators/manifest-localization.d.ts +0 -5
  938. package/dist/types/manifest/validators/package-json-recommended-fields.d.ts +0 -5
  939. package/dist/types/manifest/validators/package-name-match.d.ts +0 -5
  940. package/dist/types/manifest/validators/repository-match.d.ts +0 -5
  941. package/dist/types/manifest/validators/version-match.d.ts +0 -5
  942. package/dist/types/mock.d.ts +0 -14
  943. package/dist/types/namespace.d.ts +0 -129
  944. package/dist/types/node.d.ts +0 -7
  945. package/dist/types/path.d.ts +0 -7
  946. package/dist/types/post-process.d.ts +0 -71
  947. package/dist/types/promise.d.ts +0 -1
  948. package/dist/types/snaps.d.ts +0 -169
  949. package/dist/types/strings.d.ts +0 -8
  950. package/dist/types/structs.d.ts +0 -180
  951. package/dist/types/svg.d.ts +0 -14
  952. package/dist/types/types.d.ts +0 -103
  953. package/dist/types/ui.d.ts +0 -84
  954. package/dist/types/validation.d.ts +0 -8
  955. package/dist/types/versions.d.ts +0 -21
  956. package/dist/types/virtual-file/VirtualFile.d.ts +0 -34
  957. package/dist/types/virtual-file/index.d.ts +0 -1
  958. package/dist/types/virtual-file/node.d.ts +0 -2
  959. package/dist/types/virtual-file/toVirtualFile.d.ts +0 -21
  960. package/dist/types.js +0 -22
  961. package/dist/types.js.map +0 -1
  962. package/dist/ui.js +0 -24
  963. package/dist/ui.js.map +0 -1
  964. package/dist/validation.js +0 -27
  965. package/dist/validation.js.map +0 -1
  966. package/dist/versions.js +0 -12
  967. package/dist/versions.js.map +0 -1
  968. package/dist/virtual-file/VirtualFile.js +0 -9
  969. package/dist/virtual-file/VirtualFile.js.map +0 -1
  970. package/dist/virtual-file/index.js +0 -10
  971. package/dist/virtual-file/index.js.map +0 -1
  972. package/dist/virtual-file/node.js +0 -17
  973. package/dist/virtual-file/node.js.map +0 -1
  974. package/dist/virtual-file/toVirtualFile.js +0 -12
  975. package/dist/virtual-file/toVirtualFile.js.map +0 -1
@@ -0,0 +1,85 @@
1
+ import { JsonRpcError as RpcError } from "@metamask/rpc-errors";
2
+ import type { DataWithOptionalCause } from "@metamask/rpc-errors";
3
+ import type { SerializedSnapError, SnapError } from "@metamask/snaps-sdk";
4
+ import type { Json, JsonRpcError } from "@metamask/utils";
5
+ export declare const SNAP_ERROR_WRAPPER_CODE = -31001;
6
+ export declare const SNAP_ERROR_WRAPPER_MESSAGE = "Wrapped Snap Error";
7
+ export type SerializedSnapErrorWrapper = {
8
+ code: typeof SNAP_ERROR_WRAPPER_CODE;
9
+ message: typeof SNAP_ERROR_WRAPPER_MESSAGE;
10
+ data: {
11
+ cause: Json;
12
+ };
13
+ };
14
+ export declare class WrappedSnapError extends Error {
15
+ #private;
16
+ /**
17
+ * Create a new `WrappedSnapError`.
18
+ *
19
+ * @param error - The error to create the `WrappedSnapError` from.
20
+ */
21
+ constructor(error: unknown);
22
+ /**
23
+ * The error name.
24
+ *
25
+ * @returns The error name.
26
+ */
27
+ get name(): string;
28
+ /**
29
+ * The error message.
30
+ *
31
+ * @returns The error message.
32
+ */
33
+ get message(): string;
34
+ /**
35
+ * The error stack.
36
+ *
37
+ * @returns The error stack.
38
+ */
39
+ get stack(): string | undefined;
40
+ /**
41
+ * Convert the error to a JSON object.
42
+ *
43
+ * @returns The JSON object.
44
+ */
45
+ toJSON(): SerializedSnapErrorWrapper;
46
+ /**
47
+ * Serialize the error to a JSON object. This is called by
48
+ * `@metamask/rpc-errors` when serializing the error.
49
+ *
50
+ * @returns The JSON object.
51
+ */
52
+ serialize(): SerializedSnapErrorWrapper;
53
+ }
54
+ /**
55
+ * Check if an object is a `SnapError`.
56
+ *
57
+ * @param error - The object to check.
58
+ * @returns Whether the object is a `SnapError`.
59
+ */
60
+ export declare function isSnapError(error: unknown): error is SnapError;
61
+ /**
62
+ * Check if a JSON-RPC error is a `SnapError`.
63
+ *
64
+ * @param error - The object to check.
65
+ * @returns Whether the object is a `SnapError`.
66
+ */
67
+ export declare function isSerializedSnapError(error: JsonRpcError): error is SerializedSnapError;
68
+ /**
69
+ * Check if a JSON-RPC error is a `WrappedSnapError`.
70
+ *
71
+ * @param error - The object to check.
72
+ * @returns Whether the object is a `WrappedSnapError`.
73
+ */
74
+ export declare function isWrappedSnapError(error: unknown): error is SerializedSnapErrorWrapper;
75
+ /**
76
+ * Attempt to unwrap an unknown error to a `JsonRpcError`. This function will
77
+ * try to get the error code, message, and data from the error, and return a
78
+ * `JsonRpcError` with those properties.
79
+ *
80
+ * @param error - The error to unwrap.
81
+ * @returns A tuple containing the unwrapped error and a boolean indicating
82
+ * whether the error was handled.
83
+ */
84
+ export declare function unwrapError(error: unknown): [error: RpcError<DataWithOptionalCause>, isHandled: boolean];
85
+ //# sourceMappingURL=errors.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.mts","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,YAAY,IAAI,QAAQ,EAEzB,6BAA6B;AAC9B,OAAO,KAAK,EAAE,qBAAqB,EAAE,6BAA6B;AAClE,OAAO,KAAK,EAAE,mBAAmB,EAAE,SAAS,EAAE,4BAA4B;AAO1E,OAAO,KAAK,EAAE,IAAI,EAAE,YAAY,EAAE,wBAAwB;AAG1D,eAAO,MAAM,uBAAuB,SAAS,CAAC;AAC9C,eAAO,MAAM,0BAA0B,uBAAuB,CAAC;AAE/D,MAAM,MAAM,0BAA0B,GAAG;IACvC,IAAI,EAAE,OAAO,uBAAuB,CAAC;IACrC,OAAO,EAAE,OAAO,0BAA0B,CAAC;IAC3C,IAAI,EAAE;QACJ,KAAK,EAAE,IAAI,CAAC;KACb,CAAC;CACH,CAAC;AAEF,qBAAa,gBAAiB,SAAQ,KAAK;;IAOzC;;;;OAIG;gBACS,KAAK,EAAE,OAAO;IAS1B;;;;OAIG;IACH,IAAI,IAAI,WAEP;IAED;;;;OAIG;IACH,IAAI,OAAO,WAEV;IAED;;;;OAIG;IACH,IAAI,KAAK,uBAER;IAED;;;;OAIG;IACH,MAAM,IAAI,0BAA0B;IAcpC;;;;;OAKG;IACH,SAAS;CAGV;AAED;;;;;GAKG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,IAAI,SAAS,CAW9D;AAED;;;;;GAKG;AACH,wBAAgB,qBAAqB,CACnC,KAAK,EAAE,YAAY,GAClB,KAAK,IAAI,mBAAmB,CAE9B;AAED;;;;;GAKG;AACH,wBAAgB,kBAAkB,CAChC,KAAK,EAAE,OAAO,GACb,KAAK,IAAI,0BAA0B,CAMrC;AAuBD;;;;;;;;GAQG;AACH,wBAAgB,WAAW,CACzB,KAAK,EAAE,OAAO,GACb,CAAC,KAAK,EAAE,QAAQ,CAAC,qBAAqB,CAAC,EAAE,SAAS,EAAE,OAAO,CAAC,CAiD9D"}
package/dist/errors.mjs CHANGED
@@ -1,20 +1,181 @@
1
- import {
2
- SNAP_ERROR_WRAPPER_CODE,
3
- SNAP_ERROR_WRAPPER_MESSAGE,
4
- WrappedSnapError,
5
- isSerializedSnapError,
6
- isSnapError,
7
- isWrappedSnapError,
8
- unwrapError
9
- } from "./chunk-PZF4KWU2.mjs";
10
- import "./chunk-3RUWAMJT.mjs";
11
- export {
12
- SNAP_ERROR_WRAPPER_CODE,
13
- SNAP_ERROR_WRAPPER_MESSAGE,
14
- WrappedSnapError,
15
- isSerializedSnapError,
16
- isSnapError,
17
- isWrappedSnapError,
18
- unwrapError
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;
19
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 _WrappedSnapError_error, _WrappedSnapError_message, _WrappedSnapError_stack;
13
+ import { errorCodes, JsonRpcError as RpcError, serializeCause } from "@metamask/rpc-errors";
14
+ import { getErrorMessage, getErrorStack, SNAP_ERROR_CODE, SNAP_ERROR_MESSAGE } from "@metamask/snaps-sdk";
15
+ import { isObject, isJsonRpcError } from "@metamask/utils";
16
+ export const SNAP_ERROR_WRAPPER_CODE = -31001;
17
+ export const SNAP_ERROR_WRAPPER_MESSAGE = 'Wrapped Snap Error';
18
+ export class WrappedSnapError extends Error {
19
+ /**
20
+ * Create a new `WrappedSnapError`.
21
+ *
22
+ * @param error - The error to create the `WrappedSnapError` from.
23
+ */
24
+ constructor(error) {
25
+ const message = getErrorMessage(error);
26
+ super(message);
27
+ _WrappedSnapError_error.set(this, void 0);
28
+ _WrappedSnapError_message.set(this, void 0);
29
+ _WrappedSnapError_stack.set(this, void 0);
30
+ __classPrivateFieldSet(this, _WrappedSnapError_error, error, "f");
31
+ __classPrivateFieldSet(this, _WrappedSnapError_message, message, "f");
32
+ __classPrivateFieldSet(this, _WrappedSnapError_stack, getErrorStack(error), "f");
33
+ }
34
+ /**
35
+ * The error name.
36
+ *
37
+ * @returns The error name.
38
+ */
39
+ get name() {
40
+ return 'WrappedSnapError';
41
+ }
42
+ /**
43
+ * The error message.
44
+ *
45
+ * @returns The error message.
46
+ */
47
+ get message() {
48
+ return __classPrivateFieldGet(this, _WrappedSnapError_message, "f");
49
+ }
50
+ /**
51
+ * The error stack.
52
+ *
53
+ * @returns The error stack.
54
+ */
55
+ get stack() {
56
+ return __classPrivateFieldGet(this, _WrappedSnapError_stack, "f");
57
+ }
58
+ /**
59
+ * Convert the error to a JSON object.
60
+ *
61
+ * @returns The JSON object.
62
+ */
63
+ toJSON() {
64
+ const cause = isSnapError(__classPrivateFieldGet(this, _WrappedSnapError_error, "f"))
65
+ ? __classPrivateFieldGet(this, _WrappedSnapError_error, "f").serialize()
66
+ : serializeCause(__classPrivateFieldGet(this, _WrappedSnapError_error, "f"));
67
+ return {
68
+ code: SNAP_ERROR_WRAPPER_CODE,
69
+ message: SNAP_ERROR_WRAPPER_MESSAGE,
70
+ data: {
71
+ cause,
72
+ },
73
+ };
74
+ }
75
+ /**
76
+ * Serialize the error to a JSON object. This is called by
77
+ * `@metamask/rpc-errors` when serializing the error.
78
+ *
79
+ * @returns The JSON object.
80
+ */
81
+ serialize() {
82
+ return this.toJSON();
83
+ }
84
+ }
85
+ _WrappedSnapError_error = new WeakMap(), _WrappedSnapError_message = new WeakMap(), _WrappedSnapError_stack = new WeakMap();
86
+ /**
87
+ * Check if an object is a `SnapError`.
88
+ *
89
+ * @param error - The object to check.
90
+ * @returns Whether the object is a `SnapError`.
91
+ */
92
+ export function isSnapError(error) {
93
+ if (isObject(error) &&
94
+ 'serialize' in error &&
95
+ typeof error.serialize === 'function') {
96
+ const serialized = error.serialize();
97
+ return isJsonRpcError(serialized) && isSerializedSnapError(serialized);
98
+ }
99
+ return false;
100
+ }
101
+ /**
102
+ * Check if a JSON-RPC error is a `SnapError`.
103
+ *
104
+ * @param error - The object to check.
105
+ * @returns Whether the object is a `SnapError`.
106
+ */
107
+ export function isSerializedSnapError(error) {
108
+ return error.code === SNAP_ERROR_CODE && error.message === SNAP_ERROR_MESSAGE;
109
+ }
110
+ /**
111
+ * Check if a JSON-RPC error is a `WrappedSnapError`.
112
+ *
113
+ * @param error - The object to check.
114
+ * @returns Whether the object is a `WrappedSnapError`.
115
+ */
116
+ export function isWrappedSnapError(error) {
117
+ return (isJsonRpcError(error) &&
118
+ error.code === SNAP_ERROR_WRAPPER_CODE &&
119
+ error.message === SNAP_ERROR_WRAPPER_MESSAGE);
120
+ }
121
+ /**
122
+ * Get a JSON-RPC error with the given code, message, stack, and data.
123
+ *
124
+ * @param code - The error code.
125
+ * @param message - The error message.
126
+ * @param stack - The error stack.
127
+ * @param data - Additional data for the error.
128
+ * @returns The JSON-RPC error.
129
+ */
130
+ function getJsonRpcError(code, message, stack, data) {
131
+ const error = new RpcError(code, message, data);
132
+ error.stack = stack;
133
+ return error;
134
+ }
135
+ /**
136
+ * Attempt to unwrap an unknown error to a `JsonRpcError`. This function will
137
+ * try to get the error code, message, and data from the error, and return a
138
+ * `JsonRpcError` with those properties.
139
+ *
140
+ * @param error - The error to unwrap.
141
+ * @returns A tuple containing the unwrapped error and a boolean indicating
142
+ * whether the error was handled.
143
+ */
144
+ export function unwrapError(error) {
145
+ // This logic is a bit complicated, but it's necessary to handle all the
146
+ // different types of errors that can be thrown by a Snap.
147
+ // If the error is a wrapped Snap error, unwrap it.
148
+ if (isWrappedSnapError(error)) {
149
+ // The wrapped error can be a JSON-RPC error, or an unknown error. If it's
150
+ // a JSON-RPC error, we can unwrap it further.
151
+ if (isJsonRpcError(error.data.cause)) {
152
+ // If the JSON-RPC error is a wrapped Snap error, unwrap it further.
153
+ if (isSerializedSnapError(error.data.cause)) {
154
+ const { code, message, stack, data } = error.data.cause.data.cause;
155
+ return [getJsonRpcError(code, message, stack, data), true];
156
+ }
157
+ // Otherwise, we use the original JSON-RPC error.
158
+ const { code, message, stack, data } = error.data.cause;
159
+ return [getJsonRpcError(code, message, stack, data), false];
160
+ }
161
+ // Otherwise, we throw an internal error with the wrapped error as the
162
+ // message.
163
+ return [
164
+ getJsonRpcError(errorCodes.rpc.internal, getErrorMessage(error.data.cause), getErrorStack(error.data.cause)),
165
+ false,
166
+ ];
167
+ }
168
+ // The error can be a non-wrapped JSON-RPC error, in which case we can just
169
+ // re-throw it with the same code, message, and data.
170
+ if (isJsonRpcError(error)) {
171
+ const { code, message, stack, data } = error;
172
+ return [getJsonRpcError(code, message, stack, data), false];
173
+ }
174
+ // If the error is not a wrapped error, we don't know how to handle it, so we
175
+ // throw an internal error with the error as the message.
176
+ return [
177
+ getJsonRpcError(errorCodes.rpc.internal, getErrorMessage(error), getErrorStack(error)),
178
+ false,
179
+ ];
180
+ }
20
181
  //# sourceMappingURL=errors.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
1
+ {"version":3,"file":"errors.mjs","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,OAAO,EACL,UAAU,EACV,YAAY,IAAI,QAAQ,EACxB,cAAc,EACf,6BAA6B;AAG9B,OAAO,EACL,eAAe,EACf,aAAa,EACb,eAAe,EACf,kBAAkB,EACnB,4BAA4B;AAE7B,OAAO,EAAE,QAAQ,EAAE,cAAc,EAAE,wBAAwB;AAE3D,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,KAAK,CAAC;AAC9C,MAAM,CAAC,MAAM,0BAA0B,GAAG,oBAAoB,CAAC;AAU/D,MAAM,OAAO,gBAAiB,SAAQ,KAAK;IAOzC;;;;OAIG;IACH,YAAY,KAAc;QACxB,MAAM,OAAO,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC;QACvC,KAAK,CAAC,OAAO,CAAC,CAAC;QAbR,0CAAgB;QAEhB,4CAAiB;QAEjB,0CAAgB;QAWvB,uBAAA,IAAI,2BAAU,KAAK,MAAA,CAAC;QACpB,uBAAA,IAAI,6BAAY,OAAO,MAAA,CAAC;QACxB,uBAAA,IAAI,2BAAU,aAAa,CAAC,KAAK,CAAC,MAAA,CAAC;IACrC,CAAC;IAED;;;;OAIG;IACH,IAAI,IAAI;QACN,OAAO,kBAAkB,CAAC;IAC5B,CAAC;IAED;;;;OAIG;IACH,IAAI,OAAO;QACT,OAAO,uBAAA,IAAI,iCAAS,CAAC;IACvB,CAAC;IAED;;;;OAIG;IACH,IAAI,KAAK;QACP,OAAO,uBAAA,IAAI,+BAAO,CAAC;IACrB,CAAC;IAED;;;;OAIG;IACH,MAAM;QACJ,MAAM,KAAK,GAAG,WAAW,CAAC,uBAAA,IAAI,+BAAO,CAAC;YACpC,CAAC,CAAC,uBAAA,IAAI,+BAAO,CAAC,SAAS,EAAE;YACzB,CAAC,CAAC,cAAc,CAAC,uBAAA,IAAI,+BAAO,CAAC,CAAC;QAEhC,OAAO;YACL,IAAI,EAAE,uBAAuB;YAC7B,OAAO,EAAE,0BAA0B;YACnC,IAAI,EAAE;gBACJ,KAAK;aACN;SACF,CAAC;IACJ,CAAC;IAED;;;;;OAKG;IACH,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;IACvB,CAAC;CACF;;AAED;;;;;GAKG;AACH,MAAM,UAAU,WAAW,CAAC,KAAc;IACxC,IACE,QAAQ,CAAC,KAAK,CAAC;QACf,WAAW,IAAI,KAAK;QACpB,OAAO,KAAK,CAAC,SAAS,KAAK,UAAU,EACrC,CAAC;QACD,MAAM,UAAU,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;QACrC,OAAO,cAAc,CAAC,UAAU,CAAC,IAAI,qBAAqB,CAAC,UAAU,CAAC,CAAC;IACzE,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,qBAAqB,CACnC,KAAmB;IAEnB,OAAO,KAAK,CAAC,IAAI,KAAK,eAAe,IAAI,KAAK,CAAC,OAAO,KAAK,kBAAkB,CAAC;AAChF,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,kBAAkB,CAChC,KAAc;IAEd,OAAO,CACL,cAAc,CAAC,KAAK,CAAC;QACrB,KAAK,CAAC,IAAI,KAAK,uBAAuB;QACtC,KAAK,CAAC,OAAO,KAAK,0BAA0B,CAC7C,CAAC;AACJ,CAAC;AAED;;;;;;;;GAQG;AACH,SAAS,eAAe,CACtB,IAAY,EACZ,OAAe,EACf,KAAc,EACd,IAAW;IAEX,MAAM,KAAK,GAAG,IAAI,QAAQ,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IAChD,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;IAEpB,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;;;;;;;GAQG;AACH,MAAM,UAAU,WAAW,CACzB,KAAc;IAEd,wEAAwE;IACxE,0DAA0D;IAE1D,mDAAmD;IACnD,IAAI,kBAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;QAC9B,0EAA0E;QAC1E,8CAA8C;QAC9C,IAAI,cAAc,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;YACrC,oEAAoE;YACpE,IAAI,qBAAqB,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC5C,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;gBACnE,OAAO,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;YAC7D,CAAC;YAED,iDAAiD;YACjD,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;YACxD,OAAO,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC;QAC9D,CAAC;QAED,sEAAsE;QACtE,WAAW;QACX,OAAO;YACL,eAAe,CACb,UAAU,CAAC,GAAG,CAAC,QAAQ,EACvB,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EACjC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAChC;YACD,KAAK;SACN,CAAC;IACJ,CAAC;IAED,2EAA2E;IAC3E,qDAAqD;IACrD,IAAI,cAAc,CAAC,KAAK,CAAC,EAAE,CAAC;QAC1B,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC;QAC7C,OAAO,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC;IAC9D,CAAC;IAED,6EAA6E;IAC7E,yDAAyD;IACzD,OAAO;QACL,eAAe,CACb,UAAU,CAAC,GAAG,CAAC,QAAQ,EACvB,eAAe,CAAC,KAAK,CAAC,EACtB,aAAa,CAAC,KAAK,CAAC,CACrB;QACD,KAAK;KACN,CAAC;AACJ,CAAC","sourcesContent":["import {\n errorCodes,\n JsonRpcError as RpcError,\n serializeCause,\n} from '@metamask/rpc-errors';\nimport type { DataWithOptionalCause } from '@metamask/rpc-errors';\nimport type { SerializedSnapError, SnapError } from '@metamask/snaps-sdk';\nimport {\n getErrorMessage,\n getErrorStack,\n SNAP_ERROR_CODE,\n SNAP_ERROR_MESSAGE,\n} from '@metamask/snaps-sdk';\nimport type { Json, JsonRpcError } from '@metamask/utils';\nimport { isObject, isJsonRpcError } from '@metamask/utils';\n\nexport const SNAP_ERROR_WRAPPER_CODE = -31001;\nexport const SNAP_ERROR_WRAPPER_MESSAGE = 'Wrapped Snap Error';\n\nexport type SerializedSnapErrorWrapper = {\n code: typeof SNAP_ERROR_WRAPPER_CODE;\n message: typeof SNAP_ERROR_WRAPPER_MESSAGE;\n data: {\n cause: Json;\n };\n};\n\nexport class WrappedSnapError extends Error {\n readonly #error: unknown;\n\n readonly #message: string;\n\n readonly #stack?: string;\n\n /**\n * Create a new `WrappedSnapError`.\n *\n * @param error - The error to create the `WrappedSnapError` from.\n */\n constructor(error: unknown) {\n const message = getErrorMessage(error);\n super(message);\n\n this.#error = error;\n this.#message = message;\n this.#stack = getErrorStack(error);\n }\n\n /**\n * The error name.\n *\n * @returns The error name.\n */\n get name() {\n return 'WrappedSnapError';\n }\n\n /**\n * The error message.\n *\n * @returns The error message.\n */\n get message() {\n return this.#message;\n }\n\n /**\n * The error stack.\n *\n * @returns The error stack.\n */\n get stack() {\n return this.#stack;\n }\n\n /**\n * Convert the error to a JSON object.\n *\n * @returns The JSON object.\n */\n toJSON(): SerializedSnapErrorWrapper {\n const cause = isSnapError(this.#error)\n ? this.#error.serialize()\n : serializeCause(this.#error);\n\n return {\n code: SNAP_ERROR_WRAPPER_CODE,\n message: SNAP_ERROR_WRAPPER_MESSAGE,\n data: {\n cause,\n },\n };\n }\n\n /**\n * Serialize the error to a JSON object. This is called by\n * `@metamask/rpc-errors` when serializing the error.\n *\n * @returns The JSON object.\n */\n serialize() {\n return this.toJSON();\n }\n}\n\n/**\n * Check if an object is a `SnapError`.\n *\n * @param error - The object to check.\n * @returns Whether the object is a `SnapError`.\n */\nexport function isSnapError(error: unknown): error is SnapError {\n if (\n isObject(error) &&\n 'serialize' in error &&\n typeof error.serialize === 'function'\n ) {\n const serialized = error.serialize();\n return isJsonRpcError(serialized) && isSerializedSnapError(serialized);\n }\n\n return false;\n}\n\n/**\n * Check if a JSON-RPC error is a `SnapError`.\n *\n * @param error - The object to check.\n * @returns Whether the object is a `SnapError`.\n */\nexport function isSerializedSnapError(\n error: JsonRpcError,\n): error is SerializedSnapError {\n return error.code === SNAP_ERROR_CODE && error.message === SNAP_ERROR_MESSAGE;\n}\n\n/**\n * Check if a JSON-RPC error is a `WrappedSnapError`.\n *\n * @param error - The object to check.\n * @returns Whether the object is a `WrappedSnapError`.\n */\nexport function isWrappedSnapError(\n error: unknown,\n): error is SerializedSnapErrorWrapper {\n return (\n isJsonRpcError(error) &&\n error.code === SNAP_ERROR_WRAPPER_CODE &&\n error.message === SNAP_ERROR_WRAPPER_MESSAGE\n );\n}\n\n/**\n * Get a JSON-RPC error with the given code, message, stack, and data.\n *\n * @param code - The error code.\n * @param message - The error message.\n * @param stack - The error stack.\n * @param data - Additional data for the error.\n * @returns The JSON-RPC error.\n */\nfunction getJsonRpcError(\n code: number,\n message: string,\n stack?: string,\n data?: Json,\n) {\n const error = new RpcError(code, message, data);\n error.stack = stack;\n\n return error;\n}\n\n/**\n * Attempt to unwrap an unknown error to a `JsonRpcError`. This function will\n * try to get the error code, message, and data from the error, and return a\n * `JsonRpcError` with those properties.\n *\n * @param error - The error to unwrap.\n * @returns A tuple containing the unwrapped error and a boolean indicating\n * whether the error was handled.\n */\nexport function unwrapError(\n error: unknown,\n): [error: RpcError<DataWithOptionalCause>, isHandled: boolean] {\n // This logic is a bit complicated, but it's necessary to handle all the\n // different types of errors that can be thrown by a Snap.\n\n // If the error is a wrapped Snap error, unwrap it.\n if (isWrappedSnapError(error)) {\n // The wrapped error can be a JSON-RPC error, or an unknown error. If it's\n // a JSON-RPC error, we can unwrap it further.\n if (isJsonRpcError(error.data.cause)) {\n // If the JSON-RPC error is a wrapped Snap error, unwrap it further.\n if (isSerializedSnapError(error.data.cause)) {\n const { code, message, stack, data } = error.data.cause.data.cause;\n return [getJsonRpcError(code, message, stack, data), true];\n }\n\n // Otherwise, we use the original JSON-RPC error.\n const { code, message, stack, data } = error.data.cause;\n return [getJsonRpcError(code, message, stack, data), false];\n }\n\n // Otherwise, we throw an internal error with the wrapped error as the\n // message.\n return [\n getJsonRpcError(\n errorCodes.rpc.internal,\n getErrorMessage(error.data.cause),\n getErrorStack(error.data.cause),\n ),\n false,\n ];\n }\n\n // The error can be a non-wrapped JSON-RPC error, in which case we can just\n // re-throw it with the same code, message, and data.\n if (isJsonRpcError(error)) {\n const { code, message, stack, data } = error;\n return [getJsonRpcError(code, message, stack, data), false];\n }\n\n // If the error is not a wrapped error, we don't know how to handle it, so we\n // throw an internal error with the error as the message.\n return [\n getJsonRpcError(\n errorCodes.rpc.internal,\n getErrorMessage(error),\n getErrorStack(error),\n ),\n false,\n ];\n}\n"]}
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
4
+ // @ts-ignore - TypeScript complains about this being ESM in a CJS file, but
5
+ // `ses/lockdown` has a CommonJS entry point.
6
+ // eslint-disable-next-line import/no-unassigned-import
7
+ require("ses/lockdown");
8
+ const fs_1 = require("fs");
9
+ const handler_types_1 = require("./handler-types.cjs");
10
+ const mock_1 = require("./mock.cjs");
11
+ lockdown({
12
+ consoleTaming: 'unsafe',
13
+ errorTaming: 'unsafe',
14
+ mathTaming: 'unsafe',
15
+ dateTaming: 'unsafe',
16
+ overrideTaming: 'severe',
17
+ // We disable domain taming, because it does not work in certain cases when
18
+ // running tests. This is unlikely to be a problem in production, because
19
+ // Node.js domains are deprecated.
20
+ domainTaming: 'unsafe',
21
+ });
22
+ const snapFilePath = process.argv[2];
23
+ const snapModule = { exports: {} };
24
+ const compartment = new Compartment({
25
+ ...(0, mock_1.generateMockEndowments)(),
26
+ module: snapModule,
27
+ exports: snapModule.exports,
28
+ });
29
+ // Mirror BaseSnapExecutor
30
+ compartment.globalThis.self = compartment.globalThis;
31
+ compartment.globalThis.global = compartment.globalThis;
32
+ compartment.globalThis.window = compartment.globalThis;
33
+ compartment.evaluate((0, fs_1.readFileSync)(snapFilePath, 'utf8'));
34
+ const invalidExports = Object.keys(snapModule.exports).filter((snapExport) => !handler_types_1.SNAP_EXPORT_NAMES.includes(snapExport));
35
+ if (invalidExports.length > 0) {
36
+ // eslint-disable-next-line no-console
37
+ console.warn(`Invalid snap exports detected:\n${invalidExports.join('\n')}`);
38
+ }
39
+ // To ensure the worker exits we explicitly call exit here
40
+ // If we didn't the eval would wait for timers set during Compartment eval
41
+ process.exit(0);
42
+ //# sourceMappingURL=eval-worker.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"eval-worker.cjs","sourceRoot":"","sources":["../src/eval-worker.ts"],"names":[],"mappings":";;AAAA,6DAA6D;AAC7D,4EAA4E;AAC5E,6CAA6C;AAC7C,uDAAuD;AACvD,wBAAsB;AAEtB,2BAAkC;AAGlC,uDAAoD;AACpD,qCAAgD;AAIhD,QAAQ,CAAC;IACP,aAAa,EAAE,QAAQ;IACvB,WAAW,EAAE,QAAQ;IACrB,UAAU,EAAE,QAAQ;IACpB,UAAU,EAAE,QAAQ;IACpB,cAAc,EAAE,QAAQ;IAExB,2EAA2E;IAC3E,yEAAyE;IACzE,kCAAkC;IAClC,YAAY,EAAE,QAAQ;CACvB,CAAC,CAAC;AAEH,MAAM,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAErC,MAAM,UAAU,GAAsB,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;AAEtD,MAAM,WAAW,GAAG,IAAI,WAAW,CAAC;IAClC,GAAG,IAAA,6BAAsB,GAAE;IAC3B,MAAM,EAAE,UAAU;IAClB,OAAO,EAAE,UAAU,CAAC,OAAO;CAC5B,CAAC,CAAC;AAEH,0BAA0B;AAC1B,WAAW,CAAC,UAAU,CAAC,IAAI,GAAG,WAAW,CAAC,UAAU,CAAC;AACrD,WAAW,CAAC,UAAU,CAAC,MAAM,GAAG,WAAW,CAAC,UAAU,CAAC;AACvD,WAAW,CAAC,UAAU,CAAC,MAAM,GAAG,WAAW,CAAC,UAAU,CAAC;AAEvD,WAAW,CAAC,QAAQ,CAAC,IAAA,iBAAY,EAAC,YAAY,EAAE,MAAM,CAAC,CAAC,CAAC;AAEzD,MAAM,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,MAAM,CAC3D,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,iCAAiB,CAAC,QAAQ,CAAC,UAAyB,CAAC,CACvE,CAAC;AAEF,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;IAC9B,sCAAsC;IACtC,OAAO,CAAC,IAAI,CAAC,mCAAmC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAC/E,CAAC;AAED,0DAA0D;AAC1D,0EAA0E;AAC1E,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC","sourcesContent":["// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore - TypeScript complains about this being ESM in a CJS file, but\n// `ses/lockdown` has a CommonJS entry point.\n// eslint-disable-next-line import/no-unassigned-import\nimport 'ses/lockdown';\n\nimport { readFileSync } from 'fs';\n\nimport type { HandlerType } from './handler-types';\nimport { SNAP_EXPORT_NAMES } from './handler-types';\nimport { generateMockEndowments } from './mock';\n\ndeclare let lockdown: any, Compartment: any;\n\nlockdown({\n consoleTaming: 'unsafe',\n errorTaming: 'unsafe',\n mathTaming: 'unsafe',\n dateTaming: 'unsafe',\n overrideTaming: 'severe',\n\n // We disable domain taming, because it does not work in certain cases when\n // running tests. This is unlikely to be a problem in production, because\n // Node.js domains are deprecated.\n domainTaming: 'unsafe',\n});\n\nconst snapFilePath = process.argv[2];\n\nconst snapModule: { exports?: any } = { exports: {} };\n\nconst compartment = new Compartment({\n ...generateMockEndowments(),\n module: snapModule,\n exports: snapModule.exports,\n});\n\n// Mirror BaseSnapExecutor\ncompartment.globalThis.self = compartment.globalThis;\ncompartment.globalThis.global = compartment.globalThis;\ncompartment.globalThis.window = compartment.globalThis;\n\ncompartment.evaluate(readFileSync(snapFilePath, 'utf8'));\n\nconst invalidExports = Object.keys(snapModule.exports).filter(\n (snapExport) => !SNAP_EXPORT_NAMES.includes(snapExport as HandlerType),\n);\n\nif (invalidExports.length > 0) {\n // eslint-disable-next-line no-console\n console.warn(`Invalid snap exports detected:\\n${invalidExports.join('\\n')}`);\n}\n\n// To ensure the worker exits we explicitly call exit here\n// If we didn't the eval would wait for timers set during Compartment eval\nprocess.exit(0);\n"]}
@@ -0,0 +1,2 @@
1
+ import "ses/lockdown";
2
+ //# sourceMappingURL=eval-worker.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"eval-worker.d.cts","sourceRoot":"","sources":["../src/eval-worker.ts"],"names":[],"mappings":"AAIA,sBAAsB"}
@@ -0,0 +1,2 @@
1
+ import "ses/lockdown";
2
+ //# sourceMappingURL=eval-worker.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"eval-worker.d.mts","sourceRoot":"","sources":["../src/eval-worker.ts"],"names":[],"mappings":"AAIA,sBAAsB"}
@@ -1,43 +1,40 @@
1
- import {
2
- generateMockEndowments
3
- } from "./chunk-63OXILAY.mjs";
4
- import {
5
- SNAP_EXPORT_NAMES
6
- } from "./chunk-5R7UF7KM.mjs";
7
- import "./chunk-BGSO2GQC.mjs";
8
- import "./chunk-3RUWAMJT.mjs";
9
-
10
- // src/eval-worker.ts
1
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
2
+ // @ts-ignore - TypeScript complains about this being ESM in a CJS file, but
3
+ // `ses/lockdown` has a CommonJS entry point.
4
+ // eslint-disable-next-line import/no-unassigned-import
11
5
  import "ses/lockdown";
12
6
  import { readFileSync } from "fs";
7
+ import { SNAP_EXPORT_NAMES } from "./handler-types.mjs";
8
+ import { generateMockEndowments } from "./mock.mjs";
13
9
  lockdown({
14
- consoleTaming: "unsafe",
15
- errorTaming: "unsafe",
16
- mathTaming: "unsafe",
17
- dateTaming: "unsafe",
18
- overrideTaming: "severe",
19
- // We disable domain taming, because it does not work in certain cases when
20
- // running tests. This is unlikely to be a problem in production, because
21
- // Node.js domains are deprecated.
22
- domainTaming: "unsafe"
10
+ consoleTaming: 'unsafe',
11
+ errorTaming: 'unsafe',
12
+ mathTaming: 'unsafe',
13
+ dateTaming: 'unsafe',
14
+ overrideTaming: 'severe',
15
+ // We disable domain taming, because it does not work in certain cases when
16
+ // running tests. This is unlikely to be a problem in production, because
17
+ // Node.js domains are deprecated.
18
+ domainTaming: 'unsafe',
23
19
  });
24
- var snapFilePath = process.argv[2];
25
- var snapModule = { exports: {} };
26
- var compartment = new Compartment({
27
- ...generateMockEndowments(),
28
- module: snapModule,
29
- exports: snapModule.exports
20
+ const snapFilePath = process.argv[2];
21
+ const snapModule = { exports: {} };
22
+ const compartment = new Compartment({
23
+ ...generateMockEndowments(),
24
+ module: snapModule,
25
+ exports: snapModule.exports,
30
26
  });
27
+ // Mirror BaseSnapExecutor
31
28
  compartment.globalThis.self = compartment.globalThis;
32
29
  compartment.globalThis.global = compartment.globalThis;
33
30
  compartment.globalThis.window = compartment.globalThis;
34
- compartment.evaluate(readFileSync(snapFilePath, "utf8"));
35
- var invalidExports = Object.keys(snapModule.exports).filter(
36
- (snapExport) => !SNAP_EXPORT_NAMES.includes(snapExport)
37
- );
31
+ compartment.evaluate(readFileSync(snapFilePath, 'utf8'));
32
+ const invalidExports = Object.keys(snapModule.exports).filter((snapExport) => !SNAP_EXPORT_NAMES.includes(snapExport));
38
33
  if (invalidExports.length > 0) {
39
- console.warn(`Invalid snap exports detected:
40
- ${invalidExports.join("\n")}`);
34
+ // eslint-disable-next-line no-console
35
+ console.warn(`Invalid snap exports detected:\n${invalidExports.join('\n')}`);
41
36
  }
37
+ // To ensure the worker exits we explicitly call exit here
38
+ // If we didn't the eval would wait for timers set during Compartment eval
42
39
  process.exit(0);
43
40
  //# sourceMappingURL=eval-worker.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/eval-worker.ts"],"sourcesContent":["// eslint-disable-next-line import/no-unassigned-import\nimport 'ses/lockdown';\n\nimport { readFileSync } from 'fs';\n\nimport type { HandlerType } from './handler-types';\nimport { SNAP_EXPORT_NAMES } from './handler-types';\nimport { generateMockEndowments } from './mock';\n\ndeclare let lockdown: any, Compartment: any;\n\nlockdown({\n consoleTaming: 'unsafe',\n errorTaming: 'unsafe',\n mathTaming: 'unsafe',\n dateTaming: 'unsafe',\n overrideTaming: 'severe',\n\n // We disable domain taming, because it does not work in certain cases when\n // running tests. This is unlikely to be a problem in production, because\n // Node.js domains are deprecated.\n domainTaming: 'unsafe',\n});\n\nconst snapFilePath = process.argv[2];\n\nconst snapModule: { exports?: any } = { exports: {} };\n\nconst compartment = new Compartment({\n ...generateMockEndowments(),\n module: snapModule,\n exports: snapModule.exports,\n});\n\n// Mirror BaseSnapExecutor\ncompartment.globalThis.self = compartment.globalThis;\ncompartment.globalThis.global = compartment.globalThis;\ncompartment.globalThis.window = compartment.globalThis;\n\ncompartment.evaluate(readFileSync(snapFilePath, 'utf8'));\n\nconst invalidExports = Object.keys(snapModule.exports).filter(\n (snapExport) => !SNAP_EXPORT_NAMES.includes(snapExport as HandlerType),\n);\n\nif (invalidExports.length > 0) {\n // eslint-disable-next-line no-console\n console.warn(`Invalid snap exports detected:\\n${invalidExports.join('\\n')}`);\n}\n\n// To ensure the worker exits we explicitly call exit here\n// If we didn't the eval would wait for timers set during Compartment eval\nprocess.exit(0);\n"],"mappings":";;;;;;;;;;AACA,OAAO;AAEP,SAAS,oBAAoB;AAQ7B,SAAS;AAAA,EACP,eAAe;AAAA,EACf,aAAa;AAAA,EACb,YAAY;AAAA,EACZ,YAAY;AAAA,EACZ,gBAAgB;AAAA;AAAA;AAAA;AAAA,EAKhB,cAAc;AAChB,CAAC;AAED,IAAM,eAAe,QAAQ,KAAK,CAAC;AAEnC,IAAM,aAAgC,EAAE,SAAS,CAAC,EAAE;AAEpD,IAAM,cAAc,IAAI,YAAY;AAAA,EAClC,GAAG,uBAAuB;AAAA,EAC1B,QAAQ;AAAA,EACR,SAAS,WAAW;AACtB,CAAC;AAGD,YAAY,WAAW,OAAO,YAAY;AAC1C,YAAY,WAAW,SAAS,YAAY;AAC5C,YAAY,WAAW,SAAS,YAAY;AAE5C,YAAY,SAAS,aAAa,cAAc,MAAM,CAAC;AAEvD,IAAM,iBAAiB,OAAO,KAAK,WAAW,OAAO,EAAE;AAAA,EACrD,CAAC,eAAe,CAAC,kBAAkB,SAAS,UAAyB;AACvE;AAEA,IAAI,eAAe,SAAS,GAAG;AAE7B,UAAQ,KAAK;AAAA,EAAmC,eAAe,KAAK,IAAI,CAAC,EAAE;AAC7E;AAIA,QAAQ,KAAK,CAAC;","names":[]}
1
+ {"version":3,"file":"eval-worker.mjs","sourceRoot":"","sources":["../src/eval-worker.ts"],"names":[],"mappings":"AAAA,6DAA6D;AAC7D,4EAA4E;AAC5E,6CAA6C;AAC7C,uDAAuD;AACvD,sBAAsB;AAEtB,OAAO,EAAE,YAAY,EAAE,WAAW;AAGlC,OAAO,EAAE,iBAAiB,EAAE,4BAAwB;AACpD,OAAO,EAAE,sBAAsB,EAAE,mBAAe;AAIhD,QAAQ,CAAC;IACP,aAAa,EAAE,QAAQ;IACvB,WAAW,EAAE,QAAQ;IACrB,UAAU,EAAE,QAAQ;IACpB,UAAU,EAAE,QAAQ;IACpB,cAAc,EAAE,QAAQ;IAExB,2EAA2E;IAC3E,yEAAyE;IACzE,kCAAkC;IAClC,YAAY,EAAE,QAAQ;CACvB,CAAC,CAAC;AAEH,MAAM,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAErC,MAAM,UAAU,GAAsB,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;AAEtD,MAAM,WAAW,GAAG,IAAI,WAAW,CAAC;IAClC,GAAG,sBAAsB,EAAE;IAC3B,MAAM,EAAE,UAAU;IAClB,OAAO,EAAE,UAAU,CAAC,OAAO;CAC5B,CAAC,CAAC;AAEH,0BAA0B;AAC1B,WAAW,CAAC,UAAU,CAAC,IAAI,GAAG,WAAW,CAAC,UAAU,CAAC;AACrD,WAAW,CAAC,UAAU,CAAC,MAAM,GAAG,WAAW,CAAC,UAAU,CAAC;AACvD,WAAW,CAAC,UAAU,CAAC,MAAM,GAAG,WAAW,CAAC,UAAU,CAAC;AAEvD,WAAW,CAAC,QAAQ,CAAC,YAAY,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC,CAAC;AAEzD,MAAM,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,MAAM,CAC3D,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,iBAAiB,CAAC,QAAQ,CAAC,UAAyB,CAAC,CACvE,CAAC;AAEF,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;IAC9B,sCAAsC;IACtC,OAAO,CAAC,IAAI,CAAC,mCAAmC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAC/E,CAAC;AAED,0DAA0D;AAC1D,0EAA0E;AAC1E,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC","sourcesContent":["// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore - TypeScript complains about this being ESM in a CJS file, but\n// `ses/lockdown` has a CommonJS entry point.\n// eslint-disable-next-line import/no-unassigned-import\nimport 'ses/lockdown';\n\nimport { readFileSync } from 'fs';\n\nimport type { HandlerType } from './handler-types';\nimport { SNAP_EXPORT_NAMES } from './handler-types';\nimport { generateMockEndowments } from './mock';\n\ndeclare let lockdown: any, Compartment: any;\n\nlockdown({\n consoleTaming: 'unsafe',\n errorTaming: 'unsafe',\n mathTaming: 'unsafe',\n dateTaming: 'unsafe',\n overrideTaming: 'severe',\n\n // We disable domain taming, because it does not work in certain cases when\n // running tests. This is unlikely to be a problem in production, because\n // Node.js domains are deprecated.\n domainTaming: 'unsafe',\n});\n\nconst snapFilePath = process.argv[2];\n\nconst snapModule: { exports?: any } = { exports: {} };\n\nconst compartment = new Compartment({\n ...generateMockEndowments(),\n module: snapModule,\n exports: snapModule.exports,\n});\n\n// Mirror BaseSnapExecutor\ncompartment.globalThis.self = compartment.globalThis;\ncompartment.globalThis.global = compartment.globalThis;\ncompartment.globalThis.window = compartment.globalThis;\n\ncompartment.evaluate(readFileSync(snapFilePath, 'utf8'));\n\nconst invalidExports = Object.keys(snapModule.exports).filter(\n (snapExport) => !SNAP_EXPORT_NAMES.includes(snapExport as HandlerType),\n);\n\nif (invalidExports.length > 0) {\n // eslint-disable-next-line no-console\n console.warn(`Invalid snap exports detected:\\n${invalidExports.join('\\n')}`);\n}\n\n// To ensure the worker exits we explicitly call exit here\n// If we didn't the eval would wait for timers set during Compartment eval\nprocess.exit(0);\n"]}
package/dist/eval.cjs ADDED
@@ -0,0 +1,54 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.evalBundle = exports.SnapEvalError = void 0;
4
+ const utils_1 = require("@metamask/utils");
5
+ const child_process_1 = require("child_process");
6
+ const path_1 = require("path");
7
+ const fs_1 = require("./fs.cjs");
8
+ class SnapEvalError extends Error {
9
+ constructor(message, output) {
10
+ super(message);
11
+ this.name = 'SnapEvalError';
12
+ this.output = output;
13
+ }
14
+ }
15
+ exports.SnapEvalError = SnapEvalError;
16
+ /**
17
+ * Spawn a new process to run the provided bundle in.
18
+ *
19
+ * @param bundlePath - The path to the bundle to run.
20
+ * @returns `null` if the worker ran successfully.
21
+ * @throws If the worker failed to run successfully.
22
+ */
23
+ async function evalBundle(bundlePath) {
24
+ await (0, fs_1.validateFilePath)(bundlePath);
25
+ return new Promise((resolve, reject) => {
26
+ const worker = (0, child_process_1.fork)((0, path_1.join)(__dirname, 'eval-worker.cjs'), [bundlePath], {
27
+ // To avoid printing the output of the worker to the console, we set
28
+ // `stdio` to `pipe` and handle the output ourselves.
29
+ stdio: 'pipe',
30
+ });
31
+ let stdout = '';
32
+ let stderr = '';
33
+ (0, utils_1.assert)(worker.stdout, '`stdout` should be defined.');
34
+ (0, utils_1.assert)(worker.stderr, '`stderr` should be defined.');
35
+ worker.stdout.on('data', (data) => {
36
+ stdout += data.toString();
37
+ });
38
+ worker.stderr.on('data', (data) => {
39
+ stderr += data.toString();
40
+ });
41
+ worker.on('exit', (exitCode) => {
42
+ const output = {
43
+ stdout,
44
+ stderr,
45
+ };
46
+ if (exitCode === 0) {
47
+ return resolve(output);
48
+ }
49
+ return reject(new SnapEvalError(`Process exited with non-zero exit code: ${exitCode}.`, output));
50
+ });
51
+ });
52
+ }
53
+ exports.evalBundle = evalBundle;
54
+ //# sourceMappingURL=eval.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"eval.cjs","sourceRoot":"","sources":["../src/eval.ts"],"names":[],"mappings":";;;AAAA,2CAAyC;AACzC,iDAAqC;AACrC,+BAA4B;AAE5B,iCAAwC;AAOxC,MAAa,aAAc,SAAQ,KAAK;IAGtC,YAAY,OAAe,EAAE,MAAkB;QAC7C,KAAK,CAAC,OAAO,CAAC,CAAC;QAEf,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC;QAC5B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;CACF;AATD,sCASC;AAED;;;;;;GAMG;AACI,KAAK,UAAU,UAAU,CAAC,UAAkB;IACjD,MAAM,IAAA,qBAAgB,EAAC,UAAU,CAAC,CAAC;IAEnC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,MAAM,GAAG,IAAA,oBAAI,EAAC,IAAA,WAAI,EAAC,SAAS,EAAE,iBAAiB,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE;YACpE,oEAAoE;YACpE,qDAAqD;YACrD,KAAK,EAAE,MAAM;SACd,CAAC,CAAC;QAEH,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,IAAI,MAAM,GAAG,EAAE,CAAC;QAEhB,IAAA,cAAM,EAAC,MAAM,CAAC,MAAM,EAAE,6BAA6B,CAAC,CAAC;QACrD,IAAA,cAAM,EAAC,MAAM,CAAC,MAAM,EAAE,6BAA6B,CAAC,CAAC;QAErD,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAY,EAAE,EAAE;YACxC,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAY,EAAE,EAAE;YACxC,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,QAAgB,EAAE,EAAE;YACrC,MAAM,MAAM,GAAG;gBACb,MAAM;gBACN,MAAM;aACP,CAAC;YAEF,IAAI,QAAQ,KAAK,CAAC,EAAE,CAAC;gBACnB,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC;YACzB,CAAC;YAED,OAAO,MAAM,CACX,IAAI,aAAa,CACf,2CAA2C,QAAQ,GAAG,EACtD,MAAM,CACP,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AA1CD,gCA0CC","sourcesContent":["import { assert } from '@metamask/utils';\nimport { fork } from 'child_process';\nimport { join } from 'path';\n\nimport { validateFilePath } from './fs';\n\nexport type EvalOutput = {\n stdout: string;\n stderr: string;\n};\n\nexport class SnapEvalError extends Error {\n readonly output: EvalOutput;\n\n constructor(message: string, output: EvalOutput) {\n super(message);\n\n this.name = 'SnapEvalError';\n this.output = output;\n }\n}\n\n/**\n * Spawn a new process to run the provided bundle in.\n *\n * @param bundlePath - The path to the bundle to run.\n * @returns `null` if the worker ran successfully.\n * @throws If the worker failed to run successfully.\n */\nexport async function evalBundle(bundlePath: string): Promise<EvalOutput> {\n await validateFilePath(bundlePath);\n\n return new Promise((resolve, reject) => {\n const worker = fork(join(__dirname, 'eval-worker.cjs'), [bundlePath], {\n // To avoid printing the output of the worker to the console, we set\n // `stdio` to `pipe` and handle the output ourselves.\n stdio: 'pipe',\n });\n\n let stdout = '';\n let stderr = '';\n\n assert(worker.stdout, '`stdout` should be defined.');\n assert(worker.stderr, '`stderr` should be defined.');\n\n worker.stdout.on('data', (data: Buffer) => {\n stdout += data.toString();\n });\n\n worker.stderr.on('data', (data: Buffer) => {\n stderr += data.toString();\n });\n\n worker.on('exit', (exitCode: number) => {\n const output = {\n stdout,\n stderr,\n };\n\n if (exitCode === 0) {\n return resolve(output);\n }\n\n return reject(\n new SnapEvalError(\n `Process exited with non-zero exit code: ${exitCode}.`,\n output,\n ),\n );\n });\n });\n}\n"]}
@@ -0,0 +1,17 @@
1
+ export type EvalOutput = {
2
+ stdout: string;
3
+ stderr: string;
4
+ };
5
+ export declare class SnapEvalError extends Error {
6
+ readonly output: EvalOutput;
7
+ constructor(message: string, output: EvalOutput);
8
+ }
9
+ /**
10
+ * Spawn a new process to run the provided bundle in.
11
+ *
12
+ * @param bundlePath - The path to the bundle to run.
13
+ * @returns `null` if the worker ran successfully.
14
+ * @throws If the worker failed to run successfully.
15
+ */
16
+ export declare function evalBundle(bundlePath: string): Promise<EvalOutput>;
17
+ //# sourceMappingURL=eval.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"eval.d.cts","sourceRoot":"","sources":["../src/eval.ts"],"names":[],"mappings":"AAMA,MAAM,MAAM,UAAU,GAAG;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,qBAAa,aAAc,SAAQ,KAAK;IACtC,QAAQ,CAAC,MAAM,EAAE,UAAU,CAAC;gBAEhB,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU;CAMhD;AAED;;;;;;GAMG;AACH,wBAAsB,UAAU,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,CA0CxE"}
@@ -0,0 +1,17 @@
1
+ export type EvalOutput = {
2
+ stdout: string;
3
+ stderr: string;
4
+ };
5
+ export declare class SnapEvalError extends Error {
6
+ readonly output: EvalOutput;
7
+ constructor(message: string, output: EvalOutput);
8
+ }
9
+ /**
10
+ * Spawn a new process to run the provided bundle in.
11
+ *
12
+ * @param bundlePath - The path to the bundle to run.
13
+ * @returns `null` if the worker ran successfully.
14
+ * @throws If the worker failed to run successfully.
15
+ */
16
+ export declare function evalBundle(bundlePath: string): Promise<EvalOutput>;
17
+ //# sourceMappingURL=eval.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"eval.d.mts","sourceRoot":"","sources":["../src/eval.ts"],"names":[],"mappings":"AAMA,MAAM,MAAM,UAAU,GAAG;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,qBAAa,aAAc,SAAQ,KAAK;IACtC,QAAQ,CAAC,MAAM,EAAE,UAAU,CAAC;gBAEhB,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU;CAMhD;AAED;;;;;;GAMG;AACH,wBAAsB,UAAU,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,CA0CxE"}