@metamask/snaps-controllers 1.0.2 → 2.0.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 (322) hide show
  1. package/CHANGELOG.md +31 -562
  2. package/dist/cjs/cronjob/CronjobController.js +294 -0
  3. package/dist/cjs/cronjob/CronjobController.js.map +1 -0
  4. package/dist/cjs/cronjob/index.js +20 -0
  5. package/dist/cjs/cronjob/index.js.map +1 -0
  6. package/dist/cjs/fsm.js +69 -0
  7. package/dist/cjs/fsm.js.map +1 -0
  8. package/dist/cjs/index.js +23 -0
  9. package/dist/cjs/index.js.map +1 -0
  10. package/dist/cjs/logging.js +15 -0
  11. package/dist/cjs/logging.js.map +1 -0
  12. package/dist/cjs/services/AbstractExecutionService.js +390 -0
  13. package/dist/cjs/services/AbstractExecutionService.js.map +1 -0
  14. package/dist/cjs/services/ExecutionService.js +7 -0
  15. package/dist/cjs/services/ExecutionService.js.map +1 -0
  16. package/dist/cjs/services/ProxyPostMessageStream.js +116 -0
  17. package/dist/cjs/services/ProxyPostMessageStream.js.map +1 -0
  18. package/dist/cjs/services/browser.js +32 -0
  19. package/dist/cjs/services/browser.js.map +1 -0
  20. package/dist/cjs/services/iframe/IframeExecutionService.js +54 -0
  21. package/dist/cjs/services/iframe/IframeExecutionService.js.map +1 -0
  22. package/dist/cjs/services/iframe/index.js +20 -0
  23. package/dist/cjs/services/iframe/index.js.map +1 -0
  24. package/dist/cjs/services/index.js +32 -0
  25. package/dist/cjs/services/index.js.map +1 -0
  26. package/dist/cjs/services/node/NodeProcessExecutionService.js +30 -0
  27. package/dist/cjs/services/node/NodeProcessExecutionService.js.map +1 -0
  28. package/dist/cjs/services/node/NodeThreadExecutionService.js +30 -0
  29. package/dist/cjs/services/node/NodeThreadExecutionService.js.map +1 -0
  30. package/dist/cjs/services/node/index.js +21 -0
  31. package/dist/cjs/services/node/index.js.map +1 -0
  32. package/dist/cjs/services/offscreen/OffscreenExecutionService.js +159 -0
  33. package/dist/cjs/services/offscreen/OffscreenExecutionService.js.map +1 -0
  34. package/dist/cjs/services/offscreen/index.js +20 -0
  35. package/dist/cjs/services/offscreen/index.js.map +1 -0
  36. package/dist/cjs/services/webworker/WebWorkerExecutionService.js +148 -0
  37. package/dist/cjs/services/webworker/WebWorkerExecutionService.js.map +1 -0
  38. package/dist/cjs/services/webworker/index.js +20 -0
  39. package/dist/cjs/services/webworker/index.js.map +1 -0
  40. package/dist/cjs/snaps/RequestQueue.js +63 -0
  41. package/dist/cjs/snaps/RequestQueue.js.map +1 -0
  42. package/dist/cjs/snaps/SnapController.js +1736 -0
  43. package/dist/cjs/snaps/SnapController.js.map +1 -0
  44. package/dist/cjs/snaps/Timer.js +117 -0
  45. package/dist/cjs/snaps/Timer.js.map +1 -0
  46. package/dist/cjs/snaps/endowments/cronjob.js +100 -0
  47. package/dist/cjs/snaps/endowments/cronjob.js.map +1 -0
  48. package/dist/cjs/snaps/endowments/enum.js +24 -0
  49. package/dist/cjs/snaps/endowments/enum.js.map +1 -0
  50. package/dist/cjs/snaps/endowments/ethereum-provider.js +43 -0
  51. package/dist/cjs/snaps/endowments/ethereum-provider.js.map +1 -0
  52. package/dist/cjs/snaps/endowments/index.js +90 -0
  53. package/dist/cjs/snaps/endowments/index.js.map +1 -0
  54. package/dist/cjs/snaps/endowments/lifecycle-hooks.js +37 -0
  55. package/dist/cjs/snaps/endowments/lifecycle-hooks.js.map +1 -0
  56. package/dist/cjs/snaps/endowments/long-running.js +38 -0
  57. package/dist/cjs/snaps/endowments/long-running.js.map +1 -0
  58. package/dist/cjs/snaps/endowments/name-lookup.js +106 -0
  59. package/dist/cjs/snaps/endowments/name-lookup.js.map +1 -0
  60. package/dist/cjs/snaps/endowments/network-access.js +44 -0
  61. package/dist/cjs/snaps/endowments/network-access.js.map +1 -0
  62. package/dist/cjs/snaps/endowments/rpc.js +99 -0
  63. package/dist/cjs/snaps/endowments/rpc.js.map +1 -0
  64. package/dist/cjs/snaps/endowments/transaction-insight.js +106 -0
  65. package/dist/cjs/snaps/endowments/transaction-insight.js.map +1 -0
  66. package/dist/cjs/snaps/endowments/web-assembly.js +42 -0
  67. package/dist/cjs/snaps/endowments/web-assembly.js.map +1 -0
  68. package/dist/cjs/snaps/index.js +25 -0
  69. package/dist/cjs/snaps/index.js.map +1 -0
  70. package/dist/cjs/snaps/location/http.js +106 -0
  71. package/dist/cjs/snaps/location/http.js.map +1 -0
  72. package/dist/cjs/snaps/location/index.js +23 -0
  73. package/dist/cjs/snaps/location/index.js.map +1 -0
  74. package/dist/cjs/snaps/location/local.js +93 -0
  75. package/dist/cjs/snaps/location/local.js.map +1 -0
  76. package/dist/cjs/snaps/location/location.js +34 -0
  77. package/dist/cjs/snaps/location/location.js.map +1 -0
  78. package/dist/cjs/snaps/location/npm.js +293 -0
  79. package/dist/cjs/snaps/location/npm.js.map +1 -0
  80. package/dist/cjs/snaps/permissions.js +61 -0
  81. package/dist/cjs/snaps/permissions.js.map +1 -0
  82. package/dist/cjs/snaps/registry/index.js +21 -0
  83. package/dist/cjs/snaps/registry/index.js.map +1 -0
  84. package/dist/cjs/snaps/registry/json.js +277 -0
  85. package/dist/cjs/snaps/registry/json.js.map +1 -0
  86. package/dist/cjs/snaps/registry/registry.js +18 -0
  87. package/dist/cjs/snaps/registry/registry.js.map +1 -0
  88. package/dist/cjs/snaps/selectors.js +13 -0
  89. package/dist/cjs/snaps/selectors.js.map +1 -0
  90. package/dist/cjs/utils.js +70 -0
  91. package/dist/cjs/utils.js.map +1 -0
  92. package/dist/esm/cronjob/CronjobController.js +279 -0
  93. package/dist/esm/cronjob/CronjobController.js.map +1 -0
  94. package/dist/esm/cronjob/index.js +3 -0
  95. package/dist/esm/cronjob/index.js.map +1 -0
  96. package/dist/esm/fsm.js +70 -0
  97. package/dist/esm/fsm.js.map +1 -0
  98. package/dist/esm/index.js +6 -0
  99. package/dist/esm/index.js.map +1 -0
  100. package/dist/esm/logging.js +10 -0
  101. package/dist/esm/logging.js.map +1 -0
  102. package/dist/esm/services/AbstractExecutionService.js +373 -0
  103. package/dist/esm/services/AbstractExecutionService.js.map +1 -0
  104. package/dist/esm/services/ExecutionService.js +4 -0
  105. package/dist/esm/services/ExecutionService.js.map +1 -0
  106. package/dist/esm/services/ProxyPostMessageStream.js +109 -0
  107. package/dist/esm/services/ProxyPostMessageStream.js.map +1 -0
  108. package/dist/esm/services/browser.js +9 -0
  109. package/dist/esm/services/browser.js.map +1 -0
  110. package/dist/esm/services/iframe/IframeExecutionService.js +44 -0
  111. package/dist/esm/services/iframe/IframeExecutionService.js.map +1 -0
  112. package/dist/esm/services/iframe/index.js +3 -0
  113. package/dist/esm/services/iframe/index.js.map +1 -0
  114. package/dist/esm/services/index.js +9 -0
  115. package/dist/esm/services/index.js.map +1 -0
  116. package/dist/esm/services/node/NodeProcessExecutionService.js +20 -0
  117. package/dist/esm/services/node/NodeProcessExecutionService.js.map +1 -0
  118. package/dist/esm/services/node/NodeThreadExecutionService.js +21 -0
  119. package/dist/esm/services/node/NodeThreadExecutionService.js.map +1 -0
  120. package/dist/esm/services/node/index.js +4 -0
  121. package/dist/esm/services/node/index.js.map +1 -0
  122. package/dist/esm/services/offscreen/OffscreenExecutionService.js +149 -0
  123. package/dist/esm/services/offscreen/OffscreenExecutionService.js.map +1 -0
  124. package/dist/esm/services/offscreen/index.js +3 -0
  125. package/dist/esm/services/offscreen/index.js.map +1 -0
  126. package/dist/esm/services/webworker/WebWorkerExecutionService.js +130 -0
  127. package/dist/esm/services/webworker/WebWorkerExecutionService.js.map +1 -0
  128. package/dist/esm/services/webworker/index.js +3 -0
  129. package/dist/esm/services/webworker/index.js.map +1 -0
  130. package/dist/esm/snaps/RequestQueue.js +53 -0
  131. package/dist/esm/snaps/RequestQueue.js.map +1 -0
  132. package/dist/esm/snaps/SnapController.js +1715 -0
  133. package/dist/esm/snaps/SnapController.js.map +1 -0
  134. package/dist/esm/snaps/Timer.js +107 -0
  135. package/dist/esm/snaps/Timer.js.map +1 -0
  136. package/dist/esm/snaps/endowments/cronjob.js +99 -0
  137. package/dist/esm/snaps/endowments/cronjob.js.map +1 -0
  138. package/dist/esm/snaps/endowments/enum.js +14 -0
  139. package/dist/esm/snaps/endowments/enum.js.map +1 -0
  140. package/dist/esm/snaps/endowments/ethereum-provider.js +33 -0
  141. package/dist/esm/snaps/endowments/ethereum-provider.js.map +1 -0
  142. package/dist/esm/snaps/endowments/index.js +47 -0
  143. package/dist/esm/snaps/endowments/index.js.map +1 -0
  144. package/dist/esm/snaps/endowments/lifecycle-hooks.js +27 -0
  145. package/dist/esm/snaps/endowments/lifecycle-hooks.js.map +1 -0
  146. package/dist/esm/snaps/endowments/long-running.js +28 -0
  147. package/dist/esm/snaps/endowments/long-running.js.map +1 -0
  148. package/dist/esm/snaps/endowments/name-lookup.js +98 -0
  149. package/dist/esm/snaps/endowments/name-lookup.js.map +1 -0
  150. package/dist/esm/snaps/endowments/network-access.js +34 -0
  151. package/dist/esm/snaps/endowments/network-access.js.map +1 -0
  152. package/dist/esm/snaps/endowments/rpc.js +88 -0
  153. package/dist/esm/snaps/endowments/rpc.js.map +1 -0
  154. package/dist/esm/snaps/endowments/transaction-insight.js +99 -0
  155. package/dist/esm/snaps/endowments/transaction-insight.js.map +1 -0
  156. package/dist/esm/snaps/endowments/web-assembly.js +32 -0
  157. package/dist/esm/snaps/endowments/web-assembly.js.map +1 -0
  158. package/dist/esm/snaps/index.js +8 -0
  159. package/dist/esm/snaps/index.js.map +1 -0
  160. package/dist/{snaps → esm/snaps}/location/http.js +52 -31
  161. package/dist/esm/snaps/location/http.js.map +1 -0
  162. package/dist/esm/snaps/location/index.js +6 -0
  163. package/dist/esm/snaps/location/index.js.map +1 -0
  164. package/dist/esm/snaps/location/local.js +83 -0
  165. package/dist/esm/snaps/location/local.js.map +1 -0
  166. package/dist/esm/snaps/location/location.js +30 -0
  167. package/dist/esm/snaps/location/location.js.map +1 -0
  168. package/dist/{snaps → esm/snaps}/location/npm.js +143 -117
  169. package/dist/esm/snaps/location/npm.js.map +1 -0
  170. package/dist/esm/snaps/permissions.js +50 -0
  171. package/dist/esm/snaps/permissions.js.map +1 -0
  172. package/dist/esm/snaps/registry/index.js +4 -0
  173. package/dist/esm/snaps/registry/index.js.map +1 -0
  174. package/dist/esm/snaps/registry/json.js +267 -0
  175. package/dist/esm/snaps/registry/json.js.map +1 -0
  176. package/dist/esm/snaps/registry/registry.js +8 -0
  177. package/dist/esm/snaps/registry/registry.js.map +1 -0
  178. package/dist/esm/snaps/selectors.js +3 -0
  179. package/dist/esm/snaps/selectors.js.map +1 -0
  180. package/dist/{utils.js → esm/utils.js} +21 -30
  181. package/dist/esm/utils.js.map +1 -0
  182. package/dist/{cronjob → types/cronjob}/CronjobController.d.ts +12 -11
  183. package/dist/{fsm.d.ts → types/fsm.d.ts} +1 -1
  184. package/dist/{index.d.ts → types/index.d.ts} +0 -1
  185. package/dist/{services → types/services}/AbstractExecutionService.d.ts +4 -4
  186. package/dist/{services → types/services}/ExecutionService.d.ts +3 -3
  187. package/dist/{services/offscreen/OffscreenPostMessageStream.d.ts → types/services/ProxyPostMessageStream.d.ts} +10 -10
  188. package/dist/{services → types/services}/browser.d.ts +2 -0
  189. package/dist/{services → types/services}/iframe/IframeExecutionService.d.ts +3 -2
  190. package/dist/{services → types/services}/index.d.ts +2 -0
  191. package/dist/{services → types/services}/node/NodeProcessExecutionService.d.ts +4 -3
  192. package/dist/{services → types/services}/node/NodeThreadExecutionService.d.ts +3 -2
  193. package/dist/{services → types/services}/offscreen/OffscreenExecutionService.d.ts +4 -3
  194. package/dist/types/services/offscreen/index.d.ts +1 -0
  195. package/dist/types/services/webworker/WebWorkerExecutionService.d.ts +45 -0
  196. package/dist/types/services/webworker/index.d.ts +1 -0
  197. package/dist/{snaps → types/snaps}/SnapController.d.ts +78 -39
  198. package/dist/{snaps → types/snaps}/endowments/cronjob.d.ts +5 -3
  199. package/dist/{snaps → types/snaps}/endowments/enum.d.ts +3 -2
  200. package/dist/{snaps → types/snaps}/endowments/ethereum-provider.d.ts +2 -1
  201. package/dist/{snaps → types/snaps}/endowments/index.d.ts +23 -14
  202. package/dist/types/snaps/endowments/lifecycle-hooks.d.ts +15 -0
  203. package/dist/{snaps → types/snaps}/endowments/long-running.d.ts +2 -1
  204. package/dist/types/snaps/endowments/name-lookup.d.ts +38 -0
  205. package/dist/{snaps → types/snaps}/endowments/network-access.d.ts +2 -1
  206. package/dist/{snaps → types/snaps}/endowments/rpc.d.ts +5 -3
  207. package/dist/{snaps → types/snaps}/endowments/transaction-insight.d.ts +3 -2
  208. package/dist/{snaps → types/snaps}/endowments/web-assembly.d.ts +2 -1
  209. package/dist/{snaps → types/snaps}/index.d.ts +2 -0
  210. package/dist/{snaps → types/snaps}/location/http.d.ts +3 -2
  211. package/dist/{snaps → types/snaps}/location/local.d.ts +3 -3
  212. package/dist/{snaps → types/snaps}/location/location.d.ts +2 -2
  213. package/dist/types/snaps/location/npm.d.ts +49 -0
  214. package/dist/types/snaps/permissions.d.ts +16 -0
  215. package/dist/{snaps → types/snaps}/registry/json.d.ts +5 -4
  216. package/dist/{snaps → types/snaps}/registry/registry.d.ts +5 -5
  217. package/dist/types/snaps/selectors.d.ts +2 -0
  218. package/dist/{utils.d.ts → types/utils.d.ts} +14 -14
  219. package/package.json +55 -45
  220. package/dist/cronjob/CronjobController.js +0 -248
  221. package/dist/cronjob/CronjobController.js.map +0 -1
  222. package/dist/cronjob/index.js +0 -18
  223. package/dist/cronjob/index.js.map +0 -1
  224. package/dist/fsm.js +0 -75
  225. package/dist/fsm.js.map +0 -1
  226. package/dist/index.js +0 -22
  227. package/dist/index.js.map +0 -1
  228. package/dist/logging.js +0 -13
  229. package/dist/logging.js.map +0 -1
  230. package/dist/multichain/MultiChainController.d.ts +0 -137
  231. package/dist/multichain/MultiChainController.js +0 -339
  232. package/dist/multichain/MultiChainController.js.map +0 -1
  233. package/dist/multichain/index.d.ts +0 -3
  234. package/dist/multichain/index.js +0 -20
  235. package/dist/multichain/index.js.map +0 -1
  236. package/dist/multichain/matching.d.ts +0 -9
  237. package/dist/multichain/matching.js +0 -57
  238. package/dist/multichain/matching.js.map +0 -1
  239. package/dist/multichain/middleware.d.ts +0 -14
  240. package/dist/multichain/middleware.js +0 -42
  241. package/dist/multichain/middleware.js.map +0 -1
  242. package/dist/services/AbstractExecutionService.js +0 -318
  243. package/dist/services/AbstractExecutionService.js.map +0 -1
  244. package/dist/services/ExecutionService.js +0 -4
  245. package/dist/services/ExecutionService.js.map +0 -1
  246. package/dist/services/browser.js +0 -22
  247. package/dist/services/browser.js.map +0 -1
  248. package/dist/services/iframe/IframeExecutionService.js +0 -30
  249. package/dist/services/iframe/IframeExecutionService.js.map +0 -1
  250. package/dist/services/iframe/index.js +0 -18
  251. package/dist/services/iframe/index.js.map +0 -1
  252. package/dist/services/index.js +0 -22
  253. package/dist/services/index.js.map +0 -1
  254. package/dist/services/node/NodeProcessExecutionService.js +0 -18
  255. package/dist/services/node/NodeProcessExecutionService.js.map +0 -1
  256. package/dist/services/node/NodeThreadExecutionService.js +0 -19
  257. package/dist/services/node/NodeThreadExecutionService.js.map +0 -1
  258. package/dist/services/node/index.js +0 -19
  259. package/dist/services/node/index.js.map +0 -1
  260. package/dist/services/offscreen/OffscreenExecutionService.js +0 -100
  261. package/dist/services/offscreen/OffscreenExecutionService.js.map +0 -1
  262. package/dist/services/offscreen/OffscreenPostMessageStream.js +0 -66
  263. package/dist/services/offscreen/OffscreenPostMessageStream.js.map +0 -1
  264. package/dist/services/offscreen/index.d.ts +0 -2
  265. package/dist/services/offscreen/index.js +0 -19
  266. package/dist/services/offscreen/index.js.map +0 -1
  267. package/dist/snaps/RequestQueue.js +0 -44
  268. package/dist/snaps/RequestQueue.js.map +0 -1
  269. package/dist/snaps/SnapController.js +0 -1478
  270. package/dist/snaps/SnapController.js.map +0 -1
  271. package/dist/snaps/Timer.js +0 -86
  272. package/dist/snaps/Timer.js.map +0 -1
  273. package/dist/snaps/endowments/cronjob.js +0 -105
  274. package/dist/snaps/endowments/cronjob.js.map +0 -1
  275. package/dist/snaps/endowments/enum.js +0 -15
  276. package/dist/snaps/endowments/enum.js.map +0 -1
  277. package/dist/snaps/endowments/ethereum-provider.js +0 -32
  278. package/dist/snaps/endowments/ethereum-provider.js.map +0 -1
  279. package/dist/snaps/endowments/index.js +0 -60
  280. package/dist/snaps/endowments/index.js.map +0 -1
  281. package/dist/snaps/endowments/keyring.d.ts +0 -40
  282. package/dist/snaps/endowments/keyring.js +0 -103
  283. package/dist/snaps/endowments/keyring.js.map +0 -1
  284. package/dist/snaps/endowments/long-running.js +0 -29
  285. package/dist/snaps/endowments/long-running.js.map +0 -1
  286. package/dist/snaps/endowments/network-access.js +0 -30
  287. package/dist/snaps/endowments/network-access.js.map +0 -1
  288. package/dist/snaps/endowments/rpc.js +0 -92
  289. package/dist/snaps/endowments/rpc.js.map +0 -1
  290. package/dist/snaps/endowments/transaction-insight.js +0 -106
  291. package/dist/snaps/endowments/transaction-insight.js.map +0 -1
  292. package/dist/snaps/endowments/web-assembly.js +0 -31
  293. package/dist/snaps/endowments/web-assembly.js.map +0 -1
  294. package/dist/snaps/index.js +0 -21
  295. package/dist/snaps/index.js.map +0 -1
  296. package/dist/snaps/location/http.js.map +0 -1
  297. package/dist/snaps/location/index.js +0 -21
  298. package/dist/snaps/location/index.js.map +0 -1
  299. package/dist/snaps/location/local.js +0 -51
  300. package/dist/snaps/location/local.js.map +0 -1
  301. package/dist/snaps/location/location.js +0 -34
  302. package/dist/snaps/location/location.js.map +0 -1
  303. package/dist/snaps/location/npm.d.ts +0 -28
  304. package/dist/snaps/location/npm.js.map +0 -1
  305. package/dist/snaps/registry/index.js +0 -19
  306. package/dist/snaps/registry/index.js.map +0 -1
  307. package/dist/snaps/registry/json.js +0 -197
  308. package/dist/snaps/registry/json.js.map +0 -1
  309. package/dist/snaps/registry/registry.js +0 -11
  310. package/dist/snaps/registry/registry.js.map +0 -1
  311. package/dist/snaps/selectors.d.ts +0 -2
  312. package/dist/snaps/selectors.js +0 -6
  313. package/dist/snaps/selectors.js.map +0 -1
  314. package/dist/utils.js.map +0 -1
  315. /package/dist/{cronjob → types/cronjob}/index.d.ts +0 -0
  316. /package/dist/{logging.d.ts → types/logging.d.ts} +0 -0
  317. /package/dist/{services → types/services}/iframe/index.d.ts +0 -0
  318. /package/dist/{services → types/services}/node/index.d.ts +0 -0
  319. /package/dist/{snaps → types/snaps}/RequestQueue.d.ts +0 -0
  320. /package/dist/{snaps → types/snaps}/Timer.d.ts +0 -0
  321. /package/dist/{snaps → types/snaps}/location/index.d.ts +0 -0
  322. /package/dist/{snaps → types/snaps}/registry/index.d.ts +0 -0
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "ethereumProviderEndowmentBuilder", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return ethereumProviderEndowmentBuilder;
9
+ }
10
+ });
11
+ const _permissioncontroller = require("@metamask/permission-controller");
12
+ const _enum = require("./enum");
13
+ const permissionName = _enum.SnapEndowments.EthereumProvider;
14
+ /**
15
+ * `endowment:ethereum-provider` returns the name of the ethereum global browser API.
16
+ * This is intended to populate the endowments of the
17
+ * SES Compartment in which a Snap executes.
18
+ *
19
+ * This populates the global scope with an EIP-1193 provider, which DOES NOT implement all legacy functionality exposed to dapps.
20
+ *
21
+ * @param _builderOptions - Optional specification builder options.
22
+ * @returns The specification for the network endowment.
23
+ */ const specificationBuilder = (_builderOptions)=>{
24
+ return {
25
+ permissionType: _permissioncontroller.PermissionType.Endowment,
26
+ targetName: permissionName,
27
+ allowedCaveats: null,
28
+ endowmentGetter: (_getterOptions)=>{
29
+ return [
30
+ 'ethereum'
31
+ ];
32
+ },
33
+ subjectTypes: [
34
+ _permissioncontroller.SubjectType.Snap
35
+ ]
36
+ };
37
+ };
38
+ const ethereumProviderEndowmentBuilder = Object.freeze({
39
+ targetName: permissionName,
40
+ specificationBuilder
41
+ });
42
+
43
+ //# sourceMappingURL=ethereum-provider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/snaps/endowments/ethereum-provider.ts"],"sourcesContent":["import type {\n EndowmentGetterParams,\n PermissionSpecificationBuilder,\n ValidPermissionSpecification,\n} from '@metamask/permission-controller';\nimport { PermissionType, SubjectType } from '@metamask/permission-controller';\n\nimport { SnapEndowments } from './enum';\n\nconst permissionName = SnapEndowments.EthereumProvider;\n\ntype EthereumProviderEndowmentSpecification = ValidPermissionSpecification<{\n permissionType: PermissionType.Endowment;\n targetName: typeof permissionName;\n endowmentGetter: (_options?: any) => ['ethereum'];\n allowedCaveats: null;\n}>;\n\n/**\n * `endowment:ethereum-provider` returns the name of the ethereum global browser API.\n * This is intended to populate the endowments of the\n * SES Compartment in which a Snap executes.\n *\n * This populates the global scope with an EIP-1193 provider, which DOES NOT implement all legacy functionality exposed to dapps.\n *\n * @param _builderOptions - Optional specification builder options.\n * @returns The specification for the network endowment.\n */\nconst specificationBuilder: PermissionSpecificationBuilder<\n PermissionType.Endowment,\n any,\n EthereumProviderEndowmentSpecification\n> = (_builderOptions?: any) => {\n return {\n permissionType: PermissionType.Endowment,\n targetName: permissionName,\n allowedCaveats: null,\n endowmentGetter: (_getterOptions?: EndowmentGetterParams) => {\n return ['ethereum'];\n },\n subjectTypes: [SubjectType.Snap],\n };\n};\n\nexport const ethereumProviderEndowmentBuilder = Object.freeze({\n targetName: permissionName,\n specificationBuilder,\n} as const);\n"],"names":["ethereumProviderEndowmentBuilder","permissionName","SnapEndowments","EthereumProvider","specificationBuilder","_builderOptions","permissionType","PermissionType","Endowment","targetName","allowedCaveats","endowmentGetter","_getterOptions","subjectTypes","SubjectType","Snap","Object","freeze"],"mappings":";;;;+BA4CaA;;;eAAAA;;;sCAvC+B;sBAEb;AAE/B,MAAMC,iBAAiBC,oBAAc,CAACC,gBAAgB;AAStD;;;;;;;;;CASC,GACD,MAAMC,uBAIF,CAACC;IACH,OAAO;QACLC,gBAAgBC,oCAAc,CAACC,SAAS;QACxCC,YAAYR;QACZS,gBAAgB;QAChBC,iBAAiB,CAACC;YAChB,OAAO;gBAAC;aAAW;QACrB;QACAC,cAAc;YAACC,iCAAW,CAACC,IAAI;SAAC;IAClC;AACF;AAEO,MAAMf,mCAAmCgB,OAAOC,MAAM,CAAC;IAC5DR,YAAYR;IACZG;AACF"}
@@ -0,0 +1,90 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ function _export(target, all) {
6
+ for(var name in all)Object.defineProperty(target, name, {
7
+ enumerable: true,
8
+ get: all[name]
9
+ });
10
+ }
11
+ _export(exports, {
12
+ endowmentPermissionBuilders: function() {
13
+ return endowmentPermissionBuilders;
14
+ },
15
+ endowmentCaveatSpecifications: function() {
16
+ return endowmentCaveatSpecifications;
17
+ },
18
+ endowmentCaveatMappers: function() {
19
+ return endowmentCaveatMappers;
20
+ },
21
+ handlerEndowments: function() {
22
+ return handlerEndowments;
23
+ },
24
+ getRpcCaveatOrigins: function() {
25
+ return _rpc.getRpcCaveatOrigins;
26
+ },
27
+ getTransactionOriginCaveat: function() {
28
+ return _transactioninsight.getTransactionOriginCaveat;
29
+ },
30
+ getChainIdsCaveat: function() {
31
+ return _namelookup.getChainIdsCaveat;
32
+ }
33
+ });
34
+ const _snapsutils = require("@metamask/snaps-utils");
35
+ const _cronjob = require("./cronjob");
36
+ const _ethereumprovider = require("./ethereum-provider");
37
+ const _lifecyclehooks = require("./lifecycle-hooks");
38
+ const _longrunning = require("./long-running");
39
+ const _namelookup = require("./name-lookup");
40
+ const _networkaccess = require("./network-access");
41
+ const _rpc = require("./rpc");
42
+ const _transactioninsight = require("./transaction-insight");
43
+ const _webassembly = require("./web-assembly");
44
+ _export_star(require("./enum"), exports);
45
+ function _export_star(from, to) {
46
+ Object.keys(from).forEach(function(k) {
47
+ if (k !== "default" && !Object.prototype.hasOwnProperty.call(to, k)) {
48
+ Object.defineProperty(to, k, {
49
+ enumerable: true,
50
+ get: function() {
51
+ return from[k];
52
+ }
53
+ });
54
+ }
55
+ });
56
+ return from;
57
+ }
58
+ const endowmentPermissionBuilders = {
59
+ [_networkaccess.networkAccessEndowmentBuilder.targetName]: _networkaccess.networkAccessEndowmentBuilder,
60
+ [_longrunning.longRunningEndowmentBuilder.targetName]: _longrunning.longRunningEndowmentBuilder,
61
+ [_transactioninsight.transactionInsightEndowmentBuilder.targetName]: _transactioninsight.transactionInsightEndowmentBuilder,
62
+ [_cronjob.cronjobEndowmentBuilder.targetName]: _cronjob.cronjobEndowmentBuilder,
63
+ [_ethereumprovider.ethereumProviderEndowmentBuilder.targetName]: _ethereumprovider.ethereumProviderEndowmentBuilder,
64
+ [_rpc.rpcEndowmentBuilder.targetName]: _rpc.rpcEndowmentBuilder,
65
+ [_webassembly.webAssemblyEndowmentBuilder.targetName]: _webassembly.webAssemblyEndowmentBuilder,
66
+ [_namelookup.nameLookupEndowmentBuilder.targetName]: _namelookup.nameLookupEndowmentBuilder,
67
+ [_lifecyclehooks.lifecycleHooksEndowmentBuilder.targetName]: _lifecyclehooks.lifecycleHooksEndowmentBuilder
68
+ };
69
+ const endowmentCaveatSpecifications = {
70
+ ..._cronjob.cronjobCaveatSpecifications,
71
+ ..._transactioninsight.transactionInsightCaveatSpecifications,
72
+ ..._rpc.rpcCaveatSpecifications,
73
+ ..._namelookup.nameLookupCaveatSpecifications
74
+ };
75
+ const endowmentCaveatMappers = {
76
+ [_cronjob.cronjobEndowmentBuilder.targetName]: _cronjob.getCronjobCaveatMapper,
77
+ [_transactioninsight.transactionInsightEndowmentBuilder.targetName]: _transactioninsight.getTransactionInsightCaveatMapper,
78
+ [_rpc.rpcEndowmentBuilder.targetName]: _rpc.getRpcCaveatMapper,
79
+ [_namelookup.nameLookupEndowmentBuilder.targetName]: _namelookup.getNameLookupCaveatMapper
80
+ };
81
+ const handlerEndowments = {
82
+ [_snapsutils.HandlerType.OnRpcRequest]: _rpc.rpcEndowmentBuilder.targetName,
83
+ [_snapsutils.HandlerType.OnTransaction]: _transactioninsight.transactionInsightEndowmentBuilder.targetName,
84
+ [_snapsutils.HandlerType.OnCronjob]: _cronjob.cronjobEndowmentBuilder.targetName,
85
+ [_snapsutils.HandlerType.OnNameLookup]: _namelookup.nameLookupEndowmentBuilder.targetName,
86
+ [_snapsutils.HandlerType.OnInstall]: _lifecyclehooks.lifecycleHooksEndowmentBuilder.targetName,
87
+ [_snapsutils.HandlerType.OnUpdate]: _lifecyclehooks.lifecycleHooksEndowmentBuilder.targetName
88
+ };
89
+
90
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/snaps/endowments/index.ts"],"sourcesContent":["import type { PermissionConstraint } from '@metamask/permission-controller';\nimport { HandlerType } from '@metamask/snaps-utils';\nimport type { Json } from '@metamask/utils';\n\nimport {\n cronjobCaveatSpecifications,\n cronjobEndowmentBuilder,\n getCronjobCaveatMapper,\n} from './cronjob';\nimport { ethereumProviderEndowmentBuilder } from './ethereum-provider';\nimport { lifecycleHooksEndowmentBuilder } from './lifecycle-hooks';\nimport { longRunningEndowmentBuilder } from './long-running';\nimport {\n getNameLookupCaveatMapper,\n nameLookupCaveatSpecifications,\n nameLookupEndowmentBuilder,\n} from './name-lookup';\nimport { networkAccessEndowmentBuilder } from './network-access';\nimport {\n getRpcCaveatMapper,\n rpcCaveatSpecifications,\n rpcEndowmentBuilder,\n} from './rpc';\nimport {\n getTransactionInsightCaveatMapper,\n transactionInsightCaveatSpecifications,\n transactionInsightEndowmentBuilder,\n} from './transaction-insight';\nimport { webAssemblyEndowmentBuilder } from './web-assembly';\n\nexport const endowmentPermissionBuilders = {\n [networkAccessEndowmentBuilder.targetName]: networkAccessEndowmentBuilder,\n [longRunningEndowmentBuilder.targetName]: longRunningEndowmentBuilder,\n [transactionInsightEndowmentBuilder.targetName]:\n transactionInsightEndowmentBuilder,\n [cronjobEndowmentBuilder.targetName]: cronjobEndowmentBuilder,\n [ethereumProviderEndowmentBuilder.targetName]:\n ethereumProviderEndowmentBuilder,\n [rpcEndowmentBuilder.targetName]: rpcEndowmentBuilder,\n [webAssemblyEndowmentBuilder.targetName]: webAssemblyEndowmentBuilder,\n [nameLookupEndowmentBuilder.targetName]: nameLookupEndowmentBuilder,\n [lifecycleHooksEndowmentBuilder.targetName]: lifecycleHooksEndowmentBuilder,\n} as const;\n\nexport const endowmentCaveatSpecifications = {\n ...cronjobCaveatSpecifications,\n ...transactionInsightCaveatSpecifications,\n ...rpcCaveatSpecifications,\n ...nameLookupCaveatSpecifications,\n};\n\nexport const endowmentCaveatMappers: Record<\n string,\n (value: Json) => Pick<PermissionConstraint, 'caveats'>\n> = {\n [cronjobEndowmentBuilder.targetName]: getCronjobCaveatMapper,\n [transactionInsightEndowmentBuilder.targetName]:\n getTransactionInsightCaveatMapper,\n [rpcEndowmentBuilder.targetName]: getRpcCaveatMapper,\n [nameLookupEndowmentBuilder.targetName]: getNameLookupCaveatMapper,\n};\n\nexport const handlerEndowments: Record<HandlerType, string> = {\n [HandlerType.OnRpcRequest]: rpcEndowmentBuilder.targetName,\n [HandlerType.OnTransaction]: transactionInsightEndowmentBuilder.targetName,\n [HandlerType.OnCronjob]: cronjobEndowmentBuilder.targetName,\n [HandlerType.OnNameLookup]: nameLookupEndowmentBuilder.targetName,\n [HandlerType.OnInstall]: lifecycleHooksEndowmentBuilder.targetName,\n [HandlerType.OnUpdate]: lifecycleHooksEndowmentBuilder.targetName,\n};\n\nexport * from './enum';\nexport { getRpcCaveatOrigins } from './rpc';\nexport { getTransactionOriginCaveat } from './transaction-insight';\nexport { getChainIdsCaveat } from './name-lookup';\n"],"names":["endowmentPermissionBuilders","endowmentCaveatSpecifications","endowmentCaveatMappers","handlerEndowments","getRpcCaveatOrigins","getTransactionOriginCaveat","getChainIdsCaveat","networkAccessEndowmentBuilder","targetName","longRunningEndowmentBuilder","transactionInsightEndowmentBuilder","cronjobEndowmentBuilder","ethereumProviderEndowmentBuilder","rpcEndowmentBuilder","webAssemblyEndowmentBuilder","nameLookupEndowmentBuilder","lifecycleHooksEndowmentBuilder","cronjobCaveatSpecifications","transactionInsightCaveatSpecifications","rpcCaveatSpecifications","nameLookupCaveatSpecifications","getCronjobCaveatMapper","getTransactionInsightCaveatMapper","getRpcCaveatMapper","getNameLookupCaveatMapper","HandlerType","OnRpcRequest","OnTransaction","OnCronjob","OnNameLookup","OnInstall","OnUpdate"],"mappings":";;;;;;;;;;;IA8BaA,2BAA2B;eAA3BA;;IAcAC,6BAA6B;eAA7BA;;IAOAC,sBAAsB;eAAtBA;;IAWAC,iBAAiB;eAAjBA;;IAUJC,mBAAmB;eAAnBA,wBAAmB;;IACnBC,0BAA0B;eAA1BA,8CAA0B;;IAC1BC,iBAAiB;eAAjBA,6BAAiB;;;4BAzEE;yBAOrB;kCAC0C;gCACF;6BACH;4BAKrC;+BACuC;qBAKvC;oCAKA;6BACqC;qBA2C9B;;;;;;;;;;;;;;AAzCP,MAAMN,8BAA8B;IACzC,CAACO,4CAA6B,CAACC,UAAU,CAAC,EAAED,4CAA6B;IACzE,CAACE,wCAA2B,CAACD,UAAU,CAAC,EAAEC,wCAA2B;IACrE,CAACC,sDAAkC,CAACF,UAAU,CAAC,EAC7CE,sDAAkC;IACpC,CAACC,gCAAuB,CAACH,UAAU,CAAC,EAAEG,gCAAuB;IAC7D,CAACC,kDAAgC,CAACJ,UAAU,CAAC,EAC3CI,kDAAgC;IAClC,CAACC,wBAAmB,CAACL,UAAU,CAAC,EAAEK,wBAAmB;IACrD,CAACC,wCAA2B,CAACN,UAAU,CAAC,EAAEM,wCAA2B;IACrE,CAACC,sCAA0B,CAACP,UAAU,CAAC,EAAEO,sCAA0B;IACnE,CAACC,8CAA8B,CAACR,UAAU,CAAC,EAAEQ,8CAA8B;AAC7E;AAEO,MAAMf,gCAAgC;IAC3C,GAAGgB,oCAA2B;IAC9B,GAAGC,0DAAsC;IACzC,GAAGC,4BAAuB;IAC1B,GAAGC,0CAA8B;AACnC;AAEO,MAAMlB,yBAGT;IACF,CAACS,gCAAuB,CAACH,UAAU,CAAC,EAAEa,+BAAsB;IAC5D,CAACX,sDAAkC,CAACF,UAAU,CAAC,EAC7Cc,qDAAiC;IACnC,CAACT,wBAAmB,CAACL,UAAU,CAAC,EAAEe,uBAAkB;IACpD,CAACR,sCAA0B,CAACP,UAAU,CAAC,EAAEgB,qCAAyB;AACpE;AAEO,MAAMrB,oBAAiD;IAC5D,CAACsB,uBAAW,CAACC,YAAY,CAAC,EAAEb,wBAAmB,CAACL,UAAU;IAC1D,CAACiB,uBAAW,CAACE,aAAa,CAAC,EAAEjB,sDAAkC,CAACF,UAAU;IAC1E,CAACiB,uBAAW,CAACG,SAAS,CAAC,EAAEjB,gCAAuB,CAACH,UAAU;IAC3D,CAACiB,uBAAW,CAACI,YAAY,CAAC,EAAEd,sCAA0B,CAACP,UAAU;IACjE,CAACiB,uBAAW,CAACK,SAAS,CAAC,EAAEd,8CAA8B,CAACR,UAAU;IAClE,CAACiB,uBAAW,CAACM,QAAQ,CAAC,EAAEf,8CAA8B,CAACR,UAAU;AACnE"}
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "lifecycleHooksEndowmentBuilder", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return lifecycleHooksEndowmentBuilder;
9
+ }
10
+ });
11
+ const _permissioncontroller = require("@metamask/permission-controller");
12
+ const _enum = require("./enum");
13
+ const permissionName = _enum.SnapEndowments.LifecycleHooks;
14
+ /**
15
+ * `endowment:lifecycle-hooks` returns nothing; it is intended to be used as a
16
+ * flag by the snap controller to detect whether the snap has the capability to
17
+ * use lifecycle hooks.
18
+ *
19
+ * @param _builderOptions - Optional specification builder options.
20
+ * @returns The specification for the `lifecycle-hooks` endowment.
21
+ */ const specificationBuilder = (_builderOptions)=>{
22
+ return {
23
+ permissionType: _permissioncontroller.PermissionType.Endowment,
24
+ targetName: permissionName,
25
+ allowedCaveats: null,
26
+ endowmentGetter: (_getterOptions)=>undefined,
27
+ subjectTypes: [
28
+ _permissioncontroller.SubjectType.Snap
29
+ ]
30
+ };
31
+ };
32
+ const lifecycleHooksEndowmentBuilder = Object.freeze({
33
+ targetName: permissionName,
34
+ specificationBuilder
35
+ });
36
+
37
+ //# sourceMappingURL=lifecycle-hooks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/snaps/endowments/lifecycle-hooks.ts"],"sourcesContent":["import type {\n PermissionSpecificationBuilder,\n EndowmentGetterParams,\n ValidPermissionSpecification,\n} from '@metamask/permission-controller';\nimport { PermissionType, SubjectType } from '@metamask/permission-controller';\nimport type { NonEmptyArray } from '@metamask/utils';\n\nimport { SnapEndowments } from './enum';\n\nconst permissionName = SnapEndowments.LifecycleHooks;\n\ntype LifecycleHooksEndowmentSpecification = ValidPermissionSpecification<{\n permissionType: PermissionType.Endowment;\n targetName: typeof permissionName;\n endowmentGetter: (_options?: EndowmentGetterParams) => undefined;\n allowedCaveats: Readonly<NonEmptyArray<string>> | null;\n}>;\n\n/**\n * `endowment:lifecycle-hooks` returns nothing; it is intended to be used as a\n * flag by the snap controller to detect whether the snap has the capability to\n * use lifecycle hooks.\n *\n * @param _builderOptions - Optional specification builder options.\n * @returns The specification for the `lifecycle-hooks` endowment.\n */\nconst specificationBuilder: PermissionSpecificationBuilder<\n PermissionType.Endowment,\n any,\n LifecycleHooksEndowmentSpecification\n> = (_builderOptions?: unknown) => {\n return {\n permissionType: PermissionType.Endowment,\n targetName: permissionName,\n allowedCaveats: null,\n endowmentGetter: (_getterOptions?: EndowmentGetterParams) => undefined,\n subjectTypes: [SubjectType.Snap],\n };\n};\n\nexport const lifecycleHooksEndowmentBuilder = Object.freeze({\n targetName: permissionName,\n specificationBuilder,\n} as const);\n"],"names":["lifecycleHooksEndowmentBuilder","permissionName","SnapEndowments","LifecycleHooks","specificationBuilder","_builderOptions","permissionType","PermissionType","Endowment","targetName","allowedCaveats","endowmentGetter","_getterOptions","undefined","subjectTypes","SubjectType","Snap","Object","freeze"],"mappings":";;;;+BAyCaA;;;eAAAA;;;sCApC+B;sBAGb;AAE/B,MAAMC,iBAAiBC,oBAAc,CAACC,cAAc;AASpD;;;;;;;CAOC,GACD,MAAMC,uBAIF,CAACC;IACH,OAAO;QACLC,gBAAgBC,oCAAc,CAACC,SAAS;QACxCC,YAAYR;QACZS,gBAAgB;QAChBC,iBAAiB,CAACC,iBAA2CC;QAC7DC,cAAc;YAACC,iCAAW,CAACC,IAAI;SAAC;IAClC;AACF;AAEO,MAAMhB,iCAAiCiB,OAAOC,MAAM,CAAC;IAC1DT,YAAYR;IACZG;AACF"}
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "longRunningEndowmentBuilder", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return longRunningEndowmentBuilder;
9
+ }
10
+ });
11
+ const _permissioncontroller = require("@metamask/permission-controller");
12
+ const _enum = require("./enum");
13
+ const permissionName = _enum.SnapEndowments.LongRunning;
14
+ /**
15
+ * `endowment:long-running` returns nothing; it is intended to be used as a flag
16
+ * by the `SnapController` to make it ignore the request processing timeout
17
+ * during snap lifecycle management. Essentially, it allows a snap to take an
18
+ * infinite amount of time to process a request.
19
+ *
20
+ * @param _builderOptions - Optional specification builder options.
21
+ * @returns The specification for the long-running endowment.
22
+ */ const specificationBuilder = (_builderOptions)=>{
23
+ return {
24
+ permissionType: _permissioncontroller.PermissionType.Endowment,
25
+ targetName: permissionName,
26
+ allowedCaveats: null,
27
+ endowmentGetter: (_getterOptions)=>undefined,
28
+ subjectTypes: [
29
+ _permissioncontroller.SubjectType.Snap
30
+ ]
31
+ };
32
+ };
33
+ const longRunningEndowmentBuilder = Object.freeze({
34
+ targetName: permissionName,
35
+ specificationBuilder
36
+ });
37
+
38
+ //# sourceMappingURL=long-running.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/snaps/endowments/long-running.ts"],"sourcesContent":["import type {\n PermissionSpecificationBuilder,\n EndowmentGetterParams,\n ValidPermissionSpecification,\n} from '@metamask/permission-controller';\nimport { PermissionType, SubjectType } from '@metamask/permission-controller';\n\nimport { SnapEndowments } from './enum';\n\nconst permissionName = SnapEndowments.LongRunning;\n\ntype LongRunningEndowmentSpecification = ValidPermissionSpecification<{\n permissionType: PermissionType.Endowment;\n targetName: typeof permissionName;\n endowmentGetter: (_options?: any) => undefined;\n allowedCaveats: null;\n}>;\n\n/**\n * `endowment:long-running` returns nothing; it is intended to be used as a flag\n * by the `SnapController` to make it ignore the request processing timeout\n * during snap lifecycle management. Essentially, it allows a snap to take an\n * infinite amount of time to process a request.\n *\n * @param _builderOptions - Optional specification builder options.\n * @returns The specification for the long-running endowment.\n */\nconst specificationBuilder: PermissionSpecificationBuilder<\n PermissionType.Endowment,\n any,\n LongRunningEndowmentSpecification\n> = (_builderOptions?: any) => {\n return {\n permissionType: PermissionType.Endowment,\n targetName: permissionName,\n allowedCaveats: null,\n endowmentGetter: (_getterOptions?: EndowmentGetterParams) => undefined,\n subjectTypes: [SubjectType.Snap],\n };\n};\n\nexport const longRunningEndowmentBuilder = Object.freeze({\n targetName: permissionName,\n specificationBuilder,\n} as const);\n"],"names":["longRunningEndowmentBuilder","permissionName","SnapEndowments","LongRunning","specificationBuilder","_builderOptions","permissionType","PermissionType","Endowment","targetName","allowedCaveats","endowmentGetter","_getterOptions","undefined","subjectTypes","SubjectType","Snap","Object","freeze"],"mappings":";;;;+BAyCaA;;;eAAAA;;;sCApC+B;sBAEb;AAE/B,MAAMC,iBAAiBC,oBAAc,CAACC,WAAW;AASjD;;;;;;;;CAQC,GACD,MAAMC,uBAIF,CAACC;IACH,OAAO;QACLC,gBAAgBC,oCAAc,CAACC,SAAS;QACxCC,YAAYR;QACZS,gBAAgB;QAChBC,iBAAiB,CAACC,iBAA2CC;QAC7DC,cAAc;YAACC,iCAAW,CAACC,IAAI;SAAC;IAClC;AACF;AAEO,MAAMhB,8BAA8BiB,OAAOC,MAAM,CAAC;IACvDT,YAAYR;IACZG;AACF"}
@@ -0,0 +1,106 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ function _export(target, all) {
6
+ for(var name in all)Object.defineProperty(target, name, {
7
+ enumerable: true,
8
+ get: all[name]
9
+ });
10
+ }
11
+ _export(exports, {
12
+ nameLookupEndowmentBuilder: function() {
13
+ return nameLookupEndowmentBuilder;
14
+ },
15
+ getNameLookupCaveatMapper: function() {
16
+ return getNameLookupCaveatMapper;
17
+ },
18
+ getChainIdsCaveat: function() {
19
+ return getChainIdsCaveat;
20
+ },
21
+ nameLookupCaveatSpecifications: function() {
22
+ return nameLookupCaveatSpecifications;
23
+ }
24
+ });
25
+ const _permissioncontroller = require("@metamask/permission-controller");
26
+ const _snapsutils = require("@metamask/snaps-utils");
27
+ const _utils = require("@metamask/utils");
28
+ const _ethrpcerrors = require("eth-rpc-errors");
29
+ const _enum = require("./enum");
30
+ const permissionName = _enum.SnapEndowments.NameLookup;
31
+ /**
32
+ * `endowment:name-lookup` returns nothing; it is intended to be used as a flag
33
+ * by the extension to detect whether the snap has the capability to resolve a domain/address.
34
+ *
35
+ * @param _builderOptions - Optional specification builder options.
36
+ * @returns The specification for the name-lookup endowment.
37
+ */ const specificationBuilder = (_builderOptions)=>{
38
+ return {
39
+ permissionType: _permissioncontroller.PermissionType.Endowment,
40
+ targetName: permissionName,
41
+ allowedCaveats: [
42
+ _snapsutils.SnapCaveatType.ChainIds
43
+ ],
44
+ endowmentGetter: (_getterOptions)=>undefined,
45
+ validator: ({ caveats })=>{
46
+ if (!caveats || caveats !== null && caveats?.length > 1 || caveats?.length === 1 && caveats[0].type !== _snapsutils.SnapCaveatType.ChainIds) {
47
+ throw _ethrpcerrors.ethErrors.rpc.invalidParams({
48
+ message: `Expected a single "${_snapsutils.SnapCaveatType.ChainIds}" caveat.`
49
+ });
50
+ }
51
+ },
52
+ subjectTypes: [
53
+ _permissioncontroller.SubjectType.Snap
54
+ ]
55
+ };
56
+ };
57
+ const nameLookupEndowmentBuilder = Object.freeze({
58
+ targetName: permissionName,
59
+ specificationBuilder
60
+ });
61
+ /**
62
+ * Validates the type of the caveat value.
63
+ *
64
+ * @param caveat - The caveat to validate.
65
+ * @throws If the caveat value is invalid.
66
+ */ function validateCaveat(caveat) {
67
+ if (!(0, _utils.hasProperty)(caveat, 'value') || !(0, _utils.isPlainObject)(caveat)) {
68
+ throw _ethrpcerrors.ethErrors.rpc.invalidParams({
69
+ message: 'Expected a plain object.'
70
+ });
71
+ }
72
+ const { value } = caveat;
73
+ (0, _utils.assert)(Array.isArray(value) && value.every((val)=>(0, _snapsutils.isChainId)(val)), 'Expected caveat value to have type "string array"');
74
+ }
75
+ function getNameLookupCaveatMapper(value) {
76
+ if (!value || !Array.isArray(value) || Array.isArray(value) && value.length === 0) {
77
+ return {
78
+ caveats: null
79
+ };
80
+ }
81
+ return {
82
+ caveats: [
83
+ {
84
+ type: _snapsutils.SnapCaveatType.ChainIds,
85
+ value
86
+ }
87
+ ]
88
+ };
89
+ }
90
+ function getChainIdsCaveat(permission) {
91
+ if (!permission?.caveats) {
92
+ return null;
93
+ }
94
+ (0, _utils.assert)(permission.caveats.length === 1);
95
+ (0, _utils.assert)(permission.caveats[0].type === _snapsutils.SnapCaveatType.ChainIds);
96
+ const caveat = permission.caveats[0];
97
+ return caveat.value ?? null;
98
+ }
99
+ const nameLookupCaveatSpecifications = {
100
+ [_snapsutils.SnapCaveatType.ChainIds]: Object.freeze({
101
+ type: _snapsutils.SnapCaveatType.ChainIds,
102
+ validator: (caveat)=>validateCaveat(caveat)
103
+ })
104
+ };
105
+
106
+ //# sourceMappingURL=name-lookup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/snaps/endowments/name-lookup.ts"],"sourcesContent":["import type {\n EndowmentGetterParams,\n PermissionSpecificationBuilder,\n PermissionValidatorConstraint,\n ValidPermissionSpecification,\n Caveat,\n CaveatSpecificationConstraint,\n PermissionConstraint,\n} from '@metamask/permission-controller';\nimport { PermissionType, SubjectType } from '@metamask/permission-controller';\nimport { SnapCaveatType, isChainId } from '@metamask/snaps-utils';\nimport type { Json, NonEmptyArray } from '@metamask/utils';\nimport { assert, hasProperty, isPlainObject } from '@metamask/utils';\nimport { ethErrors } from 'eth-rpc-errors';\n\nimport { SnapEndowments } from './enum';\n\nconst permissionName = SnapEndowments.NameLookup;\n\ntype NameLookupEndowmentSpecification = ValidPermissionSpecification<{\n permissionType: PermissionType.Endowment;\n targetName: typeof permissionName;\n endowmentGetter: (_options?: EndowmentGetterParams) => undefined;\n allowedCaveats: Readonly<NonEmptyArray<string>> | null;\n validator: PermissionValidatorConstraint;\n}>;\n\n/**\n * `endowment:name-lookup` returns nothing; it is intended to be used as a flag\n * by the extension to detect whether the snap has the capability to resolve a domain/address.\n *\n * @param _builderOptions - Optional specification builder options.\n * @returns The specification for the name-lookup endowment.\n */\nconst specificationBuilder: PermissionSpecificationBuilder<\n PermissionType.Endowment,\n any,\n NameLookupEndowmentSpecification\n> = (_builderOptions?: unknown) => {\n return {\n permissionType: PermissionType.Endowment,\n targetName: permissionName,\n allowedCaveats: [SnapCaveatType.ChainIds],\n endowmentGetter: (_getterOptions?: EndowmentGetterParams) => undefined,\n validator: ({ caveats }) => {\n if (\n !caveats ||\n (caveats !== null && caveats?.length > 1) ||\n (caveats?.length === 1 && caveats[0].type !== SnapCaveatType.ChainIds)\n ) {\n throw ethErrors.rpc.invalidParams({\n message: `Expected a single \"${SnapCaveatType.ChainIds}\" caveat.`,\n });\n }\n },\n subjectTypes: [SubjectType.Snap],\n };\n};\n\nexport const nameLookupEndowmentBuilder = Object.freeze({\n targetName: permissionName,\n specificationBuilder,\n} as const);\n\n/**\n * Validates the type of the caveat value.\n *\n * @param caveat - The caveat to validate.\n * @throws If the caveat value is invalid.\n */\nfunction validateCaveat(caveat: Caveat<string, any>): void {\n if (!hasProperty(caveat, 'value') || !isPlainObject(caveat)) {\n throw ethErrors.rpc.invalidParams({\n message: 'Expected a plain object.',\n });\n }\n\n const { value } = caveat;\n\n assert(\n Array.isArray(value) && value.every((val) => isChainId(val)),\n 'Expected caveat value to have type \"string array\"',\n );\n}\n\n/**\n * Map a raw value from the `initialPermissions` to a caveat specification.\n * Note that this function does not do any validation, that's handled by the\n * PermissionsController when the permission is requested.\n *\n * @param value - The raw value from the `initialPermissions`.\n * @returns The caveat specification.\n */\nexport function getNameLookupCaveatMapper(\n value: Json,\n): Pick<PermissionConstraint, 'caveats'> {\n if (\n !value ||\n !Array.isArray(value) ||\n (Array.isArray(value) && value.length === 0)\n ) {\n return { caveats: null };\n }\n return {\n caveats: [\n {\n type: SnapCaveatType.ChainIds,\n value,\n },\n ],\n };\n}\n\n/**\n * Getter function to get the chainIds caveat from a permission.\n *\n * This does basic validation of the caveat, but does not validate the type or\n * value of the namespaces object itself, as this is handled by the\n * `PermissionsController` when the permission is requested.\n *\n * @param permission - The permission to get the `chainIds` caveat from.\n * @returns An array of `chainIds` that the snap supports.\n */\nexport function getChainIdsCaveat(\n permission?: PermissionConstraint,\n): string[] | null {\n if (!permission?.caveats) {\n return null;\n }\n\n assert(permission.caveats.length === 1);\n assert(permission.caveats[0].type === SnapCaveatType.ChainIds);\n\n const caveat = permission.caveats[0] as Caveat<string, string[]>;\n\n return caveat.value ?? null;\n}\n\nexport const nameLookupCaveatSpecifications: Record<\n SnapCaveatType.ChainIds,\n CaveatSpecificationConstraint\n> = {\n [SnapCaveatType.ChainIds]: Object.freeze({\n type: SnapCaveatType.ChainIds,\n validator: (caveat: Caveat<string, any>) => validateCaveat(caveat),\n }),\n};\n"],"names":["nameLookupEndowmentBuilder","getNameLookupCaveatMapper","getChainIdsCaveat","nameLookupCaveatSpecifications","permissionName","SnapEndowments","NameLookup","specificationBuilder","_builderOptions","permissionType","PermissionType","Endowment","targetName","allowedCaveats","SnapCaveatType","ChainIds","endowmentGetter","_getterOptions","undefined","validator","caveats","length","type","ethErrors","rpc","invalidParams","message","subjectTypes","SubjectType","Snap","Object","freeze","validateCaveat","caveat","hasProperty","isPlainObject","value","assert","Array","isArray","every","val","isChainId","permission"],"mappings":";;;;;;;;;;;IA2DaA,0BAA0B;eAA1BA;;IAkCGC,yBAAyB;eAAzBA;;IA8BAC,iBAAiB;eAAjBA;;IAeHC,8BAA8B;eAA9BA;;;sCAjI+B;4BACF;uBAES;8BACzB;sBAEK;AAE/B,MAAMC,iBAAiBC,oBAAc,CAACC,UAAU;AAUhD;;;;;;CAMC,GACD,MAAMC,uBAIF,CAACC;IACH,OAAO;QACLC,gBAAgBC,oCAAc,CAACC,SAAS;QACxCC,YAAYR;QACZS,gBAAgB;YAACC,0BAAc,CAACC,QAAQ;SAAC;QACzCC,iBAAiB,CAACC,iBAA2CC;QAC7DC,WAAW,CAAC,EAAEC,OAAO,EAAE;YACrB,IACE,CAACA,WACAA,YAAY,QAAQA,SAASC,SAAS,KACtCD,SAASC,WAAW,KAAKD,OAAO,CAAC,EAAE,CAACE,IAAI,KAAKR,0BAAc,CAACC,QAAQ,EACrE;gBACA,MAAMQ,uBAAS,CAACC,GAAG,CAACC,aAAa,CAAC;oBAChCC,SAAS,CAAC,mBAAmB,EAAEZ,0BAAc,CAACC,QAAQ,CAAC,SAAS,CAAC;gBACnE;YACF;QACF;QACAY,cAAc;YAACC,iCAAW,CAACC,IAAI;SAAC;IAClC;AACF;AAEO,MAAM7B,6BAA6B8B,OAAOC,MAAM,CAAC;IACtDnB,YAAYR;IACZG;AACF;AAEA;;;;;CAKC,GACD,SAASyB,eAAeC,MAA2B;IACjD,IAAI,CAACC,IAAAA,kBAAW,EAACD,QAAQ,YAAY,CAACE,IAAAA,oBAAa,EAACF,SAAS;QAC3D,MAAMV,uBAAS,CAACC,GAAG,CAACC,aAAa,CAAC;YAChCC,SAAS;QACX;IACF;IAEA,MAAM,EAAEU,KAAK,EAAE,GAAGH;IAElBI,IAAAA,aAAM,EACJC,MAAMC,OAAO,CAACH,UAAUA,MAAMI,KAAK,CAAC,CAACC,MAAQC,IAAAA,qBAAS,EAACD,OACvD;AAEJ;AAUO,SAASxC,0BACdmC,KAAW;IAEX,IACE,CAACA,SACD,CAACE,MAAMC,OAAO,CAACH,UACdE,MAAMC,OAAO,CAACH,UAAUA,MAAMf,MAAM,KAAK,GAC1C;QACA,OAAO;YAAED,SAAS;QAAK;IACzB;IACA,OAAO;QACLA,SAAS;YACP;gBACEE,MAAMR,0BAAc,CAACC,QAAQ;gBAC7BqB;YACF;SACD;IACH;AACF;AAYO,SAASlC,kBACdyC,UAAiC;IAEjC,IAAI,CAACA,YAAYvB,SAAS;QACxB,OAAO;IACT;IAEAiB,IAAAA,aAAM,EAACM,WAAWvB,OAAO,CAACC,MAAM,KAAK;IACrCgB,IAAAA,aAAM,EAACM,WAAWvB,OAAO,CAAC,EAAE,CAACE,IAAI,KAAKR,0BAAc,CAACC,QAAQ;IAE7D,MAAMkB,SAASU,WAAWvB,OAAO,CAAC,EAAE;IAEpC,OAAOa,OAAOG,KAAK,IAAI;AACzB;AAEO,MAAMjC,iCAGT;IACF,CAACW,0BAAc,CAACC,QAAQ,CAAC,EAAEe,OAAOC,MAAM,CAAC;QACvCT,MAAMR,0BAAc,CAACC,QAAQ;QAC7BI,WAAW,CAACc,SAAgCD,eAAeC;IAC7D;AACF"}
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "networkAccessEndowmentBuilder", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return networkAccessEndowmentBuilder;
9
+ }
10
+ });
11
+ const _permissioncontroller = require("@metamask/permission-controller");
12
+ const _enum = require("./enum");
13
+ const permissionName = _enum.SnapEndowments.NetworkAccess;
14
+ /**
15
+ * `endowment:network-access` returns the name of global browser API(s) that
16
+ * enable network access. This is intended to populate the endowments of the
17
+ * SES Compartment in which a Snap executes.
18
+ *
19
+ * @param _builderOptions - Optional specification builder options.
20
+ * @returns The specification for the network endowment.
21
+ */ const specificationBuilder = (_builderOptions)=>{
22
+ return {
23
+ permissionType: _permissioncontroller.PermissionType.Endowment,
24
+ targetName: permissionName,
25
+ allowedCaveats: null,
26
+ endowmentGetter: (_getterOptions)=>{
27
+ return [
28
+ 'fetch',
29
+ 'Request',
30
+ 'Headers',
31
+ 'Response'
32
+ ];
33
+ },
34
+ subjectTypes: [
35
+ _permissioncontroller.SubjectType.Snap
36
+ ]
37
+ };
38
+ };
39
+ const networkAccessEndowmentBuilder = Object.freeze({
40
+ targetName: permissionName,
41
+ specificationBuilder
42
+ });
43
+
44
+ //# sourceMappingURL=network-access.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/snaps/endowments/network-access.ts"],"sourcesContent":["import type {\n EndowmentGetterParams,\n PermissionSpecificationBuilder,\n ValidPermissionSpecification,\n} from '@metamask/permission-controller';\nimport { PermissionType, SubjectType } from '@metamask/permission-controller';\n\nimport { SnapEndowments } from './enum';\n\nconst permissionName = SnapEndowments.NetworkAccess;\n\ntype NetworkAccessEndowmentSpecification = ValidPermissionSpecification<{\n permissionType: PermissionType.Endowment;\n targetName: typeof permissionName;\n endowmentGetter: (\n _options?: any,\n ) => ['fetch', 'Request', 'Headers', 'Response'];\n allowedCaveats: null;\n}>;\n\n/**\n * `endowment:network-access` returns the name of global browser API(s) that\n * enable network access. This is intended to populate the endowments of the\n * SES Compartment in which a Snap executes.\n *\n * @param _builderOptions - Optional specification builder options.\n * @returns The specification for the network endowment.\n */\nconst specificationBuilder: PermissionSpecificationBuilder<\n PermissionType.Endowment,\n any,\n NetworkAccessEndowmentSpecification\n> = (_builderOptions?: any) => {\n return {\n permissionType: PermissionType.Endowment,\n targetName: permissionName,\n allowedCaveats: null,\n endowmentGetter: (_getterOptions?: EndowmentGetterParams) => {\n return ['fetch', 'Request', 'Headers', 'Response'];\n },\n subjectTypes: [SubjectType.Snap],\n };\n};\n\nexport const networkAccessEndowmentBuilder = Object.freeze({\n targetName: permissionName,\n specificationBuilder,\n} as const);\n"],"names":["networkAccessEndowmentBuilder","permissionName","SnapEndowments","NetworkAccess","specificationBuilder","_builderOptions","permissionType","PermissionType","Endowment","targetName","allowedCaveats","endowmentGetter","_getterOptions","subjectTypes","SubjectType","Snap","Object","freeze"],"mappings":";;;;+BA4CaA;;;eAAAA;;;sCAvC+B;sBAEb;AAE/B,MAAMC,iBAAiBC,oBAAc,CAACC,aAAa;AAWnD;;;;;;;CAOC,GACD,MAAMC,uBAIF,CAACC;IACH,OAAO;QACLC,gBAAgBC,oCAAc,CAACC,SAAS;QACxCC,YAAYR;QACZS,gBAAgB;QAChBC,iBAAiB,CAACC;YAChB,OAAO;gBAAC;gBAAS;gBAAW;gBAAW;aAAW;QACpD;QACAC,cAAc;YAACC,iCAAW,CAACC,IAAI;SAAC;IAClC;AACF;AAEO,MAAMf,gCAAgCgB,OAAOC,MAAM,CAAC;IACzDR,YAAYR;IACZG;AACF"}
@@ -0,0 +1,99 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ function _export(target, all) {
6
+ for(var name in all)Object.defineProperty(target, name, {
7
+ enumerable: true,
8
+ get: all[name]
9
+ });
10
+ }
11
+ _export(exports, {
12
+ rpcEndowmentBuilder: function() {
13
+ return rpcEndowmentBuilder;
14
+ },
15
+ getRpcCaveatMapper: function() {
16
+ return getRpcCaveatMapper;
17
+ },
18
+ getRpcCaveatOrigins: function() {
19
+ return getRpcCaveatOrigins;
20
+ },
21
+ rpcCaveatSpecifications: function() {
22
+ return rpcCaveatSpecifications;
23
+ }
24
+ });
25
+ const _permissioncontroller = require("@metamask/permission-controller");
26
+ const _snapsutils = require("@metamask/snaps-utils");
27
+ const _utils = require("@metamask/utils");
28
+ const _ethrpcerrors = require("eth-rpc-errors");
29
+ const _enum = require("./enum");
30
+ const targetName = _enum.SnapEndowments.Rpc;
31
+ /**
32
+ * The specification builder for the JSON-RPC endowment permission.
33
+ *
34
+ * @param _builderOptions - Optional specification builder options.
35
+ * @returns The specification for the JSON-RPC endowment permission.
36
+ */ const specificationBuilder = (_builderOptions)=>{
37
+ return {
38
+ permissionType: _permissioncontroller.PermissionType.Endowment,
39
+ targetName,
40
+ allowedCaveats: [
41
+ _snapsutils.SnapCaveatType.RpcOrigin
42
+ ],
43
+ endowmentGetter: (_getterOptions)=>undefined,
44
+ validator: ({ caveats })=>{
45
+ if (caveats?.length !== 1 || caveats[0].type !== _snapsutils.SnapCaveatType.RpcOrigin) {
46
+ throw _ethrpcerrors.ethErrors.rpc.invalidParams({
47
+ message: `Expected a single "${_snapsutils.SnapCaveatType.RpcOrigin}" caveat.`
48
+ });
49
+ }
50
+ },
51
+ subjectTypes: [
52
+ _permissioncontroller.SubjectType.Snap
53
+ ]
54
+ };
55
+ };
56
+ const rpcEndowmentBuilder = Object.freeze({
57
+ targetName,
58
+ specificationBuilder
59
+ });
60
+ /**
61
+ * Validate the value of a caveat. This does not validate the type of the
62
+ * caveat itself, only the value of the caveat.
63
+ *
64
+ * @param caveat - The caveat to validate.
65
+ * @throws If the caveat value is invalid.
66
+ */ function validateCaveatOrigins(caveat) {
67
+ if (!(0, _utils.hasProperty)(caveat, 'value') || !(0, _utils.isPlainObject)(caveat.value)) {
68
+ throw _ethrpcerrors.ethErrors.rpc.invalidParams({
69
+ message: 'Invalid JSON-RPC origins: Expected a plain object.'
70
+ });
71
+ }
72
+ const { value } = caveat;
73
+ (0, _snapsutils.assertIsRpcOrigins)(value, _ethrpcerrors.ethErrors.rpc.invalidParams);
74
+ }
75
+ function getRpcCaveatMapper(value) {
76
+ return {
77
+ caveats: [
78
+ {
79
+ type: _snapsutils.SnapCaveatType.RpcOrigin,
80
+ value
81
+ }
82
+ ]
83
+ };
84
+ }
85
+ function getRpcCaveatOrigins(permission) {
86
+ (0, _utils.assert)(permission?.caveats);
87
+ (0, _utils.assert)(permission.caveats.length === 1);
88
+ (0, _utils.assert)(permission.caveats[0].type === _snapsutils.SnapCaveatType.RpcOrigin);
89
+ const caveat = permission.caveats[0];
90
+ return caveat.value;
91
+ }
92
+ const rpcCaveatSpecifications = {
93
+ [_snapsutils.SnapCaveatType.RpcOrigin]: Object.freeze({
94
+ type: _snapsutils.SnapCaveatType.RpcOrigin,
95
+ validator: (caveat)=>validateCaveatOrigins(caveat)
96
+ })
97
+ };
98
+
99
+ //# sourceMappingURL=rpc.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/snaps/endowments/rpc.ts"],"sourcesContent":["import type {\n Caveat,\n CaveatSpecificationConstraint,\n EndowmentGetterParams,\n PermissionConstraint,\n PermissionSpecificationBuilder,\n PermissionValidatorConstraint,\n ValidPermissionSpecification,\n} from '@metamask/permission-controller';\nimport { PermissionType, SubjectType } from '@metamask/permission-controller';\nimport type { RpcOrigins } from '@metamask/snaps-utils';\nimport { assertIsRpcOrigins, SnapCaveatType } from '@metamask/snaps-utils';\nimport type { Json, NonEmptyArray } from '@metamask/utils';\nimport { hasProperty, isPlainObject, assert } from '@metamask/utils';\nimport { ethErrors } from 'eth-rpc-errors';\n\nimport { SnapEndowments } from './enum';\n\nconst targetName = SnapEndowments.Rpc;\n\ntype RpcSpecification = ValidPermissionSpecification<{\n permissionType: PermissionType.Endowment;\n targetName: typeof targetName;\n endowmentGetter: (_options?: any) => undefined;\n allowedCaveats: Readonly<NonEmptyArray<string>> | null;\n validator: PermissionValidatorConstraint;\n subjectTypes: readonly SubjectType[];\n}>;\n\ntype RpcSpecificationBuilderOptions = {\n // Empty for now.\n};\n\n/**\n * The specification builder for the JSON-RPC endowment permission.\n *\n * @param _builderOptions - Optional specification builder options.\n * @returns The specification for the JSON-RPC endowment permission.\n */\nconst specificationBuilder: PermissionSpecificationBuilder<\n PermissionType.Endowment,\n RpcSpecificationBuilderOptions,\n RpcSpecification\n> = (_builderOptions?: any): RpcSpecification => {\n return {\n permissionType: PermissionType.Endowment,\n targetName,\n allowedCaveats: [SnapCaveatType.RpcOrigin],\n endowmentGetter: (_getterOptions?: EndowmentGetterParams) => undefined,\n validator: ({ caveats }) => {\n if (\n caveats?.length !== 1 ||\n caveats[0].type !== SnapCaveatType.RpcOrigin\n ) {\n throw ethErrors.rpc.invalidParams({\n message: `Expected a single \"${SnapCaveatType.RpcOrigin}\" caveat.`,\n });\n }\n },\n subjectTypes: [SubjectType.Snap],\n };\n};\n\nexport const rpcEndowmentBuilder = Object.freeze({\n targetName,\n specificationBuilder,\n} as const);\n\n/**\n * Validate the value of a caveat. This does not validate the type of the\n * caveat itself, only the value of the caveat.\n *\n * @param caveat - The caveat to validate.\n * @throws If the caveat value is invalid.\n */\nfunction validateCaveatOrigins(caveat: Caveat<string, any>) {\n if (!hasProperty(caveat, 'value') || !isPlainObject(caveat.value)) {\n throw ethErrors.rpc.invalidParams({\n message: 'Invalid JSON-RPC origins: Expected a plain object.',\n });\n }\n\n const { value } = caveat;\n assertIsRpcOrigins(value, ethErrors.rpc.invalidParams);\n}\n\n/**\n * Map a raw value from the `initialPermissions` to a caveat specification.\n * Note that this function does not do any validation, that's handled by the\n * PermissionsController when the permission is requested.\n *\n * @param value - The raw value from the `initialPermissions`.\n * @returns The caveat specification.\n */\nexport function getRpcCaveatMapper(\n value: Json,\n): Pick<PermissionConstraint, 'caveats'> {\n return {\n caveats: [\n {\n type: SnapCaveatType.RpcOrigin,\n value,\n },\n ],\n };\n}\n\n/**\n * Getter function to get the {@link RpcOrigins} caveat value from a permission.\n *\n * @param permission - The permission to get the caveat value from.\n * @returns The caveat value.\n * @throws If the permission does not have a valid {@link RpcOrigins} caveat.\n */\nexport function getRpcCaveatOrigins(\n permission?: PermissionConstraint,\n): RpcOrigins | null {\n assert(permission?.caveats);\n assert(permission.caveats.length === 1);\n assert(permission.caveats[0].type === SnapCaveatType.RpcOrigin);\n\n const caveat = permission.caveats[0] as Caveat<string, RpcOrigins>;\n return caveat.value;\n}\n\nexport const rpcCaveatSpecifications: Record<\n SnapCaveatType.RpcOrigin,\n CaveatSpecificationConstraint\n> = {\n [SnapCaveatType.RpcOrigin]: Object.freeze({\n type: SnapCaveatType.RpcOrigin,\n validator: (caveat: Caveat<string, any>) => validateCaveatOrigins(caveat),\n }),\n};\n"],"names":["rpcEndowmentBuilder","getRpcCaveatMapper","getRpcCaveatOrigins","rpcCaveatSpecifications","targetName","SnapEndowments","Rpc","specificationBuilder","_builderOptions","permissionType","PermissionType","Endowment","allowedCaveats","SnapCaveatType","RpcOrigin","endowmentGetter","_getterOptions","undefined","validator","caveats","length","type","ethErrors","rpc","invalidParams","message","subjectTypes","SubjectType","Snap","Object","freeze","validateCaveatOrigins","caveat","hasProperty","isPlainObject","value","assertIsRpcOrigins","permission","assert"],"mappings":";;;;;;;;;;;IA+DaA,mBAAmB;eAAnBA;;IA+BGC,kBAAkB;eAAlBA;;IAoBAC,mBAAmB;eAAnBA;;IAWHC,uBAAuB;eAAvBA;;;sCApH+B;4BAEO;uBAEA;8BACzB;sBAEK;AAE/B,MAAMC,aAAaC,oBAAc,CAACC,GAAG;AAerC;;;;;CAKC,GACD,MAAMC,uBAIF,CAACC;IACH,OAAO;QACLC,gBAAgBC,oCAAc,CAACC,SAAS;QACxCP;QACAQ,gBAAgB;YAACC,0BAAc,CAACC,SAAS;SAAC;QAC1CC,iBAAiB,CAACC,iBAA2CC;QAC7DC,WAAW,CAAC,EAAEC,OAAO,EAAE;YACrB,IACEA,SAASC,WAAW,KACpBD,OAAO,CAAC,EAAE,CAACE,IAAI,KAAKR,0BAAc,CAACC,SAAS,EAC5C;gBACA,MAAMQ,uBAAS,CAACC,GAAG,CAACC,aAAa,CAAC;oBAChCC,SAAS,CAAC,mBAAmB,EAAEZ,0BAAc,CAACC,SAAS,CAAC,SAAS,CAAC;gBACpE;YACF;QACF;QACAY,cAAc;YAACC,iCAAW,CAACC,IAAI;SAAC;IAClC;AACF;AAEO,MAAM5B,sBAAsB6B,OAAOC,MAAM,CAAC;IAC/C1B;IACAG;AACF;AAEA;;;;;;CAMC,GACD,SAASwB,sBAAsBC,MAA2B;IACxD,IAAI,CAACC,IAAAA,kBAAW,EAACD,QAAQ,YAAY,CAACE,IAAAA,oBAAa,EAACF,OAAOG,KAAK,GAAG;QACjE,MAAMb,uBAAS,CAACC,GAAG,CAACC,aAAa,CAAC;YAChCC,SAAS;QACX;IACF;IAEA,MAAM,EAAEU,KAAK,EAAE,GAAGH;IAClBI,IAAAA,8BAAkB,EAACD,OAAOb,uBAAS,CAACC,GAAG,CAACC,aAAa;AACvD;AAUO,SAASvB,mBACdkC,KAAW;IAEX,OAAO;QACLhB,SAAS;YACP;gBACEE,MAAMR,0BAAc,CAACC,SAAS;gBAC9BqB;YACF;SACD;IACH;AACF;AASO,SAASjC,oBACdmC,UAAiC;IAEjCC,IAAAA,aAAM,EAACD,YAAYlB;IACnBmB,IAAAA,aAAM,EAACD,WAAWlB,OAAO,CAACC,MAAM,KAAK;IACrCkB,IAAAA,aAAM,EAACD,WAAWlB,OAAO,CAAC,EAAE,CAACE,IAAI,KAAKR,0BAAc,CAACC,SAAS;IAE9D,MAAMkB,SAASK,WAAWlB,OAAO,CAAC,EAAE;IACpC,OAAOa,OAAOG,KAAK;AACrB;AAEO,MAAMhC,0BAGT;IACF,CAACU,0BAAc,CAACC,SAAS,CAAC,EAAEe,OAAOC,MAAM,CAAC;QACxCT,MAAMR,0BAAc,CAACC,SAAS;QAC9BI,WAAW,CAACc,SAAgCD,sBAAsBC;IACpE;AACF"}
@@ -0,0 +1,106 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ function _export(target, all) {
6
+ for(var name in all)Object.defineProperty(target, name, {
7
+ enumerable: true,
8
+ get: all[name]
9
+ });
10
+ }
11
+ _export(exports, {
12
+ transactionInsightEndowmentBuilder: function() {
13
+ return transactionInsightEndowmentBuilder;
14
+ },
15
+ getTransactionInsightCaveatMapper: function() {
16
+ return getTransactionInsightCaveatMapper;
17
+ },
18
+ getTransactionOriginCaveat: function() {
19
+ return getTransactionOriginCaveat;
20
+ },
21
+ transactionInsightCaveatSpecifications: function() {
22
+ return transactionInsightCaveatSpecifications;
23
+ }
24
+ });
25
+ const _permissioncontroller = require("@metamask/permission-controller");
26
+ const _snapsutils = require("@metamask/snaps-utils");
27
+ const _utils = require("@metamask/utils");
28
+ const _ethrpcerrors = require("eth-rpc-errors");
29
+ const _enum = require("./enum");
30
+ const permissionName = _enum.SnapEndowments.TransactionInsight;
31
+ /**
32
+ * `endowment:transaction-insight` returns nothing; it is intended to be used as a flag
33
+ * by the extension to detect whether the snap has the capability to show information on the transaction confirmation screen.
34
+ *
35
+ * @param _builderOptions - Optional specification builder options.
36
+ * @returns The specification for the transaction-insight endowment.
37
+ */ const specificationBuilder = (_builderOptions)=>{
38
+ return {
39
+ permissionType: _permissioncontroller.PermissionType.Endowment,
40
+ targetName: permissionName,
41
+ allowedCaveats: [
42
+ _snapsutils.SnapCaveatType.TransactionOrigin
43
+ ],
44
+ endowmentGetter: (_getterOptions)=>undefined,
45
+ validator: ({ caveats })=>{
46
+ if (caveats !== null && caveats?.length > 1 || caveats?.length === 1 && caveats[0].type !== _snapsutils.SnapCaveatType.TransactionOrigin) {
47
+ throw _ethrpcerrors.ethErrors.rpc.invalidParams({
48
+ message: `Expected a single "${_snapsutils.SnapCaveatType.TransactionOrigin}" caveat.`
49
+ });
50
+ }
51
+ },
52
+ subjectTypes: [
53
+ _permissioncontroller.SubjectType.Snap
54
+ ]
55
+ };
56
+ };
57
+ const transactionInsightEndowmentBuilder = Object.freeze({
58
+ targetName: permissionName,
59
+ specificationBuilder
60
+ });
61
+ /**
62
+ * Validates the type of the caveat value.
63
+ *
64
+ * @param caveat - The caveat to validate.
65
+ * @throws If the caveat value is invalid.
66
+ */ function validateCaveat(caveat) {
67
+ if (!(0, _utils.hasProperty)(caveat, 'value') || !(0, _utils.isPlainObject)(caveat)) {
68
+ throw _ethrpcerrors.ethErrors.rpc.invalidParams({
69
+ message: 'Expected a plain object.'
70
+ });
71
+ }
72
+ const { value } = caveat;
73
+ (0, _utils.assert)(typeof value === 'boolean', 'Expected caveat value to have type "boolean"');
74
+ }
75
+ function getTransactionInsightCaveatMapper(value) {
76
+ if (!value || !(0, _utils.isObject)(value) || (0, _utils.isObject)(value) && Object.keys(value).length === 0) {
77
+ return {
78
+ caveats: null
79
+ };
80
+ }
81
+ return {
82
+ caveats: [
83
+ {
84
+ type: _snapsutils.SnapCaveatType.TransactionOrigin,
85
+ value: (0, _utils.hasProperty)(value, 'allowTransactionOrigin') && value.allowTransactionOrigin
86
+ }
87
+ ]
88
+ };
89
+ }
90
+ function getTransactionOriginCaveat(permission) {
91
+ if (!permission?.caveats) {
92
+ return null;
93
+ }
94
+ (0, _utils.assert)(permission.caveats.length === 1);
95
+ (0, _utils.assert)(permission.caveats[0].type === _snapsutils.SnapCaveatType.TransactionOrigin);
96
+ const caveat = permission.caveats[0];
97
+ return caveat.value ?? null;
98
+ }
99
+ const transactionInsightCaveatSpecifications = {
100
+ [_snapsutils.SnapCaveatType.TransactionOrigin]: Object.freeze({
101
+ type: _snapsutils.SnapCaveatType.TransactionOrigin,
102
+ validator: (caveat)=>validateCaveat(caveat)
103
+ })
104
+ };
105
+
106
+ //# sourceMappingURL=transaction-insight.js.map