@metamask/snaps-jest 8.2.0 → 8.3.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 (632) hide show
  1. package/CHANGELOG.md +20 -1
  2. package/README.md +2 -2
  3. package/dist/environment.cjs +96 -0
  4. package/dist/environment.cjs.map +1 -0
  5. package/dist/{types/environment.d.ts → environment.d.cts} +5 -4
  6. package/dist/environment.d.cts.map +1 -0
  7. package/dist/environment.d.mts +53 -0
  8. package/dist/environment.d.mts.map +1 -0
  9. package/dist/environment.mjs +94 -44
  10. package/dist/environment.mjs.map +1 -1
  11. package/dist/global.cjs +4 -0
  12. package/dist/global.cjs.map +1 -0
  13. package/dist/{types/global.d.ts → global.d.cts} +2 -1
  14. package/dist/global.d.cts.map +1 -0
  15. package/dist/global.d.mts +70 -0
  16. package/dist/global.d.mts.map +1 -0
  17. package/dist/global.mjs +2 -1
  18. package/dist/global.mjs.map +1 -1
  19. package/dist/helpers.cjs +240 -0
  20. package/dist/helpers.cjs.map +1 -0
  21. package/dist/{types/helpers.d.ts → helpers.d.cts} +47 -4
  22. package/dist/helpers.d.cts.map +1 -0
  23. package/dist/helpers.d.mts +132 -0
  24. package/dist/helpers.d.mts.map +1 -0
  25. package/dist/helpers.mjs +228 -42
  26. package/dist/helpers.mjs.map +1 -1
  27. package/dist/index.cjs +29 -0
  28. package/dist/index.cjs.map +1 -0
  29. package/dist/index.d.cts +6 -0
  30. package/dist/index.d.cts.map +1 -0
  31. package/dist/index.d.mts +6 -0
  32. package/dist/index.d.mts.map +1 -0
  33. package/dist/index.mjs +6 -53
  34. package/dist/index.mjs.map +1 -1
  35. package/dist/internals/environment.cjs +18 -0
  36. package/dist/internals/environment.cjs.map +1 -0
  37. package/dist/{types/internals/environment.d.ts → internals/environment.d.cts} +1 -0
  38. package/dist/internals/environment.d.cts.map +1 -0
  39. package/dist/internals/environment.d.mts +8 -0
  40. package/dist/internals/environment.d.mts.map +1 -0
  41. package/dist/internals/environment.mjs +13 -7
  42. package/dist/internals/environment.mjs.map +1 -1
  43. package/dist/internals/index.cjs +23 -0
  44. package/dist/internals/index.cjs.map +1 -0
  45. package/dist/internals/index.d.cts +7 -0
  46. package/dist/internals/index.d.cts.map +1 -0
  47. package/dist/internals/index.d.mts +7 -0
  48. package/dist/internals/index.d.mts.map +1 -0
  49. package/dist/internals/index.mjs +6 -141
  50. package/dist/internals/index.mjs.map +1 -1
  51. package/dist/internals/logger.cjs +6 -0
  52. package/dist/internals/logger.cjs.map +1 -0
  53. package/dist/{types/internals/logger.d.ts → internals/logger.d.cts} +1 -0
  54. package/dist/internals/logger.d.cts.map +1 -0
  55. package/dist/internals/logger.d.mts +3 -0
  56. package/dist/internals/logger.d.mts.map +1 -0
  57. package/dist/internals/logger.mjs +2 -7
  58. package/dist/internals/logger.mjs.map +1 -1
  59. package/dist/internals/request.cjs +143 -0
  60. package/dist/internals/request.cjs.map +1 -0
  61. package/dist/{types/internals/request.d.ts → internals/request.d.cts} +8 -7
  62. package/dist/internals/request.d.cts.map +1 -0
  63. package/dist/internals/request.d.mts +56 -0
  64. package/dist/internals/request.d.mts.map +1 -0
  65. package/dist/internals/request.mjs +137 -41
  66. package/dist/internals/request.mjs.map +1 -1
  67. package/dist/internals/server.cjs +74 -0
  68. package/dist/internals/server.cjs.map +1 -0
  69. package/dist/{types/internals/server.d.ts → internals/server.d.cts} +4 -3
  70. package/dist/internals/server.d.cts.map +1 -0
  71. package/dist/internals/server.d.mts +15 -0
  72. package/dist/internals/server.d.mts.map +1 -0
  73. package/dist/internals/server.mjs +73 -8
  74. package/dist/internals/server.mjs.map +1 -1
  75. package/dist/internals/simulation/constants.cjs +21 -0
  76. package/dist/internals/simulation/constants.cjs.map +1 -0
  77. package/dist/{types/internals/simulation/constants.d.ts → internals/simulation/constants.d.cts} +5 -0
  78. package/dist/internals/simulation/constants.d.cts.map +1 -0
  79. package/dist/internals/simulation/constants.d.mts +18 -0
  80. package/dist/internals/simulation/constants.d.mts.map +1 -0
  81. package/dist/internals/simulation/constants.mjs +17 -11
  82. package/dist/internals/simulation/constants.mjs.map +1 -1
  83. package/dist/internals/simulation/controllers.cjs +101 -0
  84. package/dist/internals/simulation/controllers.cjs.map +1 -0
  85. package/dist/{types/internals/simulation/controllers.d.ts → internals/simulation/controllers.d.cts} +15 -14
  86. package/dist/internals/simulation/controllers.d.cts.map +1 -0
  87. package/dist/internals/simulation/controllers.d.mts +41 -0
  88. package/dist/internals/simulation/controllers.d.mts.map +1 -0
  89. package/dist/internals/simulation/controllers.mjs +95 -24
  90. package/dist/internals/simulation/controllers.mjs.map +1 -1
  91. package/dist/internals/simulation/files.cjs +94 -0
  92. package/dist/internals/simulation/files.cjs.map +1 -0
  93. package/dist/{types/internals/simulation/files.d.ts → internals/simulation/files.d.cts} +6 -4
  94. package/dist/internals/simulation/files.d.cts.map +1 -0
  95. package/dist/internals/simulation/files.d.mts +49 -0
  96. package/dist/internals/simulation/files.d.mts.map +1 -0
  97. package/dist/internals/simulation/files.mjs +90 -13
  98. package/dist/internals/simulation/files.mjs.map +1 -1
  99. package/dist/internals/simulation/index.cjs +22 -0
  100. package/dist/internals/simulation/index.cjs.map +1 -0
  101. package/dist/internals/simulation/index.d.cts +6 -0
  102. package/dist/internals/simulation/index.d.cts.map +1 -0
  103. package/dist/internals/simulation/index.d.mts +6 -0
  104. package/dist/internals/simulation/index.d.mts.map +1 -0
  105. package/dist/internals/simulation/index.mjs +5 -102
  106. package/dist/internals/simulation/index.mjs.map +1 -1
  107. package/dist/internals/simulation/interface.cjs +527 -0
  108. package/dist/internals/simulation/interface.cjs.map +1 -0
  109. package/dist/{types/internals/simulation/interface.d.ts → internals/simulation/interface.d.cts} +38 -10
  110. package/dist/internals/simulation/interface.d.cts.map +1 -0
  111. package/dist/internals/simulation/interface.d.mts +152 -0
  112. package/dist/internals/simulation/interface.d.mts.map +1 -0
  113. package/dist/internals/simulation/interface.mjs +512 -30
  114. package/dist/internals/simulation/interface.mjs.map +1 -1
  115. package/dist/internals/simulation/methods/constants.cjs +72 -0
  116. package/dist/internals/simulation/methods/constants.cjs.map +1 -0
  117. package/dist/{types/internals/simulation/methods/constants.d.ts → internals/simulation/methods/constants.d.cts} +1 -0
  118. package/dist/internals/simulation/methods/constants.d.cts.map +1 -0
  119. package/dist/internals/simulation/methods/constants.d.mts +11 -0
  120. package/dist/internals/simulation/methods/constants.d.mts.map +1 -0
  121. package/dist/internals/simulation/methods/constants.mjs +68 -11
  122. package/dist/internals/simulation/methods/constants.mjs.map +1 -1
  123. package/dist/internals/simulation/methods/hooks/get-preferences.cjs +18 -0
  124. package/dist/internals/simulation/methods/hooks/get-preferences.cjs.map +1 -0
  125. package/dist/internals/simulation/methods/hooks/get-preferences.d.cts +14 -0
  126. package/dist/internals/simulation/methods/hooks/get-preferences.d.cts.map +1 -0
  127. package/dist/internals/simulation/methods/hooks/get-preferences.d.mts +14 -0
  128. package/dist/internals/simulation/methods/hooks/get-preferences.d.mts.map +1 -0
  129. package/dist/internals/simulation/methods/hooks/get-preferences.mjs +14 -0
  130. package/dist/internals/simulation/methods/hooks/get-preferences.mjs.map +1 -0
  131. package/dist/internals/simulation/methods/hooks/index.cjs +22 -0
  132. package/dist/internals/simulation/methods/hooks/index.cjs.map +1 -0
  133. package/dist/internals/simulation/methods/hooks/index.d.cts +6 -0
  134. package/dist/internals/simulation/methods/hooks/index.d.cts.map +1 -0
  135. package/dist/internals/simulation/methods/hooks/index.d.mts +6 -0
  136. package/dist/internals/simulation/methods/hooks/index.d.mts.map +1 -0
  137. package/dist/internals/simulation/methods/hooks/index.mjs +5 -38
  138. package/dist/internals/simulation/methods/hooks/index.mjs.map +1 -1
  139. package/dist/internals/simulation/methods/hooks/interface.cjs +24 -0
  140. package/dist/internals/simulation/methods/hooks/interface.cjs.map +1 -0
  141. package/dist/{types/internals/simulation/methods/hooks/interface.d.ts → internals/simulation/methods/hooks/interface.d.cts} +3 -2
  142. package/dist/internals/simulation/methods/hooks/interface.d.cts.map +1 -0
  143. package/dist/internals/simulation/methods/hooks/interface.d.mts +17 -0
  144. package/dist/internals/simulation/methods/hooks/interface.d.mts.map +1 -0
  145. package/dist/internals/simulation/methods/hooks/interface.mjs +18 -9
  146. package/dist/internals/simulation/methods/hooks/interface.mjs.map +1 -1
  147. package/dist/internals/simulation/methods/hooks/notifications.cjs +58 -0
  148. package/dist/internals/simulation/methods/hooks/notifications.cjs.map +1 -0
  149. package/dist/{types/internals/simulation/methods/hooks/notifications.d.ts → internals/simulation/methods/hooks/notifications.d.cts} +5 -4
  150. package/dist/internals/simulation/methods/hooks/notifications.d.cts.map +1 -0
  151. package/dist/internals/simulation/methods/hooks/notifications.d.mts +17 -0
  152. package/dist/internals/simulation/methods/hooks/notifications.d.mts.map +1 -0
  153. package/dist/internals/simulation/methods/hooks/notifications.mjs +54 -15
  154. package/dist/internals/simulation/methods/hooks/notifications.mjs.map +1 -1
  155. package/dist/internals/simulation/methods/hooks/request-user-approval.cjs +38 -0
  156. package/dist/internals/simulation/methods/hooks/request-user-approval.cjs.map +1 -0
  157. package/dist/internals/simulation/methods/hooks/request-user-approval.d.cts +16 -0
  158. package/dist/internals/simulation/methods/hooks/request-user-approval.d.cts.map +1 -0
  159. package/dist/internals/simulation/methods/hooks/request-user-approval.d.mts +16 -0
  160. package/dist/internals/simulation/methods/hooks/request-user-approval.d.mts.map +1 -0
  161. package/dist/internals/simulation/methods/hooks/request-user-approval.mjs +35 -0
  162. package/dist/internals/simulation/methods/hooks/request-user-approval.mjs.map +1 -0
  163. package/dist/internals/simulation/methods/hooks/state.cjs +84 -0
  164. package/dist/internals/simulation/methods/hooks/state.cjs.map +1 -0
  165. package/dist/{types/internals/simulation/methods/hooks/state.d.ts → internals/simulation/methods/hooks/state.d.cts} +3 -2
  166. package/dist/internals/simulation/methods/hooks/state.d.cts.map +1 -0
  167. package/dist/internals/simulation/methods/hooks/state.d.mts +24 -0
  168. package/dist/internals/simulation/methods/hooks/state.d.mts.map +1 -0
  169. package/dist/internals/simulation/methods/hooks/state.mjs +78 -17
  170. package/dist/internals/simulation/methods/hooks/state.mjs.map +1 -1
  171. package/dist/internals/simulation/methods/index.cjs +18 -0
  172. package/dist/internals/simulation/methods/index.cjs.map +1 -0
  173. package/dist/internals/simulation/methods/index.d.cts +2 -0
  174. package/dist/internals/simulation/methods/index.d.cts.map +1 -0
  175. package/dist/internals/simulation/methods/index.d.mts +2 -0
  176. package/dist/internals/simulation/methods/index.d.mts.map +1 -0
  177. package/dist/internals/simulation/methods/index.mjs +1 -27
  178. package/dist/internals/simulation/methods/index.mjs.map +1 -1
  179. package/dist/internals/simulation/methods/specifications.cjs +85 -0
  180. package/dist/internals/simulation/methods/specifications.cjs.map +1 -0
  181. package/dist/{types/internals/simulation/methods/specifications.d.ts → internals/simulation/methods/specifications.d.cts} +8 -7
  182. package/dist/internals/simulation/methods/specifications.d.cts.map +1 -0
  183. package/dist/internals/simulation/methods/specifications.d.mts +57 -0
  184. package/dist/internals/simulation/methods/specifications.d.mts.map +1 -0
  185. package/dist/internals/simulation/methods/specifications.mjs +77 -26
  186. package/dist/internals/simulation/methods/specifications.mjs.map +1 -1
  187. package/dist/internals/simulation/middleware/engine.cjs +37 -0
  188. package/dist/internals/simulation/middleware/engine.cjs.map +1 -0
  189. package/dist/{types/internals/simulation/middleware/engine.d.ts → internals/simulation/middleware/engine.d.cts} +8 -7
  190. package/dist/internals/simulation/middleware/engine.d.cts.map +1 -0
  191. package/dist/internals/simulation/middleware/engine.d.mts +27 -0
  192. package/dist/internals/simulation/middleware/engine.d.mts.map +1 -0
  193. package/dist/internals/simulation/middleware/engine.mjs +33 -14
  194. package/dist/internals/simulation/middleware/engine.mjs.map +1 -1
  195. package/dist/internals/simulation/middleware/index.cjs +18 -0
  196. package/dist/internals/simulation/middleware/index.cjs.map +1 -0
  197. package/dist/internals/simulation/middleware/index.d.cts +2 -0
  198. package/dist/internals/simulation/middleware/index.d.cts.map +1 -0
  199. package/dist/internals/simulation/middleware/index.d.mts +2 -0
  200. package/dist/internals/simulation/middleware/index.d.mts.map +1 -0
  201. package/dist/internals/simulation/middleware/index.mjs +1 -15
  202. package/dist/internals/simulation/middleware/index.mjs.map +1 -1
  203. package/dist/internals/simulation/middleware/internal-methods/accounts.cjs +34 -0
  204. package/dist/internals/simulation/middleware/internal-methods/accounts.cjs.map +1 -0
  205. package/dist/{types/internals/simulation/middleware/internal-methods/accounts.d.ts → internals/simulation/middleware/internal-methods/accounts.d.cts} +5 -3
  206. package/dist/internals/simulation/middleware/internal-methods/accounts.d.cts.map +1 -0
  207. package/dist/internals/simulation/middleware/internal-methods/accounts.d.mts +20 -0
  208. package/dist/internals/simulation/middleware/internal-methods/accounts.d.mts.map +1 -0
  209. package/dist/internals/simulation/middleware/internal-methods/accounts.mjs +29 -7
  210. package/dist/internals/simulation/middleware/internal-methods/accounts.mjs.map +1 -1
  211. package/dist/internals/simulation/middleware/internal-methods/index.cjs +18 -0
  212. package/dist/internals/simulation/middleware/internal-methods/index.cjs.map +1 -0
  213. package/dist/internals/simulation/middleware/internal-methods/index.d.cts +2 -0
  214. package/dist/internals/simulation/middleware/internal-methods/index.d.cts.map +1 -0
  215. package/dist/internals/simulation/middleware/internal-methods/index.d.mts +2 -0
  216. package/dist/internals/simulation/middleware/internal-methods/index.d.mts.map +1 -0
  217. package/dist/internals/simulation/middleware/internal-methods/index.mjs +1 -10
  218. package/dist/internals/simulation/middleware/internal-methods/index.mjs.map +1 -1
  219. package/dist/internals/simulation/middleware/internal-methods/middleware.cjs +44 -0
  220. package/dist/internals/simulation/middleware/internal-methods/middleware.cjs.map +1 -0
  221. package/dist/{types/internals/simulation/middleware/internal-methods/middleware.d.ts → internals/simulation/middleware/internal-methods/middleware.d.cts} +4 -3
  222. package/dist/internals/simulation/middleware/internal-methods/middleware.d.cts.map +1 -0
  223. package/dist/internals/simulation/middleware/internal-methods/middleware.d.mts +23 -0
  224. package/dist/internals/simulation/middleware/internal-methods/middleware.d.mts.map +1 -0
  225. package/dist/internals/simulation/middleware/internal-methods/middleware.mjs +38 -8
  226. package/dist/internals/simulation/middleware/internal-methods/middleware.mjs.map +1 -1
  227. package/dist/internals/simulation/middleware/internal-methods/provider-state.cjs +28 -0
  228. package/dist/internals/simulation/middleware/internal-methods/provider-state.cjs.map +1 -0
  229. package/dist/{types/internals/simulation/middleware/internal-methods/provider-state.d.ts → internals/simulation/middleware/internal-methods/provider-state.d.cts} +4 -2
  230. package/dist/internals/simulation/middleware/internal-methods/provider-state.d.cts.map +1 -0
  231. package/dist/internals/simulation/middleware/internal-methods/provider-state.d.mts +16 -0
  232. package/dist/internals/simulation/middleware/internal-methods/provider-state.d.mts.map +1 -0
  233. package/dist/internals/simulation/middleware/internal-methods/provider-state.mjs +23 -7
  234. package/dist/internals/simulation/middleware/internal-methods/provider-state.mjs.map +1 -1
  235. package/dist/internals/simulation/middleware/mock.cjs +22 -0
  236. package/dist/internals/simulation/middleware/mock.cjs.map +1 -0
  237. package/dist/{types/internals/simulation/middleware/mock.d.ts → internals/simulation/middleware/mock.d.cts} +4 -3
  238. package/dist/internals/simulation/middleware/mock.d.cts.map +1 -0
  239. package/dist/internals/simulation/middleware/mock.d.mts +11 -0
  240. package/dist/internals/simulation/middleware/mock.d.mts.map +1 -0
  241. package/dist/internals/simulation/middleware/mock.mjs +17 -8
  242. package/dist/internals/simulation/middleware/mock.mjs.map +1 -1
  243. package/dist/internals/simulation/options.cjs +25 -0
  244. package/dist/internals/simulation/options.cjs.map +1 -0
  245. package/dist/{types/internals/simulation/options.d.ts → internals/simulation/options.d.cts} +11 -8
  246. package/dist/internals/simulation/options.d.cts.map +1 -0
  247. package/dist/internals/simulation/options.d.mts +40 -0
  248. package/dist/internals/simulation/options.d.mts.map +1 -0
  249. package/dist/internals/simulation/options.mjs +20 -8
  250. package/dist/internals/simulation/options.mjs.map +1 -1
  251. package/dist/internals/simulation/simulation.cjs +155 -0
  252. package/dist/internals/simulation/simulation.cjs.map +1 -0
  253. package/dist/{types/internals/simulation/simulation.d.ts → internals/simulation/simulation.d.cts} +18 -13
  254. package/dist/internals/simulation/simulation.d.cts.map +1 -0
  255. package/dist/internals/simulation/simulation.d.mts +103 -0
  256. package/dist/internals/simulation/simulation.d.mts.map +1 -0
  257. package/dist/internals/simulation/simulation.mjs +149 -37
  258. package/dist/internals/simulation/simulation.mjs.map +1 -1
  259. package/dist/internals/simulation/store/index.cjs +21 -0
  260. package/dist/internals/simulation/store/index.cjs.map +1 -0
  261. package/dist/internals/simulation/store/index.d.cts +5 -0
  262. package/dist/internals/simulation/store/index.d.cts.map +1 -0
  263. package/dist/internals/simulation/store/index.d.mts +5 -0
  264. package/dist/internals/simulation/store/index.d.mts.map +1 -0
  265. package/dist/internals/simulation/store/index.mjs +4 -43
  266. package/dist/internals/simulation/store/index.mjs.map +1 -1
  267. package/dist/internals/simulation/store/mocks.cjs +39 -0
  268. package/dist/internals/simulation/store/mocks.cjs.map +1 -0
  269. package/dist/{types/internals/simulation/store/mocks.d.ts → internals/simulation/store/mocks.d.cts} +8 -7
  270. package/dist/internals/simulation/store/mocks.d.cts.map +1 -0
  271. package/dist/internals/simulation/store/mocks.d.mts +36 -0
  272. package/dist/internals/simulation/store/mocks.d.mts.map +1 -0
  273. package/dist/internals/simulation/store/mocks.mjs +33 -14
  274. package/dist/internals/simulation/store/mocks.mjs.map +1 -1
  275. package/dist/internals/simulation/store/notifications.cjs +35 -0
  276. package/dist/internals/simulation/store/notifications.cjs.map +1 -0
  277. package/dist/{types/internals/simulation/store/notifications.d.ts → internals/simulation/store/notifications.d.cts} +8 -7
  278. package/dist/internals/simulation/store/notifications.d.cts.map +1 -0
  279. package/dist/internals/simulation/store/notifications.d.mts +45 -0
  280. package/dist/internals/simulation/store/notifications.d.mts.map +1 -0
  281. package/dist/internals/simulation/store/notifications.mjs +30 -14
  282. package/dist/internals/simulation/store/notifications.mjs.map +1 -1
  283. package/dist/internals/simulation/store/state.cjs +54 -0
  284. package/dist/internals/simulation/store/state.cjs.map +1 -0
  285. package/dist/{types/internals/simulation/store/state.d.ts → internals/simulation/store/state.d.cts} +7 -6
  286. package/dist/internals/simulation/store/state.d.cts.map +1 -0
  287. package/dist/internals/simulation/store/state.d.mts +56 -0
  288. package/dist/internals/simulation/store/state.d.mts.map +1 -0
  289. package/dist/internals/simulation/store/state.mjs +48 -12
  290. package/dist/internals/simulation/store/state.mjs.map +1 -1
  291. package/dist/internals/simulation/store/store.cjs +51 -0
  292. package/dist/internals/simulation/store/store.cjs.map +1 -0
  293. package/dist/{types/internals/simulation/store/store.d.ts → internals/simulation/store/store.d.cts} +6 -5
  294. package/dist/internals/simulation/store/store.d.cts.map +1 -0
  295. package/dist/internals/simulation/store/store.d.mts +22 -0
  296. package/dist/internals/simulation/store/store.d.mts.map +1 -0
  297. package/dist/internals/simulation/store/store.mjs +44 -11
  298. package/dist/internals/simulation/store/store.mjs.map +1 -1
  299. package/dist/internals/simulation/store/ui.cjs +24 -0
  300. package/dist/internals/simulation/store/ui.cjs.map +1 -0
  301. package/dist/{types/internals/simulation/store/ui.d.ts → internals/simulation/store/ui.d.cts} +9 -7
  302. package/dist/internals/simulation/store/ui.d.cts.map +1 -0
  303. package/dist/internals/simulation/store/ui.d.mts +27 -0
  304. package/dist/internals/simulation/store/ui.d.mts.map +1 -0
  305. package/dist/internals/simulation/store/ui.mjs +19 -14
  306. package/dist/internals/simulation/store/ui.mjs.map +1 -1
  307. package/dist/internals/structs.cjs +157 -0
  308. package/dist/internals/structs.cjs.map +1 -0
  309. package/dist/{types/internals/structs.d.ts → internals/structs.d.cts} +67 -66
  310. package/dist/internals/structs.d.cts.map +1 -0
  311. package/dist/internals/structs.d.mts +205 -0
  312. package/dist/internals/structs.d.mts.map +1 -0
  313. package/dist/internals/structs.mjs +153 -21
  314. package/dist/internals/structs.mjs.map +1 -1
  315. package/dist/matchers.cjs +160 -0
  316. package/dist/matchers.cjs.map +1 -0
  317. package/dist/{types/matchers.d.ts → matchers.d.cts} +4 -13
  318. package/dist/matchers.d.cts.map +1 -0
  319. package/dist/matchers.d.mts +28 -0
  320. package/dist/matchers.d.mts.map +1 -0
  321. package/dist/matchers.mjs +152 -49
  322. package/dist/matchers.mjs.map +1 -1
  323. package/dist/options.cjs +24 -0
  324. package/dist/options.cjs.map +1 -0
  325. package/dist/{types/options.d.ts → options.d.cts} +8 -7
  326. package/dist/options.d.cts.map +1 -0
  327. package/dist/options.d.mts +61 -0
  328. package/dist/options.d.mts.map +1 -0
  329. package/dist/options.mjs +19 -7
  330. package/dist/options.mjs.map +1 -1
  331. package/dist/setup.cjs +7 -0
  332. package/dist/setup.cjs.map +1 -0
  333. package/dist/setup.d.cts +2 -0
  334. package/dist/setup.d.cts.map +1 -0
  335. package/dist/setup.d.mts +2 -0
  336. package/dist/setup.d.mts.map +1 -0
  337. package/dist/setup.mjs +4 -37
  338. package/dist/setup.mjs.map +1 -1
  339. package/dist/types/index.cjs +18 -0
  340. package/dist/types/index.cjs.map +1 -0
  341. package/dist/types/index.d.cts +2 -0
  342. package/dist/types/index.d.cts.map +1 -0
  343. package/dist/types/index.d.mts +2 -0
  344. package/dist/types/index.d.mts.map +1 -0
  345. package/dist/types/index.mjs +2 -0
  346. package/dist/types/index.mjs.map +1 -0
  347. package/dist/types/types.cjs +3 -0
  348. package/dist/types/types.cjs.map +1 -0
  349. package/dist/types/{types.d.ts → types.d.cts} +66 -26
  350. package/dist/types/types.d.cts.map +1 -0
  351. package/dist/types/types.d.mts +386 -0
  352. package/dist/types/types.d.mts.map +1 -0
  353. package/dist/types/types.mjs +2 -0
  354. package/dist/types/types.mjs.map +1 -0
  355. package/jest-preset.js +1 -1
  356. package/package.json +32 -30
  357. package/dist/chunk-265BMFM5.js +0 -13
  358. package/dist/chunk-265BMFM5.js.map +0 -1
  359. package/dist/chunk-2JTGBHPR.js +0 -14
  360. package/dist/chunk-2JTGBHPR.js.map +0 -1
  361. package/dist/chunk-2YE2P5BZ.js +0 -36
  362. package/dist/chunk-2YE2P5BZ.js.map +0 -1
  363. package/dist/chunk-3FNLFVV2.js +0 -15
  364. package/dist/chunk-3FNLFVV2.js.map +0 -1
  365. package/dist/chunk-3M4GRUMH.mjs +0 -54
  366. package/dist/chunk-3M4GRUMH.mjs.map +0 -1
  367. package/dist/chunk-43HRTFLS.mjs +0 -421
  368. package/dist/chunk-43HRTFLS.mjs.map +0 -1
  369. package/dist/chunk-44ARQBXS.js +0 -95
  370. package/dist/chunk-44ARQBXS.js.map +0 -1
  371. package/dist/chunk-4MAA7WGJ.js +0 -153
  372. package/dist/chunk-4MAA7WGJ.js.map +0 -1
  373. package/dist/chunk-55J6XMHW.js +0 -1
  374. package/dist/chunk-55J6XMHW.js.map +0 -1
  375. package/dist/chunk-57SGDM5B.mjs +0 -69
  376. package/dist/chunk-57SGDM5B.mjs.map +0 -1
  377. package/dist/chunk-5SGLRSWR.mjs +0 -153
  378. package/dist/chunk-5SGLRSWR.mjs.map +0 -1
  379. package/dist/chunk-5U5WB3SM.mjs +0 -41
  380. package/dist/chunk-5U5WB3SM.mjs.map +0 -1
  381. package/dist/chunk-5ZFHFICZ.mjs +0 -1
  382. package/dist/chunk-5ZFHFICZ.mjs.map +0 -1
  383. package/dist/chunk-6HHV6YFQ.mjs +0 -1
  384. package/dist/chunk-6HHV6YFQ.mjs.map +0 -1
  385. package/dist/chunk-6KXCBUNZ.mjs +0 -11
  386. package/dist/chunk-6KXCBUNZ.mjs.map +0 -1
  387. package/dist/chunk-74TIKA2T.mjs +0 -34
  388. package/dist/chunk-74TIKA2T.mjs.map +0 -1
  389. package/dist/chunk-7Y27L2EV.js +0 -211
  390. package/dist/chunk-7Y27L2EV.js.map +0 -1
  391. package/dist/chunk-ALRZENWP.mjs +0 -42
  392. package/dist/chunk-ALRZENWP.mjs.map +0 -1
  393. package/dist/chunk-B73P64TE.mjs +0 -28
  394. package/dist/chunk-B73P64TE.mjs.map +0 -1
  395. package/dist/chunk-CKRORVDW.js +0 -1
  396. package/dist/chunk-CKRORVDW.js.map +0 -1
  397. package/dist/chunk-CYPP66I7.mjs +0 -163
  398. package/dist/chunk-CYPP66I7.mjs.map +0 -1
  399. package/dist/chunk-DR6Y7IVX.js +0 -1
  400. package/dist/chunk-DR6Y7IVX.js.map +0 -1
  401. package/dist/chunk-DVDAOXO7.js +0 -134
  402. package/dist/chunk-DVDAOXO7.js.map +0 -1
  403. package/dist/chunk-EMTW3H54.js +0 -20
  404. package/dist/chunk-EMTW3H54.js.map +0 -1
  405. package/dist/chunk-FP4H3ADT.mjs +0 -20
  406. package/dist/chunk-FP4H3ADT.mjs.map +0 -1
  407. package/dist/chunk-FQWOVTBB.mjs +0 -22
  408. package/dist/chunk-FQWOVTBB.mjs.map +0 -1
  409. package/dist/chunk-GECE47HW.js +0 -1
  410. package/dist/chunk-GECE47HW.js.map +0 -1
  411. package/dist/chunk-GG2BCPQH.mjs +0 -95
  412. package/dist/chunk-GG2BCPQH.mjs.map +0 -1
  413. package/dist/chunk-GMTKFAWO.js +0 -42
  414. package/dist/chunk-GMTKFAWO.js.map +0 -1
  415. package/dist/chunk-GVTDUKXK.js +0 -421
  416. package/dist/chunk-GVTDUKXK.js.map +0 -1
  417. package/dist/chunk-H2464AXT.mjs +0 -33
  418. package/dist/chunk-H2464AXT.mjs.map +0 -1
  419. package/dist/chunk-HOI6FPLR.mjs +0 -240
  420. package/dist/chunk-HOI6FPLR.mjs.map +0 -1
  421. package/dist/chunk-HROOL3VI.js +0 -1
  422. package/dist/chunk-HROOL3VI.js.map +0 -1
  423. package/dist/chunk-IH7UNS5A.mjs +0 -36
  424. package/dist/chunk-IH7UNS5A.mjs.map +0 -1
  425. package/dist/chunk-IVFVB4VR.js +0 -163
  426. package/dist/chunk-IVFVB4VR.js.map +0 -1
  427. package/dist/chunk-IWJ4HKDR.mjs +0 -50
  428. package/dist/chunk-IWJ4HKDR.mjs.map +0 -1
  429. package/dist/chunk-IXKO6X55.mjs +0 -15
  430. package/dist/chunk-IXKO6X55.mjs.map +0 -1
  431. package/dist/chunk-J3I5KZIF.js +0 -22
  432. package/dist/chunk-J3I5KZIF.js.map +0 -1
  433. package/dist/chunk-J4ZPUCLX.mjs +0 -8
  434. package/dist/chunk-J4ZPUCLX.mjs.map +0 -1
  435. package/dist/chunk-JMDSN227.mjs +0 -25
  436. package/dist/chunk-JMDSN227.mjs.map +0 -1
  437. package/dist/chunk-KIQOUUEZ.mjs +0 -1
  438. package/dist/chunk-KIQOUUEZ.mjs.map +0 -1
  439. package/dist/chunk-KNJNL723.mjs +0 -39
  440. package/dist/chunk-KNJNL723.mjs.map +0 -1
  441. package/dist/chunk-KSIBNOB2.mjs +0 -13
  442. package/dist/chunk-KSIBNOB2.mjs.map +0 -1
  443. package/dist/chunk-LACTK6EO.js +0 -33
  444. package/dist/chunk-LACTK6EO.js.map +0 -1
  445. package/dist/chunk-LB4R3BUA.mjs +0 -36
  446. package/dist/chunk-LB4R3BUA.mjs.map +0 -1
  447. package/dist/chunk-LBC2OGSN.js +0 -48
  448. package/dist/chunk-LBC2OGSN.js.map +0 -1
  449. package/dist/chunk-MAT5SBM7.mjs +0 -211
  450. package/dist/chunk-MAT5SBM7.mjs.map +0 -1
  451. package/dist/chunk-MBQHVBLA.js +0 -89
  452. package/dist/chunk-MBQHVBLA.js.map +0 -1
  453. package/dist/chunk-MF43OG3Z.mjs +0 -1
  454. package/dist/chunk-MF43OG3Z.mjs.map +0 -1
  455. package/dist/chunk-MPZOXW6I.mjs +0 -48
  456. package/dist/chunk-MPZOXW6I.mjs.map +0 -1
  457. package/dist/chunk-N6MAO223.js +0 -60
  458. package/dist/chunk-N6MAO223.js.map +0 -1
  459. package/dist/chunk-NSMTFK33.mjs +0 -104
  460. package/dist/chunk-NSMTFK33.mjs.map +0 -1
  461. package/dist/chunk-NTOY6Y4Q.mjs +0 -1
  462. package/dist/chunk-NTOY6Y4Q.mjs.map +0 -1
  463. package/dist/chunk-O24GTINW.mjs +0 -134
  464. package/dist/chunk-O24GTINW.mjs.map +0 -1
  465. package/dist/chunk-ORO3T6BU.mjs +0 -24
  466. package/dist/chunk-ORO3T6BU.mjs.map +0 -1
  467. package/dist/chunk-PHUTP7NB.js +0 -25
  468. package/dist/chunk-PHUTP7NB.js.map +0 -1
  469. package/dist/chunk-PZDTZGSI.js +0 -34
  470. package/dist/chunk-PZDTZGSI.js.map +0 -1
  471. package/dist/chunk-Q2OQXAUM.mjs +0 -35
  472. package/dist/chunk-Q2OQXAUM.mjs.map +0 -1
  473. package/dist/chunk-RAMAN5RM.js +0 -24
  474. package/dist/chunk-RAMAN5RM.js.map +0 -1
  475. package/dist/chunk-RQKT6BQ2.mjs +0 -1
  476. package/dist/chunk-RQKT6BQ2.mjs.map +0 -1
  477. package/dist/chunk-S2HLITUN.js +0 -1
  478. package/dist/chunk-S2HLITUN.js.map +0 -1
  479. package/dist/chunk-SB5EPHE3.js +0 -41
  480. package/dist/chunk-SB5EPHE3.js.map +0 -1
  481. package/dist/chunk-SLU4FNKX.mjs +0 -60
  482. package/dist/chunk-SLU4FNKX.mjs.map +0 -1
  483. package/dist/chunk-SW65QYFV.js +0 -50
  484. package/dist/chunk-SW65QYFV.js.map +0 -1
  485. package/dist/chunk-T2PHS5FY.js +0 -28
  486. package/dist/chunk-T2PHS5FY.js.map +0 -1
  487. package/dist/chunk-TGZ7WOTJ.mjs +0 -1
  488. package/dist/chunk-TGZ7WOTJ.mjs.map +0 -1
  489. package/dist/chunk-TMAWGVZP.mjs +0 -89
  490. package/dist/chunk-TMAWGVZP.mjs.map +0 -1
  491. package/dist/chunk-TZB4LBT7.js +0 -8
  492. package/dist/chunk-TZB4LBT7.js.map +0 -1
  493. package/dist/chunk-UDOXICJK.mjs +0 -1
  494. package/dist/chunk-UDOXICJK.mjs.map +0 -1
  495. package/dist/chunk-VHJZERIC.js +0 -1
  496. package/dist/chunk-VHJZERIC.js.map +0 -1
  497. package/dist/chunk-VOYBI6T4.mjs +0 -22
  498. package/dist/chunk-VOYBI6T4.mjs.map +0 -1
  499. package/dist/chunk-VXPCUDBI.js +0 -36
  500. package/dist/chunk-VXPCUDBI.js.map +0 -1
  501. package/dist/chunk-WDYPMEZB.js +0 -22
  502. package/dist/chunk-WDYPMEZB.js.map +0 -1
  503. package/dist/chunk-WHGYMK5B.js +0 -1
  504. package/dist/chunk-WHGYMK5B.js.map +0 -1
  505. package/dist/chunk-WMLSD6B5.js +0 -54
  506. package/dist/chunk-WMLSD6B5.js.map +0 -1
  507. package/dist/chunk-WRKY2DLV.js +0 -104
  508. package/dist/chunk-WRKY2DLV.js.map +0 -1
  509. package/dist/chunk-XAOCS6ZD.js +0 -69
  510. package/dist/chunk-XAOCS6ZD.js.map +0 -1
  511. package/dist/chunk-XK5HPZZC.mjs +0 -14
  512. package/dist/chunk-XK5HPZZC.mjs.map +0 -1
  513. package/dist/chunk-XKJHFUHE.js +0 -11
  514. package/dist/chunk-XKJHFUHE.js.map +0 -1
  515. package/dist/chunk-XWGECIXI.js +0 -39
  516. package/dist/chunk-XWGECIXI.js.map +0 -1
  517. package/dist/chunk-Y3JC4WGW.js +0 -35
  518. package/dist/chunk-Y3JC4WGW.js.map +0 -1
  519. package/dist/chunk-YNUVT3HC.js +0 -240
  520. package/dist/chunk-YNUVT3HC.js.map +0 -1
  521. package/dist/chunk-ZG33OGC3.mjs +0 -1
  522. package/dist/chunk-ZG33OGC3.mjs.map +0 -1
  523. package/dist/chunk-ZTX624YO.js +0 -1
  524. package/dist/chunk-ZTX624YO.js.map +0 -1
  525. package/dist/environment.js +0 -46
  526. package/dist/environment.js.map +0 -1
  527. package/dist/global.js +0 -2
  528. package/dist/global.js.map +0 -1
  529. package/dist/helpers.js +0 -43
  530. package/dist/helpers.js.map +0 -1
  531. package/dist/index.js +0 -54
  532. package/dist/index.js.map +0 -1
  533. package/dist/internals/environment.js +0 -8
  534. package/dist/internals/environment.js.map +0 -1
  535. package/dist/internals/index.js +0 -142
  536. package/dist/internals/index.js.map +0 -1
  537. package/dist/internals/logger.js +0 -8
  538. package/dist/internals/logger.js.map +0 -1
  539. package/dist/internals/request.js +0 -42
  540. package/dist/internals/request.js.map +0 -1
  541. package/dist/internals/server.js +0 -9
  542. package/dist/internals/server.js.map +0 -1
  543. package/dist/internals/simulation/constants.js +0 -12
  544. package/dist/internals/simulation/constants.js.map +0 -1
  545. package/dist/internals/simulation/controllers.js +0 -25
  546. package/dist/internals/simulation/controllers.js.map +0 -1
  547. package/dist/internals/simulation/files.js +0 -14
  548. package/dist/internals/simulation/files.js.map +0 -1
  549. package/dist/internals/simulation/index.js +0 -103
  550. package/dist/internals/simulation/index.js.map +0 -1
  551. package/dist/internals/simulation/interface.js +0 -31
  552. package/dist/internals/simulation/interface.js.map +0 -1
  553. package/dist/internals/simulation/methods/constants.js +0 -12
  554. package/dist/internals/simulation/methods/constants.js.map +0 -1
  555. package/dist/internals/simulation/methods/hooks/get-locale.js +0 -8
  556. package/dist/internals/simulation/methods/hooks/get-locale.js.map +0 -1
  557. package/dist/internals/simulation/methods/hooks/get-locale.mjs +0 -8
  558. package/dist/internals/simulation/methods/hooks/get-locale.mjs.map +0 -1
  559. package/dist/internals/simulation/methods/hooks/index.js +0 -39
  560. package/dist/internals/simulation/methods/hooks/index.js.map +0 -1
  561. package/dist/internals/simulation/methods/hooks/interface.js +0 -10
  562. package/dist/internals/simulation/methods/hooks/interface.js.map +0 -1
  563. package/dist/internals/simulation/methods/hooks/notifications.js +0 -16
  564. package/dist/internals/simulation/methods/hooks/notifications.js.map +0 -1
  565. package/dist/internals/simulation/methods/hooks/show-dialog.js +0 -14
  566. package/dist/internals/simulation/methods/hooks/show-dialog.js.map +0 -1
  567. package/dist/internals/simulation/methods/hooks/show-dialog.mjs +0 -14
  568. package/dist/internals/simulation/methods/hooks/show-dialog.mjs.map +0 -1
  569. package/dist/internals/simulation/methods/hooks/state.js +0 -18
  570. package/dist/internals/simulation/methods/hooks/state.js.map +0 -1
  571. package/dist/internals/simulation/methods/index.js +0 -28
  572. package/dist/internals/simulation/methods/index.js.map +0 -1
  573. package/dist/internals/simulation/methods/specifications.js +0 -27
  574. package/dist/internals/simulation/methods/specifications.js.map +0 -1
  575. package/dist/internals/simulation/middleware/engine.js +0 -15
  576. package/dist/internals/simulation/middleware/engine.js.map +0 -1
  577. package/dist/internals/simulation/middleware/index.js +0 -16
  578. package/dist/internals/simulation/middleware/index.js.map +0 -1
  579. package/dist/internals/simulation/middleware/internal-methods/accounts.js +0 -8
  580. package/dist/internals/simulation/middleware/internal-methods/accounts.js.map +0 -1
  581. package/dist/internals/simulation/middleware/internal-methods/index.js +0 -11
  582. package/dist/internals/simulation/middleware/internal-methods/index.js.map +0 -1
  583. package/dist/internals/simulation/middleware/internal-methods/middleware.js +0 -10
  584. package/dist/internals/simulation/middleware/internal-methods/middleware.js.map +0 -1
  585. package/dist/internals/simulation/middleware/internal-methods/provider-state.js +0 -8
  586. package/dist/internals/simulation/middleware/internal-methods/provider-state.js.map +0 -1
  587. package/dist/internals/simulation/middleware/mock.js +0 -9
  588. package/dist/internals/simulation/middleware/mock.js.map +0 -1
  589. package/dist/internals/simulation/options.js +0 -9
  590. package/dist/internals/simulation/options.js.map +0 -1
  591. package/dist/internals/simulation/simulation.js +0 -38
  592. package/dist/internals/simulation/simulation.js.map +0 -1
  593. package/dist/internals/simulation/store/index.js +0 -44
  594. package/dist/internals/simulation/store/index.js.map +0 -1
  595. package/dist/internals/simulation/store/mocks.js +0 -16
  596. package/dist/internals/simulation/store/mocks.js.map +0 -1
  597. package/dist/internals/simulation/store/notifications.js +0 -16
  598. package/dist/internals/simulation/store/notifications.js.map +0 -1
  599. package/dist/internals/simulation/store/state.js +0 -14
  600. package/dist/internals/simulation/store/state.js.map +0 -1
  601. package/dist/internals/simulation/store/store.js +0 -12
  602. package/dist/internals/simulation/store/store.js.map +0 -1
  603. package/dist/internals/simulation/store/ui.js +0 -16
  604. package/dist/internals/simulation/store/ui.js.map +0 -1
  605. package/dist/internals/structs.js +0 -22
  606. package/dist/internals/structs.js.map +0 -1
  607. package/dist/matchers.js +0 -51
  608. package/dist/matchers.js.map +0 -1
  609. package/dist/options.js +0 -8
  610. package/dist/options.js.map +0 -1
  611. package/dist/setup.js +0 -38
  612. package/dist/setup.js.map +0 -1
  613. package/dist/tsconfig.build.tsbuildinfo +0 -1
  614. package/dist/types/index.d.ts +0 -5
  615. package/dist/types/internals/index.d.ts +0 -6
  616. package/dist/types/internals/simulation/index.d.ts +0 -5
  617. package/dist/types/internals/simulation/methods/hooks/get-locale.d.ts +0 -9
  618. package/dist/types/internals/simulation/methods/hooks/index.d.ts +0 -5
  619. package/dist/types/internals/simulation/methods/hooks/show-dialog.d.ts +0 -9
  620. package/dist/types/internals/simulation/methods/index.d.ts +0 -1
  621. package/dist/types/internals/simulation/middleware/index.d.ts +0 -1
  622. package/dist/types/internals/simulation/middleware/internal-methods/index.d.ts +0 -1
  623. package/dist/types/internals/simulation/store/index.d.ts +0 -4
  624. package/dist/types/setup.d.ts +0 -1
  625. package/dist/types/vendor/readable-stream.d.js +0 -1
  626. package/dist/types/vendor/readable-stream.d.js.map +0 -1
  627. package/dist/types/vendor/readable-stream.d.mjs +0 -1
  628. package/dist/types/vendor/readable-stream.d.mjs.map +0 -1
  629. package/dist/types.js +0 -2
  630. package/dist/types.js.map +0 -1
  631. package/dist/types.mjs +0 -2
  632. package/dist/types.mjs.map +0 -1
@@ -1,134 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunkXWGECIXIjs = require('./chunk-XWGECIXI.js');
4
-
5
-
6
- var _chunkSW65QYFVjs = require('./chunk-SW65QYFV.js');
7
-
8
-
9
- var _chunkVXPCUDBIjs = require('./chunk-VXPCUDBI.js');
10
-
11
-
12
-
13
- var _chunk44ARQBXSjs = require('./chunk-44ARQBXS.js');
14
-
15
-
16
- var _chunkMBQHVBLAjs = require('./chunk-MBQHVBLA.js');
17
-
18
-
19
- var _chunkWMLSD6B5js = require('./chunk-WMLSD6B5.js');
20
-
21
- // src/internals/simulation/simulation.ts
22
- var _basecontroller = require('@metamask/base-controller');
23
- var _jsonrpcmiddlewarestream = require('@metamask/json-rpc-middleware-stream');
24
- var _keytree = require('@metamask/key-tree');
25
-
26
-
27
-
28
-
29
-
30
- var _node = require('@metamask/snaps-controllers/node');
31
- var _snapsutils = require('@metamask/snaps-utils');
32
- var _readablestream = require('readable-stream');
33
- async function handleInstallSnap(snapId, {
34
- executionService,
35
- executionServiceOptions,
36
- options: rawOptions = {}
37
- } = {}) {
38
- const options = _chunkVXPCUDBIjs.getOptions.call(void 0, rawOptions);
39
- const location = _node.detectSnapLocation.call(void 0, snapId, {
40
- allowLocal: true
41
- });
42
- const snapFiles = await _node.fetchSnap.call(void 0, snapId, location);
43
- const { store, runSaga } = _chunkWMLSD6B5js.createStore.call(void 0, options);
44
- const controllerMessenger = new (0, _basecontroller.ControllerMessenger)();
45
- registerActions(controllerMessenger);
46
- const hooks = getHooks(options, snapFiles, snapId, controllerMessenger);
47
- const { subjectMetadataController, permissionController } = _chunk44ARQBXSjs.getControllers.call(void 0, {
48
- controllerMessenger,
49
- hooks,
50
- runSaga,
51
- options
52
- });
53
- const engine = _chunkXWGECIXIjs.createJsonRpcEngine.call(void 0, {
54
- store,
55
- hooks,
56
- permissionMiddleware: permissionController.createPermissionMiddleware({
57
- origin: snapId
58
- })
59
- });
60
- const ExecutionService = executionService ?? _node.NodeThreadExecutionService;
61
- const service = new ExecutionService({
62
- ...executionServiceOptions,
63
- messenger: controllerMessenger.getRestricted({
64
- name: "ExecutionService",
65
- allowedActions: [],
66
- allowedEvents: []
67
- }),
68
- setupSnapProvider: (_snapId, rpcStream) => {
69
- const mux = _node.setupMultiplex.call(void 0, rpcStream, "snapStream");
70
- const stream = mux.createStream("metamask-provider");
71
- const providerStream = _jsonrpcmiddlewarestream.createEngineStream.call(void 0, { engine });
72
- _readablestream.pipeline.call(void 0, stream, providerStream, stream, (error) => {
73
- if (error) {
74
- _snapsutils.logError.call(void 0, `Provider stream failure.`, error);
75
- }
76
- });
77
- }
78
- });
79
- await _chunk44ARQBXSjs.registerSnap.call(void 0, snapId, snapFiles.manifest.result, {
80
- permissionController,
81
- subjectMetadataController
82
- });
83
- await service.executeSnap({
84
- snapId,
85
- sourceCode: snapFiles.sourceCode.toString("utf8"),
86
- endowments: await _chunkMBQHVBLAjs.getEndowments.call(void 0, permissionController, snapId)
87
- });
88
- return {
89
- snapId,
90
- store,
91
- executionService: service,
92
- controllerMessenger,
93
- runSaga
94
- };
95
- }
96
- function getHooks(options, snapFiles, snapId, controllerMessenger) {
97
- return {
98
- getMnemonic: async () => Promise.resolve(_keytree.mnemonicPhraseToBytes.call(void 0, options.secretRecoveryPhrase)),
99
- getSnapFile: async (path, encoding) => await _chunkSW65QYFVjs.getSnapFile.call(void 0, snapFiles.auxiliaryFiles, path, encoding),
100
- getIsLocked: () => false,
101
- createInterface: async (...args) => controllerMessenger.call(
102
- "SnapInterfaceController:createInterface",
103
- snapId,
104
- ...args
105
- ),
106
- updateInterface: async (...args) => controllerMessenger.call(
107
- "SnapInterfaceController:updateInterface",
108
- snapId,
109
- ...args
110
- ),
111
- getInterfaceState: (...args) => controllerMessenger.call(
112
- "SnapInterfaceController:getInterface",
113
- snapId,
114
- ...args
115
- ).state
116
- };
117
- }
118
- function registerActions(controllerMessenger) {
119
- controllerMessenger.registerActionHandler(
120
- "PhishingController:maybeUpdateState",
121
- async () => Promise.resolve()
122
- );
123
- controllerMessenger.registerActionHandler(
124
- "PhishingController:testOrigin",
125
- () => ({ result: false, type: "all" })
126
- );
127
- }
128
-
129
-
130
-
131
-
132
-
133
- exports.handleInstallSnap = handleInstallSnap; exports.getHooks = getHooks; exports.registerActions = registerActions;
134
- //# sourceMappingURL=chunk-DVDAOXO7.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/internals/simulation/simulation.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AAIA,SAAS,2BAA2B;AACpC,SAAS,0BAA0B;AACnC,SAAS,6BAA6B;AAEtC;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAQP,SAAS,gBAAgB;AAEzB,SAAS,gBAAgB;AAyGzB,eAAsB,kBAKpB,QACA;AAAA,EACE;AAAA,EACA;AAAA,EACA,SAAS,aAAa,CAAC;AACzB,IAA0C,CAAC,GACnB;AACxB,QAAM,UAAU,WAAW,UAAU;AAGrC,QAAM,WAAW,mBAAmB,QAAQ;AAAA,IAC1C,YAAY;AAAA,EACd,CAAC;AAED,QAAM,YAAY,MAAM,UAAU,QAAQ,QAAQ;AAGlD,QAAM,EAAE,OAAO,QAAQ,IAAI,YAAY,OAAO;AAE9C,QAAM,sBAAsB,IAAI,oBAA8B;AAE9D,kBAAgB,mBAAmB;AAGnC,QAAM,QAAQ,SAAS,SAAS,WAAW,QAAQ,mBAAmB;AAEtE,QAAM,EAAE,2BAA2B,qBAAqB,IAAI,eAAe;AAAA,IACzE;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAED,QAAM,SAAS,oBAAoB;AAAA,IACjC;AAAA,IACA;AAAA,IACA,sBAAsB,qBAAqB,2BAA2B;AAAA,MACpE,QAAQ;AAAA,IACV,CAAC;AAAA,EACH,CAAC;AAGD,QAAM,mBAAmB,oBAAoB;AAC7C,QAAM,UAAU,IAAI,iBAAiB;AAAA,IACnC,GAAG;AAAA,IACH,WAAW,oBAAoB,cAAc;AAAA,MAC3C,MAAM;AAAA,MACN,gBAAgB,CAAC;AAAA,MACjB,eAAe,CAAC;AAAA,IAClB,CAAC;AAAA,IACD,mBAAmB,CAAC,SAAiB,cAAsB;AACzD,YAAM,MAAM,eAAe,WAAW,YAAY;AAClD,YAAM,SAAS,IAAI,aAAa,mBAAmB;AACnD,YAAM,iBAAiB,mBAAmB,EAAE,OAAO,CAAC;AAIpD,eAAS,QAAQ,gBAAgB,QAAQ,CAAC,UAAmB;AAC3D,YAAI,OAAO;AACT,mBAAS,4BAA4B,KAAK;AAAA,QAC5C;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF,CAAC;AAID,QAAM,aAAa,QAAQ,UAAU,SAAS,QAAQ;AAAA,IACpD;AAAA,IACA;AAAA,EACF,CAAC;AAGD,QAAM,QAAQ,YAAY;AAAA,IACxB;AAAA,IACA,YAAY,UAAU,WAAW,SAAS,MAAM;AAAA,IAChD,YAAY,MAAM,cAAc,sBAAsB,MAAM;AAAA,EAC9D,CAAC;AAED,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA,kBAAkB;AAAA,IAClB;AAAA,IACA;AAAA,EACF;AACF;AAWO,SAAS,SACd,SACA,WACA,QACA,qBACiB;AACjB,SAAO;AAAA,IACL,aAAa,YACX,QAAQ,QAAQ,sBAAsB,QAAQ,oBAAoB,CAAC;AAAA,IACrE,aAAa,OAAO,MAAc,aAChC,MAAM,YAAY,UAAU,gBAAgB,MAAM,QAAQ;AAAA,IAC5D,aAAa,MAAM;AAAA,IACnB,iBAAiB,UAAU,SACzB,oBAAoB;AAAA,MAClB;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IACL;AAAA,IACF,iBAAiB,UAAU,SACzB,oBAAoB;AAAA,MAClB;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IACL;AAAA,IACF,mBAAmB,IAAI,SACrB,oBAAoB;AAAA,MAClB;AAAA,MACA;AAAA,MACA,GAAG;AAAA,IACL,EAAE;AAAA,EACN;AACF;AAOO,SAAS,gBAAgB,qBAA8C;AAC5E,sBAAoB;AAAA,IAClB;AAAA,IACA,YAAY,QAAQ,QAAQ;AAAA,EAC9B;AAEA,sBAAoB;AAAA,IAClB;AAAA,IACA,OAAO,EAAE,QAAQ,OAAO,MAAM,MAAM;AAAA,EACtC;AACF","sourcesContent":["import type {\n ActionConstraint,\n EventConstraint,\n} from '@metamask/base-controller';\nimport { ControllerMessenger } from '@metamask/base-controller';\nimport { createEngineStream } from '@metamask/json-rpc-middleware-stream';\nimport { mnemonicPhraseToBytes } from '@metamask/key-tree';\nimport type { AbstractExecutionService } from '@metamask/snaps-controllers';\nimport {\n fetchSnap,\n detectSnapLocation,\n NodeThreadExecutionService,\n setupMultiplex,\n} from '@metamask/snaps-controllers/node';\nimport type {\n SnapId,\n AuxiliaryFileEncoding,\n Component,\n InterfaceState,\n} from '@metamask/snaps-sdk';\nimport type { FetchedSnapFiles } from '@metamask/snaps-utils';\nimport { logError } from '@metamask/snaps-utils';\nimport type { Duplex } from 'readable-stream';\nimport { pipeline } from 'readable-stream';\n\nimport type { RootControllerMessenger } from './controllers';\nimport { getControllers, registerSnap } from './controllers';\nimport { getSnapFile } from './files';\nimport { getEndowments } from './methods';\nimport { createJsonRpcEngine } from './middleware';\nimport type { SimulationOptions, SimulationUserOptions } from './options';\nimport { getOptions } from './options';\nimport type { RunSagaFunction, Store } from './store';\nimport { createStore } from './store';\n\n/**\n * Options for the execution service, without the options that are shared\n * between all execution services.\n *\n * @template Service - The type of the execution service, i.e., the class that\n * creates the execution service.\n */\nexport type ExecutionServiceOptions<\n Service extends new (...args: any[]) => any,\n> = Omit<\n ConstructorParameters<Service>[0],\n keyof ConstructorParameters<typeof AbstractExecutionService<unknown>>[0]\n>;\n\n/**\n * The options for running a Snap in a simulated environment.\n *\n * @property executionService - The execution service to use.\n * @property executionServiceOptions - The options to use when creating the\n * execution service, if any. This should only include options specific to the\n * provided execution service.\n * @property options - The simulation options.\n * @template Service - The type of the execution service.\n */\nexport type InstallSnapOptions<\n Service extends new (...args: any[]) => InstanceType<\n typeof AbstractExecutionService<unknown>\n >,\n> = ExecutionServiceOptions<Service> extends Record<string, never>\n ? {\n executionService: Service;\n executionServiceOptions?: ExecutionServiceOptions<Service>;\n options?: SimulationUserOptions;\n }\n : {\n executionService: Service;\n executionServiceOptions: ExecutionServiceOptions<Service>;\n options?: SimulationUserOptions;\n };\n\nexport type InstalledSnap = {\n snapId: SnapId;\n store: Store;\n executionService: InstanceType<typeof AbstractExecutionService>;\n controllerMessenger: ControllerMessenger<ActionConstraint, EventConstraint>;\n runSaga: RunSagaFunction;\n};\n\nexport type MiddlewareHooks = {\n /**\n * A hook that returns the user's secret recovery phrase.\n *\n * @returns The user's secret recovery phrase.\n */\n getMnemonic: () => Promise<Uint8Array>;\n\n /**\n * A hook that returns the Snap's auxiliary file for the given path.\n *\n * @param path - The path of the auxiliary file to get.\n * @param encoding - The encoding to use when returning the file.\n * @returns The Snap's auxiliary file for the given path.\n */\n getSnapFile: (\n path: string,\n encoding: AuxiliaryFileEncoding,\n ) => Promise<string | null>;\n\n /**\n * A hook that returns whether the client is locked or not.\n *\n * @returns A boolean flag signaling whether the client is locked.\n */\n getIsLocked: () => boolean;\n createInterface: (content: Component) => Promise<string>;\n updateInterface: (id: string, content: Component) => Promise<void>;\n getInterfaceState: (id: string) => InterfaceState;\n};\n\n/**\n * Install a Snap in a simulated environment. This will fetch the Snap files,\n * create a Redux store, set up the controllers and JSON-RPC stack, register the\n * Snap, and run the Snap code in the execution service.\n *\n * @param snapId - The ID of the Snap to install.\n * @param options - The options to use when installing the Snap.\n * @param options.executionService - The execution service to use.\n * @param options.executionServiceOptions - The options to use when creating the\n * execution service, if any. This should only include options specific to the\n * provided execution service.\n * @param options.options - The simulation options.\n * @template Service - The type of the execution service.\n */\nexport async function handleInstallSnap<\n Service extends new (...args: any[]) => InstanceType<\n typeof AbstractExecutionService\n >,\n>(\n snapId: SnapId,\n {\n executionService,\n executionServiceOptions,\n options: rawOptions = {},\n }: Partial<InstallSnapOptions<Service>> = {},\n): Promise<InstalledSnap> {\n const options = getOptions(rawOptions);\n\n // Fetch Snap files.\n const location = detectSnapLocation(snapId, {\n allowLocal: true,\n });\n\n const snapFiles = await fetchSnap(snapId, location);\n\n // Create Redux store.\n const { store, runSaga } = createStore(options);\n\n const controllerMessenger = new ControllerMessenger<any, any>();\n\n registerActions(controllerMessenger);\n\n // Set up controllers and JSON-RPC stack.\n const hooks = getHooks(options, snapFiles, snapId, controllerMessenger);\n\n const { subjectMetadataController, permissionController } = getControllers({\n controllerMessenger,\n hooks,\n runSaga,\n options,\n });\n\n const engine = createJsonRpcEngine({\n store,\n hooks,\n permissionMiddleware: permissionController.createPermissionMiddleware({\n origin: snapId,\n }),\n });\n\n // Create execution service.\n const ExecutionService = executionService ?? NodeThreadExecutionService;\n const service = new ExecutionService({\n ...executionServiceOptions,\n messenger: controllerMessenger.getRestricted({\n name: 'ExecutionService',\n allowedActions: [],\n allowedEvents: [],\n }),\n setupSnapProvider: (_snapId: string, rpcStream: Duplex) => {\n const mux = setupMultiplex(rpcStream, 'snapStream');\n const stream = mux.createStream('metamask-provider');\n const providerStream = createEngineStream({ engine });\n\n // Error function is difficult to test, so we ignore it.\n /* istanbul ignore next 2 */\n pipeline(stream, providerStream, stream, (error: unknown) => {\n if (error) {\n logError(`Provider stream failure.`, error);\n }\n });\n },\n });\n\n // Register the Snap. This sets up the Snap's permissions and subject\n // metadata.\n await registerSnap(snapId, snapFiles.manifest.result, {\n permissionController,\n subjectMetadataController,\n });\n\n // Run the Snap code in the execution service.\n await service.executeSnap({\n snapId,\n sourceCode: snapFiles.sourceCode.toString('utf8'),\n endowments: await getEndowments(permissionController, snapId),\n });\n\n return {\n snapId,\n store,\n executionService: service,\n controllerMessenger,\n runSaga,\n };\n}\n\n/**\n * Get the hooks for the simulation.\n *\n * @param options - The simulation options.\n * @param snapFiles - The Snap files.\n * @param snapId - The Snap ID.\n * @param controllerMessenger - The controller messenger.\n * @returns The hooks for the simulation.\n */\nexport function getHooks(\n options: SimulationOptions,\n snapFiles: FetchedSnapFiles,\n snapId: SnapId,\n controllerMessenger: RootControllerMessenger,\n): MiddlewareHooks {\n return {\n getMnemonic: async () =>\n Promise.resolve(mnemonicPhraseToBytes(options.secretRecoveryPhrase)),\n getSnapFile: async (path: string, encoding: AuxiliaryFileEncoding) =>\n await getSnapFile(snapFiles.auxiliaryFiles, path, encoding),\n getIsLocked: () => false,\n createInterface: async (...args) =>\n controllerMessenger.call(\n 'SnapInterfaceController:createInterface',\n snapId,\n ...args,\n ),\n updateInterface: async (...args) =>\n controllerMessenger.call(\n 'SnapInterfaceController:updateInterface',\n snapId,\n ...args,\n ),\n getInterfaceState: (...args) =>\n controllerMessenger.call(\n 'SnapInterfaceController:getInterface',\n snapId,\n ...args,\n ).state,\n };\n}\n\n/**\n * Register mocked action handlers.\n *\n * @param controllerMessenger - The controller messenger.\n */\nexport function registerActions(controllerMessenger: RootControllerMessenger) {\n controllerMessenger.registerActionHandler(\n 'PhishingController:maybeUpdateState',\n async () => Promise.resolve(),\n );\n\n controllerMessenger.registerActionHandler(\n 'PhishingController:testOrigin',\n () => ({ result: false, type: 'all' }),\n );\n}\n"]}
@@ -1,20 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunkLACTK6EOjs = require('./chunk-LACTK6EO.js');
4
-
5
- // src/internals/simulation/middleware/mock.ts
6
- function createMockMiddleware(store) {
7
- return function mockMiddleware(request, response, next, end) {
8
- const result = _chunkLACTK6EOjs.getJsonRpcMock.call(void 0, store.getState(), request.method);
9
- if (result) {
10
- response.result = result;
11
- return end();
12
- }
13
- return next();
14
- };
15
- }
16
-
17
-
18
-
19
- exports.createMockMiddleware = createMockMiddleware;
20
- //# sourceMappingURL=chunk-EMTW3H54.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/internals/simulation/middleware/mock.ts"],"names":[],"mappings":";;;;;AAYO,SAAS,qBACd,OACwC;AACxC,SAAO,SAAS,eAAe,SAAS,UAAU,MAAM,KAAK;AAC3D,UAAM,SAAS,eAAe,MAAM,SAAS,GAAG,QAAQ,MAAM;AAC9D,QAAI,QAAQ;AACV,eAAS,SAAS;AAClB,aAAO,IAAI;AAAA,IACb;AAEA,WAAO,KAAK;AAAA,EACd;AACF","sourcesContent":["import type { JsonRpcMiddleware } from '@metamask/json-rpc-engine';\nimport type { Json, JsonRpcParams } from '@metamask/utils';\n\nimport type { Store } from '../store';\nimport { getJsonRpcMock } from '../store/mocks';\n\n/**\n * Create a middleware for handling JSON-RPC methods that have been mocked.\n *\n * @param store - The Redux store to use.\n * @returns A middleware function.\n */\nexport function createMockMiddleware(\n store: Store,\n): JsonRpcMiddleware<JsonRpcParams, Json> {\n return function mockMiddleware(request, response, next, end) {\n const result = getJsonRpcMock(store.getState(), request.method);\n if (result) {\n response.result = result;\n return end();\n }\n\n return next();\n };\n}\n"]}
@@ -1,20 +0,0 @@
1
- import {
2
- getJsonRpcMock
3
- } from "./chunk-H2464AXT.mjs";
4
-
5
- // src/internals/simulation/middleware/mock.ts
6
- function createMockMiddleware(store) {
7
- return function mockMiddleware(request, response, next, end) {
8
- const result = getJsonRpcMock(store.getState(), request.method);
9
- if (result) {
10
- response.result = result;
11
- return end();
12
- }
13
- return next();
14
- };
15
- }
16
-
17
- export {
18
- createMockMiddleware
19
- };
20
- //# sourceMappingURL=chunk-FP4H3ADT.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/internals/simulation/middleware/mock.ts"],"sourcesContent":["import type { JsonRpcMiddleware } from '@metamask/json-rpc-engine';\nimport type { Json, JsonRpcParams } from '@metamask/utils';\n\nimport type { Store } from '../store';\nimport { getJsonRpcMock } from '../store/mocks';\n\n/**\n * Create a middleware for handling JSON-RPC methods that have been mocked.\n *\n * @param store - The Redux store to use.\n * @returns A middleware function.\n */\nexport function createMockMiddleware(\n store: Store,\n): JsonRpcMiddleware<JsonRpcParams, Json> {\n return function mockMiddleware(request, response, next, end) {\n const result = getJsonRpcMock(store.getState(), request.method);\n if (result) {\n response.result = result;\n return end();\n }\n\n return next();\n };\n}\n"],"mappings":";;;;;AAYO,SAAS,qBACd,OACwC;AACxC,SAAO,SAAS,eAAe,SAAS,UAAU,MAAM,KAAK;AAC3D,UAAM,SAAS,eAAe,MAAM,SAAS,GAAG,QAAQ,MAAM;AAC9D,QAAI,QAAQ;AACV,eAAS,SAAS;AAClB,aAAO,IAAI;AAAA,IACb;AAEA,WAAO,KAAK;AAAA,EACd;AACF;","names":[]}
@@ -1,22 +0,0 @@
1
- // src/internals/simulation/methods/hooks/interface.ts
2
- function getCreateInterfaceImplementation(controllerMessenger) {
3
- return async (snapId, content, context) => controllerMessenger.call(
4
- "SnapInterfaceController:createInterface",
5
- snapId,
6
- content,
7
- context
8
- );
9
- }
10
- function getGetInterfaceImplementation(controllerMessenger) {
11
- return (snapId, id) => controllerMessenger.call(
12
- "SnapInterfaceController:getInterface",
13
- snapId,
14
- id
15
- );
16
- }
17
-
18
- export {
19
- getCreateInterfaceImplementation,
20
- getGetInterfaceImplementation
21
- };
22
- //# sourceMappingURL=chunk-FQWOVTBB.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/internals/simulation/methods/hooks/interface.ts"],"sourcesContent":["import type { Component, InterfaceContext, SnapId } from '@metamask/snaps-sdk';\n\nimport type { RootControllerMessenger } from '../../controllers';\n\n/**\n * Get the implementation of the `createInterface` hook.\n *\n * @param controllerMessenger - The controller messenger used to call actions.\n * @returns The implementation of the `createInterface` hook.\n */\nexport function getCreateInterfaceImplementation(\n controllerMessenger: RootControllerMessenger,\n) {\n return async (\n snapId: SnapId,\n content: Component,\n context?: InterfaceContext,\n ) =>\n controllerMessenger.call(\n 'SnapInterfaceController:createInterface',\n snapId,\n content,\n context,\n );\n}\n\n/**\n * Get the implementation of the `getInterface` hook.\n *\n * @param controllerMessenger - The controller messenger used to call actions.\n * @returns The implementation of the `getInterface` hook.\n */\nexport function getGetInterfaceImplementation(\n controllerMessenger: RootControllerMessenger,\n) {\n return (snapId: SnapId, id: string) =>\n controllerMessenger.call(\n 'SnapInterfaceController:getInterface',\n snapId,\n id,\n );\n}\n"],"mappings":";AAUO,SAAS,iCACd,qBACA;AACA,SAAO,OACL,QACA,SACA,YAEA,oBAAoB;AAAA,IAClB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACJ;AAQO,SAAS,8BACd,qBACA;AACA,SAAO,CAAC,QAAgB,OACtB,oBAAoB;AAAA,IAClB;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACJ;","names":[]}
@@ -1 +0,0 @@
1
- "use strict";//# sourceMappingURL=chunk-GECE47HW.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"names":[],"mappings":""}
@@ -1,95 +0,0 @@
1
- import {
2
- getPermissionSpecifications
3
- } from "./chunk-TMAWGVZP.mjs";
4
- import {
5
- UNRESTRICTED_METHODS
6
- } from "./chunk-57SGDM5B.mjs";
7
-
8
- // src/internals/simulation/controllers.ts
9
- import {
10
- PermissionController,
11
- SubjectMetadataController,
12
- SubjectType
13
- } from "@metamask/permission-controller";
14
- import { SnapInterfaceController } from "@metamask/snaps-controllers";
15
- import {
16
- caveatSpecifications as snapsCaveatsSpecifications,
17
- endowmentCaveatSpecifications as snapsEndowmentCaveatSpecifications,
18
- processSnapPermissions
19
- } from "@metamask/snaps-rpc-methods";
20
- import { getSafeJson } from "@metamask/utils";
21
- function getControllers(options) {
22
- const { controllerMessenger } = options;
23
- const subjectMetadataController = new SubjectMetadataController({
24
- messenger: controllerMessenger.getRestricted({
25
- name: "SubjectMetadataController",
26
- allowedActions: [],
27
- allowedEvents: []
28
- }),
29
- subjectCacheLimit: 100
30
- });
31
- const interfaceController = new SnapInterfaceController({
32
- messenger: controllerMessenger.getRestricted({
33
- name: "SnapInterfaceController",
34
- allowedActions: [
35
- "PhishingController:maybeUpdateState",
36
- "PhishingController:testOrigin"
37
- ],
38
- allowedEvents: []
39
- })
40
- });
41
- const permissionController = getPermissionController(options);
42
- return {
43
- permissionController,
44
- subjectMetadataController,
45
- interfaceController
46
- };
47
- }
48
- function getPermissionController(options) {
49
- const { controllerMessenger } = options;
50
- const permissionSpecifications = getPermissionSpecifications(options);
51
- return new PermissionController({
52
- messenger: controllerMessenger.getRestricted({
53
- name: "PermissionController",
54
- allowedActions: [
55
- `ApprovalController:addRequest`,
56
- `ApprovalController:hasRequest`,
57
- `ApprovalController:acceptRequest`,
58
- `ApprovalController:rejectRequest`,
59
- `SnapController:getPermitted`,
60
- `SnapController:install`,
61
- `SubjectMetadataController:getSubjectMetadata`
62
- ],
63
- allowedEvents: []
64
- }),
65
- caveatSpecifications: {
66
- ...snapsCaveatsSpecifications,
67
- ...snapsEndowmentCaveatSpecifications
68
- },
69
- permissionSpecifications,
70
- unrestrictedMethods: UNRESTRICTED_METHODS
71
- });
72
- }
73
- async function registerSnap(snapId, manifest, {
74
- permissionController,
75
- subjectMetadataController
76
- }) {
77
- subjectMetadataController.addSubjectMetadata({
78
- origin: snapId,
79
- subjectType: SubjectType.Snap
80
- });
81
- const approvedPermissions = processSnapPermissions(
82
- getSafeJson(manifest.initialPermissions)
83
- );
84
- permissionController.grantPermissions({
85
- approvedPermissions,
86
- subject: { origin: snapId },
87
- preserveExistingPermissions: false
88
- });
89
- }
90
-
91
- export {
92
- getControllers,
93
- registerSnap
94
- };
95
- //# sourceMappingURL=chunk-GG2BCPQH.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/internals/simulation/controllers.ts"],"sourcesContent":["import type { ControllerMessenger } from '@metamask/base-controller';\nimport type {\n CaveatSpecificationConstraint,\n PermissionSpecificationConstraint,\n PermissionControllerActions,\n SubjectMetadataControllerActions,\n} from '@metamask/permission-controller';\nimport {\n PermissionController,\n SubjectMetadataController,\n SubjectType,\n} from '@metamask/permission-controller';\nimport { SnapInterfaceController } from '@metamask/snaps-controllers';\nimport type {\n ExecutionServiceActions,\n SnapInterfaceControllerActions,\n SnapInterfaceControllerAllowedActions,\n} from '@metamask/snaps-controllers';\nimport {\n caveatSpecifications as snapsCaveatsSpecifications,\n endowmentCaveatSpecifications as snapsEndowmentCaveatSpecifications,\n processSnapPermissions,\n} from '@metamask/snaps-rpc-methods';\nimport type { SnapId } from '@metamask/snaps-sdk';\nimport type { SnapManifest } from '@metamask/snaps-utils';\nimport { getSafeJson } from '@metamask/utils';\n\nimport { getPermissionSpecifications } from './methods';\nimport { UNRESTRICTED_METHODS } from './methods/constants';\nimport type { SimulationOptions } from './options';\nimport type { MiddlewareHooks } from './simulation';\nimport type { RunSagaFunction } from './store';\n\nexport type RootControllerAllowedActions =\n | SnapInterfaceControllerActions\n | SnapInterfaceControllerAllowedActions\n | PermissionControllerActions\n | ExecutionServiceActions\n | SubjectMetadataControllerActions;\n\nexport type RootControllerMessenger = ControllerMessenger<\n RootControllerAllowedActions,\n any\n>;\n\nexport type GetControllersOptions = {\n controllerMessenger: ControllerMessenger<any, any>;\n hooks: MiddlewareHooks;\n runSaga: RunSagaFunction;\n options: SimulationOptions;\n};\n\nexport type Controllers = {\n permissionController: PermissionController<\n PermissionSpecificationConstraint,\n CaveatSpecificationConstraint\n >;\n subjectMetadataController: SubjectMetadataController;\n interfaceController: SnapInterfaceController;\n};\n\n/**\n * Get the controllers for the Snap.\n *\n * @param options - The options.\n * @returns The controllers for the Snap.\n */\nexport function getControllers(options: GetControllersOptions): Controllers {\n const { controllerMessenger } = options;\n const subjectMetadataController = new SubjectMetadataController({\n messenger: controllerMessenger.getRestricted({\n name: 'SubjectMetadataController',\n allowedActions: [],\n allowedEvents: [],\n }),\n subjectCacheLimit: 100,\n });\n\n const interfaceController = new SnapInterfaceController({\n messenger: controllerMessenger.getRestricted({\n name: 'SnapInterfaceController',\n allowedActions: [\n 'PhishingController:maybeUpdateState',\n 'PhishingController:testOrigin',\n ],\n allowedEvents: [],\n }),\n });\n\n const permissionController = getPermissionController(options);\n\n return {\n permissionController,\n subjectMetadataController,\n interfaceController,\n };\n}\n\n/**\n * Get the permission controller for the Snap.\n *\n * @param options - The options.\n * @param options.controllerMessenger - The controller messenger.\n * @param options.options - Miscellaneous options.\n * @returns The permission controller for the Snap.\n */\nfunction getPermissionController(options: GetControllersOptions) {\n const { controllerMessenger } = options;\n const permissionSpecifications = getPermissionSpecifications(options);\n return new PermissionController({\n messenger: controllerMessenger.getRestricted({\n name: 'PermissionController',\n allowedActions: [\n `ApprovalController:addRequest`,\n `ApprovalController:hasRequest`,\n `ApprovalController:acceptRequest`,\n `ApprovalController:rejectRequest`,\n `SnapController:getPermitted`,\n `SnapController:install`,\n `SubjectMetadataController:getSubjectMetadata`,\n ],\n allowedEvents: [],\n }),\n caveatSpecifications: {\n ...snapsCaveatsSpecifications,\n ...snapsEndowmentCaveatSpecifications,\n },\n permissionSpecifications,\n unrestrictedMethods: UNRESTRICTED_METHODS,\n });\n}\n\n/**\n * Register the Snap. This sets up the Snap's permissions and subject metadata.\n *\n * @param snapId - The ID of the Snap to install.\n * @param manifest - The parsed manifest.\n * @param controllers - The controllers for the Snap.\n * @param controllers.permissionController - The permission controller.\n * @param controllers.subjectMetadataController - The subject metadata controller.\n */\nexport async function registerSnap(\n snapId: SnapId,\n manifest: SnapManifest,\n {\n permissionController,\n subjectMetadataController,\n }: Omit<Controllers, 'interfaceController'>,\n) {\n subjectMetadataController.addSubjectMetadata({\n origin: snapId,\n subjectType: SubjectType.Snap,\n });\n\n const approvedPermissions = processSnapPermissions(\n getSafeJson(manifest.initialPermissions),\n );\n\n permissionController.grantPermissions({\n approvedPermissions,\n subject: { origin: snapId },\n preserveExistingPermissions: false,\n });\n}\n"],"mappings":";;;;;;;;AAOA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,+BAA+B;AAMxC;AAAA,EACE,wBAAwB;AAAA,EACxB,iCAAiC;AAAA,EACjC;AAAA,OACK;AAGP,SAAS,mBAAmB;AA0CrB,SAAS,eAAe,SAA6C;AAC1E,QAAM,EAAE,oBAAoB,IAAI;AAChC,QAAM,4BAA4B,IAAI,0BAA0B;AAAA,IAC9D,WAAW,oBAAoB,cAAc;AAAA,MAC3C,MAAM;AAAA,MACN,gBAAgB,CAAC;AAAA,MACjB,eAAe,CAAC;AAAA,IAClB,CAAC;AAAA,IACD,mBAAmB;AAAA,EACrB,CAAC;AAED,QAAM,sBAAsB,IAAI,wBAAwB;AAAA,IACtD,WAAW,oBAAoB,cAAc;AAAA,MAC3C,MAAM;AAAA,MACN,gBAAgB;AAAA,QACd;AAAA,QACA;AAAA,MACF;AAAA,MACA,eAAe,CAAC;AAAA,IAClB,CAAC;AAAA,EACH,CAAC;AAED,QAAM,uBAAuB,wBAAwB,OAAO;AAE5D,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;AAUA,SAAS,wBAAwB,SAAgC;AAC/D,QAAM,EAAE,oBAAoB,IAAI;AAChC,QAAM,2BAA2B,4BAA4B,OAAO;AACpE,SAAO,IAAI,qBAAqB;AAAA,IAC9B,WAAW,oBAAoB,cAAc;AAAA,MAC3C,MAAM;AAAA,MACN,gBAAgB;AAAA,QACd;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACF;AAAA,MACA,eAAe,CAAC;AAAA,IAClB,CAAC;AAAA,IACD,sBAAsB;AAAA,MACpB,GAAG;AAAA,MACH,GAAG;AAAA,IACL;AAAA,IACA;AAAA,IACA,qBAAqB;AAAA,EACvB,CAAC;AACH;AAWA,eAAsB,aACpB,QACA,UACA;AAAA,EACE;AAAA,EACA;AACF,GACA;AACA,4BAA0B,mBAAmB;AAAA,IAC3C,QAAQ;AAAA,IACR,aAAa,YAAY;AAAA,EAC3B,CAAC;AAED,QAAM,sBAAsB;AAAA,IAC1B,YAAY,SAAS,kBAAkB;AAAA,EACzC;AAEA,uBAAqB,iBAAiB;AAAA,IACpC;AAAA,IACA,SAAS,EAAE,QAAQ,OAAO;AAAA,IAC1B,6BAA6B;AAAA,EAC/B,CAAC;AACH;","names":[]}
@@ -1,42 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunk2YE2P5BZjs = require('./chunk-2YE2P5BZ.js');
4
-
5
- // src/internals/simulation/methods/hooks/notifications.ts
6
- var _snapssdk = require('@metamask/snaps-sdk');
7
- var _toolkit = require('@reduxjs/toolkit');
8
- var _effects = require('redux-saga/effects');
9
- function* showNativeNotificationImplementation(_snapId, { message }) {
10
- yield _effects.put.call(void 0,
11
- _chunk2YE2P5BZjs.addNotification.call(void 0, { id: _toolkit.nanoid.call(void 0, ), type: _snapssdk.NotificationType.Native, message })
12
- );
13
- return null;
14
- }
15
- function getShowNativeNotificationImplementation(runSaga) {
16
- return async (...args) => {
17
- return await runSaga(
18
- showNativeNotificationImplementation,
19
- ...args
20
- ).toPromise();
21
- };
22
- }
23
- function* showInAppNotificationImplementation(_snapId, { message }) {
24
- yield _effects.put.call(void 0,
25
- _chunk2YE2P5BZjs.addNotification.call(void 0, { id: _toolkit.nanoid.call(void 0, ), type: _snapssdk.NotificationType.InApp, message })
26
- );
27
- return null;
28
- }
29
- function getShowInAppNotificationImplementation(runSaga) {
30
- return async (...args) => {
31
- return await runSaga(
32
- showInAppNotificationImplementation,
33
- ...args
34
- ).toPromise();
35
- };
36
- }
37
-
38
-
39
-
40
-
41
- exports.getShowNativeNotificationImplementation = getShowNativeNotificationImplementation; exports.getShowInAppNotificationImplementation = getShowInAppNotificationImplementation;
42
- //# sourceMappingURL=chunk-GMTKFAWO.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/internals/simulation/methods/hooks/notifications.ts"],"names":[],"mappings":";;;;;AACA,SAAS,wBAAwB;AACjC,SAAS,cAAc;AAEvB,SAAS,WAAW;AAcpB,UAAU,qCACR,SACA,EAAE,QAAQ,GACI;AACd,QAAM;AAAA,IACJ,gBAAgB,EAAE,IAAI,OAAO,GAAG,MAAM,iBAAiB,QAAQ,QAAQ,CAAC;AAAA,EAC1E;AAEA,SAAO;AACT;AAQO,SAAS,wCACd,SACA;AACA,SAAO,UACF,SACA;AACH,WAAO,MAAM;AAAA,MACX;AAAA,MACA,GAAG;AAAA,IACL,EAAE,UAAU;AAAA,EACd;AACF;AAWA,UAAU,oCACR,SACA,EAAE,QAAQ,GACU;AACpB,QAAM;AAAA,IACJ,gBAAgB,EAAE,IAAI,OAAO,GAAG,MAAM,iBAAiB,OAAO,QAAQ,CAAC;AAAA,EACzE;AAEA,SAAO;AACT;AAQO,SAAS,uCACd,SACA;AACA,SAAO,UACF,SACA;AACH,WAAO,MAAM;AAAA,MACX;AAAA,MACA,GAAG;AAAA,IACL,EAAE,UAAU;AAAA,EACd;AACF","sourcesContent":["import type { NotifyParams } from '@metamask/snaps-sdk';\nimport { NotificationType } from '@metamask/snaps-sdk';\nimport { nanoid } from '@reduxjs/toolkit';\nimport type { SagaIterator } from 'redux-saga';\nimport { put } from 'redux-saga/effects';\n\nimport type { RunSagaFunction } from '../../store';\nimport { addNotification } from '../../store';\n\n/**\n * Show a native notification to the user.\n *\n * @param _snapId - The ID of the Snap that created the notification.\n * @param options - The notification options.\n * @param options.message - The message to show in the notification.\n * @yields Adds the notification to the store.\n * @returns `null`.\n */\nfunction* showNativeNotificationImplementation(\n _snapId: string,\n { message }: NotifyParams,\n): SagaIterator {\n yield put(\n addNotification({ id: nanoid(), type: NotificationType.Native, message }),\n );\n\n return null;\n}\n\n/**\n * Get a method that can be used to show a native notification.\n *\n * @param runSaga - A function to run a saga outside the usual Redux flow.\n * @returns A method that can be used to show a native notification.\n */\nexport function getShowNativeNotificationImplementation(\n runSaga: RunSagaFunction,\n) {\n return async (\n ...args: Parameters<typeof showNativeNotificationImplementation>\n ) => {\n return await runSaga(\n showNativeNotificationImplementation,\n ...args,\n ).toPromise();\n };\n}\n\n/**\n * Show an in-app notification to the user.\n *\n * @param _snapId - The ID of the Snap that created the notification.\n * @param options - The notification options.\n * @param options.message - The message to show in the notification.\n * @yields Adds the notification to the store.\n * @returns `null`.\n */\nfunction* showInAppNotificationImplementation(\n _snapId: string,\n { message }: NotifyParams,\n): SagaIterator<null> {\n yield put(\n addNotification({ id: nanoid(), type: NotificationType.InApp, message }),\n );\n\n return null;\n}\n\n/**\n * Get a method that can be used to show an in-app notification.\n *\n * @param runSaga - A function to run a saga outside the usual Redux flow.\n * @returns A method that can be used to show an in-app notification.\n */\nexport function getShowInAppNotificationImplementation(\n runSaga: RunSagaFunction,\n) {\n return async (\n ...args: Parameters<typeof showInAppNotificationImplementation>\n ) => {\n return await runSaga(\n showInAppNotificationImplementation,\n ...args,\n ).toPromise();\n };\n}\n"]}