@arkade-os/sdk 0.4.26 → 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 (522) hide show
  1. package/README.md +36 -125
  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 -629
  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 -2
  156. package/dist/cjs/identity/index.js +0 -38
  157. package/dist/cjs/identity/seedIdentity.js +0 -461
  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 -200
  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 -302
  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 -159
  236. package/dist/cjs/wallet/index.js +0 -82
  237. package/dist/cjs/wallet/onchain.js +0 -290
  238. package/dist/cjs/wallet/ramps.js +0 -216
  239. package/dist/cjs/wallet/serviceWorker/wallet-message-handler.js +0 -953
  240. package/dist/cjs/wallet/serviceWorker/wallet.js +0 -1173
  241. package/dist/cjs/wallet/unroll.js +0 -289
  242. package/dist/cjs/wallet/utils.js +0 -111
  243. package/dist/cjs/wallet/validation.js +0 -154
  244. package/dist/cjs/wallet/vtxo-manager.js +0 -1142
  245. package/dist/cjs/wallet/wallet.js +0 -2049
  246. package/dist/cjs/worker/browser/service-worker-manager.js +0 -183
  247. package/dist/cjs/worker/browser/utils.js +0 -67
  248. package/dist/cjs/worker/errors.js +0 -16
  249. package/dist/cjs/worker/expo/asyncStorageTaskQueue.js +0 -78
  250. package/dist/cjs/worker/expo/index.js +0 -13
  251. package/dist/cjs/worker/expo/processors/contractPollProcessor.js +0 -62
  252. package/dist/cjs/worker/expo/processors/index.js +0 -6
  253. package/dist/cjs/worker/expo/taskQueue.js +0 -41
  254. package/dist/cjs/worker/expo/taskRunner.js +0 -73
  255. package/dist/cjs/worker/messageBus.js +0 -473
  256. package/dist/esm/adapters/asyncStorage.js +0 -1
  257. package/dist/esm/adapters/expo.js +0 -3
  258. package/dist/esm/adapters/fileSystem.js +0 -1
  259. package/dist/esm/adapters/indexedDB.js +0 -1
  260. package/dist/esm/adapters/localStorage.js +0 -1
  261. package/dist/esm/arkfee/celenv.js +0 -40
  262. package/dist/esm/arkfee/estimator.js +0 -139
  263. package/dist/esm/arkfee/index.js +0 -1
  264. package/dist/esm/arkfee/types.js +0 -22
  265. package/dist/esm/arknote/index.js +0 -124
  266. package/dist/esm/bip322/index.js +0 -267
  267. package/dist/esm/contracts/arkcontract.js +0 -140
  268. package/dist/esm/contracts/contractManager.js +0 -625
  269. package/dist/esm/contracts/contractWatcher.js +0 -594
  270. package/dist/esm/contracts/handlers/default.js +0 -90
  271. package/dist/esm/contracts/handlers/delegate.js +0 -87
  272. package/dist/esm/contracts/handlers/helpers.js +0 -110
  273. package/dist/esm/contracts/handlers/index.js +0 -12
  274. package/dist/esm/contracts/handlers/registry.js +0 -86
  275. package/dist/esm/contracts/handlers/vhtlc.js +0 -191
  276. package/dist/esm/contracts/index.js +0 -13
  277. package/dist/esm/contracts/types.js +0 -1
  278. package/dist/esm/contracts/vtxoOwnership.js +0 -69
  279. package/dist/esm/extension/asset/assetGroup.js +0 -224
  280. package/dist/esm/extension/asset/assetId.js +0 -148
  281. package/dist/esm/extension/asset/assetInput.js +0 -217
  282. package/dist/esm/extension/asset/assetOutput.js +0 -169
  283. package/dist/esm/extension/asset/assetRef.js +0 -144
  284. package/dist/esm/extension/asset/index.js +0 -8
  285. package/dist/esm/extension/asset/metadata.js +0 -182
  286. package/dist/esm/extension/asset/packet.js +0 -110
  287. package/dist/esm/extension/asset/types.js +0 -19
  288. package/dist/esm/extension/asset/utils.js +0 -99
  289. package/dist/esm/extension/index.js +0 -248
  290. package/dist/esm/extension/packet.js +0 -16
  291. package/dist/esm/forfeit.js +0 -41
  292. package/dist/esm/identity/descriptor.js +0 -161
  293. package/dist/esm/identity/descriptorProvider.js +0 -1
  294. package/dist/esm/identity/hdCapableIdentity.js +0 -1
  295. package/dist/esm/identity/index.js +0 -12
  296. package/dist/esm/identity/seedIdentity.js +0 -453
  297. package/dist/esm/identity/serialize.js +0 -164
  298. package/dist/esm/identity/singleKey.js +0 -121
  299. package/dist/esm/identity/staticDescriptorProvider.js +0 -61
  300. package/dist/esm/index.js +0 -87
  301. package/dist/esm/intent/index.js +0 -255
  302. package/dist/esm/musig2/index.js +0 -3
  303. package/dist/esm/musig2/keys.js +0 -21
  304. package/dist/esm/musig2/nonces.js +0 -11
  305. package/dist/esm/musig2/sign.js +0 -63
  306. package/dist/esm/networks.js +0 -22
  307. package/dist/esm/package.json +0 -3
  308. package/dist/esm/providers/ark.js +0 -572
  309. package/dist/esm/providers/delegator.js +0 -81
  310. package/dist/esm/providers/electrum.js +0 -864
  311. package/dist/esm/providers/errors.js +0 -54
  312. package/dist/esm/providers/expoArk.js +0 -78
  313. package/dist/esm/providers/expoIndexer.js +0 -107
  314. package/dist/esm/providers/expoUtils.js +0 -87
  315. package/dist/esm/providers/indexer.js +0 -626
  316. package/dist/esm/providers/onchain.js +0 -258
  317. package/dist/esm/providers/utils.js +0 -117
  318. package/dist/esm/repositories/contractRepository.js +0 -1
  319. package/dist/esm/repositories/inMemory/contractRepository.js +0 -51
  320. package/dist/esm/repositories/inMemory/walletRepository.js +0 -111
  321. package/dist/esm/repositories/index.js +0 -10
  322. package/dist/esm/repositories/indexedDB/contractRepository.js +0 -183
  323. package/dist/esm/repositories/indexedDB/db.js +0 -4
  324. package/dist/esm/repositories/indexedDB/manager.js +0 -95
  325. package/dist/esm/repositories/indexedDB/schema.js +0 -199
  326. package/dist/esm/repositories/indexedDB/walletRepository.js +0 -470
  327. package/dist/esm/repositories/indexedDB/websqlAdapter.js +0 -138
  328. package/dist/esm/repositories/migrations/contractRepositoryImpl.js +0 -121
  329. package/dist/esm/repositories/migrations/fromStorageAdapter.js +0 -58
  330. package/dist/esm/repositories/migrations/walletRepositoryImpl.js +0 -180
  331. package/dist/esm/repositories/realm/contractRepository.js +0 -112
  332. package/dist/esm/repositories/realm/index.js +0 -3
  333. package/dist/esm/repositories/realm/schemas.js +0 -153
  334. package/dist/esm/repositories/realm/types.js +0 -6
  335. package/dist/esm/repositories/realm/walletRepository.js +0 -301
  336. package/dist/esm/repositories/scriptFromAddress.js +0 -13
  337. package/dist/esm/repositories/serialization.js +0 -67
  338. package/dist/esm/repositories/sqlite/contractRepository.js +0 -131
  339. package/dist/esm/repositories/sqlite/index.js +0 -2
  340. package/dist/esm/repositories/sqlite/types.js +0 -1
  341. package/dist/esm/repositories/sqlite/walletRepository.js +0 -437
  342. package/dist/esm/repositories/walletRepository.js +0 -1
  343. package/dist/esm/script/address.js +0 -104
  344. package/dist/esm/script/base.js +0 -179
  345. package/dist/esm/script/default.js +0 -54
  346. package/dist/esm/script/delegate.js +0 -50
  347. package/dist/esm/script/tapscript.js +0 -615
  348. package/dist/esm/script/vhtlc.js +0 -167
  349. package/dist/esm/storage/asyncStorage.js +0 -46
  350. package/dist/esm/storage/fileSystem.js +0 -104
  351. package/dist/esm/storage/inMemory.js +0 -20
  352. package/dist/esm/storage/index.js +0 -1
  353. package/dist/esm/storage/indexedDB.js +0 -97
  354. package/dist/esm/storage/localStorage.js +0 -47
  355. package/dist/esm/tree/signingSession.js +0 -191
  356. package/dist/esm/tree/txTree.js +0 -188
  357. package/dist/esm/tree/validation.js +0 -101
  358. package/dist/esm/utils/anchor.js +0 -31
  359. package/dist/esm/utils/arkTransaction.js +0 -264
  360. package/dist/esm/utils/bip21.js +0 -123
  361. package/dist/esm/utils/syncCursors.js +0 -119
  362. package/dist/esm/utils/timelock.js +0 -22
  363. package/dist/esm/utils/transaction.js +0 -24
  364. package/dist/esm/utils/transactionHistory.js +0 -180
  365. package/dist/esm/utils/txSizeEstimator.js +0 -128
  366. package/dist/esm/utils/unknownFields.js +0 -169
  367. package/dist/esm/wallet/asset-manager.js +0 -325
  368. package/dist/esm/wallet/asset.js +0 -113
  369. package/dist/esm/wallet/batch.js +0 -180
  370. package/dist/esm/wallet/delegator.js +0 -297
  371. package/dist/esm/wallet/expo/background.js +0 -111
  372. package/dist/esm/wallet/expo/index.js +0 -2
  373. package/dist/esm/wallet/expo/wallet.js +0 -193
  374. package/dist/esm/wallet/hdDescriptorProvider.js +0 -155
  375. package/dist/esm/wallet/index.js +0 -75
  376. package/dist/esm/wallet/onchain.js +0 -285
  377. package/dist/esm/wallet/ramps.js +0 -212
  378. package/dist/esm/wallet/serviceWorker/wallet-message-handler.js +0 -946
  379. package/dist/esm/wallet/serviceWorker/wallet.js +0 -1168
  380. package/dist/esm/wallet/unroll.js +0 -285
  381. package/dist/esm/wallet/utils.js +0 -103
  382. package/dist/esm/wallet/validation.js +0 -142
  383. package/dist/esm/wallet/vtxo-manager.js +0 -1136
  384. package/dist/esm/wallet/wallet.js +0 -2041
  385. package/dist/esm/worker/browser/service-worker-manager.js +0 -177
  386. package/dist/esm/worker/browser/utils.js +0 -63
  387. package/dist/esm/worker/errors.js +0 -11
  388. package/dist/esm/worker/expo/asyncStorageTaskQueue.js +0 -74
  389. package/dist/esm/worker/expo/index.js +0 -4
  390. package/dist/esm/worker/expo/processors/contractPollProcessor.js +0 -59
  391. package/dist/esm/worker/expo/processors/index.js +0 -1
  392. package/dist/esm/worker/expo/taskQueue.js +0 -37
  393. package/dist/esm/worker/expo/taskRunner.js +0 -69
  394. package/dist/esm/worker/messageBus.js +0 -469
  395. package/dist/types/adapters/asyncStorage.d.ts +0 -2
  396. package/dist/types/adapters/expo.d.ts +0 -4
  397. package/dist/types/adapters/fileSystem.d.ts +0 -2
  398. package/dist/types/adapters/indexedDB.d.ts +0 -2
  399. package/dist/types/adapters/localStorage.d.ts +0 -2
  400. package/dist/types/arkfee/celenv.d.ts +0 -25
  401. package/dist/types/arkfee/estimator.d.ts +0 -49
  402. package/dist/types/arkfee/index.d.ts +0 -2
  403. package/dist/types/arkfee/types.d.ts +0 -38
  404. package/dist/types/arknote/index.d.ts +0 -84
  405. package/dist/types/bip322/index.d.ts +0 -55
  406. package/dist/types/contracts/arkcontract.d.ts +0 -99
  407. package/dist/types/contracts/contractManager.d.ts +0 -381
  408. package/dist/types/contracts/contractWatcher.d.ts +0 -217
  409. package/dist/types/contracts/handlers/default.d.ts +0 -19
  410. package/dist/types/contracts/handlers/delegate.d.ts +0 -21
  411. package/dist/types/contracts/handlers/helpers.d.ts +0 -19
  412. package/dist/types/contracts/handlers/index.d.ts +0 -7
  413. package/dist/types/contracts/handlers/registry.d.ts +0 -65
  414. package/dist/types/contracts/handlers/vhtlc.d.ts +0 -32
  415. package/dist/types/contracts/index.d.ts +0 -14
  416. package/dist/types/contracts/types.d.ts +0 -233
  417. package/dist/types/contracts/vtxoOwnership.d.ts +0 -33
  418. package/dist/types/extension/asset/assetGroup.d.ts +0 -119
  419. package/dist/types/extension/asset/assetId.d.ts +0 -83
  420. package/dist/types/extension/asset/assetInput.d.ts +0 -64
  421. package/dist/types/extension/asset/assetOutput.d.ts +0 -54
  422. package/dist/types/extension/asset/assetRef.d.ts +0 -91
  423. package/dist/types/extension/asset/index.d.ts +0 -8
  424. package/dist/types/extension/asset/metadata.d.ts +0 -52
  425. package/dist/types/extension/asset/packet.d.ts +0 -41
  426. package/dist/types/extension/asset/types.d.ts +0 -16
  427. package/dist/types/extension/asset/utils.d.ts +0 -21
  428. package/dist/types/extension/index.d.ts +0 -56
  429. package/dist/types/extension/packet.d.ts +0 -21
  430. package/dist/types/forfeit.d.ts +0 -18
  431. package/dist/types/identity/descriptor.d.ts +0 -61
  432. package/dist/types/identity/descriptorProvider.d.ts +0 -35
  433. package/dist/types/identity/hdCapableIdentity.d.ts +0 -44
  434. package/dist/types/identity/index.d.ts +0 -56
  435. package/dist/types/identity/seedIdentity.d.ts +0 -254
  436. package/dist/types/identity/serialize.d.ts +0 -96
  437. package/dist/types/identity/singleKey.d.ts +0 -62
  438. package/dist/types/identity/staticDescriptorProvider.d.ts +0 -18
  439. package/dist/types/index.d.ts +0 -59
  440. package/dist/types/intent/index.d.ts +0 -86
  441. package/dist/types/musig2/index.d.ts +0 -4
  442. package/dist/types/musig2/keys.d.ts +0 -9
  443. package/dist/types/musig2/nonces.d.ts +0 -14
  444. package/dist/types/musig2/sign.d.ts +0 -27
  445. package/dist/types/networks.d.ts +0 -16
  446. package/dist/types/providers/ark.d.ts +0 -369
  447. package/dist/types/providers/delegator.d.ts +0 -82
  448. package/dist/types/providers/electrum.d.ts +0 -312
  449. package/dist/types/providers/errors.d.ts +0 -13
  450. package/dist/types/providers/expoArk.d.ts +0 -22
  451. package/dist/types/providers/expoIndexer.d.ts +0 -18
  452. package/dist/types/providers/expoUtils.d.ts +0 -18
  453. package/dist/types/providers/indexer.d.ts +0 -301
  454. package/dist/types/providers/onchain.d.ts +0 -148
  455. package/dist/types/providers/utils.d.ts +0 -12
  456. package/dist/types/repositories/contractRepository.d.ts +0 -32
  457. package/dist/types/repositories/inMemory/contractRepository.d.ts +0 -17
  458. package/dist/types/repositories/inMemory/walletRepository.d.ts +0 -29
  459. package/dist/types/repositories/index.d.ts +0 -9
  460. package/dist/types/repositories/indexedDB/contractRepository.d.ts +0 -21
  461. package/dist/types/repositories/indexedDB/db.d.ts +0 -4
  462. package/dist/types/repositories/indexedDB/manager.d.ts +0 -25
  463. package/dist/types/repositories/indexedDB/schema.d.ts +0 -9
  464. package/dist/types/repositories/indexedDB/walletRepository.d.ts +0 -28
  465. package/dist/types/repositories/indexedDB/websqlAdapter.d.ts +0 -49
  466. package/dist/types/repositories/migrations/contractRepositoryImpl.d.ts +0 -24
  467. package/dist/types/repositories/migrations/fromStorageAdapter.d.ts +0 -19
  468. package/dist/types/repositories/migrations/walletRepositoryImpl.d.ts +0 -27
  469. package/dist/types/repositories/realm/contractRepository.d.ts +0 -24
  470. package/dist/types/repositories/realm/index.d.ts +0 -4
  471. package/dist/types/repositories/realm/types.d.ts +0 -16
  472. package/dist/types/repositories/realm/walletRepository.d.ts +0 -34
  473. package/dist/types/repositories/scriptFromAddress.d.ts +0 -9
  474. package/dist/types/repositories/serialization.d.ts +0 -65
  475. package/dist/types/repositories/sqlite/contractRepository.d.ts +0 -33
  476. package/dist/types/repositories/sqlite/index.d.ts +0 -3
  477. package/dist/types/repositories/sqlite/types.d.ts +0 -18
  478. package/dist/types/repositories/walletRepository.d.ts +0 -72
  479. package/dist/types/script/address.d.ts +0 -67
  480. package/dist/types/script/base.d.ts +0 -105
  481. package/dist/types/script/default.d.ts +0 -44
  482. package/dist/types/script/delegate.d.ts +0 -40
  483. package/dist/types/script/tapscript.d.ts +0 -169
  484. package/dist/types/script/vhtlc.d.ts +0 -66
  485. package/dist/types/tree/signingSession.d.ts +0 -37
  486. package/dist/types/tree/txTree.d.ts +0 -28
  487. package/dist/types/tree/validation.d.ts +0 -15
  488. package/dist/types/utils/anchor.d.ts +0 -19
  489. package/dist/types/utils/arkTransaction.d.ts +0 -49
  490. package/dist/types/utils/bip21.d.ts +0 -38
  491. package/dist/types/utils/syncCursors.d.ts +0 -60
  492. package/dist/types/utils/timelock.d.ts +0 -9
  493. package/dist/types/utils/transaction.d.ts +0 -13
  494. package/dist/types/utils/transactionHistory.d.ts +0 -15
  495. package/dist/types/utils/txSizeEstimator.d.ts +0 -40
  496. package/dist/types/utils/unknownFields.d.ts +0 -83
  497. package/dist/types/wallet/asset-manager.d.ts +0 -69
  498. package/dist/types/wallet/asset.d.ts +0 -21
  499. package/dist/types/wallet/batch.d.ts +0 -107
  500. package/dist/types/wallet/delegator.d.ts +0 -48
  501. package/dist/types/wallet/expo/background.d.ts +0 -66
  502. package/dist/types/wallet/expo/index.d.ts +0 -4
  503. package/dist/types/wallet/hdDescriptorProvider.d.ts +0 -93
  504. package/dist/types/wallet/index.d.ts +0 -755
  505. package/dist/types/wallet/onchain.d.ts +0 -109
  506. package/dist/types/wallet/ramps.d.ts +0 -64
  507. package/dist/types/wallet/serviceWorker/wallet-message-handler.d.ts +0 -543
  508. package/dist/types/wallet/serviceWorker/wallet.d.ts +0 -238
  509. package/dist/types/wallet/unroll.d.ts +0 -114
  510. package/dist/types/wallet/utils.d.ts +0 -36
  511. package/dist/types/wallet/validation.d.ts +0 -24
  512. package/dist/types/wallet/vtxo-manager.d.ts +0 -476
  513. package/dist/types/wallet/wallet.d.ts +0 -360
  514. package/dist/types/worker/browser/service-worker-manager.d.ts +0 -32
  515. package/dist/types/worker/browser/utils.d.ts +0 -17
  516. package/dist/types/worker/errors.d.ts +0 -7
  517. package/dist/types/worker/expo/index.d.ts +0 -7
  518. package/dist/types/worker/expo/processors/contractPollProcessor.d.ts +0 -19
  519. package/dist/types/worker/expo/processors/index.d.ts +0 -1
  520. package/dist/types/worker/expo/taskQueue.d.ts +0 -50
  521. package/dist/types/worker/expo/taskRunner.d.ts +0 -66
  522. package/dist/types/worker/messageBus.d.ts +0 -188
@@ -1,126 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ReadonlySingleKey = exports.SingleKey = void 0;
4
- const utils_js_1 = require("@scure/btc-signer/utils.js");
5
- const btc_signer_1 = require("@scure/btc-signer");
6
- const base_1 = require("@scure/base");
7
- const signingSession_1 = require("../tree/signingSession");
8
- const secp256k1_1 = require("@noble/secp256k1");
9
- const ALL_SIGHASH = Object.values(btc_signer_1.SigHash).filter((x) => typeof x === "number");
10
- /**
11
- * In-memory single key implementation for Bitcoin transaction signing.
12
- *
13
- * @example
14
- * ```typescript
15
- * // Create from hex string
16
- * const key = SingleKey.fromHex('your_private_key_hex');
17
- *
18
- * // Create from raw bytes
19
- * const key = SingleKey.fromPrivateKey(privateKeyBytes);
20
- *
21
- * // Create random key
22
- * const randomKey = SingleKey.fromRandomBytes();
23
- *
24
- * // Sign a transaction
25
- * const signedTx = await key.sign(transaction);
26
- * ```
27
- */
28
- class SingleKey {
29
- constructor(key) {
30
- this.key = key || (0, utils_js_1.randomPrivateKeyBytes)();
31
- }
32
- /** Create a signing identity from raw private key bytes. */
33
- static fromPrivateKey(privateKey) {
34
- return new SingleKey(privateKey);
35
- }
36
- /** Create a signing identity from a hex-encoded private key. */
37
- static fromHex(privateKeyHex) {
38
- return new SingleKey(base_1.hex.decode(privateKeyHex));
39
- }
40
- /** Create a signing identity with a freshly generated random private key. */
41
- static fromRandomBytes() {
42
- return new SingleKey((0, utils_js_1.randomPrivateKeyBytes)());
43
- }
44
- /**
45
- * Export the private key as a hex string.
46
- *
47
- * @returns The private key as a hex string
48
- */
49
- toHex() {
50
- return base_1.hex.encode(this.key);
51
- }
52
- async sign(tx, inputIndexes) {
53
- const txCpy = tx.clone();
54
- if (!inputIndexes) {
55
- try {
56
- if (!txCpy.sign(this.key, ALL_SIGHASH)) {
57
- throw new Error("Failed to sign transaction");
58
- }
59
- }
60
- catch (e) {
61
- if (e instanceof Error &&
62
- e.message.includes("No inputs signed")) {
63
- // ignore
64
- }
65
- else {
66
- throw e;
67
- }
68
- }
69
- return txCpy;
70
- }
71
- for (const inputIndex of inputIndexes) {
72
- if (!txCpy.signIdx(this.key, inputIndex, ALL_SIGHASH)) {
73
- throw new Error(`Failed to sign input #${inputIndex}`);
74
- }
75
- }
76
- return txCpy;
77
- }
78
- compressedPublicKey() {
79
- return Promise.resolve((0, utils_js_1.pubECDSA)(this.key, true));
80
- }
81
- xOnlyPublicKey() {
82
- return Promise.resolve((0, utils_js_1.pubSchnorr)(this.key));
83
- }
84
- signerSession() {
85
- return signingSession_1.TreeSignerSession.random();
86
- }
87
- async signMessage(message, signatureType = "schnorr") {
88
- if (signatureType === "ecdsa")
89
- return (0, secp256k1_1.signAsync)(message, this.key, { prehash: false });
90
- return secp256k1_1.schnorr.signAsync(message, this.key);
91
- }
92
- async toReadonly() {
93
- return new ReadonlySingleKey(await this.compressedPublicKey());
94
- }
95
- }
96
- exports.SingleKey = SingleKey;
97
- class ReadonlySingleKey {
98
- /** Create a readonly identity from a compressed public key. */
99
- constructor(publicKey) {
100
- this.publicKey = publicKey;
101
- if (publicKey.length !== 33) {
102
- throw new Error("Invalid public key length");
103
- }
104
- }
105
- /**
106
- * Create a ReadonlySingleKey from a compressed public key.
107
- *
108
- * @param publicKey - 33-byte compressed public key (02/03 prefix + 32-byte x coordinate)
109
- * @returns A new ReadonlySingleKey instance
110
- * @example
111
- * ```typescript
112
- * const pubkey = new Uint8Array(33); // your compressed public key
113
- * const readonlyKey = ReadonlySingleKey.fromPublicKey(pubkey);
114
- * ```
115
- */
116
- static fromPublicKey(publicKey) {
117
- return new ReadonlySingleKey(publicKey);
118
- }
119
- xOnlyPublicKey() {
120
- return Promise.resolve(this.publicKey.slice(1));
121
- }
122
- compressedPublicKey() {
123
- return Promise.resolve(this.publicKey);
124
- }
125
- }
126
- exports.ReadonlySingleKey = ReadonlySingleKey;
@@ -1,65 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.StaticDescriptorProvider = void 0;
4
- const base_1 = require("@scure/base");
5
- const _1 = require(".");
6
- const descriptor_1 = require("./descriptor");
7
- /**
8
- * Wraps a legacy Identity (single-key) as a DescriptorProvider.
9
- * The descriptor is always a simple tr(pubkey) format.
10
- */
11
- class StaticDescriptorProvider {
12
- constructor(identity, pubKeyHex) {
13
- this.identity = identity;
14
- this.pubKeyHex = pubKeyHex;
15
- this.descriptor = `tr(${pubKeyHex})`;
16
- }
17
- static async create(identity) {
18
- const pubKey = await identity.xOnlyPublicKey();
19
- return new StaticDescriptorProvider(identity, base_1.hex.encode(pubKey));
20
- }
21
- async getNextSigningDescriptor() {
22
- return this.descriptor;
23
- }
24
- isOurs(descriptor) {
25
- try {
26
- const normalized = (0, descriptor_1.normalizeToDescriptor)(descriptor);
27
- const pubKey = (0, descriptor_1.extractPubKey)(normalized);
28
- return pubKey.toLowerCase() === this.pubKeyHex.toLowerCase();
29
- }
30
- catch {
31
- return false;
32
- }
33
- }
34
- async signWithDescriptor(requests) {
35
- for (const request of requests) {
36
- if (!this.isOurs(request.descriptor)) {
37
- throw new Error(`Descriptor ${request.descriptor} does not belong to this provider`);
38
- }
39
- }
40
- // Use batch signing when the identity supports it (fewer confirmation popups)
41
- if ((0, _1.isBatchSignable)(this.identity)) {
42
- const signed = await this.identity.signMultiple(requests.map((r) => ({
43
- tx: r.tx,
44
- inputIndexes: r.inputIndexes,
45
- })));
46
- if (signed.length !== requests.length) {
47
- throw new Error(`signMultiple returned ${signed.length} transactions, expected ${requests.length}`);
48
- }
49
- return signed;
50
- }
51
- const results = [];
52
- for (const request of requests) {
53
- const signed = await this.identity.sign(request.tx, request.inputIndexes);
54
- results.push(signed);
55
- }
56
- return results;
57
- }
58
- async signMessageWithDescriptor(descriptor, message, type = "schnorr") {
59
- if (!this.isOurs(descriptor)) {
60
- throw new Error(`Descriptor ${descriptor} does not belong to this provider`);
61
- }
62
- return this.identity.signMessage(message, type);
63
- }
64
- }
65
- exports.StaticDescriptorProvider = StaticDescriptorProvider;
package/dist/cjs/index.js DELETED
@@ -1,200 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
19
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
20
- };
21
- var __importStar = (this && this.__importStar) || (function () {
22
- var ownKeys = function(o) {
23
- ownKeys = Object.getOwnPropertyNames || function (o) {
24
- var ar = [];
25
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
26
- return ar;
27
- };
28
- return ownKeys(o);
29
- };
30
- return function (mod) {
31
- if (mod && mod.__esModule) return mod;
32
- var result = {};
33
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
34
- __setModuleDefault(result, mod);
35
- return result;
36
- };
37
- })();
38
- Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.CLTVMultisigTapscript = exports.ConditionMultisigTapscript = exports.ConditionCSVMultisigTapscript = exports.CSVMultisigTapscript = exports.MultisigTapscript = exports.decodeTapscript = exports.DEFAULT_MESSAGE_TIMEOUTS = exports.ServiceWorkerReadonlyWallet = exports.ServiceWorkerWallet = exports.ServiceWorkerTimeoutError = exports.MessageBusNotInitializedError = exports.MESSAGE_BUS_NOT_INITIALIZED = exports.DelegatorNotConfiguredError = exports.ReadonlyWalletError = exports.WalletNotInitializedError = exports.WalletMessageHandler = exports.MessageBus = exports.setupServiceWorker = exports.SettlementEventType = exports.ChainTxType = exports.IndexerTxType = exports.TxType = exports.VHTLC = exports.VtxoScript = exports.DelegateVtxo = exports.DefaultVtxo = exports.ArkAddress = exports.RestIndexerProvider = exports.RestArkProvider = exports.WsElectrumChainSource = exports.ElectrumOnchainProvider = exports.ELECTRUM_TCP_HOST = exports.ELECTRUM_WS_URL = exports.EsploraProvider = exports.ESPLORA_URL = exports.RestDelegatorProvider = exports.DelegatorManagerImpl = exports.HDDescriptorProvider = exports.VtxoManager = exports.Ramps = exports.OnchainWallet = exports.isBatchSignable = exports.ReadonlyDescriptorIdentity = exports.MnemonicIdentity = exports.SeedIdentity = exports.ReadonlySingleKey = exports.SingleKey = exports.ReadonlyWallet = exports.Wallet = exports.asset = void 0;
40
- exports.isExpired = exports.isSubdust = exports.isSpendable = exports.isRecoverable = exports.buildForfeitTx = exports.validateConnectorsTxGraph = exports.validateVtxoTxGraph = exports.Batch = exports.maybeArkError = exports.ArkError = exports.sequenceToTimelock = exports.timelockToSequence = exports.TxWeightEstimator = exports.Transaction = exports.Unroll = exports.P2A = exports.TxTree = exports.BIP322 = exports.Intent = exports.ContractRepositoryImpl = exports.WalletRepositoryImpl = exports.rollbackMigration = exports.getMigrationStatus = exports.requiresMigration = exports.migrateWalletRepository = exports.MIGRATION_KEY = exports.InMemoryContractRepository = exports.InMemoryWalletRepository = exports.IndexedDBContractRepository = exports.IndexedDBWalletRepository = exports.openDatabase = exports.closeDatabase = exports.networks = exports.ArkNote = exports.isValidArkAddress = exports.isVtxoExpiringSoon = exports.combineTapscriptSigs = exports.hasBoardingTxExpired = exports.waitForIncomingFunds = exports.verifyTapscriptSignatures = exports.buildOffchainTx = exports.ConditionWitness = exports.VtxoTaprootTree = exports.VtxoTreeExpiry = exports.CosignerPublicKey = exports.getArkPsbtFields = exports.setArkPsbtField = exports.ArkPsbtFieldKeyType = exports.ArkPsbtFieldKey = exports.TapTreeCoder = void 0;
41
- exports.isArkContract = exports.contractFromArkContractWithAddress = exports.contractFromArkContract = exports.decodeArkContract = exports.encodeArkContract = exports.VHTLCContractHandler = exports.DelegateContractHandler = exports.DefaultContractHandler = exports.contractHandlers = exports.ContractWatcher = exports.ContractManager = exports.getSequence = void 0;
42
- const transaction_1 = require("./utils/transaction");
43
- Object.defineProperty(exports, "Transaction", { enumerable: true, get: function () { return transaction_1.Transaction; } });
44
- const singleKey_1 = require("./identity/singleKey");
45
- Object.defineProperty(exports, "SingleKey", { enumerable: true, get: function () { return singleKey_1.SingleKey; } });
46
- Object.defineProperty(exports, "ReadonlySingleKey", { enumerable: true, get: function () { return singleKey_1.ReadonlySingleKey; } });
47
- const seedIdentity_1 = require("./identity/seedIdentity");
48
- Object.defineProperty(exports, "SeedIdentity", { enumerable: true, get: function () { return seedIdentity_1.SeedIdentity; } });
49
- Object.defineProperty(exports, "MnemonicIdentity", { enumerable: true, get: function () { return seedIdentity_1.MnemonicIdentity; } });
50
- Object.defineProperty(exports, "ReadonlyDescriptorIdentity", { enumerable: true, get: function () { return seedIdentity_1.ReadonlyDescriptorIdentity; } });
51
- const identity_1 = require("./identity");
52
- Object.defineProperty(exports, "isBatchSignable", { enumerable: true, get: function () { return identity_1.isBatchSignable; } });
53
- const address_1 = require("./script/address");
54
- Object.defineProperty(exports, "ArkAddress", { enumerable: true, get: function () { return address_1.ArkAddress; } });
55
- const vhtlc_1 = require("./script/vhtlc");
56
- Object.defineProperty(exports, "VHTLC", { enumerable: true, get: function () { return vhtlc_1.VHTLC; } });
57
- const default_1 = require("./script/default");
58
- Object.defineProperty(exports, "DefaultVtxo", { enumerable: true, get: function () { return default_1.DefaultVtxo; } });
59
- const delegate_1 = require("./script/delegate");
60
- Object.defineProperty(exports, "DelegateVtxo", { enumerable: true, get: function () { return delegate_1.DelegateVtxo; } });
61
- const messageBus_1 = require("./worker/messageBus");
62
- Object.defineProperty(exports, "MessageBus", { enumerable: true, get: function () { return messageBus_1.MessageBus; } });
63
- const base_1 = require("./script/base");
64
- Object.defineProperty(exports, "VtxoScript", { enumerable: true, get: function () { return base_1.VtxoScript; } });
65
- Object.defineProperty(exports, "TapTreeCoder", { enumerable: true, get: function () { return base_1.TapTreeCoder; } });
66
- Object.defineProperty(exports, "getSequence", { enumerable: true, get: function () { return base_1.getSequence; } });
67
- const wallet_1 = require("./wallet");
68
- Object.defineProperty(exports, "TxType", { enumerable: true, get: function () { return wallet_1.TxType; } });
69
- Object.defineProperty(exports, "isSpendable", { enumerable: true, get: function () { return wallet_1.isSpendable; } });
70
- Object.defineProperty(exports, "isSubdust", { enumerable: true, get: function () { return wallet_1.isSubdust; } });
71
- Object.defineProperty(exports, "isRecoverable", { enumerable: true, get: function () { return wallet_1.isRecoverable; } });
72
- Object.defineProperty(exports, "isExpired", { enumerable: true, get: function () { return wallet_1.isExpired; } });
73
- const batch_1 = require("./wallet/batch");
74
- Object.defineProperty(exports, "Batch", { enumerable: true, get: function () { return batch_1.Batch; } });
75
- const wallet_2 = require("./wallet/wallet");
76
- Object.defineProperty(exports, "Wallet", { enumerable: true, get: function () { return wallet_2.Wallet; } });
77
- Object.defineProperty(exports, "ReadonlyWallet", { enumerable: true, get: function () { return wallet_2.ReadonlyWallet; } });
78
- Object.defineProperty(exports, "waitForIncomingFunds", { enumerable: true, get: function () { return wallet_2.waitForIncomingFunds; } });
79
- const txTree_1 = require("./tree/txTree");
80
- Object.defineProperty(exports, "TxTree", { enumerable: true, get: function () { return txTree_1.TxTree; } });
81
- const ramps_1 = require("./wallet/ramps");
82
- Object.defineProperty(exports, "Ramps", { enumerable: true, get: function () { return ramps_1.Ramps; } });
83
- const hdDescriptorProvider_1 = require("./wallet/hdDescriptorProvider");
84
- Object.defineProperty(exports, "HDDescriptorProvider", { enumerable: true, get: function () { return hdDescriptorProvider_1.HDDescriptorProvider; } });
85
- const vtxo_manager_1 = require("./wallet/vtxo-manager");
86
- Object.defineProperty(exports, "isVtxoExpiringSoon", { enumerable: true, get: function () { return vtxo_manager_1.isVtxoExpiringSoon; } });
87
- Object.defineProperty(exports, "VtxoManager", { enumerable: true, get: function () { return vtxo_manager_1.VtxoManager; } });
88
- const wallet_3 = require("./wallet/serviceWorker/wallet");
89
- Object.defineProperty(exports, "ServiceWorkerWallet", { enumerable: true, get: function () { return wallet_3.ServiceWorkerWallet; } });
90
- Object.defineProperty(exports, "ServiceWorkerReadonlyWallet", { enumerable: true, get: function () { return wallet_3.ServiceWorkerReadonlyWallet; } });
91
- Object.defineProperty(exports, "DEFAULT_MESSAGE_TIMEOUTS", { enumerable: true, get: function () { return wallet_3.DEFAULT_MESSAGE_TIMEOUTS; } });
92
- const onchain_1 = require("./wallet/onchain");
93
- Object.defineProperty(exports, "OnchainWallet", { enumerable: true, get: function () { return onchain_1.OnchainWallet; } });
94
- const utils_1 = require("./worker/browser/utils");
95
- Object.defineProperty(exports, "setupServiceWorker", { enumerable: true, get: function () { return utils_1.setupServiceWorker; } });
96
- const onchain_2 = require("./providers/onchain");
97
- Object.defineProperty(exports, "ESPLORA_URL", { enumerable: true, get: function () { return onchain_2.ESPLORA_URL; } });
98
- Object.defineProperty(exports, "EsploraProvider", { enumerable: true, get: function () { return onchain_2.EsploraProvider; } });
99
- const electrum_1 = require("./providers/electrum");
100
- Object.defineProperty(exports, "ELECTRUM_TCP_HOST", { enumerable: true, get: function () { return electrum_1.ELECTRUM_TCP_HOST; } });
101
- Object.defineProperty(exports, "ELECTRUM_WS_URL", { enumerable: true, get: function () { return electrum_1.ELECTRUM_WS_URL; } });
102
- Object.defineProperty(exports, "ElectrumOnchainProvider", { enumerable: true, get: function () { return electrum_1.ElectrumOnchainProvider; } });
103
- Object.defineProperty(exports, "WsElectrumChainSource", { enumerable: true, get: function () { return electrum_1.WsElectrumChainSource; } });
104
- const ark_1 = require("./providers/ark");
105
- Object.defineProperty(exports, "RestArkProvider", { enumerable: true, get: function () { return ark_1.RestArkProvider; } });
106
- Object.defineProperty(exports, "SettlementEventType", { enumerable: true, get: function () { return ark_1.SettlementEventType; } });
107
- const delegator_1 = require("./providers/delegator");
108
- Object.defineProperty(exports, "RestDelegatorProvider", { enumerable: true, get: function () { return delegator_1.RestDelegatorProvider; } });
109
- const tapscript_1 = require("./script/tapscript");
110
- Object.defineProperty(exports, "CLTVMultisigTapscript", { enumerable: true, get: function () { return tapscript_1.CLTVMultisigTapscript; } });
111
- Object.defineProperty(exports, "ConditionCSVMultisigTapscript", { enumerable: true, get: function () { return tapscript_1.ConditionCSVMultisigTapscript; } });
112
- Object.defineProperty(exports, "ConditionMultisigTapscript", { enumerable: true, get: function () { return tapscript_1.ConditionMultisigTapscript; } });
113
- Object.defineProperty(exports, "CSVMultisigTapscript", { enumerable: true, get: function () { return tapscript_1.CSVMultisigTapscript; } });
114
- Object.defineProperty(exports, "decodeTapscript", { enumerable: true, get: function () { return tapscript_1.decodeTapscript; } });
115
- Object.defineProperty(exports, "MultisigTapscript", { enumerable: true, get: function () { return tapscript_1.MultisigTapscript; } });
116
- const arkTransaction_1 = require("./utils/arkTransaction");
117
- Object.defineProperty(exports, "hasBoardingTxExpired", { enumerable: true, get: function () { return arkTransaction_1.hasBoardingTxExpired; } });
118
- Object.defineProperty(exports, "buildOffchainTx", { enumerable: true, get: function () { return arkTransaction_1.buildOffchainTx; } });
119
- Object.defineProperty(exports, "verifyTapscriptSignatures", { enumerable: true, get: function () { return arkTransaction_1.verifyTapscriptSignatures; } });
120
- Object.defineProperty(exports, "combineTapscriptSigs", { enumerable: true, get: function () { return arkTransaction_1.combineTapscriptSigs; } });
121
- Object.defineProperty(exports, "isValidArkAddress", { enumerable: true, get: function () { return arkTransaction_1.isValidArkAddress; } });
122
- const unknownFields_1 = require("./utils/unknownFields");
123
- Object.defineProperty(exports, "VtxoTaprootTree", { enumerable: true, get: function () { return unknownFields_1.VtxoTaprootTree; } });
124
- Object.defineProperty(exports, "ConditionWitness", { enumerable: true, get: function () { return unknownFields_1.ConditionWitness; } });
125
- Object.defineProperty(exports, "getArkPsbtFields", { enumerable: true, get: function () { return unknownFields_1.getArkPsbtFields; } });
126
- Object.defineProperty(exports, "setArkPsbtField", { enumerable: true, get: function () { return unknownFields_1.setArkPsbtField; } });
127
- Object.defineProperty(exports, "ArkPsbtFieldKey", { enumerable: true, get: function () { return unknownFields_1.ArkPsbtFieldKey; } });
128
- Object.defineProperty(exports, "ArkPsbtFieldKeyType", { enumerable: true, get: function () { return unknownFields_1.ArkPsbtFieldKeyType; } });
129
- Object.defineProperty(exports, "CosignerPublicKey", { enumerable: true, get: function () { return unknownFields_1.CosignerPublicKey; } });
130
- Object.defineProperty(exports, "VtxoTreeExpiry", { enumerable: true, get: function () { return unknownFields_1.VtxoTreeExpiry; } });
131
- const intent_1 = require("./intent");
132
- Object.defineProperty(exports, "Intent", { enumerable: true, get: function () { return intent_1.Intent; } });
133
- const bip322_1 = require("./bip322");
134
- Object.defineProperty(exports, "BIP322", { enumerable: true, get: function () { return bip322_1.BIP322; } });
135
- const arknote_1 = require("./arknote");
136
- Object.defineProperty(exports, "ArkNote", { enumerable: true, get: function () { return arknote_1.ArkNote; } });
137
- const networks_1 = require("./networks");
138
- Object.defineProperty(exports, "networks", { enumerable: true, get: function () { return networks_1.networks; } });
139
- const indexer_1 = require("./providers/indexer");
140
- Object.defineProperty(exports, "RestIndexerProvider", { enumerable: true, get: function () { return indexer_1.RestIndexerProvider; } });
141
- Object.defineProperty(exports, "IndexerTxType", { enumerable: true, get: function () { return indexer_1.IndexerTxType; } });
142
- Object.defineProperty(exports, "ChainTxType", { enumerable: true, get: function () { return indexer_1.ChainTxType; } });
143
- const anchor_1 = require("./utils/anchor");
144
- Object.defineProperty(exports, "P2A", { enumerable: true, get: function () { return anchor_1.P2A; } });
145
- const txSizeEstimator_1 = require("./utils/txSizeEstimator");
146
- Object.defineProperty(exports, "TxWeightEstimator", { enumerable: true, get: function () { return txSizeEstimator_1.TxWeightEstimator; } });
147
- const unroll_1 = require("./wallet/unroll");
148
- Object.defineProperty(exports, "Unroll", { enumerable: true, get: function () { return unroll_1.Unroll; } });
149
- const errors_1 = require("./providers/errors");
150
- Object.defineProperty(exports, "ArkError", { enumerable: true, get: function () { return errors_1.ArkError; } });
151
- Object.defineProperty(exports, "maybeArkError", { enumerable: true, get: function () { return errors_1.maybeArkError; } });
152
- const validation_1 = require("./tree/validation");
153
- Object.defineProperty(exports, "validateVtxoTxGraph", { enumerable: true, get: function () { return validation_1.validateVtxoTxGraph; } });
154
- Object.defineProperty(exports, "validateConnectorsTxGraph", { enumerable: true, get: function () { return validation_1.validateConnectorsTxGraph; } });
155
- const forfeit_1 = require("./forfeit");
156
- Object.defineProperty(exports, "buildForfeitTx", { enumerable: true, get: function () { return forfeit_1.buildForfeitTx; } });
157
- const repositories_1 = require("./repositories");
158
- Object.defineProperty(exports, "IndexedDBWalletRepository", { enumerable: true, get: function () { return repositories_1.IndexedDBWalletRepository; } });
159
- Object.defineProperty(exports, "IndexedDBContractRepository", { enumerable: true, get: function () { return repositories_1.IndexedDBContractRepository; } });
160
- Object.defineProperty(exports, "InMemoryWalletRepository", { enumerable: true, get: function () { return repositories_1.InMemoryWalletRepository; } });
161
- Object.defineProperty(exports, "InMemoryContractRepository", { enumerable: true, get: function () { return repositories_1.InMemoryContractRepository; } });
162
- Object.defineProperty(exports, "MIGRATION_KEY", { enumerable: true, get: function () { return repositories_1.MIGRATION_KEY; } });
163
- Object.defineProperty(exports, "migrateWalletRepository", { enumerable: true, get: function () { return repositories_1.migrateWalletRepository; } });
164
- Object.defineProperty(exports, "requiresMigration", { enumerable: true, get: function () { return repositories_1.requiresMigration; } });
165
- Object.defineProperty(exports, "getMigrationStatus", { enumerable: true, get: function () { return repositories_1.getMigrationStatus; } });
166
- Object.defineProperty(exports, "rollbackMigration", { enumerable: true, get: function () { return repositories_1.rollbackMigration; } });
167
- Object.defineProperty(exports, "WalletRepositoryImpl", { enumerable: true, get: function () { return repositories_1.WalletRepositoryImpl; } });
168
- Object.defineProperty(exports, "ContractRepositoryImpl", { enumerable: true, get: function () { return repositories_1.ContractRepositoryImpl; } });
169
- const delegator_2 = require("./wallet/delegator");
170
- Object.defineProperty(exports, "DelegatorManagerImpl", { enumerable: true, get: function () { return delegator_2.DelegatorManagerImpl; } });
171
- __exportStar(require("./arkfee"), exports);
172
- exports.asset = __importStar(require("./extension/asset"));
173
- // Contracts
174
- const contracts_1 = require("./contracts");
175
- Object.defineProperty(exports, "ContractManager", { enumerable: true, get: function () { return contracts_1.ContractManager; } });
176
- Object.defineProperty(exports, "ContractWatcher", { enumerable: true, get: function () { return contracts_1.ContractWatcher; } });
177
- Object.defineProperty(exports, "contractHandlers", { enumerable: true, get: function () { return contracts_1.contractHandlers; } });
178
- Object.defineProperty(exports, "DefaultContractHandler", { enumerable: true, get: function () { return contracts_1.DefaultContractHandler; } });
179
- Object.defineProperty(exports, "DelegateContractHandler", { enumerable: true, get: function () { return contracts_1.DelegateContractHandler; } });
180
- Object.defineProperty(exports, "VHTLCContractHandler", { enumerable: true, get: function () { return contracts_1.VHTLCContractHandler; } });
181
- Object.defineProperty(exports, "encodeArkContract", { enumerable: true, get: function () { return contracts_1.encodeArkContract; } });
182
- Object.defineProperty(exports, "decodeArkContract", { enumerable: true, get: function () { return contracts_1.decodeArkContract; } });
183
- Object.defineProperty(exports, "contractFromArkContract", { enumerable: true, get: function () { return contracts_1.contractFromArkContract; } });
184
- Object.defineProperty(exports, "contractFromArkContractWithAddress", { enumerable: true, get: function () { return contracts_1.contractFromArkContractWithAddress; } });
185
- Object.defineProperty(exports, "isArkContract", { enumerable: true, get: function () { return contracts_1.isArkContract; } });
186
- const timelock_1 = require("./utils/timelock");
187
- Object.defineProperty(exports, "timelockToSequence", { enumerable: true, get: function () { return timelock_1.timelockToSequence; } });
188
- Object.defineProperty(exports, "sequenceToTimelock", { enumerable: true, get: function () { return timelock_1.sequenceToTimelock; } });
189
- const manager_1 = require("./repositories/indexedDB/manager");
190
- Object.defineProperty(exports, "closeDatabase", { enumerable: true, get: function () { return manager_1.closeDatabase; } });
191
- Object.defineProperty(exports, "openDatabase", { enumerable: true, get: function () { return manager_1.openDatabase; } });
192
- const wallet_message_handler_1 = require("./wallet/serviceWorker/wallet-message-handler");
193
- Object.defineProperty(exports, "WalletMessageHandler", { enumerable: true, get: function () { return wallet_message_handler_1.WalletMessageHandler; } });
194
- Object.defineProperty(exports, "WalletNotInitializedError", { enumerable: true, get: function () { return wallet_message_handler_1.WalletNotInitializedError; } });
195
- Object.defineProperty(exports, "ReadonlyWalletError", { enumerable: true, get: function () { return wallet_message_handler_1.ReadonlyWalletError; } });
196
- Object.defineProperty(exports, "DelegatorNotConfiguredError", { enumerable: true, get: function () { return wallet_message_handler_1.DelegatorNotConfiguredError; } });
197
- const errors_2 = require("./worker/errors");
198
- Object.defineProperty(exports, "MESSAGE_BUS_NOT_INITIALIZED", { enumerable: true, get: function () { return errors_2.MESSAGE_BUS_NOT_INITIALIZED; } });
199
- Object.defineProperty(exports, "MessageBusNotInitializedError", { enumerable: true, get: function () { return errors_2.MessageBusNotInitializedError; } });
200
- Object.defineProperty(exports, "ServiceWorkerTimeoutError", { enumerable: true, get: function () { return errors_2.ServiceWorkerTimeoutError; } });
@@ -1,259 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.TAG_INTENT_PROOF = exports.OP_RETURN_EMPTY_PKSCRIPT = exports.Intent = void 0;
4
- exports.craftToSpendTx = craftToSpendTx;
5
- const btc_signer_1 = require("@scure/btc-signer");
6
- const secp256k1_js_1 = require("@noble/curves/secp256k1.js");
7
- const transaction_1 = require("../utils/transaction");
8
- const unknownFields_1 = require("../utils/unknownFields");
9
- const base_1 = require("@scure/base");
10
- const base_2 = require("../script/base");
11
- /**
12
- * Intent proof implementation for Bitcoin message signing.
13
- *
14
- * Intent proof defines a standard for signing Bitcoin messages as well as proving
15
- * ownership of outputs.
16
- *
17
- * This namespace provides utilities for creating and validating Intent proof.
18
- *
19
- * It is greatly inspired by BIP322.
20
- * @see https://github.com/bitcoin/bips/blob/master/bip-0322.mediawiki
21
- *
22
- * @example
23
- * ```typescript
24
- * // Create a Intent proof
25
- * const proof = Intent.create(
26
- * "Hello Bitcoin!",
27
- * [input],
28
- * [output]
29
- * );
30
- *
31
- * // Sign the proof
32
- * const signedProof = await identity.sign(proof);
33
- *
34
- */
35
- var Intent;
36
- (function (Intent) {
37
- /**
38
- * Creates a new Intent proof unsigned transaction.
39
- *
40
- * This function constructs a special transaction that can be signed to prove
41
- * ownership of onchain and virtual outputs. The proof includes the message to be
42
- * signed and the inputs/outputs that demonstrate ownership.
43
- *
44
- * @param message - The Intent message to be signed, either raw string of Message object
45
- * @param ins - Array of transaction inputs to prove ownership of
46
- * @param outputs - Optional array of transaction outputs
47
- * @returns An unsigned Intent proof transaction
48
- */
49
- function create(message, ins, outputs = []) {
50
- if (typeof message !== "string") {
51
- message = encodeMessage(message);
52
- }
53
- if (ins.length == 0)
54
- throw new Error("intent proof requires at least one input");
55
- const inputs = ins.map(prepareCoinAsIntentProofInput);
56
- if (!validateInputs(inputs))
57
- throw new Error("invalid inputs");
58
- if (!validateOutputs(outputs))
59
- throw new Error("invalid outputs");
60
- // Create the initial transaction to spend.
61
- const toSpend = craftToSpendTx(message, inputs[0].witnessUtxo.script);
62
- // Create the transaction to sign.
63
- return craftToSignTx(toSpend, inputs, outputs);
64
- }
65
- Intent.create = create;
66
- /**
67
- * Compute the fee paid by an intent proof transaction.
68
- *
69
- * @param proof - Intent proof transaction
70
- * @returns The fee in satoshis
71
- */
72
- function fee(proof) {
73
- let sumOfInputs = 0n;
74
- for (let i = 0; i < proof.inputsLength; i++) {
75
- const input = proof.getInput(i);
76
- if (input.witnessUtxo === undefined)
77
- throw new Error("intent proof input requires witness utxo");
78
- sumOfInputs += input.witnessUtxo.amount;
79
- }
80
- let sumOfOutputs = 0n;
81
- for (let i = 0; i < proof.outputsLength; i++) {
82
- const output = proof.getOutput(i);
83
- if (output.amount === undefined)
84
- throw new Error("intent proof output requires amount");
85
- sumOfOutputs += output.amount;
86
- }
87
- if (sumOfOutputs > sumOfInputs) {
88
- throw new Error(`intent proof output amount is greater than input amount: ${sumOfOutputs} > ${sumOfInputs}`);
89
- }
90
- return Number(sumOfInputs - sumOfOutputs);
91
- }
92
- Intent.fee = fee;
93
- /**
94
- * Serialize an intent message to the canonical JSON string used for signing.
95
- *
96
- * @param message - Intent message payload
97
- * @returns Canonical string form of the message
98
- */
99
- function encodeMessage(message) {
100
- switch (message.type) {
101
- case "register":
102
- return JSON.stringify({
103
- type: "register",
104
- onchain_output_indexes: message.onchain_output_indexes,
105
- valid_at: message.valid_at,
106
- expire_at: message.expire_at,
107
- cosigners_public_keys: message.cosigners_public_keys,
108
- });
109
- case "delete":
110
- return JSON.stringify({
111
- type: "delete",
112
- expire_at: message.expire_at,
113
- });
114
- case "get-pending-tx":
115
- return JSON.stringify({
116
- type: "get-pending-tx",
117
- expire_at: message.expire_at,
118
- });
119
- }
120
- }
121
- Intent.encodeMessage = encodeMessage;
122
- })(Intent || (exports.Intent = Intent = {}));
123
- exports.OP_RETURN_EMPTY_PKSCRIPT = new Uint8Array([btc_signer_1.OP.RETURN]);
124
- const ZERO_32 = new Uint8Array(32).fill(0);
125
- const MAX_INDEX = 0xffffffff;
126
- exports.TAG_INTENT_PROOF = "ark-intent-proof-message";
127
- function validateInput(input) {
128
- if (input.index === undefined)
129
- throw new Error("intent proof input requires index");
130
- if (input.txid === undefined)
131
- throw new Error("intent proof input requires txid");
132
- if (input.witnessUtxo === undefined)
133
- throw new Error("intent proof input requires witness utxo");
134
- return true;
135
- }
136
- function validateInputs(inputs) {
137
- inputs.forEach(validateInput);
138
- return true;
139
- }
140
- function validateOutput(output) {
141
- if (output.amount === undefined)
142
- throw new Error("intent proof output requires amount");
143
- if (output.script === undefined)
144
- throw new Error("intent proof output requires script");
145
- return true;
146
- }
147
- function validateOutputs(outputs) {
148
- outputs.forEach(validateOutput);
149
- return true;
150
- }
151
- /**
152
- * Creates the "to_spend" transaction used by both intent proofs and BIP-322.
153
- *
154
- * The message is hashed with the given tagged-hash tag before being placed
155
- * into the scriptSig as `OP_0 <hash>`.
156
- *
157
- * @param message - The message to embed
158
- * @param pkScript - The scriptPubKey of the signer's address
159
- * @param tag - Tagged-hash tag (defaults to the Arkade intent proof tag)
160
- */
161
- function craftToSpendTx(message, pkScript, tag = exports.TAG_INTENT_PROOF) {
162
- const messageHash = hashMessage(message, tag);
163
- const tx = new transaction_1.Transaction({
164
- version: 0,
165
- });
166
- // add input with zero hash and max index
167
- tx.addInput({
168
- txid: ZERO_32, // zero hash
169
- index: MAX_INDEX,
170
- sequence: 0,
171
- });
172
- // add output with zero value and provided pkScript
173
- tx.addOutput({
174
- amount: 0n,
175
- script: pkScript,
176
- });
177
- tx.updateInput(0, {
178
- finalScriptSig: btc_signer_1.Script.encode(["OP_0", messageHash]),
179
- });
180
- return tx;
181
- }
182
- // craftToSignTx creates the transaction that will be signed for the proof
183
- function craftToSignTx(toSpend, inputs, outputs) {
184
- const firstInput = inputs[0];
185
- // Proof tx is never broadcast onchain — toSpend references a zero-hash
186
- // outpoint (see BIP-322). The tx exists only as a sighash commitment
187
- // the server verifies signatures against; nLockTime and nSequence carry
188
- // no consensus meaning here, they only need to match between signer and
189
- // verifier. Use lockTime = 0 (BIP-322 convention) and leave each input's
190
- // nSequence untouched.
191
- const tx = new transaction_1.Transaction({
192
- version: 2,
193
- lockTime: 0,
194
- });
195
- // add the first "toSpend" input
196
- tx.addInput({
197
- ...firstInput,
198
- txid: toSpend.id,
199
- index: 0,
200
- witnessUtxo: {
201
- script: firstInput.witnessUtxo.script,
202
- amount: 0n,
203
- },
204
- sighashType: btc_signer_1.SigHash.ALL,
205
- });
206
- // add other inputs
207
- for (const [i, input] of inputs.entries()) {
208
- tx.addInput({
209
- ...input,
210
- sighashType: btc_signer_1.SigHash.ALL,
211
- });
212
- if (input.unknown?.length) {
213
- tx.updateInput(i + 1, {
214
- unknown: input.unknown,
215
- });
216
- }
217
- }
218
- // add the special OP_RETURN output if no outputs are provided
219
- if (outputs.length === 0) {
220
- outputs = [
221
- {
222
- amount: 0n,
223
- script: exports.OP_RETURN_EMPTY_PKSCRIPT,
224
- },
225
- ];
226
- }
227
- for (const output of outputs) {
228
- tx.addOutput({
229
- amount: output.amount,
230
- script: output.script,
231
- });
232
- }
233
- return tx;
234
- }
235
- function hashMessage(message, tag = exports.TAG_INTENT_PROOF) {
236
- return secp256k1_js_1.schnorr.utils.taggedHash(tag, new TextEncoder().encode(message));
237
- }
238
- function prepareCoinAsIntentProofInput(coin) {
239
- if (!("tapTree" in coin)) {
240
- return coin;
241
- }
242
- const vtxoScript = base_2.VtxoScript.decode(coin.tapTree);
243
- const sequence = (0, base_2.getSequence)(coin.intentTapLeafScript);
244
- const unknown = [unknownFields_1.VtxoTaprootTree.encode(coin.tapTree)];
245
- if (coin.extraWitness) {
246
- unknown.push(unknownFields_1.ConditionWitness.encode(coin.extraWitness));
247
- }
248
- return {
249
- txid: base_1.hex.decode(coin.txid),
250
- index: coin.vout,
251
- witnessUtxo: {
252
- amount: BigInt(coin.value),
253
- script: vtxoScript.pkScript,
254
- },
255
- sequence,
256
- tapLeafScript: [coin.intentTapLeafScript],
257
- unknown,
258
- };
259
- }