@metamask/snaps-controllers 9.5.0 → 9.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (716) hide show
  1. package/CHANGELOG.md +13 -1
  2. package/dist/cronjob/CronjobController.cjs +255 -0
  3. package/dist/cronjob/CronjobController.cjs.map +1 -0
  4. package/dist/{types/cronjob/CronjobController.d.ts → cronjob/CronjobController.d.cts} +8 -7
  5. package/dist/cronjob/CronjobController.d.cts.map +1 -0
  6. package/dist/cronjob/CronjobController.d.mts +121 -0
  7. package/dist/cronjob/CronjobController.d.mts.map +1 -0
  8. package/dist/cronjob/CronjobController.mjs +249 -41
  9. package/dist/cronjob/CronjobController.mjs.map +1 -1
  10. package/dist/cronjob/index.cjs +18 -0
  11. package/dist/cronjob/index.cjs.map +1 -0
  12. package/dist/cronjob/index.d.cts +2 -0
  13. package/dist/cronjob/index.d.cts.map +1 -0
  14. package/dist/cronjob/index.d.mts +2 -0
  15. package/dist/cronjob/index.d.mts.map +1 -0
  16. package/dist/cronjob/index.mjs +1 -42
  17. package/dist/cronjob/index.mjs.map +1 -1
  18. package/dist/fsm.cjs +75 -0
  19. package/dist/fsm.cjs.map +1 -0
  20. package/dist/{types/fsm.d.ts → fsm.d.cts} +2 -1
  21. package/dist/fsm.d.cts.map +1 -0
  22. package/dist/fsm.d.mts +25 -0
  23. package/dist/fsm.d.mts.map +1 -0
  24. package/dist/fsm.mjs +69 -9
  25. package/dist/fsm.mjs.map +1 -1
  26. package/dist/index.cjs +23 -0
  27. package/dist/index.cjs.map +1 -0
  28. package/dist/index.d.cts +8 -0
  29. package/dist/index.d.cts.map +1 -0
  30. package/dist/index.d.mts +8 -0
  31. package/dist/index.d.mts.map +1 -0
  32. package/dist/index.mjs +6 -124
  33. package/dist/index.mjs.map +1 -1
  34. package/dist/insights/SnapInsightsController.cjs +182 -0
  35. package/dist/insights/SnapInsightsController.cjs.map +1 -0
  36. package/dist/{types/insights/SnapInsightsController.d.ts → insights/SnapInsightsController.d.cts} +8 -7
  37. package/dist/insights/SnapInsightsController.d.cts.map +1 -0
  38. package/dist/insights/SnapInsightsController.d.mts +38 -0
  39. package/dist/insights/SnapInsightsController.d.mts.map +1 -0
  40. package/dist/insights/SnapInsightsController.mjs +176 -23
  41. package/dist/insights/SnapInsightsController.mjs.map +1 -1
  42. package/dist/insights/index.cjs +18 -0
  43. package/dist/insights/index.cjs.map +1 -0
  44. package/dist/insights/index.d.cts +2 -0
  45. package/dist/insights/index.d.cts.map +1 -0
  46. package/dist/insights/index.d.mts +2 -0
  47. package/dist/insights/index.d.mts.map +1 -0
  48. package/dist/insights/index.mjs +1 -25
  49. package/dist/insights/index.mjs.map +1 -1
  50. package/dist/interface/SnapInterfaceController.cjs +176 -0
  51. package/dist/interface/SnapInterfaceController.cjs.map +1 -0
  52. package/dist/{types/interface/SnapInterfaceController.d.ts → interface/SnapInterfaceController.d.cts} +8 -7
  53. package/dist/interface/SnapInterfaceController.d.cts.map +1 -0
  54. package/dist/interface/SnapInterfaceController.d.mts +107 -0
  55. package/dist/interface/SnapInterfaceController.d.mts.map +1 -0
  56. package/dist/interface/SnapInterfaceController.mjs +170 -7
  57. package/dist/interface/SnapInterfaceController.mjs.map +1 -1
  58. package/dist/interface/index.cjs +18 -0
  59. package/dist/interface/index.cjs.map +1 -0
  60. package/dist/interface/index.d.cts +2 -0
  61. package/dist/interface/index.d.cts.map +1 -0
  62. package/dist/interface/index.d.mts +2 -0
  63. package/dist/interface/index.d.mts.map +1 -0
  64. package/dist/interface/index.mjs +1 -9
  65. package/dist/interface/index.mjs.map +1 -1
  66. package/dist/interface/utils.cjs +165 -0
  67. package/dist/interface/utils.cjs.map +1 -0
  68. package/dist/{types/interface/utils.d.ts → interface/utils.d.cts} +3 -2
  69. package/dist/interface/utils.d.cts.map +1 -0
  70. package/dist/interface/utils.d.mts +34 -0
  71. package/dist/interface/utils.d.mts.map +1 -0
  72. package/dist/interface/utils.mjs +157 -13
  73. package/dist/interface/utils.mjs.map +1 -1
  74. package/dist/logging.cjs +13 -0
  75. package/dist/logging.cjs.map +1 -0
  76. package/dist/{types/logging.d.ts → logging.d.cts} +1 -0
  77. package/dist/logging.d.cts.map +1 -0
  78. package/dist/logging.d.mts +9 -0
  79. package/dist/logging.d.mts.map +1 -0
  80. package/dist/logging.mjs +9 -7
  81. package/dist/logging.mjs.map +1 -1
  82. package/dist/node.cjs +20 -0
  83. package/dist/node.cjs.map +1 -0
  84. package/dist/node.d.cts +3 -0
  85. package/dist/node.d.cts.map +1 -0
  86. package/dist/node.d.mts +3 -0
  87. package/dist/node.d.mts.map +1 -0
  88. package/dist/node.mjs +3 -134
  89. package/dist/node.mjs.map +1 -1
  90. package/dist/react-native.cjs +20 -0
  91. package/dist/react-native.cjs.map +1 -0
  92. package/dist/react-native.d.cts +3 -0
  93. package/dist/react-native.d.cts.map +1 -0
  94. package/dist/react-native.d.mts +3 -0
  95. package/dist/react-native.d.mts.map +1 -0
  96. package/dist/react-native.mjs +3 -131
  97. package/dist/react-native.mjs.map +1 -1
  98. package/dist/services/AbstractExecutionService.cjs +348 -0
  99. package/dist/services/AbstractExecutionService.cjs.map +1 -0
  100. package/dist/{types/services/AbstractExecutionService.d.ts → services/AbstractExecutionService.d.cts} +8 -8
  101. package/dist/services/AbstractExecutionService.d.cts.map +1 -0
  102. package/dist/services/AbstractExecutionService.d.mts +131 -0
  103. package/dist/services/AbstractExecutionService.d.mts.map +1 -0
  104. package/dist/services/AbstractExecutionService.mjs +345 -11
  105. package/dist/services/AbstractExecutionService.mjs.map +1 -1
  106. package/dist/services/ExecutionService.cjs +4 -0
  107. package/dist/services/ExecutionService.cjs.map +1 -0
  108. package/dist/{types/services/ExecutionService.d.ts → services/ExecutionService.d.cts} +4 -3
  109. package/dist/services/ExecutionService.d.cts.map +1 -0
  110. package/dist/services/ExecutionService.d.mts +69 -0
  111. package/dist/services/ExecutionService.d.mts.map +1 -0
  112. package/dist/services/ExecutionService.mjs +2 -1
  113. package/dist/services/ExecutionService.mjs.map +1 -1
  114. package/dist/services/ProxyPostMessageStream.cjs +58 -0
  115. package/dist/services/ProxyPostMessageStream.cjs.map +1 -0
  116. package/dist/{types/services/ProxyPostMessageStream.d.ts → services/ProxyPostMessageStream.d.cts} +3 -2
  117. package/dist/services/ProxyPostMessageStream.d.cts.map +1 -0
  118. package/dist/services/ProxyPostMessageStream.d.mts +35 -0
  119. package/dist/services/ProxyPostMessageStream.d.mts.map +1 -0
  120. package/dist/services/ProxyPostMessageStream.mjs +53 -6
  121. package/dist/services/ProxyPostMessageStream.mjs.map +1 -1
  122. package/dist/services/browser.cjs +27 -0
  123. package/dist/services/browser.cjs.map +1 -0
  124. package/dist/services/browser.d.cts +8 -0
  125. package/dist/services/browser.d.cts.map +1 -0
  126. package/dist/services/browser.d.mts +8 -0
  127. package/dist/services/browser.d.mts.map +1 -0
  128. package/dist/services/browser.mjs +8 -39
  129. package/dist/services/browser.mjs.map +1 -1
  130. package/dist/services/iframe/IframeExecutionService.cjs +30 -0
  131. package/dist/services/iframe/IframeExecutionService.cjs.map +1 -0
  132. package/dist/{types/services/iframe/IframeExecutionService.d.ts → services/iframe/IframeExecutionService.d.cts} +4 -3
  133. package/dist/services/iframe/IframeExecutionService.d.cts.map +1 -0
  134. package/dist/services/iframe/IframeExecutionService.d.mts +17 -0
  135. package/dist/services/iframe/IframeExecutionService.d.mts.map +1 -0
  136. package/dist/services/iframe/IframeExecutionService.mjs +26 -11
  137. package/dist/services/iframe/IframeExecutionService.mjs.map +1 -1
  138. package/dist/services/iframe/index.cjs +18 -0
  139. package/dist/services/iframe/index.cjs.map +1 -0
  140. package/dist/services/iframe/index.d.cts +2 -0
  141. package/dist/services/iframe/index.d.cts.map +1 -0
  142. package/dist/services/iframe/index.d.mts +2 -0
  143. package/dist/services/iframe/index.d.mts.map +1 -0
  144. package/dist/services/iframe/index.mjs +1 -12
  145. package/dist/services/iframe/index.mjs.map +1 -1
  146. package/dist/services/index.cjs +25 -0
  147. package/dist/services/index.cjs.map +1 -0
  148. package/dist/services/index.d.cts +7 -0
  149. package/dist/services/index.d.cts.map +1 -0
  150. package/dist/services/index.d.mts +7 -0
  151. package/dist/services/index.d.mts.map +1 -0
  152. package/dist/services/index.mjs +6 -34
  153. package/dist/services/index.mjs.map +1 -1
  154. package/dist/services/node-js/NodeProcessExecutionService.cjs +30 -0
  155. package/dist/services/node-js/NodeProcessExecutionService.cjs.map +1 -0
  156. package/dist/{types/services/node-js/NodeProcessExecutionService.d.ts → services/node-js/NodeProcessExecutionService.d.cts} +5 -4
  157. package/dist/services/node-js/NodeProcessExecutionService.d.cts.map +1 -0
  158. package/dist/services/node-js/NodeProcessExecutionService.d.mts +13 -0
  159. package/dist/services/node-js/NodeProcessExecutionService.d.mts.map +1 -0
  160. package/dist/services/node-js/NodeProcessExecutionService.mjs +26 -21
  161. package/dist/services/node-js/NodeProcessExecutionService.mjs.map +1 -1
  162. package/dist/services/node-js/NodeThreadExecutionService.cjs +32 -0
  163. package/dist/services/node-js/NodeThreadExecutionService.cjs.map +1 -0
  164. package/dist/{types/services/node-js/NodeThreadExecutionService.d.ts → services/node-js/NodeThreadExecutionService.d.cts} +5 -4
  165. package/dist/services/node-js/NodeThreadExecutionService.d.cts.map +1 -0
  166. package/dist/services/node-js/NodeThreadExecutionService.d.mts +13 -0
  167. package/dist/services/node-js/NodeThreadExecutionService.d.mts.map +1 -0
  168. package/dist/services/node-js/NodeThreadExecutionService.mjs +28 -21
  169. package/dist/services/node-js/NodeThreadExecutionService.mjs.map +1 -1
  170. package/dist/services/node-js/index.cjs +19 -0
  171. package/dist/services/node-js/index.cjs.map +1 -0
  172. package/dist/services/node-js/index.d.cts +3 -0
  173. package/dist/services/node-js/index.d.cts.map +1 -0
  174. package/dist/services/node-js/index.d.mts +3 -0
  175. package/dist/services/node-js/index.d.mts.map +1 -0
  176. package/dist/services/node-js/index.mjs +2 -26
  177. package/dist/services/node-js/index.mjs.map +1 -1
  178. package/dist/services/node.cjs +19 -0
  179. package/dist/services/node.cjs.map +1 -0
  180. package/dist/services/node.d.cts +3 -0
  181. package/dist/services/node.d.cts.map +1 -0
  182. package/dist/services/node.d.mts +3 -0
  183. package/dist/services/node.d.mts.map +1 -0
  184. package/dist/services/node.mjs +2 -44
  185. package/dist/services/node.mjs.map +1 -1
  186. package/dist/services/offscreen/OffscreenExecutionService.cjs +56 -0
  187. package/dist/services/offscreen/OffscreenExecutionService.cjs.map +1 -0
  188. package/dist/{types/services/offscreen/OffscreenExecutionService.d.ts → services/offscreen/OffscreenExecutionService.d.cts} +3 -2
  189. package/dist/services/offscreen/OffscreenExecutionService.d.cts.map +1 -0
  190. package/dist/services/offscreen/OffscreenExecutionService.d.mts +33 -0
  191. package/dist/services/offscreen/OffscreenExecutionService.d.mts.map +1 -0
  192. package/dist/services/offscreen/OffscreenExecutionService.mjs +51 -12
  193. package/dist/services/offscreen/OffscreenExecutionService.mjs.map +1 -1
  194. package/dist/services/offscreen/index.cjs +18 -0
  195. package/dist/services/offscreen/index.cjs.map +1 -0
  196. package/dist/services/offscreen/index.d.cts +2 -0
  197. package/dist/services/offscreen/index.d.cts.map +1 -0
  198. package/dist/services/offscreen/index.d.mts +2 -0
  199. package/dist/services/offscreen/index.d.mts.map +1 -0
  200. package/dist/services/offscreen/index.mjs +1 -14
  201. package/dist/services/offscreen/index.mjs.map +1 -1
  202. package/dist/services/proxy/ProxyExecutionService.cjs +85 -0
  203. package/dist/services/proxy/ProxyExecutionService.cjs.map +1 -0
  204. package/dist/{types/services/proxy/ProxyExecutionService.d.ts → services/proxy/ProxyExecutionService.d.cts} +6 -4
  205. package/dist/services/proxy/ProxyExecutionService.d.cts.map +1 -0
  206. package/dist/services/proxy/ProxyExecutionService.d.mts +41 -0
  207. package/dist/services/proxy/ProxyExecutionService.d.mts.map +1 -0
  208. package/dist/services/proxy/ProxyExecutionService.mjs +79 -11
  209. package/dist/services/proxy/ProxyExecutionService.mjs.map +1 -1
  210. package/dist/services/react-native.cjs +19 -0
  211. package/dist/services/react-native.cjs.map +1 -0
  212. package/dist/services/react-native.d.cts +3 -0
  213. package/dist/services/react-native.d.cts.map +1 -0
  214. package/dist/services/react-native.d.mts +3 -0
  215. package/dist/services/react-native.d.mts.map +1 -0
  216. package/dist/services/react-native.mjs +2 -41
  217. package/dist/services/react-native.mjs.map +1 -1
  218. package/dist/services/webview/WebViewExecutionService.cjs +54 -0
  219. package/dist/services/webview/WebViewExecutionService.cjs.map +1 -0
  220. package/dist/{types/services/webview/WebViewExecutionService.d.ts → services/webview/WebViewExecutionService.d.cts} +5 -3
  221. package/dist/services/webview/WebViewExecutionService.d.cts.map +1 -0
  222. package/dist/services/webview/WebViewExecutionService.d.mts +22 -0
  223. package/dist/services/webview/WebViewExecutionService.d.mts.map +1 -0
  224. package/dist/services/webview/WebViewExecutionService.mjs +48 -13
  225. package/dist/services/webview/WebViewExecutionService.mjs.map +1 -1
  226. package/dist/services/webview/WebViewMessageStream.cjs +89 -0
  227. package/dist/services/webview/WebViewMessageStream.cjs.map +1 -0
  228. package/dist/{types/services/webview/WebViewMessageStream.d.ts → services/webview/WebViewMessageStream.d.cts} +3 -2
  229. package/dist/services/webview/WebViewMessageStream.d.cts.map +1 -0
  230. package/dist/services/webview/WebViewMessageStream.d.mts +33 -0
  231. package/dist/services/webview/WebViewMessageStream.d.mts.map +1 -0
  232. package/dist/services/webview/WebViewMessageStream.mjs +84 -6
  233. package/dist/services/webview/WebViewMessageStream.mjs.map +1 -1
  234. package/dist/services/webview/index.cjs +18 -0
  235. package/dist/services/webview/index.cjs.map +1 -0
  236. package/dist/services/webview/index.d.cts +2 -0
  237. package/dist/services/webview/index.d.cts.map +1 -0
  238. package/dist/services/webview/index.d.mts +2 -0
  239. package/dist/services/webview/index.d.mts.map +1 -0
  240. package/dist/services/webview/index.mjs +1 -15
  241. package/dist/services/webview/index.mjs.map +1 -1
  242. package/dist/services/webworker/WebWorkerExecutionService.cjs +101 -0
  243. package/dist/services/webworker/WebWorkerExecutionService.cjs.map +1 -0
  244. package/dist/{types/services/webworker/WebWorkerExecutionService.d.ts → services/webworker/WebWorkerExecutionService.d.cts} +5 -3
  245. package/dist/services/webworker/WebWorkerExecutionService.d.cts.map +1 -0
  246. package/dist/services/webworker/WebWorkerExecutionService.d.mts +47 -0
  247. package/dist/services/webworker/WebWorkerExecutionService.d.mts.map +1 -0
  248. package/dist/services/webworker/WebWorkerExecutionService.mjs +96 -13
  249. package/dist/services/webworker/WebWorkerExecutionService.mjs.map +1 -1
  250. package/dist/services/webworker/index.cjs +18 -0
  251. package/dist/services/webworker/index.cjs.map +1 -0
  252. package/dist/services/webworker/index.d.cts +2 -0
  253. package/dist/services/webworker/index.d.cts.map +1 -0
  254. package/dist/services/webworker/index.d.mts +2 -0
  255. package/dist/services/webworker/index.d.mts.map +1 -0
  256. package/dist/services/webworker/index.mjs +1 -15
  257. package/dist/services/webworker/index.mjs.map +1 -1
  258. package/dist/snaps/RequestQueue.cjs +44 -0
  259. package/dist/snaps/RequestQueue.cjs.map +1 -0
  260. package/dist/{types/snaps/RequestQueue.d.ts → snaps/RequestQueue.d.cts} +1 -0
  261. package/dist/snaps/RequestQueue.d.cts.map +1 -0
  262. package/dist/snaps/RequestQueue.d.mts +25 -0
  263. package/dist/snaps/RequestQueue.d.mts.map +1 -0
  264. package/dist/snaps/RequestQueue.mjs +39 -7
  265. package/dist/snaps/RequestQueue.mjs.map +1 -1
  266. package/dist/snaps/SnapController.cjs +1896 -0
  267. package/dist/snaps/SnapController.cjs.map +1 -0
  268. package/dist/{types/snaps/SnapController.d.ts → snaps/SnapController.d.cts} +33 -20
  269. package/dist/snaps/SnapController.d.cts.map +1 -0
  270. package/dist/snaps/SnapController.d.mts +667 -0
  271. package/dist/snaps/SnapController.d.mts.map +1 -0
  272. package/dist/snaps/SnapController.mjs +1890 -28
  273. package/dist/snaps/SnapController.mjs.map +1 -1
  274. package/dist/snaps/Timer.cjs +103 -0
  275. package/dist/snaps/Timer.cjs.map +1 -0
  276. package/dist/{types/snaps/Timer.d.ts → snaps/Timer.d.cts} +1 -0
  277. package/dist/snaps/Timer.d.cts.map +1 -0
  278. package/dist/snaps/Timer.d.mts +47 -0
  279. package/dist/snaps/Timer.d.mts.map +1 -0
  280. package/dist/snaps/Timer.mjs +98 -7
  281. package/dist/snaps/Timer.mjs.map +1 -1
  282. package/dist/snaps/constants.cjs +24 -0
  283. package/dist/snaps/constants.cjs.map +1 -0
  284. package/dist/{types/snaps/constants.d.ts → snaps/constants.d.cts} +1 -0
  285. package/dist/snaps/constants.d.cts.map +1 -0
  286. package/dist/snaps/constants.d.mts +8 -0
  287. package/dist/snaps/constants.d.mts.map +1 -0
  288. package/dist/snaps/constants.mjs +19 -8
  289. package/dist/snaps/constants.mjs.map +1 -1
  290. package/dist/snaps/index.cjs +21 -0
  291. package/dist/snaps/index.cjs.map +1 -0
  292. package/dist/snaps/index.d.cts +5 -0
  293. package/dist/snaps/index.d.cts.map +1 -0
  294. package/dist/snaps/index.d.mts +5 -0
  295. package/dist/snaps/index.d.mts.map +1 -0
  296. package/dist/snaps/index.mjs +4 -62
  297. package/dist/snaps/index.mjs.map +1 -1
  298. package/dist/snaps/location/http.cjs +75 -0
  299. package/dist/snaps/location/http.cjs.map +1 -0
  300. package/dist/{types/snaps/location/http.d.ts → snaps/location/http.d.cts} +4 -3
  301. package/dist/snaps/location/http.d.cts.map +1 -0
  302. package/dist/snaps/location/http.d.mts +23 -0
  303. package/dist/snaps/location/http.d.mts.map +1 -0
  304. package/dist/snaps/location/http.mjs +70 -7
  305. package/dist/snaps/location/http.mjs.map +1 -1
  306. package/dist/snaps/location/index.cjs +21 -0
  307. package/dist/snaps/location/index.cjs.map +1 -0
  308. package/dist/snaps/location/index.d.cts +5 -0
  309. package/dist/snaps/location/index.d.cts.map +1 -0
  310. package/dist/snaps/location/index.d.mts +5 -0
  311. package/dist/snaps/location/index.d.mts.map +1 -0
  312. package/dist/snaps/location/index.mjs +4 -30
  313. package/dist/snaps/location/index.mjs.map +1 -1
  314. package/dist/snaps/location/local.cjs +51 -0
  315. package/dist/snaps/location/local.cjs.map +1 -0
  316. package/dist/{types/snaps/location/local.d.ts → snaps/location/local.d.cts} +4 -3
  317. package/dist/snaps/location/local.d.cts.map +1 -0
  318. package/dist/snaps/location/local.d.mts +11 -0
  319. package/dist/snaps/location/local.d.mts.map +1 -0
  320. package/dist/snaps/location/local.mjs +45 -7
  321. package/dist/snaps/location/local.mjs.map +1 -1
  322. package/dist/snaps/location/location.cjs +34 -0
  323. package/dist/{chunk-ZKG6FRKN.mjs.map → snaps/location/location.cjs.map} +1 -1
  324. package/dist/{types/snaps/location/location.d.ts → snaps/location/location.d.cts} +4 -3
  325. package/dist/snaps/location/location.d.cts.map +1 -0
  326. package/dist/snaps/location/location.d.mts +45 -0
  327. package/dist/snaps/location/location.d.mts.map +1 -0
  328. package/dist/snaps/location/location.mjs +29 -10
  329. package/dist/snaps/location/location.mjs.map +1 -1
  330. package/dist/snaps/location/npm.cjs +335 -0
  331. package/dist/snaps/location/npm.cjs.map +1 -0
  332. package/dist/{types/snaps/location/npm.d.ts → snaps/location/npm.d.cts} +5 -4
  333. package/dist/snaps/location/npm.d.cts.map +1 -0
  334. package/dist/snaps/location/npm.d.mts +84 -0
  335. package/dist/snaps/location/npm.d.mts.map +1 -0
  336. package/dist/snaps/location/npm.mjs +331 -16
  337. package/dist/snaps/location/npm.mjs.map +1 -1
  338. package/dist/snaps/registry/index.cjs +19 -0
  339. package/dist/snaps/registry/index.cjs.map +1 -0
  340. package/dist/snaps/registry/index.d.cts +3 -0
  341. package/dist/snaps/registry/index.d.cts.map +1 -0
  342. package/dist/snaps/registry/index.d.mts +3 -0
  343. package/dist/snaps/registry/index.d.mts.map +1 -0
  344. package/dist/snaps/registry/index.mjs +2 -12
  345. package/dist/snaps/registry/index.mjs.map +1 -1
  346. package/dist/snaps/registry/json.cjs +224 -0
  347. package/dist/snaps/registry/json.cjs.map +1 -0
  348. package/dist/{types/snaps/registry/json.d.ts → snaps/registry/json.d.cts} +6 -5
  349. package/dist/snaps/registry/json.d.cts.map +1 -0
  350. package/dist/snaps/registry/json.d.mts +51 -0
  351. package/dist/snaps/registry/json.d.mts.map +1 -0
  352. package/dist/snaps/registry/json.mjs +219 -7
  353. package/dist/snaps/registry/json.mjs.map +1 -1
  354. package/dist/snaps/registry/registry.cjs +11 -0
  355. package/dist/snaps/registry/registry.cjs.map +1 -0
  356. package/dist/{types/snaps/registry/registry.d.ts → snaps/registry/registry.d.cts} +4 -3
  357. package/dist/snaps/registry/registry.d.cts.map +1 -0
  358. package/dist/snaps/registry/registry.d.mts +42 -0
  359. package/dist/snaps/registry/registry.d.mts.map +1 -0
  360. package/dist/snaps/registry/registry.mjs +7 -7
  361. package/dist/snaps/registry/registry.mjs.map +1 -1
  362. package/dist/snaps/selectors.cjs +6 -0
  363. package/dist/snaps/selectors.cjs.map +1 -0
  364. package/dist/snaps/selectors.d.cts +3 -0
  365. package/dist/snaps/selectors.d.cts.map +1 -0
  366. package/dist/snaps/selectors.d.mts +3 -0
  367. package/dist/snaps/selectors.d.mts.map +1 -0
  368. package/dist/snaps/selectors.mjs +1 -7
  369. package/dist/snaps/selectors.mjs.map +1 -1
  370. package/dist/types/controllers.cjs +4 -0
  371. package/dist/types/controllers.cjs.map +1 -0
  372. package/dist/types/{types/controllers.d.ts → controllers.d.cts} +3 -2
  373. package/dist/types/controllers.d.cts.map +1 -0
  374. package/dist/types/controllers.d.mts +132 -0
  375. package/dist/types/controllers.d.mts.map +1 -0
  376. package/dist/types/controllers.mjs +2 -1
  377. package/dist/types/controllers.mjs.map +1 -1
  378. package/dist/types/encryptor.cjs +3 -0
  379. package/dist/types/encryptor.cjs.map +1 -0
  380. package/dist/types/{types/encryptor.d.ts → encryptor.d.cts} +2 -1
  381. package/dist/types/encryptor.d.cts.map +1 -0
  382. package/dist/types/encryptor.d.mts +99 -0
  383. package/dist/types/encryptor.d.mts.map +1 -0
  384. package/dist/types/encryptor.mjs +1 -1
  385. package/dist/types/encryptor.mjs.map +1 -1
  386. package/dist/types/index.cjs +19 -0
  387. package/dist/types/index.cjs.map +1 -0
  388. package/dist/types/index.d.cts +3 -0
  389. package/dist/types/index.d.cts.map +1 -0
  390. package/dist/types/index.d.mts +3 -0
  391. package/dist/types/index.d.mts.map +1 -0
  392. package/dist/types/index.mjs +2 -2
  393. package/dist/types/index.mjs.map +1 -1
  394. package/dist/utils.cjs +174 -0
  395. package/dist/utils.cjs.map +1 -0
  396. package/dist/{types/utils.d.ts → utils.d.cts} +8 -14
  397. package/dist/utils.d.cts.map +1 -0
  398. package/dist/utils.d.mts +245 -0
  399. package/dist/utils.d.mts.map +1 -0
  400. package/dist/utils.mjs +167 -22
  401. package/dist/utils.mjs.map +1 -1
  402. package/package.json +42 -30
  403. package/react-native.d.ts +3 -1
  404. package/react-native.js +1 -1
  405. package/dist/chunk-272IFIK7.mjs +0 -1
  406. package/dist/chunk-272IFIK7.mjs.map +0 -1
  407. package/dist/chunk-2D5PGL7S.js +0 -253
  408. package/dist/chunk-2D5PGL7S.js.map +0 -1
  409. package/dist/chunk-2SRKMEUV.mjs +0 -92
  410. package/dist/chunk-2SRKMEUV.mjs.map +0 -1
  411. package/dist/chunk-2XQD4P2S.mjs +0 -1
  412. package/dist/chunk-2XQD4P2S.mjs.map +0 -1
  413. package/dist/chunk-36QDTCDZ.js +0 -276
  414. package/dist/chunk-36QDTCDZ.js.map +0 -1
  415. package/dist/chunk-3RNW7OKG.mjs +0 -1
  416. package/dist/chunk-3RNW7OKG.mjs.map +0 -1
  417. package/dist/chunk-3WWZDKQL.js +0 -40
  418. package/dist/chunk-3WWZDKQL.js.map +0 -1
  419. package/dist/chunk-4CA3O64H.js +0 -13
  420. package/dist/chunk-4CA3O64H.js.map +0 -1
  421. package/dist/chunk-4HVWEABQ.mjs +0 -9
  422. package/dist/chunk-4HVWEABQ.mjs.map +0 -1
  423. package/dist/chunk-4M2FX2AT.mjs +0 -26
  424. package/dist/chunk-4M2FX2AT.mjs.map +0 -1
  425. package/dist/chunk-4URGXJP7.js +0 -1
  426. package/dist/chunk-4URGXJP7.js.map +0 -1
  427. package/dist/chunk-6EZSNS4O.mjs +0 -59
  428. package/dist/chunk-6EZSNS4O.mjs.map +0 -1
  429. package/dist/chunk-6K4MATNG.js +0 -2548
  430. package/dist/chunk-6K4MATNG.js.map +0 -1
  431. package/dist/chunk-6WGCLJGC.mjs +0 -58
  432. package/dist/chunk-6WGCLJGC.mjs.map +0 -1
  433. package/dist/chunk-6Z4WDAVC.js +0 -48
  434. package/dist/chunk-6Z4WDAVC.js.map +0 -1
  435. package/dist/chunk-7BUNUNUC.js +0 -58
  436. package/dist/chunk-7BUNUNUC.js.map +0 -1
  437. package/dist/chunk-7Y6P5FRN.js +0 -60
  438. package/dist/chunk-7Y6P5FRN.js.map +0 -1
  439. package/dist/chunk-A6WJEA3C.js +0 -1
  440. package/dist/chunk-A6WJEA3C.js.map +0 -1
  441. package/dist/chunk-AP7CJ6DA.js +0 -47
  442. package/dist/chunk-AP7CJ6DA.js.map +0 -1
  443. package/dist/chunk-B6KTRDBK.js +0 -127
  444. package/dist/chunk-B6KTRDBK.js.map +0 -1
  445. package/dist/chunk-B7R3EWM3.mjs +0 -1
  446. package/dist/chunk-B7R3EWM3.mjs.map +0 -1
  447. package/dist/chunk-BAEXVO3U.mjs +0 -1
  448. package/dist/chunk-BAEXVO3U.mjs.map +0 -1
  449. package/dist/chunk-BAUQWPSP.mjs +0 -331
  450. package/dist/chunk-BAUQWPSP.mjs.map +0 -1
  451. package/dist/chunk-BO2ZDPWV.js +0 -59
  452. package/dist/chunk-BO2ZDPWV.js.map +0 -1
  453. package/dist/chunk-BOFPNIRX.js +0 -119
  454. package/dist/chunk-BOFPNIRX.js.map +0 -1
  455. package/dist/chunk-C4D6GBMY.js +0 -71
  456. package/dist/chunk-C4D6GBMY.js.map +0 -1
  457. package/dist/chunk-D66YLO7T.js +0 -38
  458. package/dist/chunk-D66YLO7T.js.map +0 -1
  459. package/dist/chunk-D74XJG2L.js +0 -1
  460. package/dist/chunk-D74XJG2L.js.map +0 -1
  461. package/dist/chunk-DSOZPX7I.js +0 -283
  462. package/dist/chunk-DSOZPX7I.js.map +0 -1
  463. package/dist/chunk-ESQPQNEF.mjs +0 -1
  464. package/dist/chunk-ESQPQNEF.mjs.map +0 -1
  465. package/dist/chunk-EXN2TFDJ.js +0 -38
  466. package/dist/chunk-EXN2TFDJ.js.map +0 -1
  467. package/dist/chunk-F3ZMDQ52.mjs +0 -276
  468. package/dist/chunk-F3ZMDQ52.mjs.map +0 -1
  469. package/dist/chunk-FX5AADOV.mjs +0 -1
  470. package/dist/chunk-FX5AADOV.mjs.map +0 -1
  471. package/dist/chunk-FZOI4WPB.js +0 -82
  472. package/dist/chunk-FZOI4WPB.js.map +0 -1
  473. package/dist/chunk-G66GQJS6.js +0 -1
  474. package/dist/chunk-G66GQJS6.js.map +0 -1
  475. package/dist/chunk-G7U6WKWS.mjs +0 -1
  476. package/dist/chunk-G7U6WKWS.mjs.map +0 -1
  477. package/dist/chunk-HLQQTAMM.mjs +0 -105
  478. package/dist/chunk-HLQQTAMM.mjs.map +0 -1
  479. package/dist/chunk-HOY6NKQR.js +0 -1
  480. package/dist/chunk-HOY6NKQR.js.map +0 -1
  481. package/dist/chunk-HP6S5IOB.js +0 -1
  482. package/dist/chunk-HP6S5IOB.js.map +0 -1
  483. package/dist/chunk-HULNFJMA.mjs +0 -108
  484. package/dist/chunk-HULNFJMA.mjs.map +0 -1
  485. package/dist/chunk-HWJE3SDW.mjs +0 -1
  486. package/dist/chunk-HWJE3SDW.mjs.map +0 -1
  487. package/dist/chunk-I25KLPIS.js +0 -273
  488. package/dist/chunk-I25KLPIS.js.map +0 -1
  489. package/dist/chunk-I5V56NYO.mjs +0 -273
  490. package/dist/chunk-I5V56NYO.mjs.map +0 -1
  491. package/dist/chunk-IABOI7TW.mjs +0 -1
  492. package/dist/chunk-IABOI7TW.mjs.map +0 -1
  493. package/dist/chunk-IDCWJJCQ.js +0 -1
  494. package/dist/chunk-IDCWJJCQ.js.map +0 -1
  495. package/dist/chunk-IGC4E7PI.mjs +0 -71
  496. package/dist/chunk-IGC4E7PI.mjs.map +0 -1
  497. package/dist/chunk-JAUAKTUL.js +0 -1
  498. package/dist/chunk-JAUAKTUL.js.map +0 -1
  499. package/dist/chunk-JQ54YYLU.js +0 -26
  500. package/dist/chunk-JQ54YYLU.js.map +0 -1
  501. package/dist/chunk-JW7WBUL7.js +0 -1
  502. package/dist/chunk-JW7WBUL7.js.map +0 -1
  503. package/dist/chunk-K3TNQEM5.js +0 -331
  504. package/dist/chunk-K3TNQEM5.js.map +0 -1
  505. package/dist/chunk-KCMULJ2M.mjs +0 -1
  506. package/dist/chunk-KCMULJ2M.mjs.map +0 -1
  507. package/dist/chunk-KELDSV7H.js +0 -39
  508. package/dist/chunk-KELDSV7H.js.map +0 -1
  509. package/dist/chunk-KRI4OKC3.mjs +0 -127
  510. package/dist/chunk-KRI4OKC3.mjs.map +0 -1
  511. package/dist/chunk-KYRKZ3RH.mjs +0 -38
  512. package/dist/chunk-KYRKZ3RH.mjs.map +0 -1
  513. package/dist/chunk-LDL6LJ3P.mjs +0 -38
  514. package/dist/chunk-LDL6LJ3P.mjs.map +0 -1
  515. package/dist/chunk-M7DWHPVM.js +0 -1
  516. package/dist/chunk-M7DWHPVM.js.map +0 -1
  517. package/dist/chunk-NC5PBDKD.mjs +0 -47
  518. package/dist/chunk-NC5PBDKD.mjs.map +0 -1
  519. package/dist/chunk-NXZVKBSV.js +0 -9
  520. package/dist/chunk-NXZVKBSV.js.map +0 -1
  521. package/dist/chunk-NZOUFWUN.mjs +0 -1
  522. package/dist/chunk-NZOUFWUN.mjs.map +0 -1
  523. package/dist/chunk-OHMCPTOI.js +0 -1
  524. package/dist/chunk-OHMCPTOI.js.map +0 -1
  525. package/dist/chunk-OIEUL55W.js +0 -1
  526. package/dist/chunk-OIEUL55W.js.map +0 -1
  527. package/dist/chunk-OVATPF5I.js +0 -58
  528. package/dist/chunk-OVATPF5I.js.map +0 -1
  529. package/dist/chunk-P66VIDFG.js +0 -105
  530. package/dist/chunk-P66VIDFG.js.map +0 -1
  531. package/dist/chunk-P7Y6MIZW.mjs +0 -7
  532. package/dist/chunk-P7Y6MIZW.mjs.map +0 -1
  533. package/dist/chunk-PYSDWIVK.js +0 -38
  534. package/dist/chunk-PYSDWIVK.js.map +0 -1
  535. package/dist/chunk-QL3QGUTM.mjs +0 -1
  536. package/dist/chunk-QL3QGUTM.mjs.map +0 -1
  537. package/dist/chunk-QRISQRFI.js +0 -399
  538. package/dist/chunk-QRISQRFI.js.map +0 -1
  539. package/dist/chunk-QWN3UOMA.mjs +0 -2548
  540. package/dist/chunk-QWN3UOMA.mjs.map +0 -1
  541. package/dist/chunk-RZ2NHZXH.js +0 -108
  542. package/dist/chunk-RZ2NHZXH.js.map +0 -1
  543. package/dist/chunk-TG6OXBLR.js +0 -1
  544. package/dist/chunk-TG6OXBLR.js.map +0 -1
  545. package/dist/chunk-TIURYSSR.js +0 -92
  546. package/dist/chunk-TIURYSSR.js.map +0 -1
  547. package/dist/chunk-TMWMIQV4.js +0 -1
  548. package/dist/chunk-TMWMIQV4.js.map +0 -1
  549. package/dist/chunk-TSDUJNOP.mjs +0 -399
  550. package/dist/chunk-TSDUJNOP.mjs.map +0 -1
  551. package/dist/chunk-U74FML7Z.mjs +0 -1
  552. package/dist/chunk-U74FML7Z.mjs.map +0 -1
  553. package/dist/chunk-UM4NFNEI.mjs +0 -48
  554. package/dist/chunk-UM4NFNEI.mjs.map +0 -1
  555. package/dist/chunk-V6NFZ47P.mjs +0 -1
  556. package/dist/chunk-V6NFZ47P.mjs.map +0 -1
  557. package/dist/chunk-VKMY6CKT.mjs +0 -39
  558. package/dist/chunk-VKMY6CKT.mjs.map +0 -1
  559. package/dist/chunk-VNOCJWOK.js +0 -1
  560. package/dist/chunk-VNOCJWOK.js.map +0 -1
  561. package/dist/chunk-WEY7ICES.js +0 -1
  562. package/dist/chunk-WEY7ICES.js.map +0 -1
  563. package/dist/chunk-WR7CVDEY.mjs +0 -58
  564. package/dist/chunk-WR7CVDEY.mjs.map +0 -1
  565. package/dist/chunk-XO7KDFBY.mjs +0 -119
  566. package/dist/chunk-XO7KDFBY.mjs.map +0 -1
  567. package/dist/chunk-XOSHP4J3.mjs +0 -82
  568. package/dist/chunk-XOSHP4J3.mjs.map +0 -1
  569. package/dist/chunk-YRZVIDCF.mjs +0 -38
  570. package/dist/chunk-YRZVIDCF.mjs.map +0 -1
  571. package/dist/chunk-YYPUPKQY.js +0 -7
  572. package/dist/chunk-YYPUPKQY.js.map +0 -1
  573. package/dist/chunk-Z4BUMSH3.mjs +0 -283
  574. package/dist/chunk-Z4BUMSH3.mjs.map +0 -1
  575. package/dist/chunk-Z5QWRDUN.mjs +0 -253
  576. package/dist/chunk-Z5QWRDUN.mjs.map +0 -1
  577. package/dist/chunk-ZKG6FRKN.mjs +0 -40
  578. package/dist/chunk-ZQAGLOXD.mjs +0 -1
  579. package/dist/chunk-ZQAGLOXD.mjs.map +0 -1
  580. package/dist/chunk-ZVOYOZFT.mjs +0 -60
  581. package/dist/chunk-ZVOYOZFT.mjs.map +0 -1
  582. package/dist/chunk-ZZD3HUNE.mjs +0 -13
  583. package/dist/chunk-ZZD3HUNE.mjs.map +0 -1
  584. package/dist/cronjob/CronjobController.js +0 -43
  585. package/dist/cronjob/CronjobController.js.map +0 -1
  586. package/dist/cronjob/index.js +0 -43
  587. package/dist/cronjob/index.js.map +0 -1
  588. package/dist/fsm.js +0 -10
  589. package/dist/fsm.js.map +0 -1
  590. package/dist/index.js +0 -125
  591. package/dist/index.js.map +0 -1
  592. package/dist/insights/SnapInsightsController.js +0 -25
  593. package/dist/insights/SnapInsightsController.js.map +0 -1
  594. package/dist/insights/index.js +0 -26
  595. package/dist/insights/index.js.map +0 -1
  596. package/dist/interface/SnapInterfaceController.js +0 -9
  597. package/dist/interface/SnapInterfaceController.js.map +0 -1
  598. package/dist/interface/index.js +0 -10
  599. package/dist/interface/index.js.map +0 -1
  600. package/dist/interface/utils.js +0 -14
  601. package/dist/interface/utils.js.map +0 -1
  602. package/dist/logging.js +0 -8
  603. package/dist/logging.js.map +0 -1
  604. package/dist/node.js +0 -135
  605. package/dist/node.js.map +0 -1
  606. package/dist/react-native.js +0 -132
  607. package/dist/react-native.js.map +0 -1
  608. package/dist/services/AbstractExecutionService.js +0 -13
  609. package/dist/services/AbstractExecutionService.js.map +0 -1
  610. package/dist/services/ExecutionService.js +0 -2
  611. package/dist/services/ExecutionService.js.map +0 -1
  612. package/dist/services/ProxyPostMessageStream.js +0 -8
  613. package/dist/services/ProxyPostMessageStream.js.map +0 -1
  614. package/dist/services/browser.js +0 -40
  615. package/dist/services/browser.js.map +0 -1
  616. package/dist/services/iframe/IframeExecutionService.js +0 -12
  617. package/dist/services/iframe/IframeExecutionService.js.map +0 -1
  618. package/dist/services/iframe/index.js +0 -13
  619. package/dist/services/iframe/index.js.map +0 -1
  620. package/dist/services/index.js +0 -35
  621. package/dist/services/index.js.map +0 -1
  622. package/dist/services/node-js/NodeProcessExecutionService.js +0 -22
  623. package/dist/services/node-js/NodeProcessExecutionService.js.map +0 -1
  624. package/dist/services/node-js/NodeThreadExecutionService.js +0 -22
  625. package/dist/services/node-js/NodeThreadExecutionService.js.map +0 -1
  626. package/dist/services/node-js/index.js +0 -27
  627. package/dist/services/node-js/index.js.map +0 -1
  628. package/dist/services/node.js +0 -45
  629. package/dist/services/node.js.map +0 -1
  630. package/dist/services/offscreen/OffscreenExecutionService.js +0 -14
  631. package/dist/services/offscreen/OffscreenExecutionService.js.map +0 -1
  632. package/dist/services/offscreen/index.js +0 -15
  633. package/dist/services/offscreen/index.js.map +0 -1
  634. package/dist/services/proxy/ProxyExecutionService.js +0 -13
  635. package/dist/services/proxy/ProxyExecutionService.js.map +0 -1
  636. package/dist/services/react-native.js +0 -42
  637. package/dist/services/react-native.js.map +0 -1
  638. package/dist/services/webview/WebViewExecutionService.js +0 -15
  639. package/dist/services/webview/WebViewExecutionService.js.map +0 -1
  640. package/dist/services/webview/WebViewMessageStream.js +0 -8
  641. package/dist/services/webview/WebViewMessageStream.js.map +0 -1
  642. package/dist/services/webview/index.js +0 -16
  643. package/dist/services/webview/index.js.map +0 -1
  644. package/dist/services/webworker/WebWorkerExecutionService.js +0 -15
  645. package/dist/services/webworker/WebWorkerExecutionService.js.map +0 -1
  646. package/dist/services/webworker/index.js +0 -16
  647. package/dist/services/webworker/index.js.map +0 -1
  648. package/dist/snaps/RequestQueue.js +0 -8
  649. package/dist/snaps/RequestQueue.js.map +0 -1
  650. package/dist/snaps/SnapController.js +0 -30
  651. package/dist/snaps/SnapController.js.map +0 -1
  652. package/dist/snaps/Timer.js +0 -8
  653. package/dist/snaps/Timer.js.map +0 -1
  654. package/dist/snaps/constants.js +0 -10
  655. package/dist/snaps/constants.js.map +0 -1
  656. package/dist/snaps/index.js +0 -63
  657. package/dist/snaps/index.js.map +0 -1
  658. package/dist/snaps/location/http.js +0 -8
  659. package/dist/snaps/location/http.js.map +0 -1
  660. package/dist/snaps/location/index.js +0 -31
  661. package/dist/snaps/location/index.js.map +0 -1
  662. package/dist/snaps/location/local.js +0 -9
  663. package/dist/snaps/location/local.js.map +0 -1
  664. package/dist/snaps/location/location.js +0 -11
  665. package/dist/snaps/location/location.js.map +0 -1
  666. package/dist/snaps/location/npm.js +0 -18
  667. package/dist/snaps/location/npm.js.map +0 -1
  668. package/dist/snaps/registry/index.js +0 -13
  669. package/dist/snaps/registry/index.js.map +0 -1
  670. package/dist/snaps/registry/json.js +0 -9
  671. package/dist/snaps/registry/json.js.map +0 -1
  672. package/dist/snaps/registry/registry.js +0 -8
  673. package/dist/snaps/registry/registry.js.map +0 -1
  674. package/dist/snaps/selectors.js +0 -8
  675. package/dist/snaps/selectors.js.map +0 -1
  676. package/dist/tsconfig.build.tsbuildinfo +0 -1
  677. package/dist/types/controllers.js +0 -2
  678. package/dist/types/controllers.js.map +0 -1
  679. package/dist/types/cronjob/index.d.ts +0 -1
  680. package/dist/types/encryptor.js +0 -2
  681. package/dist/types/encryptor.js.map +0 -1
  682. package/dist/types/index.d.ts +0 -7
  683. package/dist/types/index.js +0 -3
  684. package/dist/types/index.js.map +0 -1
  685. package/dist/types/insights/index.d.ts +0 -1
  686. package/dist/types/interface/index.d.ts +0 -1
  687. package/dist/types/node.d.ts +0 -2
  688. package/dist/types/react-native.d.ts +0 -2
  689. package/dist/types/services/browser.d.ts +0 -7
  690. package/dist/types/services/iframe/index.d.ts +0 -1
  691. package/dist/types/services/index.d.ts +0 -6
  692. package/dist/types/services/node-js/index.d.ts +0 -2
  693. package/dist/types/services/node.d.ts +0 -2
  694. package/dist/types/services/offscreen/index.d.ts +0 -1
  695. package/dist/types/services/react-native.d.ts +0 -2
  696. package/dist/types/services/webview/index.d.ts +0 -1
  697. package/dist/types/services/webworker/index.d.ts +0 -1
  698. package/dist/types/snaps/index.d.ts +0 -4
  699. package/dist/types/snaps/location/index.d.ts +0 -4
  700. package/dist/types/snaps/registry/index.d.ts +0 -2
  701. package/dist/types/snaps/selectors.d.ts +0 -2
  702. package/dist/types/types/index.d.ts +0 -2
  703. package/dist/types/vendor/global.d.js +0 -1
  704. package/dist/types/vendor/global.d.js.map +0 -1
  705. package/dist/types/vendor/global.d.mjs +0 -1
  706. package/dist/types/vendor/global.d.mjs.map +0 -1
  707. package/dist/types/vendor/readable-stream.d.js +0 -1
  708. package/dist/types/vendor/readable-stream.d.js.map +0 -1
  709. package/dist/types/vendor/readable-stream.d.mjs +0 -1
  710. package/dist/types/vendor/readable-stream.d.mjs.map +0 -1
  711. package/dist/types/vendor/zlib.d.js +0 -1
  712. package/dist/types/vendor/zlib.d.js.map +0 -1
  713. package/dist/types/vendor/zlib.d.mjs +0 -1
  714. package/dist/types/vendor/zlib.d.mjs.map +0 -1
  715. package/dist/utils.js +0 -23
  716. package/dist/utils.js.map +0 -1
@@ -1,119 +0,0 @@
1
- // src/snaps/Timer.ts
2
- import { assert } from "@metamask/utils";
3
- var Timer = class {
4
- /**
5
- * If `ms` is smaller or equal to zero (including -Infinity), the callback is added to the event loop and executed async immediately
6
- * If `ms` is +Infinity the timer never finishes.
7
- *
8
- * @throws {@link TypeError}. If `ms` is NaN or negative.
9
- * @param ms - The number of milliseconds before the callback is called after started.
10
- */
11
- constructor(ms) {
12
- assert(
13
- !Number.isNaN(ms),
14
- new TypeError("Can't start a timer with NaN time")
15
- );
16
- assert(ms >= 0, new TypeError("Can't start a timer with negative time"));
17
- this.state = { value: "stopped", remaining: ms };
18
- }
19
- get status() {
20
- return this.state.value;
21
- }
22
- get remaining() {
23
- return this.state.remaining;
24
- }
25
- /**
26
- * Cancels the currently running timer and marks it finished.
27
- *
28
- * @throws {@link Error}. If it wasn't running or paused.
29
- */
30
- cancel() {
31
- assert(
32
- this.status === "paused" || this.status === "running",
33
- new Error("Tried to cancel a not running Timer")
34
- );
35
- this.onFinish(false);
36
- }
37
- /**
38
- * Marks the timer as finished prematurely and triggers the callback.
39
- *
40
- * @throws {@link Error}. If it wasn't running or paused.
41
- */
42
- finish() {
43
- assert(
44
- this.status !== "finished",
45
- new Error("Tried to finish a finished Timer.")
46
- );
47
- this.onFinish(true);
48
- }
49
- /**
50
- * Pauses a currently running timer, allowing it to resume later.
51
- *
52
- * @throws {@link Error}. If it wasn't running.
53
- */
54
- pause() {
55
- assert(
56
- this.state.value === "running",
57
- new Error("Tried to pause a not running Timer")
58
- );
59
- const { callback, start, timeout, remaining } = this.state;
60
- timeout !== void 0 && clearTimeout(timeout);
61
- this.state = {
62
- value: "paused",
63
- callback,
64
- remaining: remaining - (Date.now() - start)
65
- };
66
- }
67
- /**
68
- * Starts the timer.
69
- *
70
- * @param callback - The function that will be called after the timer finishes.
71
- * @throws {@link Error}. If it was already started.
72
- */
73
- start(callback) {
74
- assert(
75
- this.state.value === "stopped",
76
- new Error("Tried to start an already running Timer")
77
- );
78
- const { remaining } = this.state;
79
- this.state = { value: "paused", remaining, callback };
80
- this.resume();
81
- }
82
- /**
83
- * Resumes a currently paused timer.
84
- *
85
- * @throws {@link Error}. If it wasn't paused.
86
- */
87
- resume() {
88
- assert(
89
- this.state.value === "paused",
90
- new Error("Tried to resume not paused Timer")
91
- );
92
- const { remaining, callback } = this.state;
93
- const start = Date.now();
94
- let timeout;
95
- if (remaining !== Number.POSITIVE_INFINITY) {
96
- timeout = setTimeout(() => this.onFinish(true), remaining);
97
- }
98
- this.state = { value: "running", callback, remaining, start, timeout };
99
- }
100
- onFinish(shouldCall) {
101
- assert(this.state.value === "running" || this.state.value === "paused");
102
- if (this.state.value === "running" && this.state.timeout !== void 0) {
103
- clearTimeout(this.state.timeout);
104
- }
105
- const { callback, remaining } = this.state;
106
- this.state = {
107
- value: "finished",
108
- remaining: this.state.value === "running" ? remaining - (Date.now() - this.state.start) : remaining
109
- };
110
- if (shouldCall) {
111
- callback();
112
- }
113
- }
114
- };
115
-
116
- export {
117
- Timer
118
- };
119
- //# sourceMappingURL=chunk-XO7KDFBY.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/snaps/Timer.ts"],"sourcesContent":["import { assert } from '@metamask/utils';\n\nexport type TimerStatus = 'stopped' | 'paused' | 'running' | 'finished';\n\nexport class Timer {\n private state:\n | { value: 'stopped'; remaining: number }\n | {\n value: 'paused';\n remaining: number;\n callback: () => void;\n }\n | {\n value: 'running';\n remaining: number;\n callback: () => void;\n start: number;\n timeout?: unknown;\n }\n | { value: 'finished'; remaining: number };\n\n /**\n * If `ms` is smaller or equal to zero (including -Infinity), the callback is added to the event loop and executed async immediately\n * If `ms` is +Infinity the timer never finishes.\n *\n * @throws {@link TypeError}. If `ms` is NaN or negative.\n * @param ms - The number of milliseconds before the callback is called after started.\n */\n constructor(ms: number) {\n assert(\n !Number.isNaN(ms),\n new TypeError(\"Can't start a timer with NaN time\"),\n );\n assert(ms >= 0, new TypeError(\"Can't start a timer with negative time\"));\n this.state = { value: 'stopped', remaining: ms };\n }\n\n get status(): TimerStatus {\n return this.state.value;\n }\n\n get remaining(): number {\n return this.state.remaining;\n }\n\n /**\n * Cancels the currently running timer and marks it finished.\n *\n * @throws {@link Error}. If it wasn't running or paused.\n */\n cancel() {\n assert(\n this.status === 'paused' || this.status === 'running',\n new Error('Tried to cancel a not running Timer'),\n );\n this.onFinish(false);\n }\n\n /**\n * Marks the timer as finished prematurely and triggers the callback.\n *\n * @throws {@link Error}. If it wasn't running or paused.\n */\n finish() {\n assert(\n this.status !== 'finished',\n new Error('Tried to finish a finished Timer.'),\n );\n this.onFinish(true);\n }\n\n /**\n * Pauses a currently running timer, allowing it to resume later.\n *\n * @throws {@link Error}. If it wasn't running.\n */\n pause() {\n assert(\n this.state.value === 'running',\n new Error('Tried to pause a not running Timer'),\n );\n\n const { callback, start, timeout, remaining } = this.state;\n\n timeout !== undefined && clearTimeout(timeout as any);\n this.state = {\n value: 'paused',\n callback,\n remaining: remaining - (Date.now() - start),\n };\n }\n\n /**\n * Starts the timer.\n *\n * @param callback - The function that will be called after the timer finishes.\n * @throws {@link Error}. If it was already started.\n */\n start(callback: () => void) {\n assert(\n this.state.value === 'stopped',\n new Error('Tried to start an already running Timer'),\n );\n\n const { remaining } = this.state;\n this.state = { value: 'paused', remaining, callback };\n this.resume();\n }\n\n /**\n * Resumes a currently paused timer.\n *\n * @throws {@link Error}. If it wasn't paused.\n */\n resume() {\n assert(\n this.state.value === 'paused',\n new Error('Tried to resume not paused Timer'),\n );\n const { remaining, callback } = this.state;\n const start = Date.now();\n\n let timeout: unknown;\n // setTimeout returns immediately on +Infinity which we use\n if (remaining !== Number.POSITIVE_INFINITY) {\n timeout = setTimeout(() => this.onFinish(true), remaining);\n }\n\n this.state = { value: 'running', callback, remaining, start, timeout };\n }\n\n private onFinish(shouldCall: boolean) {\n assert(this.state.value === 'running' || this.state.value === 'paused');\n\n if (this.state.value === 'running' && this.state.timeout !== undefined) {\n clearTimeout(this.state.timeout as any);\n }\n\n const { callback, remaining } = this.state;\n this.state = {\n value: 'finished',\n remaining:\n this.state.value === 'running'\n ? remaining - (Date.now() - this.state.start)\n : remaining,\n };\n\n if (shouldCall) {\n callback();\n }\n }\n}\n"],"mappings":";AAAA,SAAS,cAAc;AAIhB,IAAM,QAAN,MAAY;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAwBjB,YAAY,IAAY;AACtB;AAAA,MACE,CAAC,OAAO,MAAM,EAAE;AAAA,MAChB,IAAI,UAAU,mCAAmC;AAAA,IACnD;AACA,WAAO,MAAM,GAAG,IAAI,UAAU,wCAAwC,CAAC;AACvE,SAAK,QAAQ,EAAE,OAAO,WAAW,WAAW,GAAG;AAAA,EACjD;AAAA,EAEA,IAAI,SAAsB;AACxB,WAAO,KAAK,MAAM;AAAA,EACpB;AAAA,EAEA,IAAI,YAAoB;AACtB,WAAO,KAAK,MAAM;AAAA,EACpB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,SAAS;AACP;AAAA,MACE,KAAK,WAAW,YAAY,KAAK,WAAW;AAAA,MAC5C,IAAI,MAAM,qCAAqC;AAAA,IACjD;AACA,SAAK,SAAS,KAAK;AAAA,EACrB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,SAAS;AACP;AAAA,MACE,KAAK,WAAW;AAAA,MAChB,IAAI,MAAM,mCAAmC;AAAA,IAC/C;AACA,SAAK,SAAS,IAAI;AAAA,EACpB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,QAAQ;AACN;AAAA,MACE,KAAK,MAAM,UAAU;AAAA,MACrB,IAAI,MAAM,oCAAoC;AAAA,IAChD;AAEA,UAAM,EAAE,UAAU,OAAO,SAAS,UAAU,IAAI,KAAK;AAErD,gBAAY,UAAa,aAAa,OAAc;AACpD,SAAK,QAAQ;AAAA,MACX,OAAO;AAAA,MACP;AAAA,MACA,WAAW,aAAa,KAAK,IAAI,IAAI;AAAA,IACvC;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,UAAsB;AAC1B;AAAA,MACE,KAAK,MAAM,UAAU;AAAA,MACrB,IAAI,MAAM,yCAAyC;AAAA,IACrD;AAEA,UAAM,EAAE,UAAU,IAAI,KAAK;AAC3B,SAAK,QAAQ,EAAE,OAAO,UAAU,WAAW,SAAS;AACpD,SAAK,OAAO;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,SAAS;AACP;AAAA,MACE,KAAK,MAAM,UAAU;AAAA,MACrB,IAAI,MAAM,kCAAkC;AAAA,IAC9C;AACA,UAAM,EAAE,WAAW,SAAS,IAAI,KAAK;AACrC,UAAM,QAAQ,KAAK,IAAI;AAEvB,QAAI;AAEJ,QAAI,cAAc,OAAO,mBAAmB;AAC1C,gBAAU,WAAW,MAAM,KAAK,SAAS,IAAI,GAAG,SAAS;AAAA,IAC3D;AAEA,SAAK,QAAQ,EAAE,OAAO,WAAW,UAAU,WAAW,OAAO,QAAQ;AAAA,EACvE;AAAA,EAEQ,SAAS,YAAqB;AACpC,WAAO,KAAK,MAAM,UAAU,aAAa,KAAK,MAAM,UAAU,QAAQ;AAEtE,QAAI,KAAK,MAAM,UAAU,aAAa,KAAK,MAAM,YAAY,QAAW;AACtE,mBAAa,KAAK,MAAM,OAAc;AAAA,IACxC;AAEA,UAAM,EAAE,UAAU,UAAU,IAAI,KAAK;AACrC,SAAK,QAAQ;AAAA,MACX,OAAO;AAAA,MACP,WACE,KAAK,MAAM,UAAU,YACjB,aAAa,KAAK,IAAI,IAAI,KAAK,MAAM,SACrC;AAAA,IACR;AAEA,QAAI,YAAY;AACd,eAAS;AAAA,IACX;AAAA,EACF;AACF;","names":[]}
@@ -1,82 +0,0 @@
1
- import {
2
- AbstractExecutionService
3
- } from "./chunk-TSDUJNOP.mjs";
4
- import {
5
- ProxyPostMessageStream
6
- } from "./chunk-ZVOYOZFT.mjs";
7
- import {
8
- __privateAdd,
9
- __privateGet,
10
- __privateSet
11
- } from "./chunk-YRZVIDCF.mjs";
12
-
13
- // src/services/proxy/ProxyExecutionService.ts
14
- import { nanoid } from "nanoid";
15
- var _stream;
16
- var ProxyExecutionService = class extends AbstractExecutionService {
17
- /**
18
- * Create a new proxy execution service.
19
- *
20
- * @param args - The constructor arguments.
21
- * @param args.messenger - The messenger to use for communication with the
22
- * `SnapController`.
23
- * @param args.setupSnapProvider - The function to use to set up the snap
24
- * provider.
25
- * @param args.stream - The stream to use for communicating with the proxy
26
- * executor.
27
- */
28
- constructor({
29
- stream,
30
- messenger,
31
- setupSnapProvider
32
- }) {
33
- super({
34
- messenger,
35
- setupSnapProvider,
36
- usePing: false
37
- });
38
- __privateAdd(this, _stream, void 0);
39
- __privateSet(this, _stream, stream);
40
- }
41
- /**
42
- * Send a termination command to the proxy stream.
43
- *
44
- * @param job - The job to terminate.
45
- */
46
- async terminateJob(job) {
47
- __privateGet(this, _stream).write({
48
- jobId: job.id,
49
- data: {
50
- jsonrpc: "2.0",
51
- method: "terminateJob",
52
- id: nanoid()
53
- }
54
- });
55
- }
56
- /**
57
- * Create a new stream for the specified job. This wraps the root stream
58
- * in a stream specific to the job.
59
- *
60
- * @param jobId - The job ID.
61
- */
62
- async initEnvStream(jobId) {
63
- const stream = new ProxyPostMessageStream({
64
- stream: __privateGet(this, _stream),
65
- jobId
66
- });
67
- await new Promise((resolve) => {
68
- stream.once("data", resolve);
69
- stream.write({
70
- name: "command",
71
- data: { jsonrpc: "2.0", method: "ping", id: nanoid() }
72
- });
73
- });
74
- return { worker: jobId, stream };
75
- }
76
- };
77
- _stream = new WeakMap();
78
-
79
- export {
80
- ProxyExecutionService
81
- };
82
- //# sourceMappingURL=chunk-XOSHP4J3.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/services/proxy/ProxyExecutionService.ts"],"sourcesContent":["import type { BasePostMessageStream } from '@metamask/post-message-stream';\nimport { nanoid } from 'nanoid';\n\nimport type {\n ExecutionServiceArgs,\n TerminateJobArgs,\n} from '../AbstractExecutionService';\nimport { AbstractExecutionService } from '../AbstractExecutionService';\nimport { ProxyPostMessageStream } from '../ProxyPostMessageStream';\n\ntype ProxyExecutionEnvironmentServiceArgs = {\n stream: BasePostMessageStream;\n} & ExecutionServiceArgs;\n\nexport class ProxyExecutionService extends AbstractExecutionService<string> {\n readonly #stream: BasePostMessageStream;\n\n /**\n * Create a new proxy execution service.\n *\n * @param args - The constructor arguments.\n * @param args.messenger - The messenger to use for communication with the\n * `SnapController`.\n * @param args.setupSnapProvider - The function to use to set up the snap\n * provider.\n * @param args.stream - The stream to use for communicating with the proxy\n * executor.\n */\n constructor({\n stream,\n messenger,\n setupSnapProvider,\n }: ProxyExecutionEnvironmentServiceArgs) {\n super({\n messenger,\n setupSnapProvider,\n usePing: false,\n });\n\n this.#stream = stream;\n }\n\n /**\n * Send a termination command to the proxy stream.\n *\n * @param job - The job to terminate.\n */\n protected async terminateJob(job: TerminateJobArgs<string>) {\n // The `AbstractExecutionService` will have already closed the job stream,\n // so we write to the runtime stream directly.\n this.#stream.write({\n jobId: job.id,\n data: {\n jsonrpc: '2.0',\n method: 'terminateJob',\n id: nanoid(),\n },\n });\n }\n\n /**\n * Create a new stream for the specified job. This wraps the root stream\n * in a stream specific to the job.\n *\n * @param jobId - The job ID.\n */\n protected async initEnvStream(jobId: string) {\n const stream = new ProxyPostMessageStream({\n stream: this.#stream,\n jobId,\n });\n\n // Send a request and await any response before continuing\n // This simulates the behaviour of non-proxy environments by effectively awaiting\n // the load of the environment inside the proxy environment\n // This assumes the proxy environment is already loaded before this function is called\n await new Promise((resolve) => {\n stream.once('data', resolve);\n stream.write({\n name: 'command',\n data: { jsonrpc: '2.0', method: 'ping', id: nanoid() },\n });\n });\n\n return { worker: jobId, stream };\n }\n}\n"],"mappings":";;;;;;;;;;;;;AACA,SAAS,cAAc;AADvB;AAcO,IAAM,wBAAN,cAAoC,yBAAiC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAc1E,YAAY;AAAA,IACV;AAAA,IACA;AAAA,IACA;AAAA,EACF,GAAyC;AACvC,UAAM;AAAA,MACJ;AAAA,MACA;AAAA,MACA,SAAS;AAAA,IACX,CAAC;AAtBH,uBAAS,SAAT;AAwBE,uBAAK,SAAU;AAAA,EACjB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAgB,aAAa,KAA+B;AAG1D,uBAAK,SAAQ,MAAM;AAAA,MACjB,OAAO,IAAI;AAAA,MACX,MAAM;AAAA,QACJ,SAAS;AAAA,QACT,QAAQ;AAAA,QACR,IAAI,OAAO;AAAA,MACb;AAAA,IACF,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAgB,cAAc,OAAe;AAC3C,UAAM,SAAS,IAAI,uBAAuB;AAAA,MACxC,QAAQ,mBAAK;AAAA,MACb;AAAA,IACF,CAAC;AAMD,UAAM,IAAI,QAAQ,CAAC,YAAY;AAC7B,aAAO,KAAK,QAAQ,OAAO;AAC3B,aAAO,MAAM;AAAA,QACX,MAAM;AAAA,QACN,MAAM,EAAE,SAAS,OAAO,QAAQ,QAAQ,IAAI,OAAO,EAAE;AAAA,MACvD,CAAC;AAAA,IACH,CAAC;AAED,WAAO,EAAE,QAAQ,OAAO,OAAO;AAAA,EACjC;AACF;AAvEW;","names":[]}
@@ -1,38 +0,0 @@
1
- var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
2
- get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
3
- }) : x)(function(x) {
4
- if (typeof require !== "undefined")
5
- return require.apply(this, arguments);
6
- throw Error('Dynamic require of "' + x + '" is not supported');
7
- });
8
- var __accessCheck = (obj, member, msg) => {
9
- if (!member.has(obj))
10
- throw TypeError("Cannot " + msg);
11
- };
12
- var __privateGet = (obj, member, getter) => {
13
- __accessCheck(obj, member, "read from private field");
14
- return getter ? getter.call(obj) : member.get(obj);
15
- };
16
- var __privateAdd = (obj, member, value) => {
17
- if (member.has(obj))
18
- throw TypeError("Cannot add the same private member more than once");
19
- member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
20
- };
21
- var __privateSet = (obj, member, value, setter) => {
22
- __accessCheck(obj, member, "write to private field");
23
- setter ? setter.call(obj, value) : member.set(obj, value);
24
- return value;
25
- };
26
- var __privateMethod = (obj, member, method) => {
27
- __accessCheck(obj, member, "access private method");
28
- return method;
29
- };
30
-
31
- export {
32
- __require,
33
- __privateGet,
34
- __privateAdd,
35
- __privateSet,
36
- __privateMethod
37
- };
38
- //# sourceMappingURL=chunk-YRZVIDCF.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -1,7 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});// src/snaps/selectors.ts
2
- var getRunnableSnaps = (snaps) => snaps.filter((snap) => snap.enabled && !snap.blocked);
3
-
4
-
5
-
6
- exports.getRunnableSnaps = getRunnableSnaps;
7
- //# sourceMappingURL=chunk-YYPUPKQY.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/snaps/selectors.ts"],"names":[],"mappings":";AAEO,IAAM,mBAAmB,CAA6B,UAC3D,MAAM,OAAO,CAAC,SAAS,KAAK,WAAW,CAAC,KAAK,OAAO","sourcesContent":["import type { TruncatedSnap } from '@metamask/snaps-utils';\n\nexport const getRunnableSnaps = <Snap extends TruncatedSnap>(snaps: Snap[]) =>\n snaps.filter((snap) => snap.enabled && !snap.blocked);\n"]}
@@ -1,283 +0,0 @@
1
- import {
2
- getRunnableSnaps
3
- } from "./chunk-P7Y6MIZW.mjs";
4
- import {
5
- Timer
6
- } from "./chunk-XO7KDFBY.mjs";
7
- import {
8
- __privateAdd,
9
- __privateGet,
10
- __privateSet
11
- } from "./chunk-YRZVIDCF.mjs";
12
-
13
- // src/cronjob/CronjobController.ts
14
- import { BaseController } from "@metamask/base-controller";
15
- import {
16
- getCronjobCaveatJobs,
17
- SnapEndowments
18
- } from "@metamask/snaps-rpc-methods";
19
- import {
20
- HandlerType,
21
- parseCronExpression,
22
- logError
23
- } from "@metamask/snaps-utils";
24
- import { Duration, inMilliseconds } from "@metamask/utils";
25
- var DAILY_TIMEOUT = inMilliseconds(24, Duration.Hour);
26
- var controllerName = "CronjobController";
27
- var _messenger, _dailyTimer, _timers, _snapIds;
28
- var CronjobController = class extends BaseController {
29
- constructor({ messenger, state }) {
30
- super({
31
- messenger,
32
- metadata: {
33
- jobs: { persist: true, anonymous: false }
34
- },
35
- name: controllerName,
36
- state: {
37
- jobs: {},
38
- ...state
39
- }
40
- });
41
- __privateAdd(this, _messenger, void 0);
42
- __privateAdd(this, _dailyTimer, void 0);
43
- __privateAdd(this, _timers, void 0);
44
- // Mapping from jobId to snapId
45
- __privateAdd(this, _snapIds, void 0);
46
- __privateSet(this, _timers, /* @__PURE__ */ new Map());
47
- __privateSet(this, _snapIds, /* @__PURE__ */ new Map());
48
- __privateSet(this, _messenger, messenger);
49
- this._handleSnapRegisterEvent = this._handleSnapRegisterEvent.bind(this);
50
- this._handleSnapUnregisterEvent = this._handleSnapUnregisterEvent.bind(this);
51
- this._handleEventSnapUpdated = this._handleEventSnapUpdated.bind(this);
52
- this.messagingSystem.subscribe(
53
- "SnapController:snapInstalled",
54
- this._handleSnapRegisterEvent
55
- );
56
- this.messagingSystem.subscribe(
57
- "SnapController:snapUninstalled",
58
- this._handleSnapUnregisterEvent
59
- );
60
- this.messagingSystem.subscribe(
61
- "SnapController:snapEnabled",
62
- this._handleSnapRegisterEvent
63
- );
64
- this.messagingSystem.subscribe(
65
- "SnapController:snapDisabled",
66
- this._handleSnapUnregisterEvent
67
- );
68
- this.messagingSystem.subscribe(
69
- "SnapController:snapUpdated",
70
- this._handleEventSnapUpdated
71
- );
72
- this.dailyCheckIn().catch((error) => {
73
- logError(error);
74
- });
75
- }
76
- /**
77
- * Retrieve all cronjob specifications for all runnable snaps.
78
- *
79
- * @returns Array of Cronjob specifications.
80
- */
81
- getAllJobs() {
82
- const snaps = this.messagingSystem.call("SnapController:getAll");
83
- const filteredSnaps = getRunnableSnaps(snaps);
84
- const jobs = filteredSnaps.map((snap) => this.getSnapJobs(snap.id));
85
- return jobs.flat().filter((job) => job !== void 0);
86
- }
87
- /**
88
- * Retrieve all Cronjob specifications for a Snap.
89
- *
90
- * @param snapId - ID of a Snap.
91
- * @returns Array of Cronjob specifications.
92
- */
93
- getSnapJobs(snapId) {
94
- const permissions = __privateGet(this, _messenger).call(
95
- "PermissionController:getPermissions",
96
- snapId
97
- );
98
- const permission = permissions?.[SnapEndowments.Cronjob];
99
- const definitions = getCronjobCaveatJobs(permission);
100
- return definitions?.map((definition, idx) => {
101
- return { ...definition, id: `${snapId}-${idx}`, snapId };
102
- });
103
- }
104
- /**
105
- * Register cron jobs for a given snap by getting specification from a permission caveats.
106
- * Once registered, each job will be scheduled.
107
- *
108
- * @param snapId - ID of a snap.
109
- */
110
- register(snapId) {
111
- const jobs = this.getSnapJobs(snapId);
112
- jobs?.forEach((job) => this.schedule(job));
113
- }
114
- /**
115
- * Schedule a new job.
116
- * This will interpret the cron expression and tell the timer to execute the job
117
- * at the next suitable point in time.
118
- * Job last run state will be initialized afterwards.
119
- *
120
- * Note: Schedule will be skipped if the job's execution time is too far in the future and
121
- * will be revisited on a daily check.
122
- *
123
- * @param job - Cronjob specification.
124
- */
125
- schedule(job) {
126
- if (__privateGet(this, _timers).has(job.id)) {
127
- return;
128
- }
129
- const parsed = parseCronExpression(job.expression);
130
- const next = parsed.next();
131
- const now = /* @__PURE__ */ new Date();
132
- const ms = next.getTime() - now.getTime();
133
- if (ms > DAILY_TIMEOUT) {
134
- return;
135
- }
136
- const timer = new Timer(ms);
137
- timer.start(() => {
138
- this.executeCronjob(job).catch((error) => {
139
- logError(error);
140
- });
141
- __privateGet(this, _timers).delete(job.id);
142
- this.schedule(job);
143
- });
144
- if (!this.state.jobs[job.id]?.lastRun) {
145
- this.updateJobLastRunState(job.id, 0);
146
- }
147
- __privateGet(this, _timers).set(job.id, timer);
148
- __privateGet(this, _snapIds).set(job.id, job.snapId);
149
- }
150
- /**
151
- * Execute job.
152
- *
153
- * @param job - Cronjob specification.
154
- */
155
- async executeCronjob(job) {
156
- this.updateJobLastRunState(job.id, Date.now());
157
- await __privateGet(this, _messenger).call("SnapController:handleRequest", {
158
- snapId: job.snapId,
159
- origin: "",
160
- handler: HandlerType.OnCronjob,
161
- request: job.request
162
- });
163
- }
164
- /**
165
- * Unregister all jobs related to the given snapId.
166
- *
167
- * @param snapId - ID of a snap.
168
- */
169
- unregister(snapId) {
170
- const jobs = [...__privateGet(this, _snapIds).entries()].filter(
171
- ([_, jobSnapId]) => jobSnapId === snapId
172
- );
173
- if (jobs.length) {
174
- jobs.forEach(([id]) => {
175
- const timer = __privateGet(this, _timers).get(id);
176
- if (timer) {
177
- timer.cancel();
178
- __privateGet(this, _timers).delete(id);
179
- __privateGet(this, _snapIds).delete(id);
180
- }
181
- });
182
- }
183
- }
184
- /**
185
- * Update time of a last run for the Cronjob specified by ID.
186
- *
187
- * @param jobId - ID of a cron job.
188
- * @param lastRun - Unix timestamp when the job was last ran.
189
- */
190
- updateJobLastRunState(jobId, lastRun) {
191
- this.update((state) => {
192
- state.jobs[jobId] = {
193
- lastRun
194
- };
195
- });
196
- }
197
- /**
198
- * Runs every 24 hours to check if new jobs need to be scheduled.
199
- *
200
- * This is necessary for longer running jobs that execute with more than 24 hours between them.
201
- */
202
- async dailyCheckIn() {
203
- const jobs = this.getAllJobs();
204
- for (const job of jobs) {
205
- const parsed = parseCronExpression(job.expression);
206
- const lastRun = this.state.jobs[job.id]?.lastRun;
207
- if (lastRun !== void 0 && parsed.hasPrev() && parsed.prev().getTime() > lastRun) {
208
- await this.executeCronjob(job);
209
- }
210
- this.schedule(job);
211
- }
212
- __privateSet(this, _dailyTimer, new Timer(DAILY_TIMEOUT));
213
- __privateGet(this, _dailyTimer).start(() => {
214
- this.dailyCheckIn().catch((error) => {
215
- logError(error);
216
- });
217
- });
218
- }
219
- /**
220
- * Run controller teardown process and unsubscribe from Snap events.
221
- */
222
- destroy() {
223
- super.destroy();
224
- this.messagingSystem.unsubscribe(
225
- "SnapController:snapInstalled",
226
- this._handleSnapRegisterEvent
227
- );
228
- this.messagingSystem.unsubscribe(
229
- "SnapController:snapUninstalled",
230
- this._handleSnapUnregisterEvent
231
- );
232
- this.messagingSystem.unsubscribe(
233
- "SnapController:snapEnabled",
234
- this._handleSnapRegisterEvent
235
- );
236
- this.messagingSystem.unsubscribe(
237
- "SnapController:snapDisabled",
238
- this._handleSnapUnregisterEvent
239
- );
240
- this.messagingSystem.unsubscribe(
241
- "SnapController:snapUpdated",
242
- this._handleEventSnapUpdated
243
- );
244
- __privateGet(this, _snapIds).forEach((snapId) => {
245
- this.unregister(snapId);
246
- });
247
- }
248
- /**
249
- * Handle events that should cause cronjobs to be registered.
250
- *
251
- * @param snap - Basic Snap information.
252
- */
253
- _handleSnapRegisterEvent(snap) {
254
- this.register(snap.id);
255
- }
256
- /**
257
- * Handle events that should cause cronjobs to be unregistered.
258
- *
259
- * @param snap - Basic Snap information.
260
- */
261
- _handleSnapUnregisterEvent(snap) {
262
- this.unregister(snap.id);
263
- }
264
- /**
265
- * Handle cron jobs on 'snapUpdated' event.
266
- *
267
- * @param snap - Basic Snap information.
268
- */
269
- _handleEventSnapUpdated(snap) {
270
- this.unregister(snap.id);
271
- this.register(snap.id);
272
- }
273
- };
274
- _messenger = new WeakMap();
275
- _dailyTimer = new WeakMap();
276
- _timers = new WeakMap();
277
- _snapIds = new WeakMap();
278
-
279
- export {
280
- DAILY_TIMEOUT,
281
- CronjobController
282
- };
283
- //# sourceMappingURL=chunk-Z4BUMSH3.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/cronjob/CronjobController.ts"],"sourcesContent":["import type {\n RestrictedControllerMessenger,\n ControllerGetStateAction,\n ControllerStateChangeEvent,\n} from '@metamask/base-controller';\nimport { BaseController } from '@metamask/base-controller';\nimport type { GetPermissions } from '@metamask/permission-controller';\nimport {\n getCronjobCaveatJobs,\n SnapEndowments,\n} from '@metamask/snaps-rpc-methods';\nimport type { SnapId } from '@metamask/snaps-sdk';\nimport type {\n TruncatedSnap,\n CronjobSpecification,\n} from '@metamask/snaps-utils';\nimport {\n HandlerType,\n parseCronExpression,\n logError,\n} from '@metamask/snaps-utils';\nimport { Duration, inMilliseconds } from '@metamask/utils';\n\nimport type {\n GetAllSnaps,\n HandleSnapRequest,\n SnapDisabled,\n SnapEnabled,\n SnapInstalled,\n SnapUninstalled,\n SnapUpdated,\n} from '..';\nimport { getRunnableSnaps } from '..';\nimport { Timer } from '../snaps/Timer';\n\nexport type CronjobControllerGetStateAction = ControllerGetStateAction<\n typeof controllerName,\n CronjobControllerState\n>;\nexport type CronjobControllerStateChangeEvent = ControllerStateChangeEvent<\n typeof controllerName,\n CronjobControllerState\n>;\nexport type CronjobControllerActions =\n | GetAllSnaps\n | HandleSnapRequest\n | GetPermissions\n | CronjobControllerGetStateAction;\n\nexport type CronjobControllerEvents =\n | SnapInstalled\n | SnapUninstalled\n | SnapUpdated\n | SnapEnabled\n | SnapDisabled\n | CronjobControllerStateChangeEvent;\n\nexport type CronjobControllerMessenger = RestrictedControllerMessenger<\n typeof controllerName,\n CronjobControllerActions,\n CronjobControllerEvents,\n CronjobControllerActions['type'],\n CronjobControllerEvents['type']\n>;\n\nexport const DAILY_TIMEOUT = inMilliseconds(24, Duration.Hour);\n\nexport type CronjobControllerArgs = {\n messenger: CronjobControllerMessenger;\n /**\n * Persisted state that will be used for rehydration.\n */\n state?: CronjobControllerState;\n};\n\nexport type Cronjob = {\n timer?: Timer;\n id: string;\n snapId: SnapId;\n} & CronjobSpecification;\n\nexport type StoredJobInformation = {\n lastRun: number;\n};\n\nexport type CronjobControllerState = {\n jobs: Record<string, StoredJobInformation>;\n};\n\nconst controllerName = 'CronjobController';\n\n/**\n * Use this controller to register and schedule periodically executed jobs\n * using RPC method hooks.\n */\nexport class CronjobController extends BaseController<\n typeof controllerName,\n CronjobControllerState,\n CronjobControllerMessenger\n> {\n #messenger: CronjobControllerMessenger;\n\n #dailyTimer!: Timer;\n\n #timers: Map<string, Timer>;\n\n // Mapping from jobId to snapId\n #snapIds: Map<string, string>;\n\n constructor({ messenger, state }: CronjobControllerArgs) {\n super({\n messenger,\n metadata: {\n jobs: { persist: true, anonymous: false },\n },\n name: controllerName,\n state: {\n jobs: {},\n ...state,\n },\n });\n this.#timers = new Map();\n this.#snapIds = new Map();\n this.#messenger = messenger;\n\n this._handleSnapRegisterEvent = this._handleSnapRegisterEvent.bind(this);\n this._handleSnapUnregisterEvent =\n this._handleSnapUnregisterEvent.bind(this);\n this._handleEventSnapUpdated = this._handleEventSnapUpdated.bind(this);\n\n // Subscribe to Snap events\n /* eslint-disable @typescript-eslint/unbound-method */\n this.messagingSystem.subscribe(\n 'SnapController:snapInstalled',\n this._handleSnapRegisterEvent,\n );\n\n this.messagingSystem.subscribe(\n 'SnapController:snapUninstalled',\n this._handleSnapUnregisterEvent,\n );\n\n this.messagingSystem.subscribe(\n 'SnapController:snapEnabled',\n this._handleSnapRegisterEvent,\n );\n\n this.messagingSystem.subscribe(\n 'SnapController:snapDisabled',\n this._handleSnapUnregisterEvent,\n );\n\n this.messagingSystem.subscribe(\n 'SnapController:snapUpdated',\n this._handleEventSnapUpdated,\n );\n /* eslint-enable @typescript-eslint/unbound-method */\n\n this.dailyCheckIn().catch((error) => {\n logError(error);\n });\n }\n\n /**\n * Retrieve all cronjob specifications for all runnable snaps.\n *\n * @returns Array of Cronjob specifications.\n */\n private getAllJobs(): Cronjob[] {\n const snaps = this.messagingSystem.call('SnapController:getAll');\n const filteredSnaps = getRunnableSnaps(snaps);\n\n const jobs = filteredSnaps.map((snap) => this.getSnapJobs(snap.id));\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n return jobs.flat().filter((job) => job !== undefined) as Cronjob[];\n }\n\n /**\n * Retrieve all Cronjob specifications for a Snap.\n *\n * @param snapId - ID of a Snap.\n * @returns Array of Cronjob specifications.\n */\n private getSnapJobs(snapId: SnapId): Cronjob[] | undefined {\n const permissions = this.#messenger.call(\n 'PermissionController:getPermissions',\n snapId,\n );\n\n const permission = permissions?.[SnapEndowments.Cronjob];\n const definitions = getCronjobCaveatJobs(permission);\n\n return definitions?.map((definition, idx) => {\n return { ...definition, id: `${snapId}-${idx}`, snapId };\n });\n }\n\n /**\n * Register cron jobs for a given snap by getting specification from a permission caveats.\n * Once registered, each job will be scheduled.\n *\n * @param snapId - ID of a snap.\n */\n register(snapId: SnapId) {\n const jobs = this.getSnapJobs(snapId);\n jobs?.forEach((job) => this.schedule(job));\n }\n\n /**\n * Schedule a new job.\n * This will interpret the cron expression and tell the timer to execute the job\n * at the next suitable point in time.\n * Job last run state will be initialized afterwards.\n *\n * Note: Schedule will be skipped if the job's execution time is too far in the future and\n * will be revisited on a daily check.\n *\n * @param job - Cronjob specification.\n */\n private schedule(job: Cronjob) {\n if (this.#timers.has(job.id)) {\n return;\n }\n\n const parsed = parseCronExpression(job.expression);\n const next = parsed.next();\n const now = new Date();\n const ms = next.getTime() - now.getTime();\n\n // Don't schedule this job yet as it is too far in the future\n if (ms > DAILY_TIMEOUT) {\n return;\n }\n\n const timer = new Timer(ms);\n timer.start(() => {\n this.executeCronjob(job).catch((error) => {\n // TODO: Decide how to handle errors.\n logError(error);\n });\n\n this.#timers.delete(job.id);\n this.schedule(job);\n });\n\n if (!this.state.jobs[job.id]?.lastRun) {\n this.updateJobLastRunState(job.id, 0); // 0 for init, never ran actually\n }\n\n this.#timers.set(job.id, timer);\n this.#snapIds.set(job.id, job.snapId);\n }\n\n /**\n * Execute job.\n *\n * @param job - Cronjob specification.\n */\n private async executeCronjob(job: Cronjob) {\n this.updateJobLastRunState(job.id, Date.now());\n await this.#messenger.call('SnapController:handleRequest', {\n snapId: job.snapId,\n origin: '',\n handler: HandlerType.OnCronjob,\n request: job.request,\n });\n }\n\n /**\n * Unregister all jobs related to the given snapId.\n *\n * @param snapId - ID of a snap.\n */\n unregister(snapId: string) {\n const jobs = [...this.#snapIds.entries()].filter(\n ([_, jobSnapId]) => jobSnapId === snapId,\n );\n\n if (jobs.length) {\n jobs.forEach(([id]) => {\n const timer = this.#timers.get(id);\n if (timer) {\n timer.cancel();\n this.#timers.delete(id);\n this.#snapIds.delete(id);\n }\n });\n }\n }\n\n /**\n * Update time of a last run for the Cronjob specified by ID.\n *\n * @param jobId - ID of a cron job.\n * @param lastRun - Unix timestamp when the job was last ran.\n */\n private updateJobLastRunState(jobId: string, lastRun: number) {\n this.update((state) => {\n state.jobs[jobId] = {\n lastRun,\n };\n });\n }\n\n /**\n * Runs every 24 hours to check if new jobs need to be scheduled.\n *\n * This is necessary for longer running jobs that execute with more than 24 hours between them.\n */\n async dailyCheckIn() {\n const jobs = this.getAllJobs();\n\n for (const job of jobs) {\n const parsed = parseCronExpression(job.expression);\n const lastRun = this.state.jobs[job.id]?.lastRun;\n // If a job was supposed to run while we were shut down but wasn't we run it now\n if (\n lastRun !== undefined &&\n parsed.hasPrev() &&\n parsed.prev().getTime() > lastRun\n ) {\n await this.executeCronjob(job);\n }\n\n // Try scheduling, will fail if an existing scheduled job is found\n this.schedule(job);\n }\n\n this.#dailyTimer = new Timer(DAILY_TIMEOUT);\n this.#dailyTimer.start(() => {\n this.dailyCheckIn().catch((error) => {\n // TODO: Decide how to handle errors.\n logError(error);\n });\n });\n }\n\n /**\n * Run controller teardown process and unsubscribe from Snap events.\n */\n destroy() {\n super.destroy();\n\n /* eslint-disable @typescript-eslint/unbound-method */\n this.messagingSystem.unsubscribe(\n 'SnapController:snapInstalled',\n this._handleSnapRegisterEvent,\n );\n\n this.messagingSystem.unsubscribe(\n 'SnapController:snapUninstalled',\n this._handleSnapUnregisterEvent,\n );\n\n this.messagingSystem.unsubscribe(\n 'SnapController:snapEnabled',\n this._handleSnapRegisterEvent,\n );\n\n this.messagingSystem.unsubscribe(\n 'SnapController:snapDisabled',\n this._handleSnapUnregisterEvent,\n );\n\n this.messagingSystem.unsubscribe(\n 'SnapController:snapUpdated',\n this._handleEventSnapUpdated,\n );\n /* eslint-enable @typescript-eslint/unbound-method */\n\n this.#snapIds.forEach((snapId) => {\n this.unregister(snapId);\n });\n }\n\n /**\n * Handle events that should cause cronjobs to be registered.\n *\n * @param snap - Basic Snap information.\n */\n private _handleSnapRegisterEvent(snap: TruncatedSnap) {\n this.register(snap.id);\n }\n\n /**\n * Handle events that should cause cronjobs to be unregistered.\n *\n * @param snap - Basic Snap information.\n */\n private _handleSnapUnregisterEvent(snap: TruncatedSnap) {\n this.unregister(snap.id);\n }\n\n /**\n * Handle cron jobs on 'snapUpdated' event.\n *\n * @param snap - Basic Snap information.\n */\n private _handleEventSnapUpdated(snap: TruncatedSnap) {\n this.unregister(snap.id);\n this.register(snap.id);\n }\n}\n"],"mappings":"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","names":[]}