@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,5 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.LocalStorageAdapter = void 0;
4
- var localStorage_1 = require("../storage/localStorage");
5
- Object.defineProperty(exports, "LocalStorageAdapter", { enumerable: true, get: function () { return localStorage_1.LocalStorageAdapter; } });
@@ -1,43 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.IntentOnchainInputEnv = exports.IntentOffchainInputEnv = exports.IntentOutputEnv = exports.OutputScriptVariableName = exports.InputTypeVariableName = exports.WeightVariableName = exports.BirthVariableName = exports.ExpiryVariableName = exports.AmountVariableName = void 0;
4
- const cel_js_1 = require("@marcbachmann/cel-js");
5
- /**
6
- * Variable names used in CEL expressions
7
- */
8
- exports.AmountVariableName = "amount";
9
- exports.ExpiryVariableName = "expiry";
10
- exports.BirthVariableName = "birth";
11
- exports.WeightVariableName = "weight";
12
- exports.InputTypeVariableName = "inputType";
13
- exports.OutputScriptVariableName = "script";
14
- const nowFunction = {
15
- signature: "now(): double",
16
- implementation: () => Math.floor(Date.now() / 1000),
17
- };
18
- /**
19
- * IntentOutputEnv is the CEL environment for output fee calculation
20
- * Variables: amount, script
21
- */
22
- exports.IntentOutputEnv = new cel_js_1.Environment()
23
- .registerVariable(exports.AmountVariableName, "double")
24
- .registerVariable(exports.OutputScriptVariableName, "string")
25
- .registerFunction(nowFunction.signature, nowFunction.implementation);
26
- /**
27
- * IntentOffchainInputEnv is the CEL environment for offchain input fee calculation
28
- * Variables: amount, expiry, birth, weight, inputType
29
- */
30
- exports.IntentOffchainInputEnv = new cel_js_1.Environment()
31
- .registerVariable(exports.AmountVariableName, "double")
32
- .registerVariable(exports.ExpiryVariableName, "double")
33
- .registerVariable(exports.BirthVariableName, "double")
34
- .registerVariable(exports.WeightVariableName, "double")
35
- .registerVariable(exports.InputTypeVariableName, "string")
36
- .registerFunction(nowFunction.signature, nowFunction.implementation);
37
- /**
38
- * IntentOnchainInputEnv is the CEL environment for onchain input fee calculation
39
- * Variables: amount
40
- */
41
- exports.IntentOnchainInputEnv = new cel_js_1.Environment()
42
- .registerVariable(exports.AmountVariableName, "double")
43
- .registerFunction(nowFunction.signature, nowFunction.implementation);
@@ -1,143 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Estimator = void 0;
4
- const celenv_js_1 = require("./celenv.js");
5
- const types_js_1 = require("./types.js");
6
- /**
7
- * Estimator evaluates CEL expressions to calculate fees for Arkade intents
8
- */
9
- class Estimator {
10
- /**
11
- * Creates a new Estimator with the given config
12
- * @param config - Configuration containing CEL programs for fee calculation
13
- */
14
- constructor(config) {
15
- this.config = config;
16
- this.intentOffchainInput = config.offchainInput
17
- ? parseProgram(config.offchainInput, celenv_js_1.IntentOffchainInputEnv)
18
- : undefined;
19
- this.intentOnchainInput = config.onchainInput
20
- ? parseProgram(config.onchainInput, celenv_js_1.IntentOnchainInputEnv)
21
- : undefined;
22
- this.intentOffchainOutput = config.offchainOutput
23
- ? parseProgram(config.offchainOutput, celenv_js_1.IntentOutputEnv)
24
- : undefined;
25
- this.intentOnchainOutput = config.onchainOutput
26
- ? parseProgram(config.onchainOutput, celenv_js_1.IntentOutputEnv)
27
- : undefined;
28
- }
29
- /**
30
- * Evaluates the fee for a given vtxo input
31
- * @param input - The offchain input to evaluate
32
- * @returns The fee amount for this input
33
- */
34
- evalOffchainInput(input) {
35
- if (!this.intentOffchainInput) {
36
- return types_js_1.FeeAmount.ZERO;
37
- }
38
- const args = inputToArgs(input);
39
- return new types_js_1.FeeAmount(this.intentOffchainInput.program(args));
40
- }
41
- /**
42
- * Evaluates the fee for a given boarding input
43
- * @param input - The onchain input to evaluate
44
- * @returns The fee amount for this input
45
- */
46
- evalOnchainInput(input) {
47
- if (!this.intentOnchainInput) {
48
- return types_js_1.FeeAmount.ZERO;
49
- }
50
- const args = {
51
- amount: Number(input.amount),
52
- };
53
- return new types_js_1.FeeAmount(this.intentOnchainInput.program(args));
54
- }
55
- /**
56
- * Evaluates the fee for a given vtxo output
57
- * @param output - The output to evaluate
58
- * @returns The fee amount for this output
59
- */
60
- evalOffchainOutput(output) {
61
- if (!this.intentOffchainOutput) {
62
- return types_js_1.FeeAmount.ZERO;
63
- }
64
- const args = outputToArgs(output);
65
- return new types_js_1.FeeAmount(this.intentOffchainOutput.program(args));
66
- }
67
- /**
68
- * Evaluates the fee for a given collaborative exit output
69
- * @param output - The output to evaluate
70
- * @returns The fee amount for this output
71
- */
72
- evalOnchainOutput(output) {
73
- if (!this.intentOnchainOutput) {
74
- return types_js_1.FeeAmount.ZERO;
75
- }
76
- const args = outputToArgs(output);
77
- return new types_js_1.FeeAmount(this.intentOnchainOutput.program(args));
78
- }
79
- /**
80
- * Evaluates the fee for a given set of inputs and outputs
81
- * @param offchainInputs - Array of offchain inputs to evaluate
82
- * @param onchainInputs - Array of onchain inputs to evaluate
83
- * @param offchainOutputs - Array of offchain outputs to evaluate
84
- * @param onchainOutputs - Array of onchain outputs to evaluate
85
- * @returns The total fee amount
86
- */
87
- eval(offchainInputs, onchainInputs, offchainOutputs, onchainOutputs) {
88
- let fee = types_js_1.FeeAmount.ZERO;
89
- for (const input of offchainInputs) {
90
- fee = fee.add(this.evalOffchainInput(input));
91
- }
92
- for (const input of onchainInputs) {
93
- fee = fee.add(this.evalOnchainInput(input));
94
- }
95
- for (const output of offchainOutputs) {
96
- fee = fee.add(this.evalOffchainOutput(output));
97
- }
98
- for (const output of onchainOutputs) {
99
- fee = fee.add(this.evalOnchainOutput(output));
100
- }
101
- return fee;
102
- }
103
- }
104
- exports.Estimator = Estimator;
105
- function inputToArgs(input) {
106
- const args = {
107
- amount: Number(input.amount),
108
- inputType: input.type,
109
- weight: input.weight,
110
- };
111
- if (input.expiry) {
112
- args.expiry = Math.floor(input.expiry.getTime() / 1000);
113
- }
114
- if (input.birth) {
115
- args.birth = Math.floor(input.birth.getTime() / 1000);
116
- }
117
- return args;
118
- }
119
- function outputToArgs(output) {
120
- return {
121
- amount: Number(output.amount),
122
- script: output.script,
123
- };
124
- }
125
- /**
126
- * Parses a CEL program and validates its return type
127
- * @param text - The CEL program text to parse
128
- * @param env - The CEL environment to use
129
- * @returns parsed and validated program
130
- */
131
- function parseProgram(text, env) {
132
- const program = env.parse(text);
133
- // Type check the program
134
- const checkResult = program.check();
135
- if (!checkResult.valid) {
136
- throw new Error(`type check failed: ${checkResult.error?.message ?? "unknown error"}`);
137
- }
138
- // Verify return type is double
139
- if (checkResult.type !== "double") {
140
- throw new Error(`expected return type double, got ${checkResult.type}`);
141
- }
142
- return { program, text };
143
- }
@@ -1,5 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Estimator = void 0;
4
- var estimator_1 = require("./estimator");
5
- Object.defineProperty(exports, "Estimator", { enumerable: true, get: function () { return estimator_1.Estimator; } });
@@ -1,26 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.FeeAmount = void 0;
4
- /**
5
- * FeeAmount is a wrapper around a number that represents a fee amount in satoshis floating point.
6
- * @param value - The fee amount in floating point.
7
- * @example
8
- * const fee = new FeeAmount(1.23456789);
9
- * console.log(fee.value); // 1.23456789
10
- * console.log(fee.satoshis); // 2
11
- */
12
- class FeeAmount {
13
- constructor(value) {
14
- this.value = value;
15
- }
16
- /** Returns the fee amount rounded up to whole satoshis. */
17
- get satoshis() {
18
- return this.value ? Math.ceil(this.value) : 0;
19
- }
20
- /** Add two fee amounts together. */
21
- add(other) {
22
- return new FeeAmount(this.value + other.value);
23
- }
24
- }
25
- exports.FeeAmount = FeeAmount;
26
- FeeAmount.ZERO = new FeeAmount(0);
@@ -1,128 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ArkNote = void 0;
4
- const base_1 = require("@scure/base");
5
- const utils_js_1 = require("@scure/btc-signer/utils.js");
6
- const btc_signer_1 = require("@scure/btc-signer");
7
- const base_2 = require("../script/base");
8
- /**
9
- * ArkNotes are special virtual outputs in the Arkade protocol that
10
- * can be created and spent without requiring any transactions.
11
- * The server mints them, and they are encoded as base58 strings
12
- * with a human-readable prefix, a preimage and a value.
13
- *
14
- * @see VtxoScript
15
- *
16
- * @example
17
- * ```typescript
18
- * // Create an ArkNote
19
- * const note = new ArkNote(preimage, 50000);
20
- *
21
- * // Encode to string
22
- * const noteString = note.toString();
23
- *
24
- * // Decode from string
25
- * const decodedNote = ArkNote.fromString(noteString);
26
- * ```
27
- */
28
- class ArkNote {
29
- /**
30
- * Create an ArkNote from a preimage and value.
31
- *
32
- * @param preimage - 32-byte preimage revealed to spend the note
33
- * @param value - Note value in satoshis
34
- * @param HRP - Optional human-readable prefix for string encoding
35
- */
36
- constructor(preimage, value, HRP = ArkNote.DefaultHRP) {
37
- this.preimage = preimage;
38
- this.value = value;
39
- this.HRP = HRP;
40
- this.vout = 0;
41
- const preimageHash = (0, utils_js_1.sha256)(this.preimage);
42
- this.vtxoScript = new base_2.VtxoScript([noteTapscript(preimageHash)]);
43
- const leaf = this.vtxoScript.leaves[0];
44
- this.txid = base_1.hex.encode(new Uint8Array(preimageHash).reverse());
45
- this.tapTree = this.vtxoScript.encode();
46
- this.forfeitTapLeafScript = leaf;
47
- this.intentTapLeafScript = leaf;
48
- this.value = value;
49
- this.status = { confirmed: true };
50
- this.extraWitness = [this.preimage];
51
- }
52
- /**
53
- * Encode the note as raw bytes.
54
- *
55
- * @returns Serialized note bytes
56
- * @see decode
57
- */
58
- encode() {
59
- const result = new Uint8Array(ArkNote.Length);
60
- result.set(this.preimage, 0);
61
- writeUInt32BE(result, this.value, this.preimage.length);
62
- return result;
63
- }
64
- /**
65
- * Decode a note from raw bytes.
66
- *
67
- * @param data - Serialized note bytes
68
- * @param hrp - Human-readable prefix expected for future string encoding
69
- * @returns Decoded ArkNote
70
- * @throws Error if the payload length is invalid
71
- * @see encode
72
- */
73
- static decode(data, hrp = ArkNote.DefaultHRP) {
74
- if (data.length !== ArkNote.Length) {
75
- throw new Error(`invalid data length: expected ${ArkNote.Length} bytes, got ${data.length}`);
76
- }
77
- const preimage = data.subarray(0, ArkNote.PreimageLength);
78
- const value = readUInt32BE(data, ArkNote.PreimageLength);
79
- return new ArkNote(preimage, value, hrp);
80
- }
81
- /**
82
- * Decode a note from its base58 string form.
83
- *
84
- * @param noteStr - Base58-encoded note string
85
- * @param hrp - Human-readable prefix expected on the note string
86
- * @returns Decoded ArkNote
87
- * @throws Error if the prefix or base58 payload is invalid
88
- * @see toString
89
- */
90
- static fromString(noteStr, hrp = ArkNote.DefaultHRP) {
91
- noteStr = noteStr.trim();
92
- if (!noteStr.startsWith(hrp)) {
93
- throw new Error(`invalid human-readable part: expected ${hrp} prefix (note '${noteStr}')`);
94
- }
95
- const encoded = noteStr.slice(hrp.length);
96
- const decoded = base_1.base58.decode(encoded);
97
- if (decoded.length === 0) {
98
- throw new Error("failed to decode base58 string");
99
- }
100
- return ArkNote.decode(decoded, hrp);
101
- }
102
- /**
103
- * Encode the note to its human-readable base58 string form.
104
- *
105
- * @returns Base58-encoded note string
106
- * @see fromString
107
- */
108
- toString() {
109
- return this.HRP + base_1.base58.encode(this.encode());
110
- }
111
- }
112
- exports.ArkNote = ArkNote;
113
- ArkNote.DefaultHRP = "arknote";
114
- ArkNote.PreimageLength = 32; // 32 bytes for the preimage
115
- ArkNote.ValueLength = 4; // 4 bytes for the value
116
- ArkNote.Length = ArkNote.PreimageLength + ArkNote.ValueLength;
117
- ArkNote.FakeOutpointIndex = 0;
118
- function writeUInt32BE(array, value, offset) {
119
- const view = new DataView(array.buffer, array.byteOffset + offset, 4);
120
- view.setUint32(0, value, false);
121
- }
122
- function readUInt32BE(array, offset) {
123
- const view = new DataView(array.buffer, array.byteOffset + offset, 4);
124
- return view.getUint32(0, false);
125
- }
126
- function noteTapscript(preimageHash) {
127
- return btc_signer_1.Script.encode(["SHA256", preimageHash, "EQUAL"]);
128
- }
@@ -1,270 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BIP322 = void 0;
4
- const btc_signer_1 = require("@scure/btc-signer");
5
- const utils_js_1 = require("@scure/btc-signer/utils.js");
6
- const secp256k1_js_1 = require("@noble/curves/secp256k1.js");
7
- const utils_js_2 = require("@noble/curves/utils.js");
8
- const base_1 = require("@scure/base");
9
- const transaction_1 = require("../utils/transaction");
10
- const intent_1 = require("../intent");
11
- const TAG_BIP322 = "BIP0322-signed-message";
12
- /**
13
- * BIP-322 simple message signing and verification.
14
- *
15
- * Supports P2TR (Taproot) signing and verification, P2WPKH verification,
16
- * and legacy P2PKH verification (Bitcoin Core signmessage format).
17
- *
18
- * Reuses the same toSpend/toSign transaction construction as Intent proofs,
19
- * but with the standard BIP-322 tagged hash ("BIP0322-signed-message")
20
- * instead of the Arkade-specific tag.
21
- *
22
- * @see https://github.com/bitcoin/bips/blob/master/bip-0322.mediawiki
23
- *
24
- * @example
25
- * ```typescript
26
- * // Sign a message (P2TR)
27
- * const signature = await BIP322.sign("Hello Bitcoin!", identity);
28
- *
29
- * // Verify a signature (P2TR or P2WPKH)
30
- * const valid = BIP322.verify("Hello Bitcoin!", signature, "bc1p...");
31
- * const valid2 = BIP322.verify("Hello Bitcoin!", signature, "bc1q...");
32
- * ```
33
- */
34
- var BIP322;
35
- (function (BIP322) {
36
- /**
37
- * Sign a message using the BIP-322 simple signature scheme.
38
- *
39
- * Constructs the standard BIP-322 toSpend and toSign transactions,
40
- * signs via the Identity interface, and returns the base64-encoded
41
- * witness stack.
42
- *
43
- * @param message - The message to sign
44
- * @param identity - Identity instance (holds the private key internally)
45
- * @param network - Optional Bitcoin network for P2TR address derivation
46
- * @returns Base64-encoded BIP-322 simple signature (witness stack)
47
- */
48
- async function sign(message, identity, network) {
49
- const xOnlyPubKey = await identity.xOnlyPublicKey();
50
- const payment = (0, btc_signer_1.p2tr)(xOnlyPubKey, undefined, network);
51
- // Build BIP-322 toSpend using shared construction with BIP-322 tag
52
- const toSpend = (0, intent_1.craftToSpendTx)(message, payment.script, TAG_BIP322);
53
- // Build BIP-322 toSign: version 0, single input spending toSpend, OP_RETURN output
54
- const toSign = craftBIP322ToSignP2TR(toSpend, payment.script, xOnlyPubKey);
55
- // Sign with identity (handles P2TR key-spend internally)
56
- const signed = await identity.sign(toSign, [0]);
57
- // Finalize and extract witness
58
- signed.finalizeIdx(0);
59
- const input = signed.getInput(0);
60
- if (!input.finalScriptWitness) {
61
- throw new Error("BIP-322: failed to produce witness after signing");
62
- }
63
- return base_1.base64.encode(btc_signer_1.RawWitness.encode(input.finalScriptWitness));
64
- }
65
- BIP322.sign = sign;
66
- /**
67
- * Verify a BIP-322 signature for a P2TR, P2WPKH, or legacy P2PKH address.
68
- *
69
- * For segwit addresses (P2TR, P2WPKH), reconstructs the BIP-322
70
- * toSpend/toSign transactions and verifies the witness signature.
71
- *
72
- * For P2PKH addresses, verifies using the Bitcoin Core legacy
73
- * `signmessage` format (compact recoverable ECDSA signature).
74
- *
75
- * @param message - The original message that was signed
76
- * @param signature - Base64-encoded signature (BIP-322 witness or legacy compact)
77
- * @param address - P2TR, P2WPKH, or P2PKH address of the signer
78
- * @param network - Optional Bitcoin network for address decoding
79
- * @returns true if the signature is valid
80
- */
81
- function verify(message, signature, address, network) {
82
- let decoded;
83
- try {
84
- decoded = (0, btc_signer_1.Address)(network).decode(address);
85
- }
86
- catch {
87
- return false;
88
- }
89
- // Legacy P2PKH: signature is base64 of 65 raw bytes, not a witness
90
- if (decoded.type === "pkh") {
91
- try {
92
- return verifyLegacy(message, base_1.base64.decode(signature), decoded.hash);
93
- }
94
- catch {
95
- return false;
96
- }
97
- }
98
- // BIP-322 simple: signature is base64 of RawWitness
99
- let pkScript;
100
- let witnessItems;
101
- try {
102
- pkScript = btc_signer_1.OutScript.encode(decoded);
103
- witnessItems = btc_signer_1.RawWitness.decode(base_1.base64.decode(signature));
104
- }
105
- catch {
106
- return false;
107
- }
108
- if (witnessItems.length === 0) {
109
- return false;
110
- }
111
- if (decoded.type === "tr") {
112
- return verifyP2TR(message, witnessItems, pkScript, decoded.pubkey);
113
- }
114
- if (decoded.type === "wpkh") {
115
- return verifyP2WPKH(message, witnessItems, pkScript, decoded.hash);
116
- }
117
- throw new Error(`BIP-322 verify: unsupported address type '${decoded.type}'`);
118
- }
119
- BIP322.verify = verify;
120
- })(BIP322 || (exports.BIP322 = BIP322 = {}));
121
- function verifyP2TR(message, witnessItems, pkScript, pubkey) {
122
- // P2TR key-spend witness is exactly [schnorr_signature].
123
- // Multiple items indicates a script-path spend, which BIP-322 simple doesn't cover.
124
- if (witnessItems.length !== 1) {
125
- return false;
126
- }
127
- const sig = witnessItems[0];
128
- if (sig.length !== 64 && sig.length !== 65) {
129
- return false;
130
- }
131
- // BIP-322 simple only allows SIGHASH_DEFAULT (64-byte sig) or SIGHASH_ALL (0x01).
132
- const sighashType = sig.length === 65 ? sig[64] : btc_signer_1.SigHash.DEFAULT;
133
- if (sighashType !== btc_signer_1.SigHash.DEFAULT && sighashType !== btc_signer_1.SigHash.ALL) {
134
- return false;
135
- }
136
- const toSpend = (0, intent_1.craftToSpendTx)(message, pkScript, TAG_BIP322);
137
- const toSign = craftBIP322ToSignP2TR(toSpend, pkScript, pubkey);
138
- const sighash = toSign.preimageWitnessV1(0, [pkScript], sighashType, [0n]);
139
- const rawSig = sig.length === 65 ? sig.subarray(0, 64) : sig;
140
- return secp256k1_js_1.schnorr.verify(rawSig, sighash, pubkey);
141
- }
142
- function verifyP2WPKH(message, witnessItems, pkScript, addressHash) {
143
- // P2WPKH witness: [der_signature || sighash_byte, compressed_pubkey]
144
- if (witnessItems.length !== 2) {
145
- return false;
146
- }
147
- const sigWithHash = witnessItems[0];
148
- const pubkey = witnessItems[1];
149
- if (pubkey.length !== 33 || sigWithHash.length < 2) {
150
- return false;
151
- }
152
- // Verify the pubkey matches the address hash
153
- const derived = (0, btc_signer_1.p2wpkh)(pubkey);
154
- if (!(0, utils_js_2.equalBytes)(derived.hash, addressHash)) {
155
- return false;
156
- }
157
- // Extract sighash type (last byte) and DER signature
158
- const sighashType = sigWithHash[sigWithHash.length - 1];
159
- const derSig = sigWithHash.subarray(0, sigWithHash.length - 1);
160
- // Build toSpend and toSign
161
- const toSpend = (0, intent_1.craftToSpendTx)(message, pkScript, TAG_BIP322);
162
- const toSign = craftBIP322ToSignSimple(toSpend, pkScript);
163
- // BIP-143 scriptCode for P2WPKH: equivalent P2PKH script
164
- const scriptCode = btc_signer_1.OutScript.encode({ type: "pkh", hash: addressHash });
165
- const sighash = toSign.preimageWitnessV0(0, scriptCode, sighashType, 0n);
166
- return secp256k1_js_1.secp256k1.verify(derSig, sighash, pubkey, {
167
- prehash: false,
168
- format: "der",
169
- });
170
- }
171
- /**
172
- * Verify a legacy Bitcoin Core signmessage signature for a P2PKH address.
173
- *
174
- * The signature is 65 bytes: [recovery_flag, r(32), s(32)].
175
- * The recovery flag encodes both the recovery ID and whether the key is
176
- * compressed: flag = 27 + recovery_id (+ 4 if compressed).
177
- */
178
- function verifyLegacy(message, sigBytes, addressHash) {
179
- if (sigBytes.length !== 65) {
180
- return false;
181
- }
182
- const flag = sigBytes[0];
183
- if (flag < 27 || flag > 34) {
184
- return false;
185
- }
186
- const compressed = flag >= 31;
187
- const recoveryId = compressed ? flag - 31 : flag - 27;
188
- const compactSig = sigBytes.subarray(1, 65);
189
- const msgHash = bitcoinMessageHash(message);
190
- try {
191
- const sig = secp256k1_js_1.secp256k1.Signature.fromBytes(compactSig, "compact").addRecoveryBit(recoveryId);
192
- const point = sig.recoverPublicKey(msgHash);
193
- const pubkeyBytes = point.toBytes(compressed);
194
- return (0, utils_js_2.equalBytes)((0, utils_js_1.hash160)(pubkeyBytes), addressHash);
195
- }
196
- catch {
197
- return false;
198
- }
199
- }
200
- /**
201
- * Compute the Bitcoin message hash: SHA256d(magic_prefix + CompactSize(len) + message).
202
- */
203
- function bitcoinMessageHash(message) {
204
- const MAGIC = new TextEncoder().encode("\x18Bitcoin Signed Message:\n");
205
- const msgBytes = new TextEncoder().encode(message);
206
- return (0, utils_js_1.sha256x2)((0, utils_js_1.concatBytes)(MAGIC, encodeCompactSize(msgBytes.length), msgBytes));
207
- }
208
- function encodeCompactSize(n) {
209
- if (n < 253)
210
- return new Uint8Array([n]);
211
- if (n <= 0xffff) {
212
- const buf = new Uint8Array(3);
213
- buf[0] = 253;
214
- buf[1] = n & 0xff;
215
- buf[2] = (n >> 8) & 0xff;
216
- return buf;
217
- }
218
- const buf = new Uint8Array(5);
219
- buf[0] = 254;
220
- buf[1] = n & 0xff;
221
- buf[2] = (n >> 8) & 0xff;
222
- buf[3] = (n >> 16) & 0xff;
223
- buf[4] = (n >> 24) & 0xff;
224
- return buf;
225
- }
226
- /**
227
- * Build the BIP-322 "toSign" transaction for P2TR key-spend.
228
- */
229
- function craftBIP322ToSignP2TR(toSpend, pkScript, tapInternalKey) {
230
- const tx = new transaction_1.Transaction({ version: 0 });
231
- tx.addInput({
232
- txid: toSpend.id,
233
- index: 0,
234
- sequence: 0,
235
- witnessUtxo: {
236
- script: pkScript,
237
- amount: 0n,
238
- },
239
- tapInternalKey,
240
- sighashType: btc_signer_1.SigHash.DEFAULT,
241
- });
242
- tx.addOutput({
243
- amount: 0n,
244
- script: intent_1.OP_RETURN_EMPTY_PKSCRIPT,
245
- });
246
- return tx;
247
- }
248
- /**
249
- * Build the BIP-322 "toSign" transaction (generic, no key metadata).
250
- *
251
- * Used for P2WPKH verification where the toSign only needs
252
- * the witnessUtxo, not tapInternalKey.
253
- */
254
- function craftBIP322ToSignSimple(toSpend, pkScript) {
255
- const tx = new transaction_1.Transaction({ version: 0 });
256
- tx.addInput({
257
- txid: toSpend.id,
258
- index: 0,
259
- sequence: 0,
260
- witnessUtxo: {
261
- script: pkScript,
262
- amount: 0n,
263
- },
264
- });
265
- tx.addOutput({
266
- amount: 0n,
267
- script: intent_1.OP_RETURN_EMPTY_PKSCRIPT,
268
- });
269
- return tx;
270
- }