@arkade-os/sdk 0.4.27 → 0.4.29

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 (532) hide show
  1. package/README.md +45 -116
  2. package/dist/adapters/asyncStorage.cjs +48 -0
  3. package/dist/adapters/asyncStorage.cjs.map +1 -0
  4. package/dist/adapters/asyncStorage.d.cts +16 -0
  5. package/dist/{types/storage → adapters}/asyncStorage.d.ts +5 -2
  6. package/dist/adapters/asyncStorage.js +46 -0
  7. package/dist/adapters/asyncStorage.js.map +1 -0
  8. package/dist/adapters/expo.cjs +19 -0
  9. package/dist/adapters/expo.cjs.map +1 -0
  10. package/dist/adapters/expo.d.cts +48 -0
  11. package/dist/adapters/expo.d.ts +48 -0
  12. package/dist/adapters/expo.js +6 -0
  13. package/dist/adapters/expo.js.map +1 -0
  14. package/dist/adapters/fileSystem.cjs +116 -0
  15. package/dist/adapters/fileSystem.cjs.map +1 -0
  16. package/dist/adapters/fileSystem.d.cts +17 -0
  17. package/dist/{types/storage → adapters}/fileSystem.d.ts +5 -2
  18. package/dist/adapters/fileSystem.js +93 -0
  19. package/dist/adapters/fileSystem.js.map +1 -0
  20. package/dist/adapters/indexedDB.cjs +103 -0
  21. package/dist/adapters/indexedDB.cjs.map +1 -0
  22. package/dist/adapters/indexedDB.d.cts +18 -0
  23. package/dist/{types/storage → adapters}/indexedDB.d.ts +5 -2
  24. package/dist/adapters/indexedDB.js +101 -0
  25. package/dist/adapters/indexedDB.js.map +1 -0
  26. package/dist/adapters/localStorage.cjs +50 -0
  27. package/dist/adapters/localStorage.cjs.map +1 -0
  28. package/dist/{types/storage/inMemory.d.ts → adapters/localStorage.d.cts} +6 -3
  29. package/dist/{types/storage → adapters}/localStorage.d.ts +5 -2
  30. package/dist/adapters/localStorage.js +48 -0
  31. package/dist/adapters/localStorage.js.map +1 -0
  32. package/dist/ark-ChhTwpLf.d.cts +3892 -0
  33. package/dist/ark-ChhTwpLf.d.ts +3892 -0
  34. package/dist/asyncStorageTaskQueue-DW1-BpI7.d.cts +49 -0
  35. package/dist/{types/worker/expo/asyncStorageTaskQueue.d.ts → asyncStorageTaskQueue-DZ0nUuEJ.d.ts} +6 -3
  36. package/dist/chunk-5BLDMQED.cjs +18 -0
  37. package/dist/chunk-5BLDMQED.cjs.map +1 -0
  38. package/dist/chunk-6FLL2Q36.cjs +2701 -0
  39. package/dist/chunk-6FLL2Q36.cjs.map +1 -0
  40. package/dist/chunk-6NWNOLL3.js +2671 -0
  41. package/dist/chunk-6NWNOLL3.js.map +1 -0
  42. package/dist/chunk-ABWRLTX5.js +210 -0
  43. package/dist/chunk-ABWRLTX5.js.map +1 -0
  44. package/dist/chunk-BVP2U66Q.js +13943 -0
  45. package/dist/chunk-BVP2U66Q.js.map +1 -0
  46. package/dist/chunk-GDCTOSMV.cjs +14058 -0
  47. package/dist/chunk-GDCTOSMV.cjs.map +1 -0
  48. package/dist/chunk-GIGILVVP.cjs +213 -0
  49. package/dist/chunk-GIGILVVP.cjs.map +1 -0
  50. package/dist/chunk-IEO3XDKI.cjs +838 -0
  51. package/dist/chunk-IEO3XDKI.cjs.map +1 -0
  52. package/dist/chunk-NSBPE2FW.js +15 -0
  53. package/dist/chunk-NSBPE2FW.js.map +1 -0
  54. package/dist/chunk-PJUFOJ2L.cjs +100 -0
  55. package/dist/chunk-PJUFOJ2L.cjs.map +1 -0
  56. package/dist/chunk-TH6T23XG.js +95 -0
  57. package/dist/chunk-TH6T23XG.js.map +1 -0
  58. package/dist/chunk-TU3LVAPX.js +769 -0
  59. package/dist/chunk-TU3LVAPX.js.map +1 -0
  60. package/dist/chunk-WMIPYZSB.cjs +803 -0
  61. package/dist/chunk-WMIPYZSB.cjs.map +1 -0
  62. package/dist/chunk-YA4G7RFB.js +829 -0
  63. package/dist/chunk-YA4G7RFB.js.map +1 -0
  64. package/dist/contracts/handlers/index.cjs +26 -0
  65. package/dist/contracts/handlers/index.cjs.map +1 -0
  66. package/dist/contracts/handlers/index.d.cts +7 -0
  67. package/dist/contracts/handlers/index.d.ts +7 -0
  68. package/dist/contracts/handlers/index.js +5 -0
  69. package/dist/contracts/handlers/index.js.map +1 -0
  70. package/dist/delegate-4JBUkUhR.d.cts +84 -0
  71. package/dist/delegate-DN7RELL1.d.ts +84 -0
  72. package/dist/{types/storage/index.d.ts → index-C0IanN1m.d.cts} +3 -1
  73. package/dist/index-C0IanN1m.d.ts +11 -0
  74. package/dist/index-Cn82bBUu.d.ts +199 -0
  75. package/dist/index-DfT5xzgY.d.cts +199 -0
  76. package/dist/index.cjs +504 -0
  77. package/dist/index.cjs.map +1 -0
  78. package/dist/index.d.cts +3469 -0
  79. package/dist/index.d.ts +3469 -0
  80. package/dist/index.js +7 -0
  81. package/dist/index.js.map +1 -0
  82. package/dist/repositories/realm/index.cjs +513 -0
  83. package/dist/repositories/realm/index.cjs.map +1 -0
  84. package/dist/repositories/realm/index.d.cts +217 -0
  85. package/dist/{types/repositories/realm/schemas.d.ts → repositories/realm/index.d.ts} +80 -112
  86. package/dist/repositories/realm/index.js +507 -0
  87. package/dist/repositories/realm/index.js.map +1 -0
  88. package/dist/repositories/sqlite/index.cjs +588 -0
  89. package/dist/repositories/sqlite/index.cjs.map +1 -0
  90. package/dist/repositories/sqlite/index.d.cts +118 -0
  91. package/dist/{types/repositories/sqlite/walletRepository.d.ts → repositories/sqlite/index.d.ts} +58 -5
  92. package/dist/repositories/sqlite/index.js +585 -0
  93. package/dist/repositories/sqlite/index.js.map +1 -0
  94. package/dist/taskRunner-B-aPfHhK.d.cts +114 -0
  95. package/dist/taskRunner-B-vG08pX.d.ts +114 -0
  96. package/dist/wallet/expo/background.cjs +93 -0
  97. package/dist/wallet/expo/background.cjs.map +1 -0
  98. package/dist/wallet/expo/background.d.cts +84 -0
  99. package/dist/wallet/expo/background.d.ts +84 -0
  100. package/dist/wallet/expo/background.js +68 -0
  101. package/dist/wallet/expo/background.js.map +1 -0
  102. package/dist/wallet/expo/index.cjs +175 -0
  103. package/dist/wallet/expo/index.cjs.map +1 -0
  104. package/dist/wallet/expo/index.d.cts +124 -0
  105. package/dist/wallet/expo/index.d.ts +124 -0
  106. package/dist/wallet/expo/index.js +173 -0
  107. package/dist/wallet/expo/index.js.map +1 -0
  108. package/dist/wallet-CCtqT2Wb.d.ts +778 -0
  109. package/dist/wallet-DjgFb_4T.d.cts +778 -0
  110. package/dist/worker/expo/index.cjs +140 -0
  111. package/dist/worker/expo/index.cjs.map +1 -0
  112. package/dist/worker/expo/index.d.cts +29 -0
  113. package/dist/worker/expo/index.d.ts +29 -0
  114. package/dist/worker/expo/index.js +121 -0
  115. package/dist/worker/expo/index.js.map +1 -0
  116. package/package.json +110 -76
  117. package/dist/cjs/adapters/asyncStorage.js +0 -5
  118. package/dist/cjs/adapters/expo.js +0 -8
  119. package/dist/cjs/adapters/fileSystem.js +0 -5
  120. package/dist/cjs/adapters/indexedDB.js +0 -5
  121. package/dist/cjs/adapters/localStorage.js +0 -5
  122. package/dist/cjs/arkfee/celenv.js +0 -43
  123. package/dist/cjs/arkfee/estimator.js +0 -143
  124. package/dist/cjs/arkfee/index.js +0 -5
  125. package/dist/cjs/arkfee/types.js +0 -26
  126. package/dist/cjs/arknote/index.js +0 -128
  127. package/dist/cjs/bip322/index.js +0 -270
  128. package/dist/cjs/contracts/arkcontract.js +0 -147
  129. package/dist/cjs/contracts/contractManager.js +0 -649
  130. package/dist/cjs/contracts/contractWatcher.js +0 -598
  131. package/dist/cjs/contracts/handlers/default.js +0 -93
  132. package/dist/cjs/contracts/handlers/delegate.js +0 -90
  133. package/dist/cjs/contracts/handlers/helpers.js +0 -115
  134. package/dist/cjs/contracts/handlers/index.js +0 -19
  135. package/dist/cjs/contracts/handlers/registry.js +0 -89
  136. package/dist/cjs/contracts/handlers/vhtlc.js +0 -194
  137. package/dist/cjs/contracts/index.js +0 -41
  138. package/dist/cjs/contracts/types.js +0 -2
  139. package/dist/cjs/contracts/vtxoOwnership.js +0 -78
  140. package/dist/cjs/extension/asset/assetGroup.js +0 -228
  141. package/dist/cjs/extension/asset/assetId.js +0 -152
  142. package/dist/cjs/extension/asset/assetInput.js +0 -222
  143. package/dist/cjs/extension/asset/assetOutput.js +0 -174
  144. package/dist/cjs/extension/asset/assetRef.js +0 -148
  145. package/dist/cjs/extension/asset/index.js +0 -23
  146. package/dist/cjs/extension/asset/metadata.js +0 -187
  147. package/dist/cjs/extension/asset/packet.js +0 -114
  148. package/dist/cjs/extension/asset/types.js +0 -22
  149. package/dist/cjs/extension/asset/utils.js +0 -105
  150. package/dist/cjs/extension/index.js +0 -254
  151. package/dist/cjs/extension/packet.js +0 -20
  152. package/dist/cjs/forfeit.js +0 -45
  153. package/dist/cjs/identity/descriptor.js +0 -169
  154. package/dist/cjs/identity/descriptorProvider.js +0 -2
  155. package/dist/cjs/identity/hdCapableIdentity.js +0 -20
  156. package/dist/cjs/identity/index.js +0 -40
  157. package/dist/cjs/identity/seedIdentity.js +0 -477
  158. package/dist/cjs/identity/serialize.js +0 -171
  159. package/dist/cjs/identity/singleKey.js +0 -126
  160. package/dist/cjs/identity/staticDescriptorProvider.js +0 -65
  161. package/dist/cjs/index.js +0 -202
  162. package/dist/cjs/intent/index.js +0 -259
  163. package/dist/cjs/musig2/index.js +0 -11
  164. package/dist/cjs/musig2/keys.js +0 -57
  165. package/dist/cjs/musig2/nonces.js +0 -48
  166. package/dist/cjs/musig2/sign.js +0 -102
  167. package/dist/cjs/networks.js +0 -26
  168. package/dist/cjs/package.json +0 -3
  169. package/dist/cjs/providers/ark.js +0 -577
  170. package/dist/cjs/providers/delegator.js +0 -85
  171. package/dist/cjs/providers/electrum.js +0 -869
  172. package/dist/cjs/providers/errors.js +0 -59
  173. package/dist/cjs/providers/expoArk.js +0 -82
  174. package/dist/cjs/providers/expoIndexer.js +0 -111
  175. package/dist/cjs/providers/expoUtils.js +0 -124
  176. package/dist/cjs/providers/indexer.js +0 -630
  177. package/dist/cjs/providers/onchain.js +0 -262
  178. package/dist/cjs/providers/utils.js +0 -121
  179. package/dist/cjs/repositories/contractRepository.js +0 -2
  180. package/dist/cjs/repositories/inMemory/contractRepository.js +0 -55
  181. package/dist/cjs/repositories/inMemory/walletRepository.js +0 -115
  182. package/dist/cjs/repositories/index.js +0 -34
  183. package/dist/cjs/repositories/indexedDB/contractRepository.js +0 -187
  184. package/dist/cjs/repositories/indexedDB/db.js +0 -19
  185. package/dist/cjs/repositories/indexedDB/manager.js +0 -100
  186. package/dist/cjs/repositories/indexedDB/schema.js +0 -204
  187. package/dist/cjs/repositories/indexedDB/walletRepository.js +0 -474
  188. package/dist/cjs/repositories/indexedDB/websqlAdapter.js +0 -144
  189. package/dist/cjs/repositories/migrations/contractRepositoryImpl.js +0 -127
  190. package/dist/cjs/repositories/migrations/fromStorageAdapter.js +0 -66
  191. package/dist/cjs/repositories/migrations/walletRepositoryImpl.js +0 -184
  192. package/dist/cjs/repositories/realm/contractRepository.js +0 -116
  193. package/dist/cjs/repositories/realm/index.js +0 -11
  194. package/dist/cjs/repositories/realm/schemas.js +0 -157
  195. package/dist/cjs/repositories/realm/types.js +0 -7
  196. package/dist/cjs/repositories/realm/walletRepository.js +0 -305
  197. package/dist/cjs/repositories/scriptFromAddress.js +0 -16
  198. package/dist/cjs/repositories/serialization.js +0 -82
  199. package/dist/cjs/repositories/sqlite/contractRepository.js +0 -135
  200. package/dist/cjs/repositories/sqlite/index.js +0 -7
  201. package/dist/cjs/repositories/sqlite/types.js +0 -2
  202. package/dist/cjs/repositories/sqlite/walletRepository.js +0 -441
  203. package/dist/cjs/repositories/walletRepository.js +0 -2
  204. package/dist/cjs/script/address.js +0 -108
  205. package/dist/cjs/script/base.js +0 -185
  206. package/dist/cjs/script/default.js +0 -57
  207. package/dist/cjs/script/delegate.js +0 -53
  208. package/dist/cjs/script/tapscript.js +0 -619
  209. package/dist/cjs/script/vhtlc.js +0 -170
  210. package/dist/cjs/storage/asyncStorage.js +0 -50
  211. package/dist/cjs/storage/fileSystem.js +0 -141
  212. package/dist/cjs/storage/inMemory.js +0 -24
  213. package/dist/cjs/storage/index.js +0 -2
  214. package/dist/cjs/storage/indexedDB.js +0 -101
  215. package/dist/cjs/storage/localStorage.js +0 -51
  216. package/dist/cjs/tree/signingSession.js +0 -229
  217. package/dist/cjs/tree/txTree.js +0 -192
  218. package/dist/cjs/tree/validation.js +0 -107
  219. package/dist/cjs/utils/anchor.js +0 -35
  220. package/dist/cjs/utils/arkTransaction.js +0 -271
  221. package/dist/cjs/utils/bip21.js +0 -127
  222. package/dist/cjs/utils/syncCursors.js +0 -128
  223. package/dist/cjs/utils/timelock.js +0 -59
  224. package/dist/cjs/utils/transaction.js +0 -28
  225. package/dist/cjs/utils/transactionHistory.js +0 -183
  226. package/dist/cjs/utils/txSizeEstimator.js +0 -132
  227. package/dist/cjs/utils/unknownFields.js +0 -174
  228. package/dist/cjs/wallet/asset-manager.js +0 -330
  229. package/dist/cjs/wallet/asset.js +0 -119
  230. package/dist/cjs/wallet/batch.js +0 -183
  231. package/dist/cjs/wallet/delegator.js +0 -308
  232. package/dist/cjs/wallet/expo/background.js +0 -116
  233. package/dist/cjs/wallet/expo/index.js +0 -9
  234. package/dist/cjs/wallet/expo/wallet.js +0 -230
  235. package/dist/cjs/wallet/hdDescriptorProvider.js +0 -188
  236. package/dist/cjs/wallet/index.js +0 -82
  237. package/dist/cjs/wallet/inputSignerRouter.js +0 -98
  238. package/dist/cjs/wallet/onchain.js +0 -290
  239. package/dist/cjs/wallet/ramps.js +0 -216
  240. package/dist/cjs/wallet/serviceWorker/wallet-message-handler.js +0 -953
  241. package/dist/cjs/wallet/serviceWorker/wallet.js +0 -1174
  242. package/dist/cjs/wallet/signingErrors.js +0 -32
  243. package/dist/cjs/wallet/unroll.js +0 -293
  244. package/dist/cjs/wallet/utils.js +0 -111
  245. package/dist/cjs/wallet/validation.js +0 -154
  246. package/dist/cjs/wallet/vtxo-manager.js +0 -1142
  247. package/dist/cjs/wallet/wallet.js +0 -2195
  248. package/dist/cjs/wallet/walletReceiveRotator.js +0 -547
  249. package/dist/cjs/worker/browser/service-worker-manager.js +0 -183
  250. package/dist/cjs/worker/browser/utils.js +0 -67
  251. package/dist/cjs/worker/errors.js +0 -16
  252. package/dist/cjs/worker/expo/asyncStorageTaskQueue.js +0 -78
  253. package/dist/cjs/worker/expo/index.js +0 -13
  254. package/dist/cjs/worker/expo/processors/contractPollProcessor.js +0 -62
  255. package/dist/cjs/worker/expo/processors/index.js +0 -6
  256. package/dist/cjs/worker/expo/taskQueue.js +0 -41
  257. package/dist/cjs/worker/expo/taskRunner.js +0 -73
  258. package/dist/cjs/worker/messageBus.js +0 -474
  259. package/dist/esm/adapters/asyncStorage.js +0 -1
  260. package/dist/esm/adapters/expo.js +0 -3
  261. package/dist/esm/adapters/fileSystem.js +0 -1
  262. package/dist/esm/adapters/indexedDB.js +0 -1
  263. package/dist/esm/adapters/localStorage.js +0 -1
  264. package/dist/esm/arkfee/celenv.js +0 -40
  265. package/dist/esm/arkfee/estimator.js +0 -139
  266. package/dist/esm/arkfee/index.js +0 -1
  267. package/dist/esm/arkfee/types.js +0 -22
  268. package/dist/esm/arknote/index.js +0 -124
  269. package/dist/esm/bip322/index.js +0 -267
  270. package/dist/esm/contracts/arkcontract.js +0 -140
  271. package/dist/esm/contracts/contractManager.js +0 -645
  272. package/dist/esm/contracts/contractWatcher.js +0 -594
  273. package/dist/esm/contracts/handlers/default.js +0 -90
  274. package/dist/esm/contracts/handlers/delegate.js +0 -87
  275. package/dist/esm/contracts/handlers/helpers.js +0 -110
  276. package/dist/esm/contracts/handlers/index.js +0 -12
  277. package/dist/esm/contracts/handlers/registry.js +0 -86
  278. package/dist/esm/contracts/handlers/vhtlc.js +0 -191
  279. package/dist/esm/contracts/index.js +0 -13
  280. package/dist/esm/contracts/types.js +0 -1
  281. package/dist/esm/contracts/vtxoOwnership.js +0 -69
  282. package/dist/esm/extension/asset/assetGroup.js +0 -224
  283. package/dist/esm/extension/asset/assetId.js +0 -148
  284. package/dist/esm/extension/asset/assetInput.js +0 -217
  285. package/dist/esm/extension/asset/assetOutput.js +0 -169
  286. package/dist/esm/extension/asset/assetRef.js +0 -144
  287. package/dist/esm/extension/asset/index.js +0 -8
  288. package/dist/esm/extension/asset/metadata.js +0 -182
  289. package/dist/esm/extension/asset/packet.js +0 -110
  290. package/dist/esm/extension/asset/types.js +0 -19
  291. package/dist/esm/extension/asset/utils.js +0 -99
  292. package/dist/esm/extension/index.js +0 -248
  293. package/dist/esm/extension/packet.js +0 -16
  294. package/dist/esm/forfeit.js +0 -41
  295. package/dist/esm/identity/descriptor.js +0 -161
  296. package/dist/esm/identity/descriptorProvider.js +0 -1
  297. package/dist/esm/identity/hdCapableIdentity.js +0 -17
  298. package/dist/esm/identity/index.js +0 -13
  299. package/dist/esm/identity/seedIdentity.js +0 -469
  300. package/dist/esm/identity/serialize.js +0 -164
  301. package/dist/esm/identity/singleKey.js +0 -121
  302. package/dist/esm/identity/staticDescriptorProvider.js +0 -61
  303. package/dist/esm/index.js +0 -87
  304. package/dist/esm/intent/index.js +0 -255
  305. package/dist/esm/musig2/index.js +0 -3
  306. package/dist/esm/musig2/keys.js +0 -21
  307. package/dist/esm/musig2/nonces.js +0 -11
  308. package/dist/esm/musig2/sign.js +0 -63
  309. package/dist/esm/networks.js +0 -22
  310. package/dist/esm/package.json +0 -3
  311. package/dist/esm/providers/ark.js +0 -572
  312. package/dist/esm/providers/delegator.js +0 -81
  313. package/dist/esm/providers/electrum.js +0 -864
  314. package/dist/esm/providers/errors.js +0 -54
  315. package/dist/esm/providers/expoArk.js +0 -78
  316. package/dist/esm/providers/expoIndexer.js +0 -107
  317. package/dist/esm/providers/expoUtils.js +0 -87
  318. package/dist/esm/providers/indexer.js +0 -626
  319. package/dist/esm/providers/onchain.js +0 -258
  320. package/dist/esm/providers/utils.js +0 -117
  321. package/dist/esm/repositories/contractRepository.js +0 -1
  322. package/dist/esm/repositories/inMemory/contractRepository.js +0 -51
  323. package/dist/esm/repositories/inMemory/walletRepository.js +0 -111
  324. package/dist/esm/repositories/index.js +0 -10
  325. package/dist/esm/repositories/indexedDB/contractRepository.js +0 -183
  326. package/dist/esm/repositories/indexedDB/db.js +0 -4
  327. package/dist/esm/repositories/indexedDB/manager.js +0 -95
  328. package/dist/esm/repositories/indexedDB/schema.js +0 -199
  329. package/dist/esm/repositories/indexedDB/walletRepository.js +0 -470
  330. package/dist/esm/repositories/indexedDB/websqlAdapter.js +0 -138
  331. package/dist/esm/repositories/migrations/contractRepositoryImpl.js +0 -121
  332. package/dist/esm/repositories/migrations/fromStorageAdapter.js +0 -58
  333. package/dist/esm/repositories/migrations/walletRepositoryImpl.js +0 -180
  334. package/dist/esm/repositories/realm/contractRepository.js +0 -112
  335. package/dist/esm/repositories/realm/index.js +0 -3
  336. package/dist/esm/repositories/realm/schemas.js +0 -153
  337. package/dist/esm/repositories/realm/types.js +0 -6
  338. package/dist/esm/repositories/realm/walletRepository.js +0 -301
  339. package/dist/esm/repositories/scriptFromAddress.js +0 -13
  340. package/dist/esm/repositories/serialization.js +0 -67
  341. package/dist/esm/repositories/sqlite/contractRepository.js +0 -131
  342. package/dist/esm/repositories/sqlite/index.js +0 -2
  343. package/dist/esm/repositories/sqlite/types.js +0 -1
  344. package/dist/esm/repositories/sqlite/walletRepository.js +0 -437
  345. package/dist/esm/repositories/walletRepository.js +0 -1
  346. package/dist/esm/script/address.js +0 -104
  347. package/dist/esm/script/base.js +0 -179
  348. package/dist/esm/script/default.js +0 -54
  349. package/dist/esm/script/delegate.js +0 -50
  350. package/dist/esm/script/tapscript.js +0 -615
  351. package/dist/esm/script/vhtlc.js +0 -167
  352. package/dist/esm/storage/asyncStorage.js +0 -46
  353. package/dist/esm/storage/fileSystem.js +0 -104
  354. package/dist/esm/storage/inMemory.js +0 -20
  355. package/dist/esm/storage/index.js +0 -1
  356. package/dist/esm/storage/indexedDB.js +0 -97
  357. package/dist/esm/storage/localStorage.js +0 -47
  358. package/dist/esm/tree/signingSession.js +0 -191
  359. package/dist/esm/tree/txTree.js +0 -188
  360. package/dist/esm/tree/validation.js +0 -101
  361. package/dist/esm/utils/anchor.js +0 -31
  362. package/dist/esm/utils/arkTransaction.js +0 -264
  363. package/dist/esm/utils/bip21.js +0 -123
  364. package/dist/esm/utils/syncCursors.js +0 -119
  365. package/dist/esm/utils/timelock.js +0 -22
  366. package/dist/esm/utils/transaction.js +0 -24
  367. package/dist/esm/utils/transactionHistory.js +0 -180
  368. package/dist/esm/utils/txSizeEstimator.js +0 -128
  369. package/dist/esm/utils/unknownFields.js +0 -169
  370. package/dist/esm/wallet/asset-manager.js +0 -325
  371. package/dist/esm/wallet/asset.js +0 -113
  372. package/dist/esm/wallet/batch.js +0 -180
  373. package/dist/esm/wallet/delegator.js +0 -303
  374. package/dist/esm/wallet/expo/background.js +0 -111
  375. package/dist/esm/wallet/expo/index.js +0 -2
  376. package/dist/esm/wallet/expo/wallet.js +0 -193
  377. package/dist/esm/wallet/hdDescriptorProvider.js +0 -184
  378. package/dist/esm/wallet/index.js +0 -75
  379. package/dist/esm/wallet/inputSignerRouter.js +0 -94
  380. package/dist/esm/wallet/onchain.js +0 -285
  381. package/dist/esm/wallet/ramps.js +0 -212
  382. package/dist/esm/wallet/serviceWorker/wallet-message-handler.js +0 -946
  383. package/dist/esm/wallet/serviceWorker/wallet.js +0 -1169
  384. package/dist/esm/wallet/signingErrors.js +0 -27
  385. package/dist/esm/wallet/unroll.js +0 -289
  386. package/dist/esm/wallet/utils.js +0 -103
  387. package/dist/esm/wallet/validation.js +0 -142
  388. package/dist/esm/wallet/vtxo-manager.js +0 -1136
  389. package/dist/esm/wallet/wallet.js +0 -2186
  390. package/dist/esm/wallet/walletReceiveRotator.js +0 -540
  391. package/dist/esm/worker/browser/service-worker-manager.js +0 -177
  392. package/dist/esm/worker/browser/utils.js +0 -63
  393. package/dist/esm/worker/errors.js +0 -11
  394. package/dist/esm/worker/expo/asyncStorageTaskQueue.js +0 -74
  395. package/dist/esm/worker/expo/index.js +0 -4
  396. package/dist/esm/worker/expo/processors/contractPollProcessor.js +0 -59
  397. package/dist/esm/worker/expo/processors/index.js +0 -1
  398. package/dist/esm/worker/expo/taskQueue.js +0 -37
  399. package/dist/esm/worker/expo/taskRunner.js +0 -69
  400. package/dist/esm/worker/messageBus.js +0 -470
  401. package/dist/types/adapters/asyncStorage.d.ts +0 -2
  402. package/dist/types/adapters/expo.d.ts +0 -4
  403. package/dist/types/adapters/fileSystem.d.ts +0 -2
  404. package/dist/types/adapters/indexedDB.d.ts +0 -2
  405. package/dist/types/adapters/localStorage.d.ts +0 -2
  406. package/dist/types/arkfee/celenv.d.ts +0 -25
  407. package/dist/types/arkfee/estimator.d.ts +0 -49
  408. package/dist/types/arkfee/index.d.ts +0 -2
  409. package/dist/types/arkfee/types.d.ts +0 -38
  410. package/dist/types/arknote/index.d.ts +0 -84
  411. package/dist/types/bip322/index.d.ts +0 -55
  412. package/dist/types/contracts/arkcontract.d.ts +0 -99
  413. package/dist/types/contracts/contractManager.d.ts +0 -411
  414. package/dist/types/contracts/contractWatcher.d.ts +0 -217
  415. package/dist/types/contracts/handlers/default.d.ts +0 -19
  416. package/dist/types/contracts/handlers/delegate.d.ts +0 -21
  417. package/dist/types/contracts/handlers/helpers.d.ts +0 -19
  418. package/dist/types/contracts/handlers/index.d.ts +0 -7
  419. package/dist/types/contracts/handlers/registry.d.ts +0 -65
  420. package/dist/types/contracts/handlers/vhtlc.d.ts +0 -32
  421. package/dist/types/contracts/index.d.ts +0 -14
  422. package/dist/types/contracts/types.d.ts +0 -250
  423. package/dist/types/contracts/vtxoOwnership.d.ts +0 -33
  424. package/dist/types/extension/asset/assetGroup.d.ts +0 -119
  425. package/dist/types/extension/asset/assetId.d.ts +0 -83
  426. package/dist/types/extension/asset/assetInput.d.ts +0 -64
  427. package/dist/types/extension/asset/assetOutput.d.ts +0 -54
  428. package/dist/types/extension/asset/assetRef.d.ts +0 -91
  429. package/dist/types/extension/asset/index.d.ts +0 -8
  430. package/dist/types/extension/asset/metadata.d.ts +0 -52
  431. package/dist/types/extension/asset/packet.d.ts +0 -41
  432. package/dist/types/extension/asset/types.d.ts +0 -16
  433. package/dist/types/extension/asset/utils.d.ts +0 -21
  434. package/dist/types/extension/index.d.ts +0 -56
  435. package/dist/types/extension/packet.d.ts +0 -21
  436. package/dist/types/forfeit.d.ts +0 -18
  437. package/dist/types/identity/descriptor.d.ts +0 -61
  438. package/dist/types/identity/descriptorProvider.d.ts +0 -42
  439. package/dist/types/identity/hdCapableIdentity.d.ts +0 -71
  440. package/dist/types/identity/index.d.ts +0 -57
  441. package/dist/types/identity/seedIdentity.d.ts +0 -270
  442. package/dist/types/identity/serialize.d.ts +0 -96
  443. package/dist/types/identity/singleKey.d.ts +0 -62
  444. package/dist/types/identity/staticDescriptorProvider.d.ts +0 -18
  445. package/dist/types/index.d.ts +0 -59
  446. package/dist/types/intent/index.d.ts +0 -86
  447. package/dist/types/musig2/index.d.ts +0 -4
  448. package/dist/types/musig2/keys.d.ts +0 -9
  449. package/dist/types/musig2/nonces.d.ts +0 -14
  450. package/dist/types/musig2/sign.d.ts +0 -27
  451. package/dist/types/networks.d.ts +0 -16
  452. package/dist/types/providers/ark.d.ts +0 -369
  453. package/dist/types/providers/delegator.d.ts +0 -82
  454. package/dist/types/providers/electrum.d.ts +0 -312
  455. package/dist/types/providers/errors.d.ts +0 -13
  456. package/dist/types/providers/expoArk.d.ts +0 -22
  457. package/dist/types/providers/expoIndexer.d.ts +0 -18
  458. package/dist/types/providers/expoUtils.d.ts +0 -18
  459. package/dist/types/providers/indexer.d.ts +0 -301
  460. package/dist/types/providers/onchain.d.ts +0 -148
  461. package/dist/types/providers/utils.d.ts +0 -12
  462. package/dist/types/repositories/contractRepository.d.ts +0 -32
  463. package/dist/types/repositories/inMemory/contractRepository.d.ts +0 -17
  464. package/dist/types/repositories/inMemory/walletRepository.d.ts +0 -29
  465. package/dist/types/repositories/index.d.ts +0 -9
  466. package/dist/types/repositories/indexedDB/contractRepository.d.ts +0 -21
  467. package/dist/types/repositories/indexedDB/db.d.ts +0 -4
  468. package/dist/types/repositories/indexedDB/manager.d.ts +0 -25
  469. package/dist/types/repositories/indexedDB/schema.d.ts +0 -9
  470. package/dist/types/repositories/indexedDB/walletRepository.d.ts +0 -28
  471. package/dist/types/repositories/indexedDB/websqlAdapter.d.ts +0 -49
  472. package/dist/types/repositories/migrations/contractRepositoryImpl.d.ts +0 -24
  473. package/dist/types/repositories/migrations/fromStorageAdapter.d.ts +0 -19
  474. package/dist/types/repositories/migrations/walletRepositoryImpl.d.ts +0 -27
  475. package/dist/types/repositories/realm/contractRepository.d.ts +0 -24
  476. package/dist/types/repositories/realm/index.d.ts +0 -4
  477. package/dist/types/repositories/realm/types.d.ts +0 -16
  478. package/dist/types/repositories/realm/walletRepository.d.ts +0 -34
  479. package/dist/types/repositories/scriptFromAddress.d.ts +0 -9
  480. package/dist/types/repositories/serialization.d.ts +0 -65
  481. package/dist/types/repositories/sqlite/contractRepository.d.ts +0 -33
  482. package/dist/types/repositories/sqlite/index.d.ts +0 -3
  483. package/dist/types/repositories/sqlite/types.d.ts +0 -18
  484. package/dist/types/repositories/walletRepository.d.ts +0 -72
  485. package/dist/types/script/address.d.ts +0 -67
  486. package/dist/types/script/base.d.ts +0 -105
  487. package/dist/types/script/default.d.ts +0 -44
  488. package/dist/types/script/delegate.d.ts +0 -40
  489. package/dist/types/script/tapscript.d.ts +0 -169
  490. package/dist/types/script/vhtlc.d.ts +0 -66
  491. package/dist/types/tree/signingSession.d.ts +0 -37
  492. package/dist/types/tree/txTree.d.ts +0 -28
  493. package/dist/types/tree/validation.d.ts +0 -15
  494. package/dist/types/utils/anchor.d.ts +0 -19
  495. package/dist/types/utils/arkTransaction.d.ts +0 -49
  496. package/dist/types/utils/bip21.d.ts +0 -38
  497. package/dist/types/utils/syncCursors.d.ts +0 -60
  498. package/dist/types/utils/timelock.d.ts +0 -9
  499. package/dist/types/utils/transaction.d.ts +0 -13
  500. package/dist/types/utils/transactionHistory.d.ts +0 -15
  501. package/dist/types/utils/txSizeEstimator.d.ts +0 -40
  502. package/dist/types/utils/unknownFields.d.ts +0 -83
  503. package/dist/types/wallet/asset-manager.d.ts +0 -69
  504. package/dist/types/wallet/asset.d.ts +0 -21
  505. package/dist/types/wallet/batch.d.ts +0 -107
  506. package/dist/types/wallet/delegator.d.ts +0 -48
  507. package/dist/types/wallet/expo/background.d.ts +0 -66
  508. package/dist/types/wallet/expo/index.d.ts +0 -4
  509. package/dist/types/wallet/expo/wallet.d.ts +0 -99
  510. package/dist/types/wallet/hdDescriptorProvider.d.ts +0 -114
  511. package/dist/types/wallet/index.d.ts +0 -789
  512. package/dist/types/wallet/inputSignerRouter.d.ts +0 -35
  513. package/dist/types/wallet/onchain.d.ts +0 -109
  514. package/dist/types/wallet/ramps.d.ts +0 -64
  515. package/dist/types/wallet/serviceWorker/wallet-message-handler.d.ts +0 -543
  516. package/dist/types/wallet/serviceWorker/wallet.d.ts +0 -248
  517. package/dist/types/wallet/signingErrors.d.ts +0 -19
  518. package/dist/types/wallet/unroll.d.ts +0 -114
  519. package/dist/types/wallet/utils.d.ts +0 -36
  520. package/dist/types/wallet/validation.d.ts +0 -24
  521. package/dist/types/wallet/vtxo-manager.d.ts +0 -476
  522. package/dist/types/wallet/wallet.d.ts +0 -409
  523. package/dist/types/wallet/walletReceiveRotator.d.ts +0 -306
  524. package/dist/types/worker/browser/service-worker-manager.d.ts +0 -32
  525. package/dist/types/worker/browser/utils.d.ts +0 -17
  526. package/dist/types/worker/errors.d.ts +0 -7
  527. package/dist/types/worker/expo/index.d.ts +0 -7
  528. package/dist/types/worker/expo/processors/contractPollProcessor.d.ts +0 -19
  529. package/dist/types/worker/expo/processors/index.d.ts +0 -1
  530. package/dist/types/worker/expo/taskQueue.d.ts +0 -50
  531. package/dist/types/worker/expo/taskRunner.d.ts +0 -66
  532. package/dist/types/worker/messageBus.d.ts +0 -189
@@ -1,953 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.WalletMessageHandler = exports.DEFAULT_MESSAGE_TAG = exports.DelegatorNotConfiguredError = exports.ReadonlyWalletError = exports.WalletNotInitializedError = void 0;
4
- const indexer_1 = require("../../providers/indexer");
5
- const index_1 = require("../index");
6
- const utils_1 = require("../utils");
7
- const transactionHistory_1 = require("../../utils/transactionHistory");
8
- const vtxoOwnership_1 = require("../../contracts/vtxoOwnership");
9
- const scriptFromAddress_1 = require("../../repositories/scriptFromAddress");
10
- class WalletNotInitializedError extends Error {
11
- constructor() {
12
- super("Wallet handler not initialized");
13
- this.name = "WalletNotInitializedError";
14
- }
15
- }
16
- exports.WalletNotInitializedError = WalletNotInitializedError;
17
- class ReadonlyWalletError extends Error {
18
- constructor() {
19
- super("Read-only wallet: operation requires signing");
20
- this.name = "ReadonlyWalletError";
21
- }
22
- }
23
- exports.ReadonlyWalletError = ReadonlyWalletError;
24
- class DelegatorNotConfiguredError extends Error {
25
- constructor() {
26
- super("Delegator not configured");
27
- this.name = "DelegatorNotConfiguredError";
28
- }
29
- }
30
- exports.DelegatorNotConfiguredError = DelegatorNotConfiguredError;
31
- exports.DEFAULT_MESSAGE_TAG = "WALLET_UPDATER";
32
- class WalletMessageHandler {
33
- /**
34
- * Instantiate a new WalletUpdater.
35
- * Can override the default `messageTag` allowing more than one updater to run in parallel.
36
- * Note that the default ServiceWorkerWallet sends messages to the default WalletUpdater tag.
37
- */
38
- constructor(options) {
39
- this.onNextTick = [];
40
- this.messageTag = options?.messageTag ?? exports.DEFAULT_MESSAGE_TAG;
41
- }
42
- // lifecycle methods
43
- async start(...params) {
44
- const [services, repositories] = params;
45
- this.readonlyWallet = services.readonlyWallet;
46
- this.wallet = services.wallet;
47
- this.arkProvider = services.arkProvider;
48
- this.walletRepository = repositories.walletRepository;
49
- }
50
- async stop() {
51
- if (this.incomingFundsSubscription) {
52
- this.incomingFundsSubscription();
53
- this.incomingFundsSubscription = undefined;
54
- }
55
- if (this.contractEventsSubscription) {
56
- this.contractEventsSubscription();
57
- this.contractEventsSubscription = undefined;
58
- }
59
- // Dispose the wallet to stop VtxoManager background tasks
60
- // (auto-renewal, boarding input polling) and ContractWatcher.
61
- try {
62
- if (this.wallet) {
63
- await this.wallet.dispose();
64
- }
65
- else if (this.readonlyWallet) {
66
- await this.readonlyWallet.dispose();
67
- }
68
- }
69
- catch (_) {
70
- // best-effort teardown
71
- }
72
- this.wallet = undefined;
73
- this.readonlyWallet = undefined;
74
- this.arkProvider = undefined;
75
- this.indexerProvider = undefined;
76
- }
77
- async tick(_now) {
78
- const results = await Promise.allSettled(this.onNextTick.map((fn) => fn()));
79
- this.onNextTick = [];
80
- return results
81
- .map((result) => {
82
- if (result.status === "fulfilled") {
83
- return result.value;
84
- }
85
- else {
86
- console.error(`[${this.messageTag}] tick failed`, result.reason);
87
- // TODO: how to deliver errors down the stream? a broadcast?
88
- return null;
89
- }
90
- })
91
- .filter((response) => response !== null);
92
- }
93
- scheduleForNextTick(callback) {
94
- this.onNextTick.push(callback);
95
- }
96
- requireWallet() {
97
- if (!this.wallet) {
98
- throw new ReadonlyWalletError();
99
- }
100
- return this.wallet;
101
- }
102
- tagged(res) {
103
- return {
104
- ...res,
105
- tag: this.messageTag,
106
- };
107
- }
108
- // Flows that surrender control to the Ark server and the other participants
109
- // in a batch round: quiet gaps between protocol events can easily exceed
110
- // the bus-level messageTimeoutMs. Liveness is covered out-of-band by the
111
- // page-side PING / MESSAGE_BUS_NOT_INITIALIZED path triggered by concurrent
112
- // short requests (GET_STATUS, GET_BALANCE, ...).
113
- isLongRunning(message) {
114
- return (message.type === "SETTLE" ||
115
- message.type === "RECOVER_VTXOS" ||
116
- message.type === "RENEW_VTXOS");
117
- }
118
- async handleMessage(message) {
119
- const id = message.id;
120
- if (message.type === "INIT_WALLET") {
121
- await this.handleInitWallet(message);
122
- return this.tagged({
123
- id,
124
- type: "WALLET_INITIALIZED",
125
- });
126
- }
127
- if (!this.readonlyWallet) {
128
- return this.tagged({
129
- id,
130
- error: new WalletNotInitializedError(),
131
- });
132
- }
133
- try {
134
- switch (message.type) {
135
- case "SETTLE": {
136
- const response = await this.handleSettle(message);
137
- return this.tagged({
138
- id,
139
- ...response,
140
- });
141
- }
142
- case "SEND_BITCOIN": {
143
- const response = await this.handleSendBitcoin(message);
144
- return this.tagged({
145
- id,
146
- ...response,
147
- });
148
- }
149
- case "GET_ADDRESS": {
150
- const address = await this.readonlyWallet.getAddress();
151
- return this.tagged({
152
- id,
153
- type: "ADDRESS",
154
- payload: { address },
155
- });
156
- }
157
- case "GET_BOARDING_ADDRESS": {
158
- const address = await this.readonlyWallet.getBoardingAddress();
159
- return this.tagged({
160
- id,
161
- type: "BOARDING_ADDRESS",
162
- payload: { address },
163
- });
164
- }
165
- case "GET_BALANCE": {
166
- const balance = await this.handleGetBalance();
167
- return this.tagged({
168
- id,
169
- type: "BALANCE",
170
- payload: balance,
171
- });
172
- }
173
- case "GET_VTXOS": {
174
- const vtxos = await this.handleGetVtxos(message);
175
- return {
176
- tag: this.messageTag,
177
- id,
178
- type: "VTXOS",
179
- payload: { vtxos },
180
- };
181
- }
182
- case "GET_BOARDING_UTXOS": {
183
- const utxos = await this.getAllBoardingUtxos();
184
- return this.tagged({
185
- id,
186
- type: "BOARDING_UTXOS",
187
- payload: { utxos },
188
- });
189
- }
190
- case "GET_TRANSACTION_HISTORY": {
191
- const allVtxos = await this.getVtxosFromRepo();
192
- const transactions = (await this.buildTransactionHistoryFromCache(allVtxos)) ?? [];
193
- return this.tagged({
194
- id,
195
- type: "TRANSACTION_HISTORY",
196
- payload: { transactions },
197
- });
198
- }
199
- case "GET_STATUS": {
200
- const pubKey = await this.readonlyWallet.identity.xOnlyPublicKey();
201
- return this.tagged({
202
- id,
203
- type: "WALLET_STATUS",
204
- payload: {
205
- walletInitialized: true,
206
- xOnlyPublicKey: pubKey,
207
- },
208
- });
209
- }
210
- case "CLEAR": {
211
- await this.clear();
212
- return this.tagged({
213
- id,
214
- type: "CLEAR_SUCCESS",
215
- payload: { cleared: true },
216
- });
217
- }
218
- case "RELOAD_WALLET": {
219
- await this.reloadWallet();
220
- return this.tagged({
221
- id,
222
- type: "RELOAD_SUCCESS",
223
- payload: { reloaded: true },
224
- });
225
- }
226
- case "SIGN_TRANSACTION": {
227
- const response = await this.handleSignTransaction(message);
228
- return this.tagged({
229
- id,
230
- ...response,
231
- });
232
- }
233
- case "CREATE_CONTRACT": {
234
- const manager = await this.readonlyWallet.getContractManager();
235
- const contract = await manager.createContract(message.payload);
236
- return this.tagged({
237
- id,
238
- type: "CONTRACT_CREATED",
239
- payload: { contract },
240
- });
241
- }
242
- case "GET_CONTRACTS": {
243
- const manager = await this.readonlyWallet.getContractManager();
244
- const contracts = await manager.getContracts(message.payload.filter);
245
- return this.tagged({
246
- id,
247
- type: "CONTRACTS",
248
- payload: { contracts },
249
- });
250
- }
251
- case "GET_CONTRACTS_WITH_VTXOS": {
252
- const manager = await this.readonlyWallet.getContractManager();
253
- const contracts = await manager.getContractsWithVtxos(message.payload.filter);
254
- return this.tagged({
255
- id,
256
- type: "CONTRACTS_WITH_VTXOS",
257
- payload: { contracts },
258
- });
259
- }
260
- case "ANNOTATE_VTXOS": {
261
- const manager = await this.readonlyWallet.getContractManager();
262
- const annotated = await manager.annotateVtxos(message.payload.vtxos);
263
- return this.tagged({
264
- id,
265
- type: "ANNOTATED_VTXOS",
266
- payload: { vtxos: annotated },
267
- });
268
- }
269
- case "UPDATE_CONTRACT": {
270
- const manager = await this.readonlyWallet.getContractManager();
271
- const contract = await manager.updateContract(message.payload.script, message.payload.updates);
272
- return this.tagged({
273
- id,
274
- type: "CONTRACT_UPDATED",
275
- payload: { contract },
276
- });
277
- }
278
- case "DELETE_CONTRACT": {
279
- const manager = await this.readonlyWallet.getContractManager();
280
- await manager.deleteContract(message.payload.script);
281
- return this.tagged({
282
- id,
283
- type: "CONTRACT_DELETED",
284
- payload: { deleted: true },
285
- });
286
- }
287
- case "GET_SPENDABLE_PATHS": {
288
- const manager = await this.readonlyWallet.getContractManager();
289
- const paths = await manager.getSpendablePaths(message.payload.options);
290
- return this.tagged({
291
- id,
292
- type: "SPENDABLE_PATHS",
293
- payload: { paths },
294
- });
295
- }
296
- case "GET_ALL_SPENDING_PATHS": {
297
- const manager = await this.readonlyWallet.getContractManager();
298
- const paths = await manager.getAllSpendingPaths(message.payload.options);
299
- return this.tagged({
300
- id,
301
- type: "ALL_SPENDING_PATHS",
302
- payload: { paths },
303
- });
304
- }
305
- case "IS_CONTRACT_MANAGER_WATCHING": {
306
- const manager = await this.readonlyWallet.getContractManager();
307
- const isWatching = await manager.isWatching();
308
- return this.tagged({
309
- id,
310
- type: "CONTRACT_WATCHING",
311
- payload: { isWatching },
312
- });
313
- }
314
- case "REFRESH_VTXOS": {
315
- const manager = await this.readonlyWallet.getContractManager();
316
- await manager.refreshVtxos(message.payload);
317
- return this.tagged({
318
- id,
319
- type: "REFRESH_VTXOS_SUCCESS",
320
- });
321
- }
322
- case "REFRESH_OUTPOINTS": {
323
- const manager = await this.readonlyWallet.getContractManager();
324
- const { outpoints } = message
325
- .payload;
326
- await manager.refreshOutpoints(outpoints);
327
- return this.tagged({
328
- id,
329
- type: "REFRESH_OUTPOINTS_SUCCESS",
330
- });
331
- }
332
- case "SEND": {
333
- const { recipients } = message.payload;
334
- const txid = await this.wallet.send(...recipients);
335
- return this.tagged({
336
- id,
337
- type: "SEND_SUCCESS",
338
- payload: { txid },
339
- });
340
- }
341
- case "GET_ASSET_DETAILS": {
342
- const { assetId } = message
343
- .payload;
344
- const assetDetails = await this.readonlyWallet.assetManager.getAssetDetails(assetId);
345
- return this.tagged({
346
- id,
347
- type: "ASSET_DETAILS",
348
- payload: { assetDetails },
349
- });
350
- }
351
- case "ISSUE": {
352
- const { params } = message.payload;
353
- const result = await this.wallet.assetManager.issue(params);
354
- return this.tagged({
355
- id,
356
- type: "ISSUE_SUCCESS",
357
- payload: { result },
358
- });
359
- }
360
- case "REISSUE": {
361
- const { params } = message.payload;
362
- const txid = await this.wallet.assetManager.reissue(params);
363
- return this.tagged({
364
- id,
365
- type: "REISSUE_SUCCESS",
366
- payload: { txid },
367
- });
368
- }
369
- case "BURN": {
370
- const { params } = message.payload;
371
- const txid = await this.wallet.assetManager.burn(params);
372
- return this.tagged({
373
- id,
374
- type: "BURN_SUCCESS",
375
- payload: { txid },
376
- });
377
- }
378
- case "DELEGATE": {
379
- const response = await this.handleDelegate(message);
380
- return this.tagged({ id, ...response });
381
- }
382
- case "GET_DELEGATE_INFO": {
383
- const wallet = this.requireWallet();
384
- const delegatorManager = await wallet.getDelegatorManager();
385
- if (!delegatorManager) {
386
- throw new DelegatorNotConfiguredError();
387
- }
388
- const info = await delegatorManager.getDelegateInfo();
389
- return this.tagged({
390
- id,
391
- type: "DELEGATE_INFO",
392
- payload: { info },
393
- });
394
- }
395
- case "RECOVER_VTXOS": {
396
- const wallet = this.requireWallet();
397
- const vtxoManager = await wallet.getVtxoManager();
398
- const txid = await vtxoManager.recoverVtxos((e) => {
399
- this.scheduleForNextTick(() => this.tagged({
400
- id,
401
- type: "RECOVER_VTXOS_EVENT",
402
- payload: e,
403
- }));
404
- });
405
- return this.tagged({
406
- id,
407
- type: "RECOVER_VTXOS_SUCCESS",
408
- payload: { txid },
409
- });
410
- }
411
- case "GET_RECOVERABLE_BALANCE": {
412
- const wallet = this.requireWallet();
413
- const vtxoManager = await wallet.getVtxoManager();
414
- const balance = await vtxoManager.getRecoverableBalance();
415
- return this.tagged({
416
- id,
417
- type: "RECOVERABLE_BALANCE",
418
- payload: {
419
- recoverable: balance.recoverable.toString(),
420
- subdust: balance.subdust.toString(),
421
- includesSubdust: balance.includesSubdust,
422
- vtxoCount: balance.vtxoCount,
423
- },
424
- });
425
- }
426
- case "GET_EXPIRING_VTXOS": {
427
- const wallet = this.requireWallet();
428
- const vtxoManager = await wallet.getVtxoManager();
429
- const vtxos = await vtxoManager.getExpiringVtxos(message.payload.thresholdMs);
430
- return this.tagged({
431
- id,
432
- type: "EXPIRING_VTXOS",
433
- payload: { vtxos },
434
- });
435
- }
436
- case "RENEW_VTXOS": {
437
- const wallet = this.requireWallet();
438
- const vtxoManager = await wallet.getVtxoManager();
439
- const txid = await vtxoManager.renewVtxos((e) => {
440
- this.scheduleForNextTick(() => this.tagged({
441
- id,
442
- type: "RENEW_VTXOS_EVENT",
443
- payload: e,
444
- }));
445
- });
446
- return this.tagged({
447
- id,
448
- type: "RENEW_VTXOS_SUCCESS",
449
- payload: { txid },
450
- });
451
- }
452
- case "GET_EXPIRED_BOARDING_UTXOS": {
453
- const wallet = this.requireWallet();
454
- const vtxoManager = await wallet.getVtxoManager();
455
- const utxos = await vtxoManager.getExpiredBoardingUtxos();
456
- return this.tagged({
457
- id,
458
- type: "EXPIRED_BOARDING_UTXOS",
459
- payload: { utxos },
460
- });
461
- }
462
- case "SWEEP_EXPIRED_BOARDING_UTXOS": {
463
- const wallet = this.requireWallet();
464
- const vtxoManager = await wallet.getVtxoManager();
465
- const txid = await vtxoManager.sweepExpiredBoardingUtxos();
466
- return this.tagged({
467
- id,
468
- type: "SWEEP_EXPIRED_BOARDING_UTXOS_SUCCESS",
469
- payload: { txid },
470
- });
471
- }
472
- default:
473
- console.error("Unknown message type", message);
474
- throw new Error("Unknown message");
475
- }
476
- }
477
- catch (error) {
478
- return this.tagged({ id, error: error });
479
- }
480
- }
481
- // Wallet methods
482
- async handleInitWallet({ payload }) {
483
- const { arkServerUrl } = payload;
484
- this.indexerProvider = new indexer_1.RestIndexerProvider(arkServerUrl);
485
- await this.onWalletInitialized();
486
- }
487
- async handleGetBalance() {
488
- const [boardingUtxos, allVtxos] = await Promise.all([
489
- this.getAllBoardingUtxos(),
490
- this.getVtxosFromRepo(),
491
- ]);
492
- // boarding
493
- let confirmed = 0;
494
- let unconfirmed = 0;
495
- for (const utxo of boardingUtxos) {
496
- if (utxo.status.confirmed) {
497
- confirmed += utxo.value;
498
- }
499
- else {
500
- unconfirmed += utxo.value;
501
- }
502
- }
503
- // offchain — split spendable vs swept from single repo read
504
- const spendableVtxos = allVtxos.filter(index_1.isSpendable);
505
- const sweptVtxos = allVtxos.filter((vtxo) => vtxo.virtualStatus.state === "swept");
506
- let settled = 0;
507
- let preconfirmed = 0;
508
- let recoverable = 0;
509
- for (const vtxo of spendableVtxos) {
510
- if (vtxo.virtualStatus.state === "settled") {
511
- settled += vtxo.value;
512
- }
513
- else if (vtxo.virtualStatus.state === "preconfirmed") {
514
- preconfirmed += vtxo.value;
515
- }
516
- }
517
- for (const vtxo of sweptVtxos) {
518
- if ((0, index_1.isSpendable)(vtxo)) {
519
- recoverable += vtxo.value;
520
- }
521
- }
522
- const totalBoarding = confirmed + unconfirmed;
523
- const totalOffchain = settled + preconfirmed + recoverable;
524
- // aggregate asset balances from spendable virtual outputs
525
- const assetBalances = new Map();
526
- for (const vtxo of spendableVtxos) {
527
- if (vtxo.assets) {
528
- for (const a of vtxo.assets) {
529
- const current = assetBalances.get(a.assetId) ?? 0n;
530
- assetBalances.set(a.assetId, current + a.amount);
531
- }
532
- }
533
- }
534
- const assets = Array.from(assetBalances.entries()).map(([assetId, amount]) => ({ assetId, amount }));
535
- return {
536
- boarding: {
537
- confirmed,
538
- unconfirmed,
539
- total: totalBoarding,
540
- },
541
- settled,
542
- preconfirmed,
543
- available: settled + preconfirmed,
544
- recoverable,
545
- total: totalBoarding + totalOffchain,
546
- assets,
547
- };
548
- }
549
- async getAllBoardingUtxos() {
550
- if (!this.readonlyWallet)
551
- return [];
552
- return this.readonlyWallet.getBoardingUtxos();
553
- }
554
- /**
555
- * Get spendable vtxos from the repository
556
- */
557
- async getSpendableVtxos() {
558
- const vtxos = await this.getVtxosFromRepo();
559
- return vtxos.filter(index_1.isSpendable);
560
- }
561
- async onWalletInitialized() {
562
- if (!this.readonlyWallet ||
563
- !this.arkProvider ||
564
- !this.indexerProvider ||
565
- !this.walletRepository) {
566
- return;
567
- }
568
- // Initialize contract manager FIRST — this populates the repository
569
- // with full virtual output history for all contracts (one indexer call per contract)
570
- await this.ensureContractEventBroadcasting();
571
- // Refresh cached data (virtual outputs, boarding inputs, tx history)
572
- await this.refreshCachedData();
573
- // Recover pending transactions (init-only, not on reload).
574
- // Pending txs only exist if a send was interrupted mid-finalization.
575
- if (this.wallet) {
576
- try {
577
- const vtxos = await this.getVtxosFromRepo();
578
- const { pending, finalized } = await this.wallet.finalizePendingTxs(vtxos.filter((vtxo) => vtxo.virtualStatus.state !== "swept" &&
579
- vtxo.virtualStatus.state !== "settled"));
580
- console.info(`Recovered ${finalized.length}/${pending.length} pending transactions: ${finalized.join(", ")}`);
581
- }
582
- catch (error) {
583
- console.error("Error recovering pending transactions:", error);
584
- }
585
- }
586
- // unsubscribe previous subscription if any
587
- if (this.incomingFundsSubscription)
588
- this.incomingFundsSubscription();
589
- const address = await this.readonlyWallet.getAddress();
590
- // subscribe for incoming funds and notify all clients when new funds arrive
591
- this.incomingFundsSubscription =
592
- await this.readonlyWallet.notifyIncomingFunds(async (funds) => {
593
- if (funds.type === "vtxo") {
594
- // `funds.newVtxos` / `funds.spentVtxos` are already
595
- // ExtendedVirtualCoin — annotation happened inside the
596
- // underlying Wallet's subscription handler before this
597
- // callback fired. Re-annotating here would only duplicate
598
- // work and re-expose us to `annotateVtxos` throws.
599
- const { newVtxos, spentVtxos } = funds;
600
- if (newVtxos.length + spentVtxos.length === 0)
601
- return;
602
- // Save virtual outputs using unified repository. The
603
- // event may carry rows for several scripts (other
604
- // contracts the wallet watches), so split by script and
605
- // save each bucket under its own contract address rather
606
- // than saving a mixed-script array under one address.
607
- const byScript = new Map();
608
- for (const v of [...newVtxos, ...spentVtxos]) {
609
- if (!v.script) {
610
- // Without a script we can't route the row to the
611
- // right contract bucket; surface the drop instead
612
- // of silently losing the VTXO.
613
- console.warn(`WalletMessageHandler.notifyIncomingFunds: dropping VTXO without script ${v.txid}:${v.vout}`);
614
- continue;
615
- }
616
- const arr = byScript.get(v.script) ?? [];
617
- arr.push(v);
618
- byScript.set(v.script, arr);
619
- }
620
- let walletScript;
621
- try {
622
- walletScript = (0, scriptFromAddress_1.scriptFromArkAddress)(address);
623
- }
624
- catch {
625
- walletScript = undefined;
626
- }
627
- const cm = await this.readonlyWallet.getContractManager();
628
- const contracts = await cm.getContracts();
629
- const addrByScript = new Map(contracts.map((c) => [c.script, c.address]));
630
- for (const [script, vtxos] of byScript) {
631
- const filtered = (0, vtxoOwnership_1.warnAndFilterVtxosForScript)(vtxos, script, "WalletMessageHandler.notifyIncomingFunds");
632
- if (filtered.length === 0)
633
- continue;
634
- const targetAddress = script === walletScript
635
- ? address
636
- : addrByScript.get(script);
637
- if (!targetAddress)
638
- continue;
639
- if (this.walletRepository) {
640
- await (0, vtxoOwnership_1.saveVtxosForContract)(this.walletRepository, { script, address: targetAddress }, filtered);
641
- }
642
- }
643
- // notify all clients about the virtual output state update
644
- this.scheduleForNextTick(() => this.tagged({
645
- type: "VTXO_UPDATE",
646
- broadcast: true,
647
- payload: { newVtxos, spentVtxos },
648
- }));
649
- }
650
- if (funds.type === "utxo") {
651
- const utxos = funds.coins.map((utxo) => (0, utils_1.extendCoin)(this.readonlyWallet, utxo));
652
- const boardingAddress = await this.readonlyWallet.getBoardingAddress();
653
- // save boarding inputs using unified repository
654
- // TODO: remove UTXOs by address
655
- // await this.walletRepository.clearUtxos(boardingAddress);
656
- await this.walletRepository?.saveUtxos(boardingAddress, utxos);
657
- // notify all clients about the boarding input state update
658
- this.scheduleForNextTick(() => this.tagged({
659
- type: "UTXO_UPDATE",
660
- broadcast: true,
661
- payload: { coins: utxos },
662
- }));
663
- }
664
- });
665
- // Eagerly start the VtxoManager so its background tasks (auto-renewal,
666
- // boarding input polling/sweep) run inside the service worker without
667
- // waiting for a client to send a VtxoManager message first.
668
- if (this.wallet) {
669
- try {
670
- await this.wallet.getVtxoManager();
671
- }
672
- catch (error) {
673
- console.error("Error starting VtxoManager:", error);
674
- }
675
- }
676
- }
677
- /**
678
- * Refresh virtual outputs, boarding inputs, and transaction history from cache.
679
- * Shared by onWalletInitialized (full bootstrap) and reloadWallet
680
- * (post-refresh), avoiding duplicate subscriptions and VtxoManager restarts.
681
- */
682
- async refreshCachedData() {
683
- if (!this.readonlyWallet || !this.walletRepository) {
684
- return;
685
- }
686
- // Read virtual outputs from repository (now populated by contract manager)
687
- const vtxos = await this.getVtxosFromRepo();
688
- // Fetch boarding inputs and save using unified repository
689
- const boardingAddress = await this.readonlyWallet.getBoardingAddress();
690
- const coins = await this.readonlyWallet.onchainProvider.getCoins(boardingAddress);
691
- await this.walletRepository.deleteUtxos(boardingAddress);
692
- await this.walletRepository.saveUtxos(boardingAddress, coins.map((utxo) => (0, utils_1.extendCoin)(this.readonlyWallet, utxo)));
693
- // Build transaction history from cached virtual outputs (no indexer call)
694
- const address = await this.readonlyWallet.getAddress();
695
- const txs = await this.buildTransactionHistoryFromCache(vtxos);
696
- if (txs)
697
- await this.walletRepository.saveTransactions(address, txs);
698
- }
699
- /**
700
- * Force a full VTXO refresh from the indexer, then refresh cached data.
701
- * Used by RELOAD_WALLET to ensure fresh data without re-subscribing
702
- * to incoming funds or restarting the VtxoManager.
703
- */
704
- async reloadWallet() {
705
- if (!this.readonlyWallet)
706
- return;
707
- const manager = await this.readonlyWallet.getContractManager();
708
- await manager.refreshVtxos();
709
- await this.refreshCachedData();
710
- }
711
- async handleSettle(message) {
712
- const wallet = this.requireWallet();
713
- const txid = await wallet.settle(message.payload.params, (e) => {
714
- this.scheduleForNextTick(() => this.tagged({
715
- id: message.id,
716
- type: "SETTLE_EVENT",
717
- payload: e,
718
- }));
719
- });
720
- if (!txid) {
721
- throw new Error("Settlement failed");
722
- }
723
- return { type: "SETTLE_SUCCESS", payload: { txid } };
724
- }
725
- async handleSendBitcoin(message) {
726
- const wallet = this.requireWallet();
727
- const txid = await wallet.sendBitcoin(message.payload);
728
- if (!txid) {
729
- throw new Error("Send bitcoin failed");
730
- }
731
- return {
732
- type: "SEND_BITCOIN_SUCCESS",
733
- payload: { txid },
734
- };
735
- }
736
- async handleSignTransaction(message) {
737
- const wallet = this.requireWallet();
738
- const { tx, inputIndexes } = message.payload;
739
- const signature = await wallet.identity.sign(tx, inputIndexes);
740
- if (!signature) {
741
- throw new Error("Sign transaction failed");
742
- }
743
- return {
744
- type: "SIGN_TRANSACTION",
745
- payload: { tx: signature },
746
- };
747
- }
748
- async handleDelegate(message) {
749
- const wallet = this.requireWallet();
750
- const delegatorManager = await wallet.getDelegatorManager();
751
- if (!delegatorManager) {
752
- throw new DelegatorNotConfiguredError();
753
- }
754
- const { vtxoOutpoints, destination, delegateAt } = message.payload;
755
- const allVtxos = await wallet.getVtxos();
756
- const outpointSet = new Set(vtxoOutpoints.map((o) => `${o.txid}:${o.vout}`));
757
- const filtered = allVtxos
758
- .filter((v) => outpointSet.has(`${v.txid}:${v.vout}`))
759
- .map((v) => ({ ...v, contractScript: v.script }));
760
- const result = await delegatorManager.delegate(filtered, destination, delegateAt !== undefined ? new Date(delegateAt) : undefined);
761
- return {
762
- tag: this.messageTag,
763
- type: "DELEGATE_SUCCESS",
764
- payload: {
765
- delegated: result.delegated.map((o) => ({
766
- txid: o.txid,
767
- vout: o.vout,
768
- })),
769
- failed: result.failed.map((f) => ({
770
- outpoints: f.outpoints.map((o) => ({
771
- txid: o.txid,
772
- vout: o.vout,
773
- })),
774
- error: String(f.error),
775
- })),
776
- },
777
- };
778
- }
779
- async handleGetVtxos(message) {
780
- if (!this.readonlyWallet) {
781
- throw new WalletNotInitializedError();
782
- }
783
- const vtxos = await this.getSpendableVtxos();
784
- const dustAmount = this.readonlyWallet.dustAmount;
785
- const includeRecoverable = message.payload.filter?.withRecoverable ?? false;
786
- const filteredVtxos = includeRecoverable
787
- ? vtxos
788
- : vtxos.filter((v) => {
789
- if (dustAmount != null && (0, index_1.isSubdust)(v, dustAmount)) {
790
- return false;
791
- }
792
- if ((0, index_1.isRecoverable)(v)) {
793
- return false;
794
- }
795
- if ((0, index_1.isExpired)(v)) {
796
- return false;
797
- }
798
- return true;
799
- });
800
- return filteredVtxos;
801
- }
802
- async clear() {
803
- if (!this.readonlyWallet)
804
- return;
805
- if (this.incomingFundsSubscription)
806
- this.incomingFundsSubscription();
807
- if (this.contractEventsSubscription) {
808
- this.contractEventsSubscription();
809
- this.contractEventsSubscription = undefined;
810
- }
811
- // Dispose the wallet to stop the ContractWatcher (and its polling
812
- // intervals) before clearing the repositories, otherwise the poller
813
- // will hit a closing IndexedDB connection.
814
- try {
815
- if (this.wallet) {
816
- await this.wallet.dispose();
817
- }
818
- else {
819
- await this.readonlyWallet.dispose();
820
- }
821
- }
822
- catch (_) {
823
- // best-effort teardown
824
- }
825
- try {
826
- await this.walletRepository?.clear();
827
- }
828
- catch (_) {
829
- console.warn("Failed to clear vtxos from wallet repository");
830
- }
831
- this.wallet = undefined;
832
- this.readonlyWallet = undefined;
833
- this.arkProvider = undefined;
834
- this.indexerProvider = undefined;
835
- }
836
- /**
837
- * Read all virtual outputs from the repository, aggregated across all contract
838
- * addresses and the wallet's primary address, with deduplication.
839
- */
840
- async getVtxosFromRepo() {
841
- if (!this.walletRepository || !this.readonlyWallet)
842
- return [];
843
- const seen = new Set();
844
- const allVtxos = [];
845
- const addVtxos = (vtxos) => {
846
- for (const vtxo of vtxos) {
847
- const key = `${vtxo.txid}:${vtxo.vout}`;
848
- if (!seen.has(key)) {
849
- seen.add(key);
850
- allVtxos.push(vtxo);
851
- }
852
- }
853
- };
854
- // Aggregate virtual outputs from all contract addresses. Address
855
- // buckets may carry legacy duplicate rows from other contracts; gate
856
- // each bucket by its owning contract script before deduplication so a
857
- // wrong-script row never wins the txid:vout race.
858
- const manager = await this.readonlyWallet.getContractManager();
859
- const contracts = await manager.getContracts();
860
- for (const contract of contracts) {
861
- addVtxos(await (0, vtxoOwnership_1.getVtxosForContract)(this.walletRepository, contract));
862
- }
863
- // Also check the wallet's primary address. Decode it to its script
864
- // and apply the same script gate. Failing to decode the wallet's own
865
- // address is a structural bug — surfacing the error is safer than
866
- // silently dropping the primary bucket and zeroing the user's
867
- // visible balance.
868
- const walletAddress = await this.readonlyWallet.getAddress();
869
- let walletScript;
870
- try {
871
- walletScript = (0, scriptFromAddress_1.scriptFromArkAddress)(walletAddress);
872
- }
873
- catch (e) {
874
- throw new Error(`WalletMessageHandler.getVtxosFromRepo: failed to derive script from wallet address ${walletAddress}: ${e instanceof Error ? e.message : String(e)}`);
875
- }
876
- const walletVtxos = await this.walletRepository.getVtxos(walletAddress);
877
- addVtxos((0, vtxoOwnership_1.filterVtxosForScript)(walletVtxos, walletScript));
878
- return allVtxos;
879
- }
880
- /**
881
- * Build transaction history from cached virtual outputs without hitting the indexer.
882
- * Falls back to indexer only for uncached transaction timestamps.
883
- */
884
- async buildTransactionHistoryFromCache(vtxos) {
885
- if (!this.readonlyWallet)
886
- return null;
887
- const { boardingTxs, commitmentsToIgnore } = await this.readonlyWallet.getBoardingTxs();
888
- // Build a lookup for cached virtual output timestamps, keyed by txid.
889
- // Multiple virtual outputs can share a txid (different vouts) — we keep the
890
- // earliest createdAt so the history ordering is stable.
891
- const vtxoCreatedAt = new Map();
892
- for (const vtxo of vtxos) {
893
- const existing = vtxoCreatedAt.get(vtxo.txid);
894
- const ts = vtxo.createdAt.getTime();
895
- if (existing === undefined || ts < existing) {
896
- vtxoCreatedAt.set(vtxo.txid, ts);
897
- }
898
- }
899
- // Pre-fetch uncached timestamps in a single batched indexer call.
900
- // buildTransactionHistory needs these for spent-offchain virtual outputs with
901
- // no change outputs (i.e. arkTxId is set but no virtual output has txid === arkTxId).
902
- if (this.indexerProvider) {
903
- const uncachedTxids = new Set();
904
- for (const vtxo of vtxos) {
905
- if (vtxo.isSpent &&
906
- vtxo.arkTxId &&
907
- !vtxoCreatedAt.has(vtxo.arkTxId) &&
908
- !vtxos.some((v) => v.txid === vtxo.arkTxId)) {
909
- uncachedTxids.add(vtxo.arkTxId);
910
- }
911
- }
912
- if (uncachedTxids.size > 0) {
913
- const outpoints = [...uncachedTxids].map((txid) => ({
914
- txid,
915
- vout: 0,
916
- }));
917
- const BATCH_SIZE = 100;
918
- for (let i = 0; i < outpoints.length; i += BATCH_SIZE) {
919
- const res = await this.indexerProvider.getVtxos({
920
- outpoints: outpoints.slice(i, i + BATCH_SIZE),
921
- });
922
- for (const v of res.vtxos) {
923
- vtxoCreatedAt.set(v.txid, v.createdAt.getTime());
924
- }
925
- }
926
- }
927
- }
928
- const getTxCreatedAt = async (txid) => {
929
- return vtxoCreatedAt.get(txid);
930
- };
931
- return (0, transactionHistory_1.buildTransactionHistory)(vtxos, boardingTxs, commitmentsToIgnore, getTxCreatedAt);
932
- }
933
- async ensureContractEventBroadcasting() {
934
- if (!this.readonlyWallet)
935
- return;
936
- if (this.contractEventsSubscription)
937
- return;
938
- try {
939
- const manager = await this.readonlyWallet.getContractManager();
940
- this.contractEventsSubscription = manager.onContractEvent((event) => {
941
- this.scheduleForNextTick(() => this.tagged({
942
- type: "CONTRACT_EVENT",
943
- broadcast: true,
944
- payload: { event },
945
- }));
946
- });
947
- }
948
- catch (error) {
949
- console.error("Error subscribing to contract events:", error);
950
- }
951
- }
952
- }
953
- exports.WalletMessageHandler = WalletMessageHandler;