@arkade-os/sdk 0.4.27 → 0.4.28

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (531) hide show
  1. package/README.md +31 -100
  2. package/dist/adapters/asyncStorage.cjs +48 -0
  3. package/dist/adapters/asyncStorage.cjs.map +1 -0
  4. package/dist/adapters/asyncStorage.d.cts +16 -0
  5. package/dist/{types/storage → adapters}/asyncStorage.d.ts +5 -2
  6. package/dist/adapters/asyncStorage.js +46 -0
  7. package/dist/adapters/asyncStorage.js.map +1 -0
  8. package/dist/adapters/expo.cjs +19 -0
  9. package/dist/adapters/expo.cjs.map +1 -0
  10. package/dist/adapters/expo.d.cts +48 -0
  11. package/dist/adapters/expo.d.ts +48 -0
  12. package/dist/adapters/expo.js +6 -0
  13. package/dist/adapters/expo.js.map +1 -0
  14. package/dist/adapters/fileSystem.cjs +116 -0
  15. package/dist/adapters/fileSystem.cjs.map +1 -0
  16. package/dist/adapters/fileSystem.d.cts +17 -0
  17. package/dist/{types/storage → adapters}/fileSystem.d.ts +5 -2
  18. package/dist/adapters/fileSystem.js +93 -0
  19. package/dist/adapters/fileSystem.js.map +1 -0
  20. package/dist/adapters/indexedDB.cjs +103 -0
  21. package/dist/adapters/indexedDB.cjs.map +1 -0
  22. package/dist/adapters/indexedDB.d.cts +18 -0
  23. package/dist/{types/storage → adapters}/indexedDB.d.ts +5 -2
  24. package/dist/adapters/indexedDB.js +101 -0
  25. package/dist/adapters/indexedDB.js.map +1 -0
  26. package/dist/adapters/localStorage.cjs +50 -0
  27. package/dist/adapters/localStorage.cjs.map +1 -0
  28. package/dist/{types/storage/inMemory.d.ts → adapters/localStorage.d.cts} +6 -3
  29. package/dist/{types/storage → adapters}/localStorage.d.ts +5 -2
  30. package/dist/adapters/localStorage.js +48 -0
  31. package/dist/adapters/localStorage.js.map +1 -0
  32. package/dist/ark-TZ1gXAXU.d.cts +3880 -0
  33. package/dist/ark-TZ1gXAXU.d.ts +3880 -0
  34. package/dist/{types/worker/expo/asyncStorageTaskQueue.d.ts → asyncStorageTaskQueue-Cb1F_Z9s.d.ts} +6 -3
  35. package/dist/asyncStorageTaskQueue-EFqSmYTg.d.cts +49 -0
  36. package/dist/chunk-5BLDMQED.cjs +18 -0
  37. package/dist/chunk-5BLDMQED.cjs.map +1 -0
  38. package/dist/chunk-5PG7DV7A.cjs +805 -0
  39. package/dist/chunk-5PG7DV7A.cjs.map +1 -0
  40. package/dist/chunk-A3EMF7RN.js +95 -0
  41. package/dist/chunk-A3EMF7RN.js.map +1 -0
  42. package/dist/chunk-ADV27S4N.cjs +2701 -0
  43. package/dist/chunk-ADV27S4N.cjs.map +1 -0
  44. package/dist/chunk-BQLHADL7.js +13805 -0
  45. package/dist/chunk-BQLHADL7.js.map +1 -0
  46. package/dist/chunk-CFZMTDWI.js +209 -0
  47. package/dist/chunk-CFZMTDWI.js.map +1 -0
  48. package/dist/chunk-FG5ACJJW.cjs +212 -0
  49. package/dist/chunk-FG5ACJJW.cjs.map +1 -0
  50. package/dist/chunk-HW3JJ323.js +768 -0
  51. package/dist/chunk-HW3JJ323.js.map +1 -0
  52. package/dist/chunk-I3DGUUCT.cjs +838 -0
  53. package/dist/chunk-I3DGUUCT.cjs.map +1 -0
  54. package/dist/chunk-IPX2R7FR.cjs +100 -0
  55. package/dist/chunk-IPX2R7FR.cjs.map +1 -0
  56. package/dist/chunk-NSBPE2FW.js +15 -0
  57. package/dist/chunk-NSBPE2FW.js.map +1 -0
  58. package/dist/chunk-T64LAI7L.js +829 -0
  59. package/dist/chunk-T64LAI7L.js.map +1 -0
  60. package/dist/chunk-ZBUDLTBO.js +2671 -0
  61. package/dist/chunk-ZBUDLTBO.js.map +1 -0
  62. package/dist/chunk-ZLO6NETT.cjs +13910 -0
  63. package/dist/chunk-ZLO6NETT.cjs.map +1 -0
  64. package/dist/contracts/handlers/index.cjs +26 -0
  65. package/dist/contracts/handlers/index.cjs.map +1 -0
  66. package/dist/contracts/handlers/index.d.cts +7 -0
  67. package/dist/contracts/handlers/index.d.ts +7 -0
  68. package/dist/contracts/handlers/index.js +5 -0
  69. package/dist/contracts/handlers/index.js.map +1 -0
  70. package/dist/delegate-BFZs69hp.d.cts +84 -0
  71. package/dist/delegate-aaVGfWsV.d.ts +84 -0
  72. package/dist/index-B22cA64m.d.cts +199 -0
  73. package/dist/{types/storage/index.d.ts → index-C0IanN1m.d.cts} +3 -1
  74. package/dist/index-C0IanN1m.d.ts +11 -0
  75. package/dist/index-NDla_UoJ.d.ts +199 -0
  76. package/dist/index.cjs +480 -0
  77. package/dist/index.cjs.map +1 -0
  78. package/dist/index.d.cts +3343 -0
  79. package/dist/index.d.ts +3343 -0
  80. package/dist/index.js +7 -0
  81. package/dist/index.js.map +1 -0
  82. package/dist/repositories/realm/index.cjs +513 -0
  83. package/dist/repositories/realm/index.cjs.map +1 -0
  84. package/dist/repositories/realm/index.d.cts +217 -0
  85. package/dist/{types/repositories/realm/schemas.d.ts → repositories/realm/index.d.ts} +80 -112
  86. package/dist/repositories/realm/index.js +507 -0
  87. package/dist/repositories/realm/index.js.map +1 -0
  88. package/dist/repositories/sqlite/index.cjs +588 -0
  89. package/dist/repositories/sqlite/index.cjs.map +1 -0
  90. package/dist/repositories/sqlite/index.d.cts +118 -0
  91. package/dist/{types/repositories/sqlite/walletRepository.d.ts → repositories/sqlite/index.d.ts} +58 -5
  92. package/dist/repositories/sqlite/index.js +585 -0
  93. package/dist/repositories/sqlite/index.js.map +1 -0
  94. package/dist/taskRunner-C6Ff4OaU.d.cts +114 -0
  95. package/dist/taskRunner-yvPN8Z0K.d.ts +114 -0
  96. package/dist/wallet/expo/background.cjs +93 -0
  97. package/dist/wallet/expo/background.cjs.map +1 -0
  98. package/dist/wallet/expo/background.d.cts +84 -0
  99. package/dist/wallet/expo/background.d.ts +84 -0
  100. package/dist/wallet/expo/background.js +68 -0
  101. package/dist/wallet/expo/background.js.map +1 -0
  102. package/dist/wallet/expo/index.cjs +171 -0
  103. package/dist/wallet/expo/index.cjs.map +1 -0
  104. package/dist/wallet/expo/index.d.cts +122 -0
  105. package/dist/{types/wallet/expo/wallet.d.ts → wallet/expo/index.d.ts} +45 -22
  106. package/dist/wallet/expo/index.js +169 -0
  107. package/dist/wallet/expo/index.js.map +1 -0
  108. package/dist/wallet-AF-p-OWj.d.cts +774 -0
  109. package/dist/wallet-D9NBRqvC.d.ts +774 -0
  110. package/dist/worker/expo/index.cjs +140 -0
  111. package/dist/worker/expo/index.cjs.map +1 -0
  112. package/dist/worker/expo/index.d.cts +29 -0
  113. package/dist/worker/expo/index.d.ts +29 -0
  114. package/dist/worker/expo/index.js +121 -0
  115. package/dist/worker/expo/index.js.map +1 -0
  116. package/package.json +110 -76
  117. package/dist/cjs/adapters/asyncStorage.js +0 -5
  118. package/dist/cjs/adapters/expo.js +0 -8
  119. package/dist/cjs/adapters/fileSystem.js +0 -5
  120. package/dist/cjs/adapters/indexedDB.js +0 -5
  121. package/dist/cjs/adapters/localStorage.js +0 -5
  122. package/dist/cjs/arkfee/celenv.js +0 -43
  123. package/dist/cjs/arkfee/estimator.js +0 -143
  124. package/dist/cjs/arkfee/index.js +0 -5
  125. package/dist/cjs/arkfee/types.js +0 -26
  126. package/dist/cjs/arknote/index.js +0 -128
  127. package/dist/cjs/bip322/index.js +0 -270
  128. package/dist/cjs/contracts/arkcontract.js +0 -147
  129. package/dist/cjs/contracts/contractManager.js +0 -649
  130. package/dist/cjs/contracts/contractWatcher.js +0 -598
  131. package/dist/cjs/contracts/handlers/default.js +0 -93
  132. package/dist/cjs/contracts/handlers/delegate.js +0 -90
  133. package/dist/cjs/contracts/handlers/helpers.js +0 -115
  134. package/dist/cjs/contracts/handlers/index.js +0 -19
  135. package/dist/cjs/contracts/handlers/registry.js +0 -89
  136. package/dist/cjs/contracts/handlers/vhtlc.js +0 -194
  137. package/dist/cjs/contracts/index.js +0 -41
  138. package/dist/cjs/contracts/types.js +0 -2
  139. package/dist/cjs/contracts/vtxoOwnership.js +0 -78
  140. package/dist/cjs/extension/asset/assetGroup.js +0 -228
  141. package/dist/cjs/extension/asset/assetId.js +0 -152
  142. package/dist/cjs/extension/asset/assetInput.js +0 -222
  143. package/dist/cjs/extension/asset/assetOutput.js +0 -174
  144. package/dist/cjs/extension/asset/assetRef.js +0 -148
  145. package/dist/cjs/extension/asset/index.js +0 -23
  146. package/dist/cjs/extension/asset/metadata.js +0 -187
  147. package/dist/cjs/extension/asset/packet.js +0 -114
  148. package/dist/cjs/extension/asset/types.js +0 -22
  149. package/dist/cjs/extension/asset/utils.js +0 -105
  150. package/dist/cjs/extension/index.js +0 -254
  151. package/dist/cjs/extension/packet.js +0 -20
  152. package/dist/cjs/forfeit.js +0 -45
  153. package/dist/cjs/identity/descriptor.js +0 -169
  154. package/dist/cjs/identity/descriptorProvider.js +0 -2
  155. package/dist/cjs/identity/hdCapableIdentity.js +0 -20
  156. package/dist/cjs/identity/index.js +0 -40
  157. package/dist/cjs/identity/seedIdentity.js +0 -477
  158. package/dist/cjs/identity/serialize.js +0 -171
  159. package/dist/cjs/identity/singleKey.js +0 -126
  160. package/dist/cjs/identity/staticDescriptorProvider.js +0 -65
  161. package/dist/cjs/index.js +0 -202
  162. package/dist/cjs/intent/index.js +0 -259
  163. package/dist/cjs/musig2/index.js +0 -11
  164. package/dist/cjs/musig2/keys.js +0 -57
  165. package/dist/cjs/musig2/nonces.js +0 -48
  166. package/dist/cjs/musig2/sign.js +0 -102
  167. package/dist/cjs/networks.js +0 -26
  168. package/dist/cjs/package.json +0 -3
  169. package/dist/cjs/providers/ark.js +0 -577
  170. package/dist/cjs/providers/delegator.js +0 -85
  171. package/dist/cjs/providers/electrum.js +0 -869
  172. package/dist/cjs/providers/errors.js +0 -59
  173. package/dist/cjs/providers/expoArk.js +0 -82
  174. package/dist/cjs/providers/expoIndexer.js +0 -111
  175. package/dist/cjs/providers/expoUtils.js +0 -124
  176. package/dist/cjs/providers/indexer.js +0 -630
  177. package/dist/cjs/providers/onchain.js +0 -262
  178. package/dist/cjs/providers/utils.js +0 -121
  179. package/dist/cjs/repositories/contractRepository.js +0 -2
  180. package/dist/cjs/repositories/inMemory/contractRepository.js +0 -55
  181. package/dist/cjs/repositories/inMemory/walletRepository.js +0 -115
  182. package/dist/cjs/repositories/index.js +0 -34
  183. package/dist/cjs/repositories/indexedDB/contractRepository.js +0 -187
  184. package/dist/cjs/repositories/indexedDB/db.js +0 -19
  185. package/dist/cjs/repositories/indexedDB/manager.js +0 -100
  186. package/dist/cjs/repositories/indexedDB/schema.js +0 -204
  187. package/dist/cjs/repositories/indexedDB/walletRepository.js +0 -474
  188. package/dist/cjs/repositories/indexedDB/websqlAdapter.js +0 -144
  189. package/dist/cjs/repositories/migrations/contractRepositoryImpl.js +0 -127
  190. package/dist/cjs/repositories/migrations/fromStorageAdapter.js +0 -66
  191. package/dist/cjs/repositories/migrations/walletRepositoryImpl.js +0 -184
  192. package/dist/cjs/repositories/realm/contractRepository.js +0 -116
  193. package/dist/cjs/repositories/realm/index.js +0 -11
  194. package/dist/cjs/repositories/realm/schemas.js +0 -157
  195. package/dist/cjs/repositories/realm/types.js +0 -7
  196. package/dist/cjs/repositories/realm/walletRepository.js +0 -305
  197. package/dist/cjs/repositories/scriptFromAddress.js +0 -16
  198. package/dist/cjs/repositories/serialization.js +0 -82
  199. package/dist/cjs/repositories/sqlite/contractRepository.js +0 -135
  200. package/dist/cjs/repositories/sqlite/index.js +0 -7
  201. package/dist/cjs/repositories/sqlite/types.js +0 -2
  202. package/dist/cjs/repositories/sqlite/walletRepository.js +0 -441
  203. package/dist/cjs/repositories/walletRepository.js +0 -2
  204. package/dist/cjs/script/address.js +0 -108
  205. package/dist/cjs/script/base.js +0 -185
  206. package/dist/cjs/script/default.js +0 -57
  207. package/dist/cjs/script/delegate.js +0 -53
  208. package/dist/cjs/script/tapscript.js +0 -619
  209. package/dist/cjs/script/vhtlc.js +0 -170
  210. package/dist/cjs/storage/asyncStorage.js +0 -50
  211. package/dist/cjs/storage/fileSystem.js +0 -141
  212. package/dist/cjs/storage/inMemory.js +0 -24
  213. package/dist/cjs/storage/index.js +0 -2
  214. package/dist/cjs/storage/indexedDB.js +0 -101
  215. package/dist/cjs/storage/localStorage.js +0 -51
  216. package/dist/cjs/tree/signingSession.js +0 -229
  217. package/dist/cjs/tree/txTree.js +0 -192
  218. package/dist/cjs/tree/validation.js +0 -107
  219. package/dist/cjs/utils/anchor.js +0 -35
  220. package/dist/cjs/utils/arkTransaction.js +0 -271
  221. package/dist/cjs/utils/bip21.js +0 -127
  222. package/dist/cjs/utils/syncCursors.js +0 -128
  223. package/dist/cjs/utils/timelock.js +0 -59
  224. package/dist/cjs/utils/transaction.js +0 -28
  225. package/dist/cjs/utils/transactionHistory.js +0 -183
  226. package/dist/cjs/utils/txSizeEstimator.js +0 -132
  227. package/dist/cjs/utils/unknownFields.js +0 -174
  228. package/dist/cjs/wallet/asset-manager.js +0 -330
  229. package/dist/cjs/wallet/asset.js +0 -119
  230. package/dist/cjs/wallet/batch.js +0 -183
  231. package/dist/cjs/wallet/delegator.js +0 -308
  232. package/dist/cjs/wallet/expo/background.js +0 -116
  233. package/dist/cjs/wallet/expo/index.js +0 -9
  234. package/dist/cjs/wallet/expo/wallet.js +0 -230
  235. package/dist/cjs/wallet/hdDescriptorProvider.js +0 -188
  236. package/dist/cjs/wallet/index.js +0 -82
  237. package/dist/cjs/wallet/inputSignerRouter.js +0 -98
  238. package/dist/cjs/wallet/onchain.js +0 -290
  239. package/dist/cjs/wallet/ramps.js +0 -216
  240. package/dist/cjs/wallet/serviceWorker/wallet-message-handler.js +0 -953
  241. package/dist/cjs/wallet/serviceWorker/wallet.js +0 -1174
  242. package/dist/cjs/wallet/signingErrors.js +0 -32
  243. package/dist/cjs/wallet/unroll.js +0 -293
  244. package/dist/cjs/wallet/utils.js +0 -111
  245. package/dist/cjs/wallet/validation.js +0 -154
  246. package/dist/cjs/wallet/vtxo-manager.js +0 -1142
  247. package/dist/cjs/wallet/wallet.js +0 -2195
  248. package/dist/cjs/wallet/walletReceiveRotator.js +0 -547
  249. package/dist/cjs/worker/browser/service-worker-manager.js +0 -183
  250. package/dist/cjs/worker/browser/utils.js +0 -67
  251. package/dist/cjs/worker/errors.js +0 -16
  252. package/dist/cjs/worker/expo/asyncStorageTaskQueue.js +0 -78
  253. package/dist/cjs/worker/expo/index.js +0 -13
  254. package/dist/cjs/worker/expo/processors/contractPollProcessor.js +0 -62
  255. package/dist/cjs/worker/expo/processors/index.js +0 -6
  256. package/dist/cjs/worker/expo/taskQueue.js +0 -41
  257. package/dist/cjs/worker/expo/taskRunner.js +0 -73
  258. package/dist/cjs/worker/messageBus.js +0 -474
  259. package/dist/esm/adapters/asyncStorage.js +0 -1
  260. package/dist/esm/adapters/expo.js +0 -3
  261. package/dist/esm/adapters/fileSystem.js +0 -1
  262. package/dist/esm/adapters/indexedDB.js +0 -1
  263. package/dist/esm/adapters/localStorage.js +0 -1
  264. package/dist/esm/arkfee/celenv.js +0 -40
  265. package/dist/esm/arkfee/estimator.js +0 -139
  266. package/dist/esm/arkfee/index.js +0 -1
  267. package/dist/esm/arkfee/types.js +0 -22
  268. package/dist/esm/arknote/index.js +0 -124
  269. package/dist/esm/bip322/index.js +0 -267
  270. package/dist/esm/contracts/arkcontract.js +0 -140
  271. package/dist/esm/contracts/contractManager.js +0 -645
  272. package/dist/esm/contracts/contractWatcher.js +0 -594
  273. package/dist/esm/contracts/handlers/default.js +0 -90
  274. package/dist/esm/contracts/handlers/delegate.js +0 -87
  275. package/dist/esm/contracts/handlers/helpers.js +0 -110
  276. package/dist/esm/contracts/handlers/index.js +0 -12
  277. package/dist/esm/contracts/handlers/registry.js +0 -86
  278. package/dist/esm/contracts/handlers/vhtlc.js +0 -191
  279. package/dist/esm/contracts/index.js +0 -13
  280. package/dist/esm/contracts/types.js +0 -1
  281. package/dist/esm/contracts/vtxoOwnership.js +0 -69
  282. package/dist/esm/extension/asset/assetGroup.js +0 -224
  283. package/dist/esm/extension/asset/assetId.js +0 -148
  284. package/dist/esm/extension/asset/assetInput.js +0 -217
  285. package/dist/esm/extension/asset/assetOutput.js +0 -169
  286. package/dist/esm/extension/asset/assetRef.js +0 -144
  287. package/dist/esm/extension/asset/index.js +0 -8
  288. package/dist/esm/extension/asset/metadata.js +0 -182
  289. package/dist/esm/extension/asset/packet.js +0 -110
  290. package/dist/esm/extension/asset/types.js +0 -19
  291. package/dist/esm/extension/asset/utils.js +0 -99
  292. package/dist/esm/extension/index.js +0 -248
  293. package/dist/esm/extension/packet.js +0 -16
  294. package/dist/esm/forfeit.js +0 -41
  295. package/dist/esm/identity/descriptor.js +0 -161
  296. package/dist/esm/identity/descriptorProvider.js +0 -1
  297. package/dist/esm/identity/hdCapableIdentity.js +0 -17
  298. package/dist/esm/identity/index.js +0 -13
  299. package/dist/esm/identity/seedIdentity.js +0 -469
  300. package/dist/esm/identity/serialize.js +0 -164
  301. package/dist/esm/identity/singleKey.js +0 -121
  302. package/dist/esm/identity/staticDescriptorProvider.js +0 -61
  303. package/dist/esm/index.js +0 -87
  304. package/dist/esm/intent/index.js +0 -255
  305. package/dist/esm/musig2/index.js +0 -3
  306. package/dist/esm/musig2/keys.js +0 -21
  307. package/dist/esm/musig2/nonces.js +0 -11
  308. package/dist/esm/musig2/sign.js +0 -63
  309. package/dist/esm/networks.js +0 -22
  310. package/dist/esm/package.json +0 -3
  311. package/dist/esm/providers/ark.js +0 -572
  312. package/dist/esm/providers/delegator.js +0 -81
  313. package/dist/esm/providers/electrum.js +0 -864
  314. package/dist/esm/providers/errors.js +0 -54
  315. package/dist/esm/providers/expoArk.js +0 -78
  316. package/dist/esm/providers/expoIndexer.js +0 -107
  317. package/dist/esm/providers/expoUtils.js +0 -87
  318. package/dist/esm/providers/indexer.js +0 -626
  319. package/dist/esm/providers/onchain.js +0 -258
  320. package/dist/esm/providers/utils.js +0 -117
  321. package/dist/esm/repositories/contractRepository.js +0 -1
  322. package/dist/esm/repositories/inMemory/contractRepository.js +0 -51
  323. package/dist/esm/repositories/inMemory/walletRepository.js +0 -111
  324. package/dist/esm/repositories/index.js +0 -10
  325. package/dist/esm/repositories/indexedDB/contractRepository.js +0 -183
  326. package/dist/esm/repositories/indexedDB/db.js +0 -4
  327. package/dist/esm/repositories/indexedDB/manager.js +0 -95
  328. package/dist/esm/repositories/indexedDB/schema.js +0 -199
  329. package/dist/esm/repositories/indexedDB/walletRepository.js +0 -470
  330. package/dist/esm/repositories/indexedDB/websqlAdapter.js +0 -138
  331. package/dist/esm/repositories/migrations/contractRepositoryImpl.js +0 -121
  332. package/dist/esm/repositories/migrations/fromStorageAdapter.js +0 -58
  333. package/dist/esm/repositories/migrations/walletRepositoryImpl.js +0 -180
  334. package/dist/esm/repositories/realm/contractRepository.js +0 -112
  335. package/dist/esm/repositories/realm/index.js +0 -3
  336. package/dist/esm/repositories/realm/schemas.js +0 -153
  337. package/dist/esm/repositories/realm/types.js +0 -6
  338. package/dist/esm/repositories/realm/walletRepository.js +0 -301
  339. package/dist/esm/repositories/scriptFromAddress.js +0 -13
  340. package/dist/esm/repositories/serialization.js +0 -67
  341. package/dist/esm/repositories/sqlite/contractRepository.js +0 -131
  342. package/dist/esm/repositories/sqlite/index.js +0 -2
  343. package/dist/esm/repositories/sqlite/types.js +0 -1
  344. package/dist/esm/repositories/sqlite/walletRepository.js +0 -437
  345. package/dist/esm/repositories/walletRepository.js +0 -1
  346. package/dist/esm/script/address.js +0 -104
  347. package/dist/esm/script/base.js +0 -179
  348. package/dist/esm/script/default.js +0 -54
  349. package/dist/esm/script/delegate.js +0 -50
  350. package/dist/esm/script/tapscript.js +0 -615
  351. package/dist/esm/script/vhtlc.js +0 -167
  352. package/dist/esm/storage/asyncStorage.js +0 -46
  353. package/dist/esm/storage/fileSystem.js +0 -104
  354. package/dist/esm/storage/inMemory.js +0 -20
  355. package/dist/esm/storage/index.js +0 -1
  356. package/dist/esm/storage/indexedDB.js +0 -97
  357. package/dist/esm/storage/localStorage.js +0 -47
  358. package/dist/esm/tree/signingSession.js +0 -191
  359. package/dist/esm/tree/txTree.js +0 -188
  360. package/dist/esm/tree/validation.js +0 -101
  361. package/dist/esm/utils/anchor.js +0 -31
  362. package/dist/esm/utils/arkTransaction.js +0 -264
  363. package/dist/esm/utils/bip21.js +0 -123
  364. package/dist/esm/utils/syncCursors.js +0 -119
  365. package/dist/esm/utils/timelock.js +0 -22
  366. package/dist/esm/utils/transaction.js +0 -24
  367. package/dist/esm/utils/transactionHistory.js +0 -180
  368. package/dist/esm/utils/txSizeEstimator.js +0 -128
  369. package/dist/esm/utils/unknownFields.js +0 -169
  370. package/dist/esm/wallet/asset-manager.js +0 -325
  371. package/dist/esm/wallet/asset.js +0 -113
  372. package/dist/esm/wallet/batch.js +0 -180
  373. package/dist/esm/wallet/delegator.js +0 -303
  374. package/dist/esm/wallet/expo/background.js +0 -111
  375. package/dist/esm/wallet/expo/index.js +0 -2
  376. package/dist/esm/wallet/expo/wallet.js +0 -193
  377. package/dist/esm/wallet/hdDescriptorProvider.js +0 -184
  378. package/dist/esm/wallet/index.js +0 -75
  379. package/dist/esm/wallet/inputSignerRouter.js +0 -94
  380. package/dist/esm/wallet/onchain.js +0 -285
  381. package/dist/esm/wallet/ramps.js +0 -212
  382. package/dist/esm/wallet/serviceWorker/wallet-message-handler.js +0 -946
  383. package/dist/esm/wallet/serviceWorker/wallet.js +0 -1169
  384. package/dist/esm/wallet/signingErrors.js +0 -27
  385. package/dist/esm/wallet/unroll.js +0 -289
  386. package/dist/esm/wallet/utils.js +0 -103
  387. package/dist/esm/wallet/validation.js +0 -142
  388. package/dist/esm/wallet/vtxo-manager.js +0 -1136
  389. package/dist/esm/wallet/wallet.js +0 -2186
  390. package/dist/esm/wallet/walletReceiveRotator.js +0 -540
  391. package/dist/esm/worker/browser/service-worker-manager.js +0 -177
  392. package/dist/esm/worker/browser/utils.js +0 -63
  393. package/dist/esm/worker/errors.js +0 -11
  394. package/dist/esm/worker/expo/asyncStorageTaskQueue.js +0 -74
  395. package/dist/esm/worker/expo/index.js +0 -4
  396. package/dist/esm/worker/expo/processors/contractPollProcessor.js +0 -59
  397. package/dist/esm/worker/expo/processors/index.js +0 -1
  398. package/dist/esm/worker/expo/taskQueue.js +0 -37
  399. package/dist/esm/worker/expo/taskRunner.js +0 -69
  400. package/dist/esm/worker/messageBus.js +0 -470
  401. package/dist/types/adapters/asyncStorage.d.ts +0 -2
  402. package/dist/types/adapters/expo.d.ts +0 -4
  403. package/dist/types/adapters/fileSystem.d.ts +0 -2
  404. package/dist/types/adapters/indexedDB.d.ts +0 -2
  405. package/dist/types/adapters/localStorage.d.ts +0 -2
  406. package/dist/types/arkfee/celenv.d.ts +0 -25
  407. package/dist/types/arkfee/estimator.d.ts +0 -49
  408. package/dist/types/arkfee/index.d.ts +0 -2
  409. package/dist/types/arkfee/types.d.ts +0 -38
  410. package/dist/types/arknote/index.d.ts +0 -84
  411. package/dist/types/bip322/index.d.ts +0 -55
  412. package/dist/types/contracts/arkcontract.d.ts +0 -99
  413. package/dist/types/contracts/contractManager.d.ts +0 -411
  414. package/dist/types/contracts/contractWatcher.d.ts +0 -217
  415. package/dist/types/contracts/handlers/default.d.ts +0 -19
  416. package/dist/types/contracts/handlers/delegate.d.ts +0 -21
  417. package/dist/types/contracts/handlers/helpers.d.ts +0 -19
  418. package/dist/types/contracts/handlers/index.d.ts +0 -7
  419. package/dist/types/contracts/handlers/registry.d.ts +0 -65
  420. package/dist/types/contracts/handlers/vhtlc.d.ts +0 -32
  421. package/dist/types/contracts/index.d.ts +0 -14
  422. package/dist/types/contracts/types.d.ts +0 -250
  423. package/dist/types/contracts/vtxoOwnership.d.ts +0 -33
  424. package/dist/types/extension/asset/assetGroup.d.ts +0 -119
  425. package/dist/types/extension/asset/assetId.d.ts +0 -83
  426. package/dist/types/extension/asset/assetInput.d.ts +0 -64
  427. package/dist/types/extension/asset/assetOutput.d.ts +0 -54
  428. package/dist/types/extension/asset/assetRef.d.ts +0 -91
  429. package/dist/types/extension/asset/index.d.ts +0 -8
  430. package/dist/types/extension/asset/metadata.d.ts +0 -52
  431. package/dist/types/extension/asset/packet.d.ts +0 -41
  432. package/dist/types/extension/asset/types.d.ts +0 -16
  433. package/dist/types/extension/asset/utils.d.ts +0 -21
  434. package/dist/types/extension/index.d.ts +0 -56
  435. package/dist/types/extension/packet.d.ts +0 -21
  436. package/dist/types/forfeit.d.ts +0 -18
  437. package/dist/types/identity/descriptor.d.ts +0 -61
  438. package/dist/types/identity/descriptorProvider.d.ts +0 -42
  439. package/dist/types/identity/hdCapableIdentity.d.ts +0 -71
  440. package/dist/types/identity/index.d.ts +0 -57
  441. package/dist/types/identity/seedIdentity.d.ts +0 -270
  442. package/dist/types/identity/serialize.d.ts +0 -96
  443. package/dist/types/identity/singleKey.d.ts +0 -62
  444. package/dist/types/identity/staticDescriptorProvider.d.ts +0 -18
  445. package/dist/types/index.d.ts +0 -59
  446. package/dist/types/intent/index.d.ts +0 -86
  447. package/dist/types/musig2/index.d.ts +0 -4
  448. package/dist/types/musig2/keys.d.ts +0 -9
  449. package/dist/types/musig2/nonces.d.ts +0 -14
  450. package/dist/types/musig2/sign.d.ts +0 -27
  451. package/dist/types/networks.d.ts +0 -16
  452. package/dist/types/providers/ark.d.ts +0 -369
  453. package/dist/types/providers/delegator.d.ts +0 -82
  454. package/dist/types/providers/electrum.d.ts +0 -312
  455. package/dist/types/providers/errors.d.ts +0 -13
  456. package/dist/types/providers/expoArk.d.ts +0 -22
  457. package/dist/types/providers/expoIndexer.d.ts +0 -18
  458. package/dist/types/providers/expoUtils.d.ts +0 -18
  459. package/dist/types/providers/indexer.d.ts +0 -301
  460. package/dist/types/providers/onchain.d.ts +0 -148
  461. package/dist/types/providers/utils.d.ts +0 -12
  462. package/dist/types/repositories/contractRepository.d.ts +0 -32
  463. package/dist/types/repositories/inMemory/contractRepository.d.ts +0 -17
  464. package/dist/types/repositories/inMemory/walletRepository.d.ts +0 -29
  465. package/dist/types/repositories/index.d.ts +0 -9
  466. package/dist/types/repositories/indexedDB/contractRepository.d.ts +0 -21
  467. package/dist/types/repositories/indexedDB/db.d.ts +0 -4
  468. package/dist/types/repositories/indexedDB/manager.d.ts +0 -25
  469. package/dist/types/repositories/indexedDB/schema.d.ts +0 -9
  470. package/dist/types/repositories/indexedDB/walletRepository.d.ts +0 -28
  471. package/dist/types/repositories/indexedDB/websqlAdapter.d.ts +0 -49
  472. package/dist/types/repositories/migrations/contractRepositoryImpl.d.ts +0 -24
  473. package/dist/types/repositories/migrations/fromStorageAdapter.d.ts +0 -19
  474. package/dist/types/repositories/migrations/walletRepositoryImpl.d.ts +0 -27
  475. package/dist/types/repositories/realm/contractRepository.d.ts +0 -24
  476. package/dist/types/repositories/realm/index.d.ts +0 -4
  477. package/dist/types/repositories/realm/types.d.ts +0 -16
  478. package/dist/types/repositories/realm/walletRepository.d.ts +0 -34
  479. package/dist/types/repositories/scriptFromAddress.d.ts +0 -9
  480. package/dist/types/repositories/serialization.d.ts +0 -65
  481. package/dist/types/repositories/sqlite/contractRepository.d.ts +0 -33
  482. package/dist/types/repositories/sqlite/index.d.ts +0 -3
  483. package/dist/types/repositories/sqlite/types.d.ts +0 -18
  484. package/dist/types/repositories/walletRepository.d.ts +0 -72
  485. package/dist/types/script/address.d.ts +0 -67
  486. package/dist/types/script/base.d.ts +0 -105
  487. package/dist/types/script/default.d.ts +0 -44
  488. package/dist/types/script/delegate.d.ts +0 -40
  489. package/dist/types/script/tapscript.d.ts +0 -169
  490. package/dist/types/script/vhtlc.d.ts +0 -66
  491. package/dist/types/tree/signingSession.d.ts +0 -37
  492. package/dist/types/tree/txTree.d.ts +0 -28
  493. package/dist/types/tree/validation.d.ts +0 -15
  494. package/dist/types/utils/anchor.d.ts +0 -19
  495. package/dist/types/utils/arkTransaction.d.ts +0 -49
  496. package/dist/types/utils/bip21.d.ts +0 -38
  497. package/dist/types/utils/syncCursors.d.ts +0 -60
  498. package/dist/types/utils/timelock.d.ts +0 -9
  499. package/dist/types/utils/transaction.d.ts +0 -13
  500. package/dist/types/utils/transactionHistory.d.ts +0 -15
  501. package/dist/types/utils/txSizeEstimator.d.ts +0 -40
  502. package/dist/types/utils/unknownFields.d.ts +0 -83
  503. package/dist/types/wallet/asset-manager.d.ts +0 -69
  504. package/dist/types/wallet/asset.d.ts +0 -21
  505. package/dist/types/wallet/batch.d.ts +0 -107
  506. package/dist/types/wallet/delegator.d.ts +0 -48
  507. package/dist/types/wallet/expo/background.d.ts +0 -66
  508. package/dist/types/wallet/expo/index.d.ts +0 -4
  509. package/dist/types/wallet/hdDescriptorProvider.d.ts +0 -114
  510. package/dist/types/wallet/index.d.ts +0 -789
  511. package/dist/types/wallet/inputSignerRouter.d.ts +0 -35
  512. package/dist/types/wallet/onchain.d.ts +0 -109
  513. package/dist/types/wallet/ramps.d.ts +0 -64
  514. package/dist/types/wallet/serviceWorker/wallet-message-handler.d.ts +0 -543
  515. package/dist/types/wallet/serviceWorker/wallet.d.ts +0 -248
  516. package/dist/types/wallet/signingErrors.d.ts +0 -19
  517. package/dist/types/wallet/unroll.d.ts +0 -114
  518. package/dist/types/wallet/utils.d.ts +0 -36
  519. package/dist/types/wallet/validation.d.ts +0 -24
  520. package/dist/types/wallet/vtxo-manager.d.ts +0 -476
  521. package/dist/types/wallet/wallet.d.ts +0 -409
  522. package/dist/types/wallet/walletReceiveRotator.d.ts +0 -306
  523. package/dist/types/worker/browser/service-worker-manager.d.ts +0 -32
  524. package/dist/types/worker/browser/utils.d.ts +0 -17
  525. package/dist/types/worker/errors.d.ts +0 -7
  526. package/dist/types/worker/expo/index.d.ts +0 -7
  527. package/dist/types/worker/expo/processors/contractPollProcessor.d.ts +0 -19
  528. package/dist/types/worker/expo/processors/index.d.ts +0 -1
  529. package/dist/types/worker/expo/taskQueue.d.ts +0 -50
  530. package/dist/types/worker/expo/taskRunner.d.ts +0 -66
  531. package/dist/types/worker/messageBus.d.ts +0 -189
@@ -1,477 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ReadonlyDescriptorIdentity = exports.MnemonicIdentity = exports.SeedIdentity = void 0;
4
- exports.serializeSeedOwnedSigningIdentity = serializeSeedOwnedSigningIdentity;
5
- exports.serializeSeedOwnedReadonlyIdentity = serializeSeedOwnedReadonlyIdentity;
6
- const bip39_1 = require("@scure/bip39");
7
- const english_js_1 = require("@scure/bip39/wordlists/english.js");
8
- const utils_js_1 = require("@scure/btc-signer/utils.js");
9
- const btc_signer_1 = require("@scure/btc-signer");
10
- const base_1 = require("@scure/base");
11
- const signingSession_1 = require("../tree/signingSession");
12
- const secp256k1_1 = require("@noble/secp256k1");
13
- const descriptors_scure_1 = require("@bitcoinerlab/descriptors-scure");
14
- const descriptor_1 = require("./descriptor");
15
- const ALL_SIGHASH = Object.values(btc_signer_1.SigHash).filter((x) => typeof x === "number");
16
- /**
17
- * Secret-bearing state for seed-backed identities, held off the public
18
- * instance surface. Accessed only by the SDK-internal serializer helpers
19
- * below; application code cannot read these via ordinary field access.
20
- *
21
- * Using a module-private WeakMap (rather than `private` / `protected`)
22
- * matters because TypeScript visibility is a compile-time boundary only:
23
- * JavaScript consumers could still read public fields. A WeakMap removes
24
- * that enumeration path entirely.
25
- */
26
- const seedBytes = new WeakMap();
27
- const mnemonicMeta = new WeakMap();
28
- /**
29
- * Seed-based identity derived from a raw seed and an account descriptor
30
- * *template*.
31
- *
32
- * This is the recommended identity type for most applications. It uses
33
- * standard BIP86 (Taproot) derivation by default; callers that need a
34
- * different path supply the wildcard template directly.
35
- *
36
- * Prefer this (or @see MnemonicIdentity) over `SingleKey` for new
37
- * integrations — `SingleKey` exists for backward compatibility with
38
- * raw nsec-style keys.
39
- *
40
- * The identity holds the wildcard *template* (e.g.
41
- * `tr([fp/86'/0'/0']xpub/0/*)`) on its public {@link descriptor}
42
- * field. HD rotation reads it directly; consumers that need a
43
- * concrete descriptor at a specific index materialize it themselves
44
- * (see `HDDescriptorProvider` in the wallet layer).
45
- *
46
- * Exposes seed-level primitives (signing, derivation, the template)
47
- * but is deliberately NOT a `DescriptorProvider`. Wrap it explicitly
48
- * to get one:
49
- * - `HDDescriptorProvider` for rotating receive addresses.
50
- * - {@link StaticDescriptorProvider} for legacy, single-key behaviour.
51
- *
52
- * The split prevents a SeedIdentity from being silently used as a
53
- * concrete descriptor source, which would defeat HD rotation without
54
- * any compile-time signal that something was wrong.
55
- *
56
- * @example
57
- * ```typescript
58
- * const seed = mnemonicToSeedSync(mnemonic);
59
- *
60
- * // Testnet (BIP86 wildcard descriptor m/86'/1'/0'/0/*)
61
- * const identity = SeedIdentity.fromSeed(seed, { isMainnet: false });
62
- *
63
- * // Mainnet (BIP86 wildcard descriptor m/86'/0'/0'/0/*)
64
- * const identity = SeedIdentity.fromSeed(seed, { isMainnet: true });
65
- *
66
- * // Caller-supplied wildcard descriptor (must end in `/*)`).
67
- * const identity = SeedIdentity.fromSeed(seed, { descriptor });
68
- * ```
69
- */
70
- class SeedIdentity {
71
- /**
72
- * Constructs a SeedIdentity from a 64-byte seed and either a
73
- * caller-supplied wildcard descriptor (`{ descriptor }`) or the
74
- * default BIP86 path at the requested network (`{ isMainnet }`).
75
- * Prefer the {@link fromSeed} factory for symmetry with
76
- * {@link MnemonicIdentity.fromMnemonic}.
77
- *
78
- * Throws on a non-wildcard descriptor, an xpub mismatch with the
79
- * seed, or a missing derivation path.
80
- */
81
- constructor(seed, opts = {}) {
82
- if (seed.length !== 64) {
83
- throw new Error("Seed must be 64 bytes");
84
- }
85
- // Resolve the descriptor: caller-supplied wins; otherwise build
86
- // the BIP86 default at the requested network via the library.
87
- let descriptor;
88
- let network;
89
- if ("descriptor" in opts && typeof opts.descriptor === "string") {
90
- descriptor = opts.descriptor;
91
- network = (0, descriptor_1.isMainnetDescriptor)(descriptor)
92
- ? descriptors_scure_1.networks.bitcoin
93
- : descriptors_scure_1.networks.testnet;
94
- }
95
- else {
96
- network =
97
- (opts.isMainnet ?? true)
98
- ? descriptors_scure_1.networks.bitcoin
99
- : descriptors_scure_1.networks.testnet;
100
- descriptor = descriptors_scure_1.scriptExpressions.trBIP32({
101
- masterNode: descriptors_scure_1.HDKey.fromMasterSeed(seed, network.bip32),
102
- network,
103
- account: 0,
104
- change: 0,
105
- index: "*",
106
- });
107
- }
108
- // Parse the descriptor, substituting the wildcard at index 0.
109
- // The library raises "index passed for non-ranged descriptor"
110
- // if the input isn't a wildcard template, which we re-wrap so
111
- // the caller sees what they actually got wrong.
112
- let expansion;
113
- try {
114
- expansion = (0, descriptors_scure_1.expand)({ descriptor, network, index: 0 });
115
- }
116
- catch (e) {
117
- throw new Error(`SeedIdentity requires a wildcard descriptor template (must end in "/*)"); ${e instanceof Error ? e.message : String(e)}`);
118
- }
119
- const keyInfo = expansion.expansionMap?.["@0"];
120
- // Defensive copy: `derivedKey` and `descriptor` are computed eagerly
121
- // from the bytes we're about to stash, so a later mutation of the
122
- // caller's buffer must not drift the serialized `seed` out of sync
123
- // with the live identity state.
124
- seedBytes.set(this, new Uint8Array(seed));
125
- this.descriptor = descriptor;
126
- if (!keyInfo?.originPath) {
127
- throw new Error("Descriptor must include a key origin path");
128
- }
129
- // Verify the xpub in the descriptor matches our seed (validates
130
- // that the descriptor was generated from this seed; we don't
131
- // need to keep the xpub around afterwards — `isOurs` re-derives
132
- // it from `this.descriptor` on demand).
133
- const masterNode = descriptors_scure_1.HDKey.fromMasterSeed(seed, network.bip32);
134
- const accountNode = masterNode.derive(`m${keyInfo.originPath}`);
135
- if (accountNode.publicExtendedKey !== keyInfo.bip32?.toBase58()) {
136
- throw new Error("xpub mismatch: derived key does not match descriptor");
137
- }
138
- // Derive the private key for index 0 using the full path
139
- if (!keyInfo.path) {
140
- throw new Error("Descriptor must specify a full derivation path");
141
- }
142
- const derivedNode = masterNode.derive(keyInfo.path);
143
- if (!derivedNode.privateKey) {
144
- throw new Error("Failed to derive private key");
145
- }
146
- this.derivedKey = derivedNode.privateKey;
147
- }
148
- /**
149
- * Creates a SeedIdentity from a raw 64-byte seed.
150
- *
151
- * Pass `{ isMainnet }` for default BIP86 derivation, or
152
- * `{ descriptor }` for a caller-supplied account-descriptor
153
- * template (the option's value must end with `/*)`).
154
- *
155
- * @param seed - 64-byte seed (typically from mnemonicToSeedSync)
156
- * @param opts - Network selection or descriptor template.
157
- */
158
- static fromSeed(seed, opts = {}) {
159
- return new SeedIdentity(seed, opts);
160
- }
161
- async xOnlyPublicKey() {
162
- return (0, utils_js_1.pubSchnorr)(this.derivedKey);
163
- }
164
- async compressedPublicKey() {
165
- return (0, utils_js_1.pubECDSA)(this.derivedKey, true);
166
- }
167
- async sign(tx, inputIndexes) {
168
- return this.signTxWithKey(tx, this.derivedKey, inputIndexes);
169
- }
170
- async signMessage(message, signatureType = "schnorr") {
171
- return this.signMessageWithKey(this.derivedKey, message, signatureType);
172
- }
173
- signerSession() {
174
- return signingSession_1.TreeSignerSession.random();
175
- }
176
- /**
177
- * Converts to a watch-only identity that cannot sign. Carries the
178
- * template forward, so the readonly side stays HD-capable (can
179
- * derive descriptors at any index without seed access).
180
- */
181
- async toReadonly() {
182
- return ReadonlyDescriptorIdentity.fromDescriptor(this.descriptor);
183
- }
184
- /**
185
- * Returns true when `descriptor` is derived from this identity's seed.
186
- * HD descriptors match by account xpub; bare `tr(pubkey)` descriptors
187
- * match by raw pubkey. See {@link descriptorIsOurs}.
188
- *
189
- * @deprecated Prefer `DescriptorProvider.isOurs()` via
190
- * `HDDescriptorProvider` for rotating HD wallets or
191
- * `StaticDescriptorProvider` for legacy single-key wallets.
192
- */
193
- isOurs(descriptor) {
194
- return (0, descriptor_1.descriptorIsOurs)(descriptor, this.descriptor, (0, utils_js_1.pubSchnorr)(this.derivedKey));
195
- }
196
- /**
197
- * Signs each request with the key derived from its descriptor.
198
- * Each descriptor must share this identity's seed ({@link isOurs}).
199
- *
200
- * @deprecated Prefer `DescriptorProvider.signWithDescriptor()` via
201
- * `HDDescriptorProvider` or `StaticDescriptorProvider`. Identities keep
202
- * this method only as backing implementation for descriptor providers.
203
- */
204
- async signWithDescriptor(requests) {
205
- return requests.map((request) => {
206
- if (!this.isOurs(request.descriptor)) {
207
- throw new Error(`Descriptor ${request.descriptor} does not belong to this identity`);
208
- }
209
- const key = this.derivePrivateKeyForDescriptor(request.descriptor);
210
- return this.signTxWithKey(request.tx, key, request.inputIndexes);
211
- });
212
- }
213
- /**
214
- * Signs a message with the key derived from `descriptor`.
215
- *
216
- * @deprecated Prefer `DescriptorProvider.signMessageWithDescriptor()` via
217
- * `HDDescriptorProvider` or `StaticDescriptorProvider`. Identities keep
218
- * this method only as backing implementation for descriptor providers.
219
- */
220
- async signMessageWithDescriptor(descriptor, message, signatureType = "schnorr") {
221
- if (!this.isOurs(descriptor)) {
222
- throw new Error(`Descriptor ${descriptor} does not belong to this identity`);
223
- }
224
- const key = this.derivePrivateKeyForDescriptor(descriptor);
225
- return this.signMessageWithKey(key, message, signatureType);
226
- }
227
- // ── internal helpers ─────────────────────────────────────────────
228
- derivePrivateKeyForDescriptor(descriptor) {
229
- const network = (0, descriptor_1.isMainnetDescriptor)(descriptor)
230
- ? descriptors_scure_1.networks.bitcoin
231
- : descriptors_scure_1.networks.testnet;
232
- const expansion = (0, descriptors_scure_1.expand)({ descriptor, network });
233
- if (expansion.isRanged) {
234
- throw new Error("Cannot sign with a wildcard descriptor; derive a concrete index first");
235
- }
236
- const keyInfo = expansion.expansionMap?.["@0"];
237
- if (!keyInfo?.path) {
238
- throw new Error("Descriptor must specify a full derivation path for signing");
239
- }
240
- const seed = seedBytes.get(this);
241
- if (!seed) {
242
- throw new Error("Seed bytes not available for descriptor signing");
243
- }
244
- const masterNode = descriptors_scure_1.HDKey.fromMasterSeed(seed, network.bip32);
245
- const node = masterNode.derive(keyInfo.path);
246
- if (!node.privateKey) {
247
- throw new Error("Failed to derive private key for descriptor");
248
- }
249
- return node.privateKey;
250
- }
251
- signTxWithKey(tx, key, inputIndexes) {
252
- const txCpy = tx.clone();
253
- if (!inputIndexes) {
254
- try {
255
- if (!txCpy.sign(key, ALL_SIGHASH)) {
256
- throw new Error("Failed to sign transaction");
257
- }
258
- }
259
- catch (e) {
260
- if (e instanceof Error &&
261
- e.message.includes("No inputs signed")) {
262
- // ignore
263
- }
264
- else {
265
- throw e;
266
- }
267
- }
268
- }
269
- else {
270
- for (const idx of inputIndexes) {
271
- if (!txCpy.signIdx(key, idx, ALL_SIGHASH)) {
272
- throw new Error(`Failed to sign input #${idx}`);
273
- }
274
- }
275
- }
276
- return txCpy;
277
- }
278
- signMessageWithKey(key, message, signatureType) {
279
- if (signatureType === "ecdsa")
280
- return (0, secp256k1_1.signAsync)(message, key, { prehash: false });
281
- return secp256k1_1.schnorr.signAsync(message, key);
282
- }
283
- }
284
- exports.SeedIdentity = SeedIdentity;
285
- /**
286
- * Mnemonic-based identity derived from a BIP39 phrase.
287
- *
288
- * This is the most user-friendly identity type — recommended for wallet
289
- * applications where users manage their own backup phrase. Extends
290
- * @see SeedIdentity with mnemonic validation and optional passphrase
291
- * support.
292
- *
293
- * @example
294
- * ```typescript
295
- * const identity = MnemonicIdentity.fromMnemonic(
296
- * 'abandon abandon abandon ...',
297
- * { isMainnet: true, passphrase: 'secret' }
298
- * );
299
- * ```
300
- */
301
- class MnemonicIdentity extends SeedIdentity {
302
- constructor(phrase, opts) {
303
- const { passphrase } = opts;
304
- super((0, bip39_1.mnemonicToSeedSync)(phrase, passphrase), opts);
305
- mnemonicMeta.set(this, { mnemonic: phrase, passphrase });
306
- }
307
- /**
308
- * Creates a MnemonicIdentity from a BIP39 mnemonic phrase.
309
- *
310
- * Pass `{ isMainnet }` for default BIP86 derivation, or
311
- * `{ descriptor }` for a caller-supplied account-descriptor
312
- * template (the option's value must end with `/*)`).
313
- *
314
- * @param phrase - BIP39 mnemonic phrase (12 or 24 words)
315
- * @param opts - Network selection or descriptor template, plus optional passphrase
316
- */
317
- static fromMnemonic(phrase, opts = {}) {
318
- if (!(0, bip39_1.validateMnemonic)(phrase, english_js_1.wordlist)) {
319
- throw new Error("Invalid mnemonic");
320
- }
321
- return new MnemonicIdentity(phrase, opts);
322
- }
323
- }
324
- exports.MnemonicIdentity = MnemonicIdentity;
325
- /**
326
- * Watch-only HD identity from a descriptor *template*.
327
- *
328
- * Can derive public keys but cannot sign transactions. Use this for
329
- * watch-only wallets — given just an xpub-based template, the readonly
330
- * side still rotates through HD indices.
331
- *
332
- * Constructed from a wildcard template (e.g.
333
- * `tr([fp/86'/0'/0']xpub.../0/*)`); the {@link descriptor} field
334
- * holds it for HD providers to consume.
335
- *
336
- * @example
337
- * ```typescript
338
- * const ro = ReadonlyDescriptorIdentity.fromDescriptor(
339
- * "tr([fp/86'/0'/0']xpub.../0/*)"
340
- * );
341
- * ro.descriptor;
342
- * // => "tr([fp/86'/0'/0']xpub.../0/*)" — the template
343
- * ```
344
- */
345
- class ReadonlyDescriptorIdentity {
346
- constructor(descriptor) {
347
- const network = (0, descriptor_1.isMainnetDescriptor)(descriptor)
348
- ? descriptors_scure_1.networks.bitcoin
349
- : descriptors_scure_1.networks.testnet;
350
- // Library substitutes the wildcard at index 0 and raises
351
- // "index passed for non-ranged descriptor" if `descriptor` isn't
352
- // actually a wildcard template — re-wrap so the caller sees
353
- // the higher-level invariant they violated.
354
- let expansion;
355
- try {
356
- expansion = (0, descriptors_scure_1.expand)({ descriptor, network, index: 0 });
357
- }
358
- catch (e) {
359
- throw new Error(`ReadonlyDescriptorIdentity requires a wildcard descriptor template (must end in "/*)"); ${e instanceof Error ? e.message : String(e)}`);
360
- }
361
- const keyInfo = expansion.expansionMap?.["@0"];
362
- if (!keyInfo?.pubkey) {
363
- throw new Error("Failed to derive public key from descriptor");
364
- }
365
- if (!keyInfo.bip32) {
366
- throw new Error("Cannot determine compressed public key parity from descriptor");
367
- }
368
- this.descriptor = descriptor;
369
- this.indexZero = keyInfo;
370
- }
371
- /**
372
- * Creates a ReadonlyDescriptorIdentity from an account-descriptor
373
- * *template* (must end with the BIP-32 wildcard suffix `/*)`).
374
- *
375
- * @param descriptor - Wildcard-suffixed Taproot template
376
- * (`tr([fp/path']xpub.../child/*)`).
377
- */
378
- static fromDescriptor(descriptor) {
379
- return new ReadonlyDescriptorIdentity(descriptor);
380
- }
381
- async xOnlyPublicKey() {
382
- // Validated non-null in the constructor.
383
- return this.indexZero.pubkey;
384
- }
385
- async compressedPublicKey() {
386
- const { bip32, keyPath } = this.indexZero;
387
- // bip32 validated non-null in the constructor; derivePath
388
- // returns a fresh node so this is a read of the index-0
389
- // compressed pubkey, not a mutation of the stored one.
390
- if (keyPath) {
391
- // Strip leading "/" — the library's derivePath prepends "m/" itself
392
- return bip32.derivePath(keyPath.replace(/^\//, "")).publicKey;
393
- }
394
- return bip32.publicKey;
395
- }
396
- /**
397
- * Returns true when `descriptor` derives from this identity's xpub.
398
- * HD descriptors match by account xpub; bare `tr(pubkey)` descriptors
399
- * fall back to comparing against the index-0 x-only pubkey. See
400
- * {@link descriptorIsOurs}.
401
- *
402
- * @deprecated Prefer `DescriptorProvider.isOurs()` via
403
- * `HDDescriptorProvider` for rotating HD wallets or
404
- * `StaticDescriptorProvider` for legacy single-key wallets.
405
- */
406
- isOurs(descriptor) {
407
- return (0, descriptor_1.descriptorIsOurs)(descriptor, this.descriptor, this.indexZero.pubkey);
408
- }
409
- }
410
- exports.ReadonlyDescriptorIdentity = ReadonlyDescriptorIdentity;
411
- /**
412
- * Serialize a seed-backed signing identity into a
413
- * {@link SerializedSigningIdentity} envelope without exposing the
414
- * underlying secret material on the public instance surface.
415
- *
416
- * Called by {@link serializeSigningIdentity}; application code should
417
- * prefer that public dispatcher instead of calling this directly. This
418
- * helper is deliberately kept out of the `src/identity` barrel so it is
419
- * not part of the package's public export surface.
420
- *
421
- * Secret-surface trade-off: the resulting envelope carries master-seed
422
- * material — the BIP39 mnemonic (+ optional passphrase) for
423
- * `MnemonicIdentity` or the raw 64-byte seed for `SeedIdentity`. A party
424
- * that reads this envelope can derive any key under the HD tree, not
425
- * just the key currently in use. The pre-change `SingleKey` flow only
426
- * shipped one derived private key and therefore had a smaller blast
427
- * radius. This is an intentional design trade to preserve class and
428
- * descriptor identity across the page / service-worker boundary; the
429
- * page already holds the same material so that it can re-initialize a
430
- * killed worker. Transport is same-origin `postMessage` only. See the
431
- * threat-model note in `src/worker/browser/README.md`.
432
- *
433
- * @internal
434
- */
435
- function serializeSeedOwnedSigningIdentity(identity) {
436
- if (identity instanceof MnemonicIdentity) {
437
- const meta = mnemonicMeta.get(identity);
438
- if (!meta) {
439
- throw new Error("MnemonicIdentity is missing internal secret state; was it constructed via MnemonicIdentity.fromMnemonic()?");
440
- }
441
- const envelope = {
442
- type: "mnemonic",
443
- mnemonic: meta.mnemonic,
444
- descriptor: identity.descriptor,
445
- };
446
- if (meta.passphrase !== undefined) {
447
- envelope.passphrase = meta.passphrase;
448
- }
449
- return envelope;
450
- }
451
- const seed = seedBytes.get(identity);
452
- if (!seed) {
453
- throw new Error("SeedIdentity is missing internal secret state; was it constructed via SeedIdentity.fromSeed() or the class constructor?");
454
- }
455
- return {
456
- type: "seed",
457
- seed: base_1.hex.encode(seed),
458
- descriptor: identity.descriptor,
459
- };
460
- }
461
- /**
462
- * Downgrade a seed-backed or descriptor-backed identity into a readonly
463
- * descriptor envelope. Always produces a descriptor-only shape — secret
464
- * material never crosses this path, even if the input is a signing
465
- * identity.
466
- *
467
- * Deliberately kept out of the `src/identity` barrel; consumers should go
468
- * through {@link serializeReadonlyIdentity}.
469
- *
470
- * @internal
471
- */
472
- function serializeSeedOwnedReadonlyIdentity(identity) {
473
- return {
474
- type: "readonly-descriptor",
475
- descriptor: identity.descriptor,
476
- };
477
- }
@@ -1,171 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.isSigningSerialized = isSigningSerialized;
4
- exports.serializeSigningIdentity = serializeSigningIdentity;
5
- exports.serializeReadonlyIdentity = serializeReadonlyIdentity;
6
- exports.hydrateIdentity = hydrateIdentity;
7
- exports.normalizeSerializedIdentity = normalizeSerializedIdentity;
8
- const base_1 = require("@scure/base");
9
- const singleKey_1 = require("./singleKey");
10
- const seedIdentity_1 = require("./seedIdentity");
11
- /** Type guard — true for signing envelopes, false for readonly envelopes. */
12
- function isSigningSerialized(s) {
13
- return (s.type === "single-key" || s.type === "seed" || s.type === "mnemonic");
14
- }
15
- function hasToHex(identity) {
16
- return typeof identity.toHex === "function";
17
- }
18
- /**
19
- * Serialize a signing identity into a structured-clone safe envelope for
20
- * transport across the service-worker boundary.
21
- *
22
- * Supports SDK-owned signing identities directly. For custom identities, a
23
- * duck-typed `toHex()` fallback preserves compatibility with existing
24
- * `SingleKey`-like implementations.
25
- */
26
- function serializeSigningIdentity(identity) {
27
- // Seed-backed identities (including MnemonicIdentity, which extends
28
- // SeedIdentity) delegate to the colocated helper so secret material
29
- // stays behind the WeakMap-backed internal state in seedIdentity.ts.
30
- if (identity instanceof seedIdentity_1.SeedIdentity) {
31
- return (0, seedIdentity_1.serializeSeedOwnedSigningIdentity)(identity);
32
- }
33
- if (identity instanceof singleKey_1.SingleKey) {
34
- return { type: "single-key", privateKey: identity.toHex() };
35
- }
36
- if (hasToHex(identity)) {
37
- return { type: "single-key", privateKey: identity.toHex() };
38
- }
39
- throw new Error("Unsupported signing identity: cannot serialize for service-worker transport");
40
- }
41
- /**
42
- * Serialize a readonly identity into a structured-clone safe envelope.
43
- *
44
- * Works for any `ReadonlyIdentity` via `compressedPublicKey()`. When called
45
- * with a signing identity, produces a readonly envelope (never ships signing
46
- * material) — callers that need to preserve signing capability across the
47
- * boundary must use {@link serializeSigningIdentity}.
48
- */
49
- async function serializeReadonlyIdentity(identity) {
50
- if (identity instanceof seedIdentity_1.SeedIdentity ||
51
- identity instanceof seedIdentity_1.ReadonlyDescriptorIdentity) {
52
- return (0, seedIdentity_1.serializeSeedOwnedReadonlyIdentity)(identity);
53
- }
54
- return {
55
- type: "readonly-single-key",
56
- publicKey: base_1.hex.encode(await identity.compressedPublicKey()),
57
- };
58
- }
59
- /**
60
- * Rehydrate a serialized identity envelope back into an identity instance.
61
- * The return type is the union of signing and readonly; use
62
- * {@link isSigningSerialized} on the envelope before hydration if the caller
63
- * needs to know which side it ends up on.
64
- *
65
- * Envelopes store the wildcard template directly (see
66
- * `serializeSeedOwnedSigningIdentity` / `serializeSeedOwnedReadonlyIdentity`),
67
- * so the `descriptor` field is passed straight through to the
68
- * template-only factories.
69
- */
70
- function hydrateIdentity(s) {
71
- switch (s.type) {
72
- case "single-key":
73
- return singleKey_1.SingleKey.fromHex(s.privateKey);
74
- case "readonly-single-key":
75
- return singleKey_1.ReadonlySingleKey.fromPublicKey(base_1.hex.decode(s.publicKey));
76
- case "seed":
77
- return seedIdentity_1.SeedIdentity.fromSeed(base_1.hex.decode(s.seed), {
78
- descriptor: s.descriptor,
79
- });
80
- case "mnemonic":
81
- return seedIdentity_1.MnemonicIdentity.fromMnemonic(s.mnemonic, {
82
- descriptor: s.descriptor,
83
- passphrase: s.passphrase,
84
- });
85
- case "readonly-descriptor":
86
- return seedIdentity_1.ReadonlyDescriptorIdentity.fromDescriptor(s.descriptor);
87
- default:
88
- // Belt-and-suspenders: `normalizeSerializedIdentity` already
89
- // rejects unknown `type` values at the wire boundary. Without
90
- // this throw, an unknown type would fall through and return
91
- // undefined, which callers would then cast to Identity and
92
- // crash downstream with an opaque error.
93
- throw new Error(`Unknown serialized identity type: ${String(s.type)}`);
94
- }
95
- }
96
- let warnedLegacyShape = false;
97
- /**
98
- * Accept either a modern {@link SerializedIdentity} envelope or a legacy
99
- * `{ privateKey }` / `{ publicKey }` shape and normalize to a
100
- * {@link SerializedIdentity}. Emits a one-time deprecation warning when a
101
- * legacy shape is seen.
102
- *
103
- * Intended for the worker-side boundary; new page builds always emit tagged
104
- * envelopes via {@link serializeSigningIdentity} /
105
- * {@link serializeReadonlyIdentity}.
106
- */
107
- function normalizeSerializedIdentity(shape) {
108
- if ("type" in shape) {
109
- assertValidSerializedIdentity(shape);
110
- return shape;
111
- }
112
- if (!warnedLegacyShape) {
113
- warnedLegacyShape = true;
114
- console.warn("[ts-sdk] Received legacy serialized identity shape " +
115
- "(privateKey/publicKey). Upgrade the page build to the latest " +
116
- "@arkade-os/sdk — this compatibility path will be removed in " +
117
- "the next major.");
118
- }
119
- if ("privateKey" in shape && typeof shape.privateKey === "string") {
120
- return { type: "single-key", privateKey: shape.privateKey };
121
- }
122
- if ("publicKey" in shape && typeof shape.publicKey === "string") {
123
- return { type: "readonly-single-key", publicKey: shape.publicKey };
124
- }
125
- throw new Error("Unrecognized serialized identity shape");
126
- }
127
- /**
128
- * Runtime-validate that a tagged envelope carries the fields its variant
129
- * requires. The SDK's own serializer produces well-formed envelopes; this
130
- * guard exists so a malformed message (older SDK version mismatch,
131
- * hand-built config, etc.) fails loudly at the wire boundary rather than
132
- * with an opaque `"Cannot read properties of undefined"` deep inside a
133
- * hydrator.
134
- */
135
- function assertValidSerializedIdentity(s) {
136
- const kind = s.type;
137
- const bad = (field, expected) => {
138
- throw new Error(`Malformed serialized identity ({ type: ${JSON.stringify(kind)} }): ` +
139
- `missing or invalid "${field}" (expected ${expected})`);
140
- };
141
- const asStr = (key) => {
142
- const v = s[key];
143
- return typeof v === "string" ? v : bad(key, "string");
144
- };
145
- switch (kind) {
146
- case "single-key":
147
- asStr("privateKey");
148
- return;
149
- case "readonly-single-key":
150
- asStr("publicKey");
151
- return;
152
- case "seed":
153
- asStr("seed");
154
- asStr("descriptor");
155
- return;
156
- case "mnemonic": {
157
- asStr("mnemonic");
158
- asStr("descriptor");
159
- const passphrase = s.passphrase;
160
- if (passphrase !== undefined && typeof passphrase !== "string") {
161
- bad("passphrase", "string | undefined");
162
- }
163
- return;
164
- }
165
- case "readonly-descriptor":
166
- asStr("descriptor");
167
- return;
168
- default:
169
- throw new Error(`Unknown serialized identity type: ${String(kind)}`);
170
- }
171
- }