@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,188 +0,0 @@
1
- import { Transaction } from "@scure/btc-signer/transaction.js";
2
- import { base64 } from "@scure/base";
3
- import { hex } from "@scure/base";
4
- /**
5
- * TxTree is a graph of bitcoin transactions.
6
- * It is used to represent batch tree created during settlement session
7
- */
8
- export class TxTree {
9
- constructor(root, children = new Map()) {
10
- this.root = root;
11
- this.children = children;
12
- }
13
- static create(chunks) {
14
- if (chunks.length === 0) {
15
- throw new Error("empty chunks");
16
- }
17
- // Create a map to store all chunks by their txid for easy lookup
18
- const chunksByTxid = new Map();
19
- for (const chunk of chunks) {
20
- const decodedChunk = decodeNode(chunk);
21
- const txid = decodedChunk.tx.id;
22
- chunksByTxid.set(txid, decodedChunk);
23
- }
24
- // Find the root chunks (the ones that aren't referenced as a child)
25
- const rootTxids = [];
26
- for (const [txid] of chunksByTxid) {
27
- let isChild = false;
28
- for (const [otherTxid, otherChunk] of chunksByTxid) {
29
- if (otherTxid === txid) {
30
- // skip self
31
- continue;
32
- }
33
- // check if the current chunk is a child of the other chunk
34
- isChild = hasChild(otherChunk, txid);
35
- if (isChild) {
36
- break;
37
- }
38
- }
39
- // if the chunk is not a child of any other chunk, it is a root
40
- if (!isChild) {
41
- rootTxids.push(txid);
42
- continue;
43
- }
44
- }
45
- if (rootTxids.length === 0) {
46
- throw new Error("no root chunk found");
47
- }
48
- if (rootTxids.length > 1) {
49
- throw new Error(`multiple root chunks found: ${rootTxids.join(", ")}`);
50
- }
51
- const graph = buildGraph(rootTxids[0], chunksByTxid);
52
- if (!graph) {
53
- throw new Error(`chunk not found for root txid: ${rootTxids[0]}`);
54
- }
55
- // verify that the number of chunks is equal to the number node in the graph
56
- if (graph.nbOfNodes() !== chunks.length) {
57
- throw new Error(`number of chunks (${chunks.length}) is not equal to the number of nodes in the graph (${graph.nbOfNodes()})`);
58
- }
59
- return graph;
60
- }
61
- nbOfNodes() {
62
- let count = 1; // count this node
63
- for (const child of this.children.values()) {
64
- count += child.nbOfNodes();
65
- }
66
- return count;
67
- }
68
- validate() {
69
- if (!this.root) {
70
- throw new Error("unexpected nil root");
71
- }
72
- const nbOfOutputs = this.root.outputsLength;
73
- const nbOfInputs = this.root.inputsLength;
74
- if (nbOfInputs !== 1) {
75
- throw new Error(`unexpected number of inputs: ${nbOfInputs}, expected 1`);
76
- }
77
- // the children map can't be bigger than the number of outputs (excluding the P2A)
78
- // a graph can be "partial" and specify only some of the outputs as children,
79
- // that's why we allow len(g.Children) to be less than nbOfOutputs-1
80
- if (this.children.size > nbOfOutputs - 1) {
81
- throw new Error(`unexpected number of children: ${this.children.size}, expected maximum ${nbOfOutputs - 1}`);
82
- }
83
- // validate each child
84
- for (const [outputIndex, child] of this.children) {
85
- if (outputIndex >= nbOfOutputs) {
86
- throw new Error(`output index ${outputIndex} is out of bounds (nb of outputs: ${nbOfOutputs})`);
87
- }
88
- child.validate();
89
- const childInput = child.root.getInput(0);
90
- const parentTxid = this.root.id;
91
- // verify the input of the child is the output of the parent
92
- if (!childInput.txid ||
93
- hex.encode(childInput.txid) !== parentTxid ||
94
- childInput.index !== outputIndex) {
95
- throw new Error(`input of child ${outputIndex} is not the output of the parent`);
96
- }
97
- // verify the sum of the child's outputs is equal to the output of the parent
98
- let childOutputsSum = 0n;
99
- for (let i = 0; i < child.root.outputsLength; i++) {
100
- const output = child.root.getOutput(i);
101
- if (output?.amount) {
102
- childOutputsSum += output.amount;
103
- }
104
- }
105
- const parentOutput = this.root.getOutput(outputIndex);
106
- if (!parentOutput?.amount) {
107
- throw new Error(`parent output ${outputIndex} has no amount`);
108
- }
109
- if (childOutputsSum !== parentOutput.amount) {
110
- throw new Error(`sum of child's outputs is not equal to the output of the parent: ${childOutputsSum} != ${parentOutput.amount}`);
111
- }
112
- }
113
- }
114
- leaves() {
115
- if (this.children.size === 0) {
116
- return [this.root];
117
- }
118
- const leaves = [];
119
- for (const child of this.children.values()) {
120
- leaves.push(...child.leaves());
121
- }
122
- return leaves;
123
- }
124
- get txid() {
125
- return this.root.id;
126
- }
127
- find(txid) {
128
- if (txid === this.txid) {
129
- return this;
130
- }
131
- for (const child of this.children.values()) {
132
- const found = child.find(txid);
133
- if (found) {
134
- return found;
135
- }
136
- }
137
- return null;
138
- }
139
- update(txid, fn) {
140
- if (txid === this.txid) {
141
- fn(this.root);
142
- return;
143
- }
144
- for (const child of this.children.values()) {
145
- try {
146
- child.update(txid, fn);
147
- return;
148
- }
149
- catch (error) {
150
- // Continue searching in other children if not found
151
- continue;
152
- }
153
- }
154
- throw new Error(`tx not found: ${txid}`);
155
- }
156
- *iterator() {
157
- for (const child of this.children.values()) {
158
- yield* child.iterator();
159
- }
160
- yield this;
161
- }
162
- }
163
- // Helper function to check if a chunk has a specific child
164
- function hasChild(chunk, childTxid) {
165
- return Object.values(chunk.children).includes(childTxid);
166
- }
167
- // buildGraph recursively builds the TxGraph starting from the given txid
168
- function buildGraph(rootTxid, chunksByTxid) {
169
- const chunk = chunksByTxid.get(rootTxid);
170
- if (!chunk) {
171
- return null;
172
- }
173
- const rootTx = chunk.tx;
174
- const children = new Map();
175
- // Recursively build children graphs
176
- for (const [outputIndexStr, childTxid] of Object.entries(chunk.children)) {
177
- const outputIndex = parseInt(outputIndexStr);
178
- const childGraph = buildGraph(childTxid, chunksByTxid);
179
- if (childGraph) {
180
- children.set(outputIndex, childGraph);
181
- }
182
- }
183
- return new TxTree(rootTx, children);
184
- }
185
- function decodeNode(chunk) {
186
- const tx = Transaction.fromPSBT(base64.decode(chunk.tx));
187
- return { tx, children: chunk.children };
188
- }
@@ -1,101 +0,0 @@
1
- import { hex } from "@scure/base";
2
- import { Transaction } from "@scure/btc-signer/transaction.js";
3
- import { base64 } from "@scure/base";
4
- import { aggregateKeys } from "../musig2/index.js";
5
- import { CosignerPublicKey, getArkPsbtFields } from "../utils/unknownFields.js";
6
- export const ErrInvalidSettlementTx = (tx) => new Error(`invalid settlement transaction: ${tx}`);
7
- export const ErrInvalidSettlementTxOutputs = new Error("invalid settlement transaction outputs");
8
- export const ErrEmptyTree = new Error("empty tree");
9
- export const ErrNumberOfInputs = new Error("invalid number of inputs");
10
- export const ErrWrongSettlementTxid = new Error("wrong settlement txid");
11
- export const ErrInvalidAmount = new Error("invalid amount");
12
- export const ErrNoLeaves = new Error("no leaves");
13
- export const ErrInvalidTaprootScript = new Error("invalid taproot script");
14
- export const ErrInvalidRoundTxOutputs = new Error("invalid round transaction outputs");
15
- export const ErrWrongCommitmentTxid = new Error("wrong commitment txid");
16
- export const ErrMissingCosignersPublicKeys = new Error("missing cosigners public keys");
17
- const BATCH_OUTPUT_VTXO_INDEX = 0;
18
- const BATCH_OUTPUT_CONNECTORS_INDEX = 1;
19
- export function validateConnectorsTxGraph(settlementTxB64, connectorsGraph) {
20
- connectorsGraph.validate();
21
- if (connectorsGraph.root.inputsLength !== 1)
22
- throw ErrNumberOfInputs;
23
- const rootInput = connectorsGraph.root.getInput(0);
24
- const settlementTx = Transaction.fromPSBT(base64.decode(settlementTxB64));
25
- if (settlementTx.outputsLength <= BATCH_OUTPUT_CONNECTORS_INDEX)
26
- throw ErrInvalidSettlementTxOutputs;
27
- const expectedRootTxid = settlementTx.id;
28
- if (!rootInput.txid)
29
- throw ErrWrongSettlementTxid;
30
- if (hex.encode(rootInput.txid) !== expectedRootTxid)
31
- throw ErrWrongSettlementTxid;
32
- if (rootInput.index !== BATCH_OUTPUT_CONNECTORS_INDEX)
33
- throw ErrWrongSettlementTxid;
34
- }
35
- // ValidateVtxoTxGraph checks if the given virtual output tx graph is valid.
36
- // The function validates:
37
- // - the number of nodes
38
- // - the number of leaves
39
- // - children coherence with parent.
40
- // - every control block and taproot output scripts.
41
- // - input and output amounts.
42
- export function validateVtxoTxGraph(graph, roundTransaction, sweepTapTreeRoot) {
43
- if (roundTransaction.outputsLength < BATCH_OUTPUT_VTXO_INDEX + 1) {
44
- throw ErrInvalidRoundTxOutputs;
45
- }
46
- const batchOutputAmount = roundTransaction.getOutput(BATCH_OUTPUT_VTXO_INDEX)?.amount;
47
- if (!batchOutputAmount) {
48
- throw ErrInvalidRoundTxOutputs;
49
- }
50
- if (!graph.root) {
51
- throw ErrEmptyTree;
52
- }
53
- const rootInput = graph.root.getInput(0);
54
- const commitmentTxid = roundTransaction.id;
55
- if (!rootInput.txid ||
56
- hex.encode(rootInput.txid) !== commitmentTxid ||
57
- rootInput.index !== BATCH_OUTPUT_VTXO_INDEX) {
58
- throw ErrWrongCommitmentTxid;
59
- }
60
- let sumRootValue = 0n;
61
- for (let i = 0; i < graph.root.outputsLength; i++) {
62
- const output = graph.root.getOutput(i);
63
- if (output?.amount) {
64
- sumRootValue += output.amount;
65
- }
66
- }
67
- if (sumRootValue !== batchOutputAmount) {
68
- throw ErrInvalidAmount;
69
- }
70
- const leaves = graph.leaves();
71
- if (leaves.length === 0) {
72
- throw ErrNoLeaves;
73
- }
74
- // validate the graph structure
75
- graph.validate();
76
- // iterates over all the nodes of the graph to verify that cosigners public keys are corresponding to the parent output
77
- for (const g of graph.iterator()) {
78
- for (const [childIndex, child] of g.children) {
79
- const parentOutput = g.root.getOutput(childIndex);
80
- if (!parentOutput?.script) {
81
- throw new Error(`parent output ${childIndex} not found`);
82
- }
83
- const previousScriptKey = parentOutput.script.slice(2);
84
- if (previousScriptKey.length !== 32) {
85
- throw new Error(`parent output ${childIndex} has invalid script`);
86
- }
87
- const cosigners = getArkPsbtFields(child.root, 0, CosignerPublicKey);
88
- if (cosigners.length === 0) {
89
- throw ErrMissingCosignersPublicKeys;
90
- }
91
- const cosignerKeys = cosigners.map((c) => c.key);
92
- const { finalKey } = aggregateKeys(cosignerKeys, true, {
93
- taprootTweak: sweepTapTreeRoot,
94
- });
95
- if (!finalKey ||
96
- hex.encode(finalKey.slice(1)) !== hex.encode(previousScriptKey)) {
97
- throw ErrInvalidTaprootScript;
98
- }
99
- }
100
- }
101
- }
@@ -1,31 +0,0 @@
1
- import { hex } from "@scure/base";
2
- export const ANCHOR_VALUE = 0n;
3
- export const ANCHOR_PKSCRIPT = new Uint8Array([0x51, 0x02, 0x4e, 0x73]);
4
- /**
5
- * A zero-value anchor output.
6
- */
7
- export const P2A = {
8
- script: ANCHOR_PKSCRIPT,
9
- amount: ANCHOR_VALUE,
10
- };
11
- const hexP2Ascript = hex.encode(P2A.script);
12
- /**
13
- * search for anchor in the given transaction.
14
- * @throws {Error} if the anchor is not found or has the wrong amount
15
- */
16
- export function findP2AOutput(tx) {
17
- for (let i = 0; i < tx.outputsLength; i++) {
18
- const output = tx.getOutput(i);
19
- if (output.script && hex.encode(output.script) === hexP2Ascript) {
20
- if (output.amount !== P2A.amount) {
21
- throw new Error(`P2A output has wrong amount, expected ${P2A.amount} got ${output.amount}`);
22
- }
23
- return {
24
- txid: tx.id,
25
- index: i,
26
- witnessUtxo: P2A,
27
- };
28
- }
29
- }
30
- throw new Error("P2A output not found");
31
- }
@@ -1,264 +0,0 @@
1
- import { schnorr } from "@noble/curves/secp256k1.js";
2
- import { hex } from "@scure/base";
3
- import { DEFAULT_SEQUENCE, Script, SigHash } from "@scure/btc-signer";
4
- import { tapLeafHash } from "@scure/btc-signer/payment.js";
5
- import { CLTVMultisigTapscript, decodeTapscript, } from "../script/tapscript.js";
6
- import { scriptFromTapLeafScript, VtxoScript, } from "../script/base.js";
7
- import { P2A } from "./anchor.js";
8
- import { setArkPsbtField, VtxoTaprootTree } from "./unknownFields.js";
9
- import { Transaction } from "./transaction.js";
10
- import { ArkAddress } from "../script/address.js";
11
- import { Extension } from "../extension/index.js";
12
- /**
13
- * Builds an offchain transaction with checkpoint transactions.
14
- *
15
- * Creates one checkpoint transaction per input and a virtual transaction that
16
- * combines all the checkpoints, sending to the specified outputs. This is the
17
- * core function for creating Arkade transactions.
18
- *
19
- * @param inputs - Array of virtual transaction inputs
20
- * @param outputs - Array of transaction outputs
21
- * @param serverUnrollScript - Server unroll script for checkpoint transactions
22
- * @returns Object containing the virtual transaction and checkpoint transactions
23
- */
24
- export function buildOffchainTx(inputs, outputs, serverUnrollScript) {
25
- // TODO: use arkd /info
26
- const MAX_OP_RETURN = 2;
27
- let countOpReturn = 0;
28
- let hasExtensionOutput = false;
29
- for (const [index, output] of outputs.entries()) {
30
- if (!output.script)
31
- throw new Error(`missing output script ${index}`);
32
- const isExtension = Extension.isExtension(output.script);
33
- const isOpReturn = isExtension || Script.decode(output.script)[0] === "RETURN";
34
- if (isOpReturn) {
35
- countOpReturn++;
36
- }
37
- if (!isExtension)
38
- continue;
39
- if (hasExtensionOutput)
40
- throw new Error("multiple extension outputs");
41
- hasExtensionOutput = true;
42
- }
43
- if (countOpReturn > MAX_OP_RETURN) {
44
- throw new Error(`too many OP_RETURN outputs: ${countOpReturn} > ${MAX_OP_RETURN}`);
45
- }
46
- const checkpoints = inputs.map((input) => buildCheckpointTx(input, serverUnrollScript));
47
- const arkTx = buildVirtualTx(checkpoints.map((c) => c.input), outputs);
48
- return {
49
- arkTx,
50
- checkpoints: checkpoints.map((c) => c.tx),
51
- };
52
- }
53
- function buildVirtualTx(inputs, outputs) {
54
- let lockTime = 0n;
55
- for (const input of inputs) {
56
- const tapscript = decodeTapscript(scriptFromTapLeafScript(input.tapLeafScript));
57
- if (CLTVMultisigTapscript.is(tapscript)) {
58
- if (lockTime !== 0n) {
59
- // if a locktime is already set, check if the new locktime is in the same unit
60
- if (isSeconds(lockTime) !==
61
- isSeconds(tapscript.params.absoluteTimelock)) {
62
- throw new Error("cannot mix seconds and blocks locktime");
63
- }
64
- }
65
- if (tapscript.params.absoluteTimelock > lockTime) {
66
- lockTime = tapscript.params.absoluteTimelock;
67
- }
68
- }
69
- }
70
- const tx = new Transaction({
71
- version: 3,
72
- lockTime: Number(lockTime),
73
- });
74
- for (const [i, input] of inputs.entries()) {
75
- tx.addInput({
76
- txid: input.txid,
77
- index: input.vout,
78
- sequence: lockTime ? DEFAULT_SEQUENCE - 1 : undefined,
79
- witnessUtxo: {
80
- script: VtxoScript.decode(input.tapTree).pkScript,
81
- amount: BigInt(input.value),
82
- },
83
- tapLeafScript: [input.tapLeafScript],
84
- });
85
- setArkPsbtField(tx, i, VtxoTaprootTree, input.tapTree);
86
- }
87
- for (const output of outputs) {
88
- tx.addOutput(output);
89
- }
90
- // add the anchor output
91
- tx.addOutput(P2A);
92
- return tx;
93
- }
94
- function buildCheckpointTx(vtxo, serverUnrollScript) {
95
- // create the checkpoint virtual output script from collaborative closure
96
- const collaborativeClosure = decodeTapscript(scriptFromTapLeafScript(vtxo.tapLeafScript));
97
- // create the checkpoint virtual output script combining collaborative closure and server unroll script
98
- const checkpointVtxoScript = new VtxoScript([
99
- serverUnrollScript.script,
100
- collaborativeClosure.script,
101
- ]);
102
- // build the checkpoint virtual tx
103
- const checkpointTx = buildVirtualTx([vtxo], [
104
- {
105
- amount: BigInt(vtxo.value),
106
- script: checkpointVtxoScript.pkScript,
107
- },
108
- ]);
109
- // get the collaborative leaf proof
110
- const collaborativeLeafProof = checkpointVtxoScript.findLeaf(hex.encode(collaborativeClosure.script));
111
- // create the checkpoint input that will be used as input of the virtual tx
112
- const checkpointInput = {
113
- txid: checkpointTx.id,
114
- vout: 0,
115
- value: vtxo.value,
116
- tapLeafScript: collaborativeLeafProof,
117
- tapTree: checkpointVtxoScript.encode(),
118
- };
119
- return {
120
- tx: checkpointTx,
121
- input: checkpointInput,
122
- };
123
- }
124
- const nLocktimeMinSeconds = 500000000n;
125
- function isSeconds(locktime) {
126
- return locktime >= nLocktimeMinSeconds;
127
- }
128
- export function hasBoardingTxExpired(coin, boardingTimelock, chainTipHeight) {
129
- if (!coin.status.block_time)
130
- return false;
131
- if (boardingTimelock.value === 0n)
132
- return true;
133
- if (boardingTimelock.type === "blocks") {
134
- if (chainTipHeight === undefined || !coin.status.block_height)
135
- return false;
136
- return (BigInt(chainTipHeight - coin.status.block_height) >=
137
- boardingTimelock.value);
138
- }
139
- // validate expiry in terms of seconds
140
- const now = BigInt(Math.floor(Date.now() / 1000));
141
- const blockTime = BigInt(Math.floor(coin.status.block_time));
142
- return blockTime + boardingTimelock.value <= now;
143
- }
144
- /**
145
- * Formats a sighash type as a hex string (e.g., 0x01)
146
- */
147
- function formatSighash(type) {
148
- return `0x${type.toString(16).padStart(2, "0")}`;
149
- }
150
- /**
151
- * Verify tapscript signatures on a transaction input
152
- * @param tx Transaction to verify
153
- * @param inputIndex Index of the input to verify
154
- * @param requiredSigners List of required signer pubkeys (hex encoded)
155
- * @param excludePubkeys List of pubkeys to exclude from verification (hex encoded, e.g., server key not yet signed)
156
- * @param allowedSighashTypes List of allowed sighash types (defaults to [SigHash.DEFAULT])
157
- * @throws Error if verification fails
158
- */
159
- export function verifyTapscriptSignatures(tx, inputIndex, requiredSigners, excludePubkeys = [], allowedSighashTypes = [SigHash.DEFAULT]) {
160
- const input = tx.getInput(inputIndex);
161
- // Collect prevout scripts and amounts for ALL inputs (required for preimageWitnessV1)
162
- const prevoutScripts = [];
163
- const prevoutAmounts = [];
164
- for (let i = 0; i < tx.inputsLength; i++) {
165
- const inp = tx.getInput(i);
166
- if (!inp.witnessUtxo) {
167
- throw new Error(`Input ${i} is missing witnessUtxo`);
168
- }
169
- prevoutScripts.push(inp.witnessUtxo.script);
170
- prevoutAmounts.push(inp.witnessUtxo.amount);
171
- }
172
- // Verify tapScriptSig signatures
173
- if (!input.tapScriptSig || input.tapScriptSig.length === 0) {
174
- throw new Error(`Input ${inputIndex} is missing tapScriptSig`);
175
- }
176
- // Verify each signature in tapScriptSig
177
- for (const [tapScriptSigData, signature] of input.tapScriptSig) {
178
- const pubKey = tapScriptSigData.pubKey;
179
- const pubKeyHex = hex.encode(pubKey);
180
- // Skip verification for excluded pubkeys
181
- if (excludePubkeys.includes(pubKeyHex)) {
182
- continue;
183
- }
184
- // Extract sighash type from signature
185
- // Schnorr signatures are 64 bytes, with optional 1-byte sighash appended
186
- const sighashType = signature.length === 65 ? signature[64] : SigHash.DEFAULT;
187
- const sig = signature.subarray(0, 64);
188
- // Verify sighash type is allowed
189
- if (!allowedSighashTypes.includes(sighashType)) {
190
- const sighashName = formatSighash(sighashType);
191
- throw new Error(`Unallowed sighash type ${sighashName} for input ${inputIndex}, pubkey ${pubKeyHex}.`);
192
- }
193
- // Find the tapLeafScript that matches this signature's leafHash
194
- if (!input.tapLeafScript || input.tapLeafScript.length === 0) {
195
- throw new Error();
196
- }
197
- // Search for the leaf that matches the leafHash in tapScriptSigData
198
- const leafHash = tapScriptSigData.leafHash;
199
- const leafHashHex = hex.encode(leafHash);
200
- let matchingScript;
201
- let matchingVersion;
202
- for (const [_, scriptWithVersion] of input.tapLeafScript) {
203
- const script = scriptWithVersion.subarray(0, -1);
204
- const version = scriptWithVersion[scriptWithVersion.length - 1];
205
- // Compute the leaf hash for this script and compare as hex strings
206
- const computedLeafHash = tapLeafHash(script, version);
207
- const computedHex = hex.encode(computedLeafHash);
208
- if (computedHex === leafHashHex) {
209
- matchingScript = script;
210
- matchingVersion = version;
211
- break;
212
- }
213
- }
214
- if (!matchingScript || matchingVersion === undefined) {
215
- throw new Error(`Input ${inputIndex}: No tapLeafScript found matching leafHash ${hex.encode(leafHash)}`);
216
- }
217
- // Reconstruct the message that was signed
218
- // Note: preimageWitnessV1 requires ALL input prevout scripts and amounts
219
- const message = tx.preimageWitnessV1(inputIndex, prevoutScripts, sighashType, prevoutAmounts, undefined, matchingScript, matchingVersion);
220
- // Verify the schnorr signature
221
- const isValid = schnorr.verify(sig, message, pubKey);
222
- if (!isValid) {
223
- throw new Error(`Invalid signature for input ${inputIndex}, pubkey ${pubKeyHex}`);
224
- }
225
- }
226
- // Verify we have signatures from all required signers (excluding those we're skipping)
227
- const signedPubkeys = input.tapScriptSig.map(([data]) => hex.encode(data.pubKey));
228
- const requiredNotExcluded = requiredSigners.filter((pk) => !excludePubkeys.includes(pk));
229
- const missingSigners = requiredNotExcluded.filter((pk) => !signedPubkeys.includes(pk));
230
- if (missingSigners.length > 0) {
231
- throw new Error(`Missing signatures from: ${missingSigners.map((pk) => pk.slice(0, 16)).join(", ")}...`);
232
- }
233
- }
234
- /**
235
- * Merges the signed transaction with the original transaction
236
- * @param signedTx signed transaction
237
- * @param originalTx original transaction
238
- */
239
- export function combineTapscriptSigs(signedTx, originalTx) {
240
- for (let i = 0; i < signedTx.inputsLength; i++) {
241
- const input = originalTx.getInput(i);
242
- const signedInput = signedTx.getInput(i);
243
- if (!input.tapScriptSig)
244
- throw new Error("No tapScriptSig");
245
- originalTx.updateInput(i, {
246
- tapScriptSig: input.tapScriptSig?.concat(signedInput.tapScriptSig),
247
- });
248
- }
249
- return originalTx;
250
- }
251
- /**
252
- * Validates if a given string is a valid Arkade address by attempting to decode it.
253
- * @param address The Arkade address to validate.
254
- * @returns True if the address is valid, false otherwise.
255
- */
256
- export function isValidArkAddress(address) {
257
- try {
258
- ArkAddress.decode(address);
259
- return true;
260
- }
261
- catch (e) {
262
- return false;
263
- }
264
- }