@arkade-os/sdk 0.4.27 → 0.4.28

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 (531) hide show
  1. package/README.md +31 -100
  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-TZ1gXAXU.d.cts +3880 -0
  33. package/dist/ark-TZ1gXAXU.d.ts +3880 -0
  34. package/dist/{types/worker/expo/asyncStorageTaskQueue.d.ts → asyncStorageTaskQueue-Cb1F_Z9s.d.ts} +6 -3
  35. package/dist/asyncStorageTaskQueue-EFqSmYTg.d.cts +49 -0
  36. package/dist/chunk-5BLDMQED.cjs +18 -0
  37. package/dist/chunk-5BLDMQED.cjs.map +1 -0
  38. package/dist/chunk-5PG7DV7A.cjs +805 -0
  39. package/dist/chunk-5PG7DV7A.cjs.map +1 -0
  40. package/dist/chunk-A3EMF7RN.js +95 -0
  41. package/dist/chunk-A3EMF7RN.js.map +1 -0
  42. package/dist/chunk-ADV27S4N.cjs +2701 -0
  43. package/dist/chunk-ADV27S4N.cjs.map +1 -0
  44. package/dist/chunk-BQLHADL7.js +13805 -0
  45. package/dist/chunk-BQLHADL7.js.map +1 -0
  46. package/dist/chunk-CFZMTDWI.js +209 -0
  47. package/dist/chunk-CFZMTDWI.js.map +1 -0
  48. package/dist/chunk-FG5ACJJW.cjs +212 -0
  49. package/dist/chunk-FG5ACJJW.cjs.map +1 -0
  50. package/dist/chunk-HW3JJ323.js +768 -0
  51. package/dist/chunk-HW3JJ323.js.map +1 -0
  52. package/dist/chunk-I3DGUUCT.cjs +838 -0
  53. package/dist/chunk-I3DGUUCT.cjs.map +1 -0
  54. package/dist/chunk-IPX2R7FR.cjs +100 -0
  55. package/dist/chunk-IPX2R7FR.cjs.map +1 -0
  56. package/dist/chunk-NSBPE2FW.js +15 -0
  57. package/dist/chunk-NSBPE2FW.js.map +1 -0
  58. package/dist/chunk-T64LAI7L.js +829 -0
  59. package/dist/chunk-T64LAI7L.js.map +1 -0
  60. package/dist/chunk-ZBUDLTBO.js +2671 -0
  61. package/dist/chunk-ZBUDLTBO.js.map +1 -0
  62. package/dist/chunk-ZLO6NETT.cjs +13910 -0
  63. package/dist/chunk-ZLO6NETT.cjs.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-BFZs69hp.d.cts +84 -0
  71. package/dist/delegate-aaVGfWsV.d.ts +84 -0
  72. package/dist/index-B22cA64m.d.cts +199 -0
  73. package/dist/{types/storage/index.d.ts → index-C0IanN1m.d.cts} +3 -1
  74. package/dist/index-C0IanN1m.d.ts +11 -0
  75. package/dist/index-NDla_UoJ.d.ts +199 -0
  76. package/dist/index.cjs +480 -0
  77. package/dist/index.cjs.map +1 -0
  78. package/dist/index.d.cts +3343 -0
  79. package/dist/index.d.ts +3343 -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-C6Ff4OaU.d.cts +114 -0
  95. package/dist/taskRunner-yvPN8Z0K.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 +171 -0
  103. package/dist/wallet/expo/index.cjs.map +1 -0
  104. package/dist/wallet/expo/index.d.cts +122 -0
  105. package/dist/{types/wallet/expo/wallet.d.ts → wallet/expo/index.d.ts} +45 -22
  106. package/dist/wallet/expo/index.js +169 -0
  107. package/dist/wallet/expo/index.js.map +1 -0
  108. package/dist/wallet-AF-p-OWj.d.cts +774 -0
  109. package/dist/wallet-D9NBRqvC.d.ts +774 -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/hdDescriptorProvider.d.ts +0 -114
  510. package/dist/types/wallet/index.d.ts +0 -789
  511. package/dist/types/wallet/inputSignerRouter.d.ts +0 -35
  512. package/dist/types/wallet/onchain.d.ts +0 -109
  513. package/dist/types/wallet/ramps.d.ts +0 -64
  514. package/dist/types/wallet/serviceWorker/wallet-message-handler.d.ts +0 -543
  515. package/dist/types/wallet/serviceWorker/wallet.d.ts +0 -248
  516. package/dist/types/wallet/signingErrors.d.ts +0 -19
  517. package/dist/types/wallet/unroll.d.ts +0 -114
  518. package/dist/types/wallet/utils.d.ts +0 -36
  519. package/dist/types/wallet/validation.d.ts +0 -24
  520. package/dist/types/wallet/vtxo-manager.d.ts +0 -476
  521. package/dist/types/wallet/wallet.d.ts +0 -409
  522. package/dist/types/wallet/walletReceiveRotator.d.ts +0 -306
  523. package/dist/types/worker/browser/service-worker-manager.d.ts +0 -32
  524. package/dist/types/worker/browser/utils.d.ts +0 -17
  525. package/dist/types/worker/errors.d.ts +0 -7
  526. package/dist/types/worker/expo/index.d.ts +0 -7
  527. package/dist/types/worker/expo/processors/contractPollProcessor.d.ts +0 -19
  528. package/dist/types/worker/expo/processors/index.d.ts +0 -1
  529. package/dist/types/worker/expo/taskQueue.d.ts +0 -50
  530. package/dist/types/worker/expo/taskRunner.d.ts +0 -66
  531. package/dist/types/worker/messageBus.d.ts +0 -189
@@ -1,547 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.WalletReceiveRotator = exports.ROTATION_MAX_BACKOFF_MS = exports.NonRangeableDescriptorError = exports.WALLET_RECEIVE_SOURCE = void 0;
4
- exports.hasReceiveRotatorFactory = hasReceiveRotatorFactory;
5
- exports.rebuildTapscript = rebuildTapscript;
6
- const descriptors_scure_1 = require("@bitcoinerlab/descriptors-scure");
7
- const utils_js_1 = require("@scure/btc-signer/utils.js");
8
- const base_1 = require("@scure/base");
9
- const descriptor_1 = require("../identity/descriptor");
10
- const hdCapableIdentity_1 = require("../identity/hdCapableIdentity");
11
- const default_1 = require("../script/default");
12
- const delegate_1 = require("../script/delegate");
13
- const timelock_1 = require("../utils/timelock");
14
- const hdDescriptorProvider_1 = require("./hdDescriptorProvider");
15
- /** Type guard: does this provider implement {@link ReceiveRotatorFactory}? */
16
- function hasReceiveRotatorFactory(provider) {
17
- return (typeof provider
18
- .createReceiveRotator === "function");
19
- }
20
- function hasPeekableDescriptor(provider) {
21
- return (typeof provider
22
- .getCurrentSigningDescriptor === "function");
23
- }
24
- /**
25
- * Sentinel value stored in `contract.metadata.source` to identify the
26
- * wallet's current display contract. Borrowed from btcpay-arkade's
27
- * source-tagging pattern: every contract records "where and why it was
28
- * generated", and the wallet only cares about the ones it generated for
29
- * its own receive address.
30
- *
31
- * Tagging makes the boot lookup unambiguous — the rotator filters on
32
- * `metadata.source === WALLET_RECEIVE_SOURCE` rather than on "any active
33
- * default contract", so a contract repo that also holds default contracts
34
- * created for other reasons (legacy timelock variants, external
35
- * integrations) doesn't confuse the wallet's display state.
36
- */
37
- exports.WALLET_RECEIVE_SOURCE = "wallet-receive";
38
- /**
39
- * Thrown when a descriptor expected to be rangeable (have a wildcard
40
- * leaf) cannot produce a leaf pubkey. Surfaces from the rotator's
41
- * `defaultBoot` path so `resolveBoot` can distinguish a legitimate
42
- * incompatibility (silent fallback under `walletMode: 'auto'`) from
43
- * any other runtime failure.
44
- */
45
- class NonRangeableDescriptorError extends Error {
46
- constructor(message, options) {
47
- super(message, options);
48
- this.name = "NonRangeableDescriptorError";
49
- }
50
- }
51
- exports.NonRangeableDescriptorError = NonRangeableDescriptorError;
52
- /**
53
- * Cap on the exponential backoff applied to repeated rotation
54
- * failures. After this delay, every fresh `vtxo_received` event
55
- * re-attempts a rotation at this rate until one succeeds (which
56
- * resets the counter) or the wallet is disposed.
57
- */
58
- exports.ROTATION_MAX_BACKOFF_MS = 60000;
59
- /**
60
- * Owns the wallet's HD receive-rotation lifecycle.
61
- *
62
- * The rotator is constructed only when the wallet's `walletMode`
63
- * resolves to a {@link DescriptorProvider}; static wallets and
64
- * non-HD-capable wallets under `'auto'` never see one.
65
- *
66
- * Lifecycle:
67
- * 1. `resolveBoot()` — pre-Wallet-construction. Resolves the provider
68
- * from `walletMode`, then either reuses the existing display
69
- * contract's pubkey (if any) or allocates the first descriptor.
70
- * Returns the rotator paired with the boot pubkey.
71
- * 2. `install(wallet)` — post-`getVtxoManager()`. Subscribes to
72
- * `vtxo_received` on the contract manager and routes matching events
73
- * through the rotation chain.
74
- * 3. `dispose()` — tears down the subscription and drains any in-flight
75
- * rotation so the contract manager can be disposed cleanly.
76
- *
77
- * This class follows the dotnet-sdk's split of responsibilities: the
78
- * provider is a pure rotating allocator; "what address am I currently
79
- * bound to?" is answered by querying the contract repository, not by
80
- * asking the provider.
81
- */
82
- class WalletReceiveRotator {
83
- constructor(provider, priorTaggedScript, logger) {
84
- this.provider = provider;
85
- this.chain = Promise.resolve();
86
- /**
87
- * Consecutive rotation failures since the last successful rotate.
88
- * Drives an exponential backoff (capped at
89
- * {@link ROTATION_MAX_BACKOFF_MS}) so a broken provider can't make
90
- * the rotator hammer `getNextSigningDescriptor` + `createContract`
91
- * on every inbound VTXO. Reset to zero on a successful rotate.
92
- */
93
- this.consecutiveFailures = 0;
94
- /**
95
- * Unix-ms timestamp before which incoming `vtxo_received` events
96
- * skip the rotation attempt entirely. Zero means "no backoff
97
- * active" — the next event can rotate immediately.
98
- */
99
- this.nextRotationAllowedAt = 0;
100
- this.currentTaggedScript = priorTaggedScript;
101
- this.logger = logger ?? console;
102
- }
103
- /**
104
- * Phase 1 — pre-Wallet-construction. Resolves `walletMode` to a
105
- * {@link DescriptorProvider}, then asks that provider to construct
106
- * the rotator (delegated through
107
- * {@link DescriptorProvider.createReceiveRotator}, which falls back
108
- * to {@link defaultBoot} when the provider doesn't override it).
109
- *
110
- * Returns the rotator paired with the offchain tapscript the wallet
111
- * should actually install (rebuilt to the resolved receive pubkey
112
- * when it differs from the identity's static pubkey), or
113
- * `undefined` when the wallet should stay on the static path.
114
- *
115
- * Errors during pubkey resolution propagate when:
116
- * - `walletMode === 'hd'` (caller asked for HD; loud failure expected).
117
- * - `walletMode` is a {@link DescriptorProvider} (caller supplied an
118
- * explicit allocator; silently degrading would hide misconfig).
119
- *
120
- * Errors are silently swallowed (returning `undefined`) only under
121
- * `walletMode: 'auto'` with the built-in HD provider, to preserve
122
- * backwards compatibility with wallets whose identity descriptor
123
- * isn't actually rangeable.
124
- */
125
- static async resolveBoot(config, setup) {
126
- const provider = await resolveDescriptorProvider(config, setup.walletRepository);
127
- if (!provider)
128
- return undefined;
129
- const allowSilentFallback = (config.walletMode ?? "auto") === "auto";
130
- const expectedContractType = setup.offchainTapscript instanceof delegate_1.DelegateVtxo.Script
131
- ? "delegate"
132
- : "default";
133
- const factoryOpts = {
134
- walletRepository: setup.walletRepository,
135
- contractRepository: setup.contractRepository,
136
- serverPubKey: setup.serverPubKey,
137
- expectedContractType,
138
- };
139
- let boot;
140
- try {
141
- boot = hasReceiveRotatorFactory(provider)
142
- ? await provider.createReceiveRotator(factoryOpts)
143
- : await WalletReceiveRotator.defaultBoot(provider, factoryOpts);
144
- }
145
- catch (e) {
146
- // Only swallow non-rangeable-descriptor errors, and only
147
- // under `walletMode: 'auto'`. Explicit HD/`DescriptorProvider`
148
- // callers always see the failure.
149
- if (allowSilentFallback &&
150
- e instanceof NonRangeableDescriptorError) {
151
- return undefined;
152
- }
153
- throw e;
154
- }
155
- if (!boot)
156
- return undefined;
157
- // Rebuild the offchain tapscript with the resolved receive
158
- // pubkey. Skipping the rebuild when pubkeys already match keeps
159
- // the tapscript instance stable for static / first-boot paths
160
- // (no allocation churn, no observable change for callers
161
- // that retain the reference across `Wallet.create`).
162
- const offchainTapscript = (0, utils_js_1.equalBytes)(boot.receivePubkey, setup.offchainTapscript.options.pubKey)
163
- ? setup.offchainTapscript
164
- : rebuildTapscript(setup.offchainTapscript, boot.receivePubkey);
165
- return { rotator: boot.rotator, offchainTapscript, provider };
166
- }
167
- /**
168
- * Default factory-shaped boot any
169
- * {@link ReceiveRotatorFactory.createReceiveRotator} implementation
170
- * can delegate to. Pulls the wallet's current display contract from
171
- * the contract repository (or allocates a fresh receive descriptor
172
- * via the provider when no tagged display contract exists), and
173
- * returns the rotator paired with the resolved receive pubkey.
174
- *
175
- * Used internally by `resolveBoot` when the provider doesn't
176
- * implement {@link ReceiveRotatorFactory}. Exported so providers
177
- * that *do* override can still invoke the default work for the
178
- * parts of the boot path they don't want to customise. Tapscript
179
- * construction is intentionally NOT in here — that's the
180
- * orchestrator's job.
181
- */
182
- static async defaultBoot(provider, opts) {
183
- const existing = await pickActiveReceive(opts.contractRepository, opts.serverPubKey, opts.expectedContractType);
184
- if (existing) {
185
- return {
186
- rotator: new WalletReceiveRotator(provider, existing.script, opts.logger),
187
- receivePubkey: existing.pubKey,
188
- };
189
- }
190
- // No tagged display contract on this repo. Avoid burning a
191
- // fresh HD index per restart: re-derive the descriptor at the
192
- // most recently allocated index when the provider supports it
193
- // (HD-style allocators do; static / one-shot providers don't
194
- // and fall through to a regular allocation, which is a no-op
195
- // for them anyway).
196
- let descriptor;
197
- if (hasPeekableDescriptor(provider)) {
198
- descriptor = await provider.getCurrentSigningDescriptor();
199
- }
200
- descriptor ?? (descriptor = await provider.getNextSigningDescriptor());
201
- return {
202
- rotator: new WalletReceiveRotator(provider, undefined, opts.logger),
203
- receivePubkey: deriveLeafPubkey(descriptor),
204
- };
205
- }
206
- /**
207
- * Phase 2 — post-`getVtxoManager()`. Subscribe to `vtxo_received`
208
- * and trigger a rotation whenever the currently-active display
209
- * contract receives funds. Old display contracts remain `active`
210
- * in the repo so earlier shared addresses keep crediting this
211
- * wallet.
212
- */
213
- async install(wallet) {
214
- const manager = await wallet.getContractManager();
215
- this.unsubscribe = manager.onContractEvent((event) => {
216
- if (event.type !== "vtxo_received")
217
- return;
218
- if (event.contractScript !== wallet.defaultContractScript)
219
- return;
220
- // Serialise rotations: each `vtxo_received` event is its
221
- // own rotation trigger (BIP-44-style: one receive ⇒ one
222
- // fresh address), so two rapid events on the same script
223
- // are *expected* to burn two consecutive HD indices. The
224
- // chain here only prevents the rotate → rebuild →
225
- // createContract sequences from interleaving; it does not
226
- // — and intentionally does not — dedupe events on the same
227
- // script. `runRotateWithBackoff` owns the failure handling
228
- // — it logs, increments the consecutive-failure counter,
229
- // and gates future attempts behind exponential backoff so
230
- // a broken provider can't make the rotator hammer
231
- // `createContract` on every event.
232
- this.chain = this.chain
233
- .catch(() => undefined)
234
- .then(() => this.runRotateWithBackoff(wallet));
235
- });
236
- }
237
- /**
238
- * Run a single rotation attempt, applying exponential backoff on
239
- * failure. Public-shaped behavior:
240
- * - During a backoff window: log + skip (no `rotate()` call).
241
- * - On success: reset failure count and backoff.
242
- * - On failure: increment counter, schedule next attempt at
243
- * `min(2^consecutiveFailures * 1s, ROTATION_MAX_BACKOFF_MS)`.
244
- *
245
- * Errors are deliberately swallowed (logged, not rethrown) so the
246
- * surrounding `chain` Promise never settles to rejected — the next
247
- * `vtxo_received` event must still get a chance to run.
248
- */
249
- async runRotateWithBackoff(wallet) {
250
- const now = Date.now();
251
- if (now < this.nextRotationAllowedAt) {
252
- this.logger.error("WalletReceiveRotator: skipping rotation (in backoff)", {
253
- consecutiveFailures: this.consecutiveFailures,
254
- retryInMs: this.nextRotationAllowedAt - now,
255
- });
256
- return;
257
- }
258
- try {
259
- await this.rotate(wallet);
260
- this.consecutiveFailures = 0;
261
- this.nextRotationAllowedAt = 0;
262
- }
263
- catch (err) {
264
- this.consecutiveFailures += 1;
265
- // 2^1=2s, 2^2=4s, … capped at ROTATION_MAX_BACKOFF_MS (60s).
266
- // `Math.min` on the exponent prevents `2 ** 1024` overflow
267
- // for pathologically long failure streaks.
268
- const exponent = Math.min(this.consecutiveFailures, 16);
269
- const backoffMs = Math.min(2 ** exponent * 1000, exports.ROTATION_MAX_BACKOFF_MS);
270
- this.nextRotationAllowedAt = Date.now() + backoffMs;
271
- this.logger.error("WalletReceiveRotator: rotation failed", err, {
272
- consecutiveFailures: this.consecutiveFailures,
273
- nextAttemptInMs: backoffMs,
274
- });
275
- }
276
- }
277
- /**
278
- * Wait for any in-flight rotation to complete. Useful in tests
279
- * that need to observe the post-rotation state after dispatching
280
- * a `vtxo_received` event synchronously; production code rarely
281
- * needs to call this directly.
282
- */
283
- async drain() {
284
- await this.chain.catch(() => undefined);
285
- }
286
- /**
287
- * Tear down the subscription first so no late `vtxo_received` event
288
- * can queue work on a disposing wallet, then drain any in-flight
289
- * rotation so its `createContract` finishes before the contract
290
- * manager itself disposes.
291
- */
292
- async dispose() {
293
- if (this.unsubscribe) {
294
- try {
295
- this.unsubscribe();
296
- }
297
- catch {
298
- // best-effort teardown
299
- }
300
- finally {
301
- this.unsubscribe = undefined;
302
- }
303
- }
304
- await this.chain.catch(() => undefined);
305
- }
306
- /**
307
- * Allocate the next descriptor, swap it into the wallet's active
308
- * offchain tapscript, register the new tagged contract, and retire
309
- * the previous tagged contract (if any) by setting its state to
310
- * `inactive`. The contract watcher keeps watching inactive
311
- * contracts until their VTXOs are spent, so funds in flight at the
312
- * old display address are not lost — only the address stops being
313
- * advertised.
314
- *
315
- * Contract type matches the wallet's tapscript shape: a default
316
- * wallet rotates to a new `default` contract, a delegate wallet to
317
- * a new `delegate` contract.
318
- *
319
- * The first rotation on a fresh wallet does NOT deactivate
320
- * anything: `currentTaggedScript` is `undefined` because the wallet
321
- * was displaying the untagged index-0 baseline, which must stay
322
- * active forever.
323
- */
324
- async rotate(wallet) {
325
- // Build the new tapscript + derived strings entirely locally,
326
- // so the wallet's visible state (`offchainTapscript`,
327
- // `defaultContractScript`, `getAddress()`) doesn't change
328
- // until the contract registration has succeeded. If
329
- // `createContract` throws partway, the wallet is still
330
- // displaying the OLD (registered) address — no
331
- // unwatched-display-window.
332
- const descriptor = await this.provider.getNextSigningDescriptor();
333
- const pubKey = deriveLeafPubkey(descriptor);
334
- const newTapscript = rebuildTapscript(wallet.offchainTapscript, pubKey);
335
- const newScript = base_1.hex.encode(newTapscript.pkScript);
336
- const newAddress = newTapscript
337
- .address(wallet.network.hrp, wallet.arkServerPublicKey)
338
- .encode();
339
- const manager = await wallet.getContractManager();
340
- const csvTimelock = newTapscript.options.csvTimelock ??
341
- default_1.DefaultVtxo.Script.DEFAULT_TIMELOCK;
342
- const csvTimelockStr = (0, timelock_1.timelockToSequence)(csvTimelock).toString();
343
- const serverPubKeyHex = base_1.hex.encode(newTapscript.options.serverPubKey);
344
- const baseParams = {
345
- script: newScript,
346
- address: newAddress,
347
- state: "active",
348
- // Persist the materialized signing descriptor alongside the
349
- // source tag. The wallet's spending paths read this at sign
350
- // time to route inputs locked by a rotated pubkey through
351
- // `DescriptorProvider.signWithDescriptor` instead of the
352
- // identity's index-0 key. Without it, post-rotation sends
353
- // produce unsigned PSBTs that the server rejects with
354
- // `INVALID_PSBT_INPUT (5): missing tapscript spend sig`.
355
- metadata: {
356
- source: exports.WALLET_RECEIVE_SOURCE,
357
- signingDescriptor: descriptor,
358
- },
359
- };
360
- if (newTapscript instanceof delegate_1.DelegateVtxo.Script) {
361
- await manager.createContract({
362
- ...baseParams,
363
- type: "delegate",
364
- params: {
365
- pubKey: base_1.hex.encode(pubKey),
366
- serverPubKey: serverPubKeyHex,
367
- delegatePubKey: base_1.hex.encode(newTapscript.options.delegatePubKey),
368
- csvTimelock: csvTimelockStr,
369
- },
370
- });
371
- }
372
- else {
373
- await manager.createContract({
374
- ...baseParams,
375
- type: "default",
376
- params: {
377
- pubKey: base_1.hex.encode(pubKey),
378
- serverPubKey: serverPubKeyHex,
379
- csvTimelock: csvTimelockStr,
380
- },
381
- });
382
- }
383
- // Persistence succeeded — commit the new tapscript to the
384
- // wallet's visible state. From this point onward
385
- // `wallet.defaultContractScript` and `getAddress()` reflect
386
- // the rotated identity. `setOffchainTapscriptForRotation` is
387
- // the only write path; the field is read-only otherwise.
388
- wallet.setOffchainTapscriptForRotation(newTapscript);
389
- // Retire the previous tagged contract (if any). The order
390
- // matters: deactivate FIRST, then update `currentTaggedScript`,
391
- // so that if `setContractState` throws the next rotation will
392
- // retry deactivating the same orphaned contract instead of
393
- // racing forward and orphaning the new one.
394
- const previousTagged = this.currentTaggedScript;
395
- if (previousTagged !== undefined && previousTagged !== newScript) {
396
- await manager.setContractState(previousTagged, "inactive");
397
- }
398
- this.currentTaggedScript = newScript;
399
- }
400
- }
401
- exports.WalletReceiveRotator = WalletReceiveRotator;
402
- /**
403
- * Extract the x-only (32-byte) pubkey from a materialized HD descriptor.
404
- *
405
- * `expand()` populates `@0.pubkey` for non-ranged descriptors (including
406
- * HD ones where a concrete child index has been substituted for the
407
- * wildcard). This sidesteps `extractPubKey`, which intentionally rejects
408
- * any descriptor carrying a `bip32` key because it was designed for
409
- * static `tr(pubkey)` inputs.
410
- */
411
- function deriveLeafPubkey(descriptor) {
412
- const network = (0, descriptor_1.isMainnetDescriptor)(descriptor)
413
- ? descriptors_scure_1.networks.bitcoin
414
- : descriptors_scure_1.networks.testnet;
415
- // `expand` raises when the descriptor still carries a wildcard or
416
- // is otherwise non-rangeable. Wrap so callers (most importantly
417
- // `resolveBoot`'s silent-fallback path) can branch on a typed
418
- // error class instead of grepping `err.message`.
419
- let expansion;
420
- try {
421
- expansion = (0, descriptors_scure_1.expand)({ descriptor, network });
422
- }
423
- catch (e) {
424
- throw new NonRangeableDescriptorError(`Cannot derive leaf pubkey from descriptor (length=${descriptor.length}): ` +
425
- `ensure the descriptor is materialized (no wildcard) and parsable.`, { cause: e });
426
- }
427
- const key = expansion.expansionMap?.["@0"];
428
- if (!key?.pubkey) {
429
- // Avoid interpolating the descriptor itself: it normally
430
- // contains an xpub, but a misconfigured caller could pass an
431
- // xprv, and error messages surface in logs / crash reporters /
432
- // Sentry. The length is enough context for debugging.
433
- throw new NonRangeableDescriptorError(`Cannot derive leaf pubkey from descriptor (length=${descriptor.length}): ` +
434
- `descriptor parsed but no '@0' pubkey was found in the expansion map. ` +
435
- `The rotator expects a materialized tr(xpub/.../*) shape; ensure the ` +
436
- `descriptor has no wildcard and that its key resolves into the '@0' slot.`);
437
- }
438
- return key.pubkey;
439
- }
440
- /**
441
- * Rebuild the given offchain tapscript with a different owner pubkey,
442
- * preserving its {@link DelegateVtxo.Script} vs {@link DefaultVtxo.Script}
443
- * shape and all other options.
444
- *
445
- * Exported because the wallet's boot path also needs to rebuild the
446
- * initial tapscript when the resolved boot pubkey differs from the
447
- * identity's default pubkey.
448
- */
449
- function rebuildTapscript(current, pubKey) {
450
- if (current instanceof delegate_1.DelegateVtxo.Script) {
451
- return new delegate_1.DelegateVtxo.Script({ ...current.options, pubKey });
452
- }
453
- return new default_1.DefaultVtxo.Script({ ...current.options, pubKey });
454
- }
455
- /**
456
- * Look up the most-recently-created active tagged display contract that
457
- * this wallet itself generated. Returns the contract's pubkey + script,
458
- * or `undefined` when no such contract exists — the caller should treat
459
- * that as "fresh wallet (or static-only history) on this repo" and
460
- * allocate a new descriptor.
461
- *
462
- * Filters by `serverPubKey` so a contract repo seeded against a different
463
- * server doesn't accidentally resurrect an unrelated pubkey, and by the
464
- * `metadata.source` sentinel so untagged baseline contracts (and
465
- * contracts created by other code paths — legacy timelock registrations,
466
- * external integrations) are not mistaken for the wallet's display
467
- * address.
468
- *
469
- * When `expectedType` is provided, only contracts of that type are considered,
470
- * preventing a "default" wallet from accidentally picking up a "delegate" contract
471
- * or vice versa.
472
- */
473
- async function pickActiveReceive(contractRepository, serverPubKey, expectedType) {
474
- // Both `default` and `delegate` contract types can be the wallet's
475
- // display address (delegate wallets use the delegate variant). The
476
- // `metadata.source` tag is the discriminator that says "this is the
477
- // one I generated for myself."
478
- const candidates = await contractRepository.getContracts({
479
- type: expectedType ? [expectedType] : ["default", "delegate"],
480
- state: "active",
481
- });
482
- const serverPubKeyHex = base_1.hex.encode(serverPubKey);
483
- const matching = candidates
484
- .filter((c) => c.params.serverPubKey === serverPubKeyHex &&
485
- c.metadata?.source === exports.WALLET_RECEIVE_SOURCE)
486
- .sort((a, b) => b.createdAt - a.createdAt);
487
- const newest = matching[0];
488
- if (!newest?.params.pubKey)
489
- return undefined;
490
- try {
491
- return {
492
- pubKey: base_1.hex.decode(newest.params.pubKey),
493
- script: newest.script,
494
- };
495
- }
496
- catch {
497
- return undefined;
498
- }
499
- }
500
- /**
501
- * Resolve the polymorphic `walletMode` config field into a concrete
502
- * {@link DescriptorProvider} (or `undefined` for the static path).
503
- *
504
- * - `'auto'` *(default)*: **short-term**, behaves like `'static'` — no
505
- * HD rotation. See the `TODO` below for the criteria to flip this
506
- * back to the identity-probing behaviour.
507
- * - `'static'`: returns `undefined`.
508
- * - A {@link DescriptorProvider} instance: returns it as-is.
509
- * - `'hd'`: builds the built-in HD provider from the identity. Throws
510
- * if the identity isn't HD-capable or the descriptor isn't rangeable —
511
- * no silent fallback.
512
- */
513
- async function resolveDescriptorProvider(config, walletRepository) {
514
- const mode = config.walletMode ?? "auto";
515
- // TODO(hd-maturation): TEMPORARY — collapse `'auto'` into `'static'`
516
- // until the HD receive-rotation pipeline has soaked in the field.
517
- // Flip `'auto'` back to its identity-probing behaviour once:
518
- // 1. At least one consumer (btcpay-arkade, arkade-os/wallet,
519
- // Fulmine) has been running with `walletMode: 'hd'` against
520
- // mainnet for ≥ 1 month with no rotation-induced fund-loss
521
- // or address-drift reports.
522
- // 2. The test `default ('auto') currently behaves like 'static'`
523
- // in `test/walletHdRotation.test.ts` is flipped in the same
524
- // commit (it's the explicit gate — flipping the default
525
- // MUST flip the test).
526
- // 3. The `WalletMode` docstring in `src/wallet/index.ts` is
527
- // updated to drop the "behaves like 'static' for now" notice.
528
- if (mode === "static" || mode === "auto")
529
- return undefined;
530
- if (typeof mode !== "string") {
531
- // Caller supplied a DescriptorProvider directly.
532
- return mode;
533
- }
534
- // mode === 'hd'
535
- if (!(0, hdCapableIdentity_1.isHDCapableIdentity)(config.identity)) {
536
- throw new Error("walletMode 'hd' requires an HD-capable identity " +
537
- "(SeedIdentity / MnemonicIdentity with a rangeable BIP-32 " +
538
- "descriptor) or an explicit DescriptorProvider.");
539
- }
540
- try {
541
- return await hdDescriptorProvider_1.HDDescriptorProvider.create(config.identity, walletRepository);
542
- }
543
- catch (e) {
544
- throw new Error("walletMode 'hd' failed to initialize: " +
545
- (e instanceof Error ? e.message : String(e)), { cause: e });
546
- }
547
- }