@ledgerhq/coin-bitcoin 0.4.0-nightly.0

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 (1055) hide show
  1. package/.eslintrc.js +20 -0
  2. package/.turbo/turbo-build.log +4 -0
  3. package/.unimportedrc.json +43 -0
  4. package/CHANGELOG.md +16 -0
  5. package/LICENSE.txt +21 -0
  6. package/jest.config.js +10 -0
  7. package/lib/account.d.ts +7 -0
  8. package/lib/account.d.ts.map +1 -0
  9. package/lib/account.js +13 -0
  10. package/lib/account.js.map +1 -0
  11. package/lib/bech32m.d.ts +16 -0
  12. package/lib/bech32m.d.ts.map +1 -0
  13. package/lib/bech32m.js +166 -0
  14. package/lib/bech32m.js.map +1 -0
  15. package/lib/bridge/js.d.ts +41 -0
  16. package/lib/bridge/js.d.ts.map +1 -0
  17. package/lib/bridge/js.js +92 -0
  18. package/lib/bridge/js.js.map +1 -0
  19. package/lib/bridge.integration.test.d.ts +4 -0
  20. package/lib/bridge.integration.test.d.ts.map +1 -0
  21. package/lib/bridge.integration.test.js +47 -0
  22. package/lib/bridge.integration.test.js.map +1 -0
  23. package/lib/cache.d.ts +17 -0
  24. package/lib/cache.d.ts.map +1 -0
  25. package/lib/cache.js +62 -0
  26. package/lib/cache.js.map +1 -0
  27. package/lib/cli-transaction.d.ts +30 -0
  28. package/lib/cli-transaction.d.ts.map +1 -0
  29. package/lib/cli-transaction.js +61 -0
  30. package/lib/cli-transaction.js.map +1 -0
  31. package/lib/crypto-util.d.ts +5 -0
  32. package/lib/crypto-util.d.ts.map +1 -0
  33. package/lib/crypto-util.js +25 -0
  34. package/lib/crypto-util.js.map +1 -0
  35. package/lib/datasets/bitcoin.d.ts +7 -0
  36. package/lib/datasets/bitcoin.d.ts.map +1 -0
  37. package/lib/datasets/bitcoin.js +318 -0
  38. package/lib/datasets/bitcoin.js.map +1 -0
  39. package/lib/datasets/bitcoin.scanAccounts.1.d.ts +6 -0
  40. package/lib/datasets/bitcoin.scanAccounts.1.d.ts.map +1 -0
  41. package/lib/datasets/bitcoin.scanAccounts.1.js +240 -0
  42. package/lib/datasets/bitcoin.scanAccounts.1.js.map +1 -0
  43. package/lib/datasets/bitcoin_cash.d.ts +5 -0
  44. package/lib/datasets/bitcoin_cash.d.ts.map +1 -0
  45. package/lib/datasets/bitcoin_cash.js +45 -0
  46. package/lib/datasets/bitcoin_cash.js.map +1 -0
  47. package/lib/datasets/bitcoin_gold.d.ts +5 -0
  48. package/lib/datasets/bitcoin_gold.d.ts.map +1 -0
  49. package/lib/datasets/bitcoin_gold.js +73 -0
  50. package/lib/datasets/bitcoin_gold.js.map +1 -0
  51. package/lib/datasets/dash.d.ts +5 -0
  52. package/lib/datasets/dash.d.ts.map +1 -0
  53. package/lib/datasets/dash.js +37 -0
  54. package/lib/datasets/dash.js.map +1 -0
  55. package/lib/datasets/decred.d.ts +5 -0
  56. package/lib/datasets/decred.d.ts.map +1 -0
  57. package/lib/datasets/decred.js +43 -0
  58. package/lib/datasets/decred.js.map +1 -0
  59. package/lib/datasets/digibyte.d.ts +5 -0
  60. package/lib/datasets/digibyte.d.ts.map +1 -0
  61. package/lib/datasets/digibyte.js +166 -0
  62. package/lib/datasets/digibyte.js.map +1 -0
  63. package/lib/datasets/digibyte.scanAccounts.1.d.ts +6 -0
  64. package/lib/datasets/digibyte.scanAccounts.1.d.ts.map +1 -0
  65. package/lib/datasets/digibyte.scanAccounts.1.js +56 -0
  66. package/lib/datasets/digibyte.scanAccounts.1.js.map +1 -0
  67. package/lib/datasets/dogecoin.d.ts +5 -0
  68. package/lib/datasets/dogecoin.d.ts.map +1 -0
  69. package/lib/datasets/dogecoin.js +37 -0
  70. package/lib/datasets/dogecoin.js.map +1 -0
  71. package/lib/datasets/komodo.d.ts +5 -0
  72. package/lib/datasets/komodo.d.ts.map +1 -0
  73. package/lib/datasets/komodo.js +43 -0
  74. package/lib/datasets/komodo.js.map +1 -0
  75. package/lib/datasets/litecoin.d.ts +5 -0
  76. package/lib/datasets/litecoin.d.ts.map +1 -0
  77. package/lib/datasets/litecoin.js +187 -0
  78. package/lib/datasets/litecoin.js.map +1 -0
  79. package/lib/datasets/litecoin.scanAccounts.1.d.ts +6 -0
  80. package/lib/datasets/litecoin.scanAccounts.1.d.ts.map +1 -0
  81. package/lib/datasets/litecoin.scanAccounts.1.js +56 -0
  82. package/lib/datasets/litecoin.scanAccounts.1.js.map +1 -0
  83. package/lib/datasets/peercoin.d.ts +5 -0
  84. package/lib/datasets/peercoin.d.ts.map +1 -0
  85. package/lib/datasets/peercoin.js +37 -0
  86. package/lib/datasets/peercoin.js.map +1 -0
  87. package/lib/datasets/pivx.d.ts +5 -0
  88. package/lib/datasets/pivx.d.ts.map +1 -0
  89. package/lib/datasets/pivx.js +37 -0
  90. package/lib/datasets/pivx.js.map +1 -0
  91. package/lib/datasets/qtum.d.ts +5 -0
  92. package/lib/datasets/qtum.d.ts.map +1 -0
  93. package/lib/datasets/qtum.js +57 -0
  94. package/lib/datasets/qtum.js.map +1 -0
  95. package/lib/datasets/vertcoin.d.ts +5 -0
  96. package/lib/datasets/vertcoin.d.ts.map +1 -0
  97. package/lib/datasets/vertcoin.js +69 -0
  98. package/lib/datasets/vertcoin.js.map +1 -0
  99. package/lib/datasets/viacoin.d.ts +5 -0
  100. package/lib/datasets/viacoin.d.ts.map +1 -0
  101. package/lib/datasets/viacoin.js +45 -0
  102. package/lib/datasets/viacoin.js.map +1 -0
  103. package/lib/datasets/zcash.d.ts +5 -0
  104. package/lib/datasets/zcash.d.ts.map +1 -0
  105. package/lib/datasets/zcash.js +43 -0
  106. package/lib/datasets/zcash.js.map +1 -0
  107. package/lib/datasets/zencash.d.ts +5 -0
  108. package/lib/datasets/zencash.d.ts.map +1 -0
  109. package/lib/datasets/zencash.js +37 -0
  110. package/lib/datasets/zencash.js.map +1 -0
  111. package/lib/descriptor.d.ts +19 -0
  112. package/lib/descriptor.d.ts.map +1 -0
  113. package/lib/descriptor.js +127 -0
  114. package/lib/descriptor.js.map +1 -0
  115. package/lib/descriptor.test.d.ts +2 -0
  116. package/lib/descriptor.test.d.ts.map +1 -0
  117. package/lib/descriptor.test.js +55 -0
  118. package/lib/descriptor.test.js.map +1 -0
  119. package/lib/deviceTransactionConfig.d.ts +11 -0
  120. package/lib/deviceTransactionConfig.d.ts.map +1 -0
  121. package/lib/deviceTransactionConfig.js +26 -0
  122. package/lib/deviceTransactionConfig.js.map +1 -0
  123. package/lib/errors.d.ts +7 -0
  124. package/lib/errors.d.ts.map +1 -0
  125. package/lib/errors.js +7 -0
  126. package/lib/errors.js.map +1 -0
  127. package/lib/explorer.d.ts +10 -0
  128. package/lib/explorer.d.ts.map +1 -0
  129. package/lib/explorer.js +38 -0
  130. package/lib/explorer.js.map +1 -0
  131. package/lib/formatters.d.ts +9 -0
  132. package/lib/formatters.d.ts.map +1 -0
  133. package/lib/formatters.js +51 -0
  134. package/lib/formatters.js.map +1 -0
  135. package/lib/getAccountNetworkInfo.d.ts +6 -0
  136. package/lib/getAccountNetworkInfo.d.ts.map +1 -0
  137. package/lib/getAccountNetworkInfo.js +69 -0
  138. package/lib/getAccountNetworkInfo.js.map +1 -0
  139. package/lib/getAccountNetworkInfo.test.d.ts +2 -0
  140. package/lib/getAccountNetworkInfo.test.d.ts.map +1 -0
  141. package/lib/getAccountNetworkInfo.test.js +49 -0
  142. package/lib/getAccountNetworkInfo.test.js.map +1 -0
  143. package/lib/hw-getAddress.d.ts +5 -0
  144. package/lib/hw-getAddress.d.ts.map +1 -0
  145. package/lib/hw-getAddress.js +45 -0
  146. package/lib/hw-getAddress.js.map +1 -0
  147. package/lib/hw-signMessage.d.ts +7 -0
  148. package/lib/hw-signMessage.d.ts.map +1 -0
  149. package/lib/hw-signMessage.js +27 -0
  150. package/lib/hw-signMessage.js.map +1 -0
  151. package/lib/js-broadcast.d.ts +11 -0
  152. package/lib/js-broadcast.d.ts.map +1 -0
  153. package/lib/js-broadcast.js +48 -0
  154. package/lib/js-broadcast.js.map +1 -0
  155. package/lib/js-buildTransaction.d.ts +5 -0
  156. package/lib/js-buildTransaction.d.ts.map +1 -0
  157. package/lib/js-buildTransaction.js +75 -0
  158. package/lib/js-buildTransaction.js.map +1 -0
  159. package/lib/js-createTransaction.d.ts +9 -0
  160. package/lib/js-createTransaction.d.ts.map +1 -0
  161. package/lib/js-createTransaction.js +26 -0
  162. package/lib/js-createTransaction.js.map +1 -0
  163. package/lib/js-estimateMaxSpendable.d.ts +15 -0
  164. package/lib/js-estimateMaxSpendable.d.ts.map +1 -0
  165. package/lib/js-estimateMaxSpendable.js +58 -0
  166. package/lib/js-estimateMaxSpendable.js.map +1 -0
  167. package/lib/js-getFeesForTransaction.d.ts +13 -0
  168. package/lib/js-getFeesForTransaction.d.ts.map +1 -0
  169. package/lib/js-getFeesForTransaction.js +52 -0
  170. package/lib/js-getFeesForTransaction.js.map +1 -0
  171. package/lib/js-getTransactionStatus.d.ts +5 -0
  172. package/lib/js-getTransactionStatus.d.ts.map +1 -0
  173. package/lib/js-getTransactionStatus.js +113 -0
  174. package/lib/js-getTransactionStatus.js.map +1 -0
  175. package/lib/js-prepareTransaction.d.ts +5 -0
  176. package/lib/js-prepareTransaction.d.ts.map +1 -0
  177. package/lib/js-prepareTransaction.js +35 -0
  178. package/lib/js-prepareTransaction.js.map +1 -0
  179. package/lib/js-signOperation.d.ts +6 -0
  180. package/lib/js-signOperation.d.ts.map +1 -0
  181. package/lib/js-signOperation.js +152 -0
  182. package/lib/js-signOperation.js.map +1 -0
  183. package/lib/js-synchronisation.d.ts +13 -0
  184. package/lib/js-synchronisation.d.ts.map +1 -0
  185. package/lib/js-synchronisation.js +198 -0
  186. package/lib/js-synchronisation.js.map +1 -0
  187. package/lib/logic.d.ts +36 -0
  188. package/lib/logic.d.ts.map +1 -0
  189. package/lib/logic.js +266 -0
  190. package/lib/logic.js.map +1 -0
  191. package/lib/logic.unit.test.d.ts +2 -0
  192. package/lib/logic.unit.test.d.ts.map +1 -0
  193. package/lib/logic.unit.test.js +35 -0
  194. package/lib/logic.unit.test.js.map +1 -0
  195. package/lib/mockBtcSigner.d.ts +20 -0
  196. package/lib/mockBtcSigner.d.ts.map +1 -0
  197. package/lib/mockBtcSigner.js +63 -0
  198. package/lib/mockBtcSigner.js.map +1 -0
  199. package/lib/networks.d.ts +3 -0
  200. package/lib/networks.d.ts.map +1 -0
  201. package/lib/networks.js +341 -0
  202. package/lib/networks.js.map +1 -0
  203. package/lib/publicAddresses.test.d.ts +2 -0
  204. package/lib/publicAddresses.test.d.ts.map +1 -0
  205. package/lib/publicAddresses.test.js +12 -0
  206. package/lib/publicAddresses.test.js.map +1 -0
  207. package/lib/serialization.d.ts +11 -0
  208. package/lib/serialization.d.ts.map +1 -0
  209. package/lib/serialization.js +65 -0
  210. package/lib/serialization.js.map +1 -0
  211. package/lib/serialization.test.d.ts +2 -0
  212. package/lib/serialization.test.d.ts.map +1 -0
  213. package/lib/serialization.test.js +108 -0
  214. package/lib/serialization.test.js.map +1 -0
  215. package/lib/signer.d.ts +70 -0
  216. package/lib/signer.d.ts.map +1 -0
  217. package/lib/signer.js +3 -0
  218. package/lib/signer.js.map +1 -0
  219. package/lib/specs.d.ts +23 -0
  220. package/lib/specs.d.ts.map +1 -0
  221. package/lib/specs.js +524 -0
  222. package/lib/specs.js.map +1 -0
  223. package/lib/speculos-deviceActions.d.ts +4 -0
  224. package/lib/speculos-deviceActions.d.ts.map +1 -0
  225. package/lib/speculos-deviceActions.js +61 -0
  226. package/lib/speculos-deviceActions.js.map +1 -0
  227. package/lib/transaction.d.ts +16 -0
  228. package/lib/transaction.d.ts.map +1 -0
  229. package/lib/transaction.js +114 -0
  230. package/lib/transaction.js.map +1 -0
  231. package/lib/types.d.ts +140 -0
  232. package/lib/types.d.ts.map +1 -0
  233. package/lib/types.js +23 -0
  234. package/lib/types.js.map +1 -0
  235. package/lib/wallet-btc/__tests__/bitcoin.test.d.ts +2 -0
  236. package/lib/wallet-btc/__tests__/bitcoin.test.d.ts.map +1 -0
  237. package/lib/wallet-btc/__tests__/bitcoin.test.js +309 -0
  238. package/lib/wallet-btc/__tests__/bitcoin.test.js.map +1 -0
  239. package/lib/wallet-btc/__tests__/logic.d.ts +2 -0
  240. package/lib/wallet-btc/__tests__/logic.d.ts.map +1 -0
  241. package/lib/wallet-btc/__tests__/logic.js +24 -0
  242. package/lib/wallet-btc/__tests__/logic.js.map +1 -0
  243. package/lib/wallet-btc/__tests__/utils.test.d.ts +2 -0
  244. package/lib/wallet-btc/__tests__/utils.test.d.ts.map +1 -0
  245. package/lib/wallet-btc/__tests__/utils.test.js +223 -0
  246. package/lib/wallet-btc/__tests__/utils.test.js.map +1 -0
  247. package/lib/wallet-btc/__tests__/wallet.errorpropagation.integration.test.d.ts +2 -0
  248. package/lib/wallet-btc/__tests__/wallet.errorpropagation.integration.test.d.ts.map +1 -0
  249. package/lib/wallet-btc/__tests__/wallet.errorpropagation.integration.test.js +46 -0
  250. package/lib/wallet-btc/__tests__/wallet.errorpropagation.integration.test.js.map +1 -0
  251. package/lib/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.d.ts +2 -0
  252. package/lib/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.d.ts.map +1 -0
  253. package/lib/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.js +78 -0
  254. package/lib/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.js.map +1 -0
  255. package/lib/wallet-btc/__tests__/wallet.explorer.integration.test.d.ts +2 -0
  256. package/lib/wallet-btc/__tests__/wallet.explorer.integration.test.d.ts.map +1 -0
  257. package/lib/wallet-btc/__tests__/wallet.explorer.integration.test.js +43 -0
  258. package/lib/wallet-btc/__tests__/wallet.explorer.integration.test.js.map +1 -0
  259. package/lib/wallet-btc/__tests__/wallet.explorer.unit.test.d.ts +2 -0
  260. package/lib/wallet-btc/__tests__/wallet.explorer.unit.test.d.ts.map +1 -0
  261. package/lib/wallet-btc/__tests__/wallet.explorer.unit.test.js +189 -0
  262. package/lib/wallet-btc/__tests__/wallet.explorer.unit.test.js.map +1 -0
  263. package/lib/wallet-btc/__tests__/wallet.integration.test.d.ts +2 -0
  264. package/lib/wallet-btc/__tests__/wallet.integration.test.d.ts.map +1 -0
  265. package/lib/wallet-btc/__tests__/wallet.integration.test.js +110 -0
  266. package/lib/wallet-btc/__tests__/wallet.integration.test.js.map +1 -0
  267. package/lib/wallet-btc/__tests__/wallet.storage.unit.test.d.ts +2 -0
  268. package/lib/wallet-btc/__tests__/wallet.storage.unit.test.d.ts.map +1 -0
  269. package/lib/wallet-btc/__tests__/wallet.storage.unit.test.js +176 -0
  270. package/lib/wallet-btc/__tests__/wallet.storage.unit.test.js.map +1 -0
  271. package/lib/wallet-btc/__tests__/xpub.getAddress.integration.test.d.ts +2 -0
  272. package/lib/wallet-btc/__tests__/xpub.getAddress.integration.test.d.ts.map +1 -0
  273. package/lib/wallet-btc/__tests__/xpub.getAddress.integration.test.js +77 -0
  274. package/lib/wallet-btc/__tests__/xpub.getAddress.integration.test.js.map +1 -0
  275. package/lib/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.d.ts +2 -0
  276. package/lib/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.d.ts.map +1 -0
  277. package/lib/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.js +325 -0
  278. package/lib/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.js.map +1 -0
  279. package/lib/wallet-btc/__tests__/xpub.reorg.integration.test.d.ts +2 -0
  280. package/lib/wallet-btc/__tests__/xpub.reorg.integration.test.d.ts.map +1 -0
  281. package/lib/wallet-btc/__tests__/xpub.reorg.integration.test.js +152 -0
  282. package/lib/wallet-btc/__tests__/xpub.reorg.integration.test.js.map +1 -0
  283. package/lib/wallet-btc/__tests__/xpub.synced.integration.test.d.ts +2 -0
  284. package/lib/wallet-btc/__tests__/xpub.synced.integration.test.d.ts.map +1 -0
  285. package/lib/wallet-btc/__tests__/xpub.synced.integration.test.js +74 -0
  286. package/lib/wallet-btc/__tests__/xpub.synced.integration.test.js.map +1 -0
  287. package/lib/wallet-btc/__tests__/xpub.syncing.integration.test.d.ts +2 -0
  288. package/lib/wallet-btc/__tests__/xpub.syncing.integration.test.d.ts.map +1 -0
  289. package/lib/wallet-btc/__tests__/xpub.syncing.integration.test.js +209 -0
  290. package/lib/wallet-btc/__tests__/xpub.syncing.integration.test.js.map +1 -0
  291. package/lib/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.d.ts +2 -0
  292. package/lib/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.d.ts.map +1 -0
  293. package/lib/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.js +186 -0
  294. package/lib/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.js.map +1 -0
  295. package/lib/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.d.ts +2 -0
  296. package/lib/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.d.ts.map +1 -0
  297. package/lib/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.js +178 -0
  298. package/lib/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.js.map +1 -0
  299. package/lib/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.d.ts +2 -0
  300. package/lib/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.d.ts.map +1 -0
  301. package/lib/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.js +100 -0
  302. package/lib/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.js.map +1 -0
  303. package/lib/wallet-btc/__tests__/xpub.txs.integration.test.d.ts +2 -0
  304. package/lib/wallet-btc/__tests__/xpub.txs.integration.test.d.ts.map +1 -0
  305. package/lib/wallet-btc/__tests__/xpub.txs.integration.test.js +315 -0
  306. package/lib/wallet-btc/__tests__/xpub.txs.integration.test.js.map +1 -0
  307. package/lib/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.d.ts +2 -0
  308. package/lib/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.d.ts.map +1 -0
  309. package/lib/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.js +171 -0
  310. package/lib/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.js.map +1 -0
  311. package/lib/wallet-btc/__tests__/xpub.utxo.unit.test.d.ts +2 -0
  312. package/lib/wallet-btc/__tests__/xpub.utxo.unit.test.d.ts.map +1 -0
  313. package/lib/wallet-btc/__tests__/xpub.utxo.unit.test.js +51 -0
  314. package/lib/wallet-btc/__tests__/xpub.utxo.unit.test.js.map +1 -0
  315. package/lib/wallet-btc/account.d.ts +27 -0
  316. package/lib/wallet-btc/account.d.ts.map +1 -0
  317. package/lib/wallet-btc/account.js +3 -0
  318. package/lib/wallet-btc/account.js.map +1 -0
  319. package/lib/wallet-btc/crypto/base.d.ts +33 -0
  320. package/lib/wallet-btc/crypto/base.d.ts.map +1 -0
  321. package/lib/wallet-btc/crypto/base.js +196 -0
  322. package/lib/wallet-btc/crypto/base.js.map +1 -0
  323. package/lib/wallet-btc/crypto/bip32.d.ts +11 -0
  324. package/lib/wallet-btc/crypto/bip32.d.ts.map +1 -0
  325. package/lib/wallet-btc/crypto/bip32.js +45 -0
  326. package/lib/wallet-btc/crypto/bip32.js.map +1 -0
  327. package/lib/wallet-btc/crypto/bitcoin.d.ts +13 -0
  328. package/lib/wallet-btc/crypto/bitcoin.d.ts.map +1 -0
  329. package/lib/wallet-btc/crypto/bitcoin.js +226 -0
  330. package/lib/wallet-btc/crypto/bitcoin.js.map +1 -0
  331. package/lib/wallet-btc/crypto/bitcoincash.d.ts +13 -0
  332. package/lib/wallet-btc/crypto/bitcoincash.d.ts.map +1 -0
  333. package/lib/wallet-btc/crypto/bitcoincash.js +55 -0
  334. package/lib/wallet-btc/crypto/bitcoincash.js.map +1 -0
  335. package/lib/wallet-btc/crypto/bitcoingold.d.ts +8 -0
  336. package/lib/wallet-btc/crypto/bitcoingold.d.ts.map +1 -0
  337. package/lib/wallet-btc/crypto/bitcoingold.js +17 -0
  338. package/lib/wallet-btc/crypto/bitcoingold.js.map +1 -0
  339. package/lib/wallet-btc/crypto/dash.d.ts +8 -0
  340. package/lib/wallet-btc/crypto/dash.d.ts.map +1 -0
  341. package/lib/wallet-btc/crypto/dash.js +25 -0
  342. package/lib/wallet-btc/crypto/dash.js.map +1 -0
  343. package/lib/wallet-btc/crypto/decred.d.ts +15 -0
  344. package/lib/wallet-btc/crypto/decred.d.ts.map +1 -0
  345. package/lib/wallet-btc/crypto/decred.js +121 -0
  346. package/lib/wallet-btc/crypto/decred.js.map +1 -0
  347. package/lib/wallet-btc/crypto/digibyte.d.ts +9 -0
  348. package/lib/wallet-btc/crypto/digibyte.d.ts.map +1 -0
  349. package/lib/wallet-btc/crypto/digibyte.js +58 -0
  350. package/lib/wallet-btc/crypto/digibyte.js.map +1 -0
  351. package/lib/wallet-btc/crypto/doge.d.ts +8 -0
  352. package/lib/wallet-btc/crypto/doge.d.ts.map +1 -0
  353. package/lib/wallet-btc/crypto/doge.js +19 -0
  354. package/lib/wallet-btc/crypto/doge.js.map +1 -0
  355. package/lib/wallet-btc/crypto/factory.d.ts +3 -0
  356. package/lib/wallet-btc/crypto/factory.d.ts.map +1 -0
  357. package/lib/wallet-btc/crypto/factory.js +132 -0
  358. package/lib/wallet-btc/crypto/factory.js.map +1 -0
  359. package/lib/wallet-btc/crypto/index.d.ts +19 -0
  360. package/lib/wallet-btc/crypto/index.d.ts.map +1 -0
  361. package/lib/wallet-btc/crypto/index.js +44 -0
  362. package/lib/wallet-btc/crypto/index.js.map +1 -0
  363. package/lib/wallet-btc/crypto/komodo.d.ts +8 -0
  364. package/lib/wallet-btc/crypto/komodo.d.ts.map +1 -0
  365. package/lib/wallet-btc/crypto/komodo.js +20 -0
  366. package/lib/wallet-btc/crypto/komodo.js.map +1 -0
  367. package/lib/wallet-btc/crypto/litecoin.d.ts +10 -0
  368. package/lib/wallet-btc/crypto/litecoin.d.ts.map +1 -0
  369. package/lib/wallet-btc/crypto/litecoin.js +56 -0
  370. package/lib/wallet-btc/crypto/litecoin.js.map +1 -0
  371. package/lib/wallet-btc/crypto/peercoin.d.ts +8 -0
  372. package/lib/wallet-btc/crypto/peercoin.d.ts.map +1 -0
  373. package/lib/wallet-btc/crypto/peercoin.js +19 -0
  374. package/lib/wallet-btc/crypto/peercoin.js.map +1 -0
  375. package/lib/wallet-btc/crypto/pivx.d.ts +8 -0
  376. package/lib/wallet-btc/crypto/pivx.d.ts.map +1 -0
  377. package/lib/wallet-btc/crypto/pivx.js +21 -0
  378. package/lib/wallet-btc/crypto/pivx.js.map +1 -0
  379. package/lib/wallet-btc/crypto/qtum.d.ts +8 -0
  380. package/lib/wallet-btc/crypto/qtum.d.ts.map +1 -0
  381. package/lib/wallet-btc/crypto/qtum.js +17 -0
  382. package/lib/wallet-btc/crypto/qtum.js.map +1 -0
  383. package/lib/wallet-btc/crypto/secp256k1.d.ts +16 -0
  384. package/lib/wallet-btc/crypto/secp256k1.d.ts.map +1 -0
  385. package/lib/wallet-btc/crypto/secp256k1.js +26 -0
  386. package/lib/wallet-btc/crypto/secp256k1.js.map +1 -0
  387. package/lib/wallet-btc/crypto/stealth.d.ts +8 -0
  388. package/lib/wallet-btc/crypto/stealth.d.ts.map +1 -0
  389. package/lib/wallet-btc/crypto/stealth.js +21 -0
  390. package/lib/wallet-btc/crypto/stealth.js.map +1 -0
  391. package/lib/wallet-btc/crypto/types.d.ts +11 -0
  392. package/lib/wallet-btc/crypto/types.d.ts.map +1 -0
  393. package/lib/wallet-btc/crypto/types.js +3 -0
  394. package/lib/wallet-btc/crypto/types.js.map +1 -0
  395. package/lib/wallet-btc/crypto/via.d.ts +8 -0
  396. package/lib/wallet-btc/crypto/via.d.ts.map +1 -0
  397. package/lib/wallet-btc/crypto/via.js +17 -0
  398. package/lib/wallet-btc/crypto/via.js.map +1 -0
  399. package/lib/wallet-btc/crypto/vtc.d.ts +8 -0
  400. package/lib/wallet-btc/crypto/vtc.d.ts.map +1 -0
  401. package/lib/wallet-btc/crypto/vtc.js +17 -0
  402. package/lib/wallet-btc/crypto/vtc.js.map +1 -0
  403. package/lib/wallet-btc/crypto/zec.d.ts +13 -0
  404. package/lib/wallet-btc/crypto/zec.d.ts.map +1 -0
  405. package/lib/wallet-btc/crypto/zec.js +95 -0
  406. package/lib/wallet-btc/crypto/zec.js.map +1 -0
  407. package/lib/wallet-btc/crypto/zen.d.ts +13 -0
  408. package/lib/wallet-btc/crypto/zen.d.ts.map +1 -0
  409. package/lib/wallet-btc/crypto/zen.js +116 -0
  410. package/lib/wallet-btc/crypto/zen.js.map +1 -0
  411. package/lib/wallet-btc/explorer/index.d.ts +47 -0
  412. package/lib/wallet-btc/explorer/index.d.ts.map +1 -0
  413. package/lib/wallet-btc/explorer/index.js +191 -0
  414. package/lib/wallet-btc/explorer/index.js.map +1 -0
  415. package/lib/wallet-btc/explorer/types.d.ts +18 -0
  416. package/lib/wallet-btc/explorer/types.d.ts.map +1 -0
  417. package/lib/wallet-btc/explorer/types.js +3 -0
  418. package/lib/wallet-btc/explorer/types.js.map +1 -0
  419. package/lib/wallet-btc/index.d.ts +16 -0
  420. package/lib/wallet-btc/index.d.ts.map +1 -0
  421. package/lib/wallet-btc/index.js +38 -0
  422. package/lib/wallet-btc/index.js.map +1 -0
  423. package/lib/wallet-btc/pickingstrategies/CoinSelect.d.ts +18 -0
  424. package/lib/wallet-btc/pickingstrategies/CoinSelect.d.ts.map +1 -0
  425. package/lib/wallet-btc/pickingstrategies/CoinSelect.js +186 -0
  426. package/lib/wallet-btc/pickingstrategies/CoinSelect.js.map +1 -0
  427. package/lib/wallet-btc/pickingstrategies/DeepFirst.d.ts +17 -0
  428. package/lib/wallet-btc/pickingstrategies/DeepFirst.d.ts.map +1 -0
  429. package/lib/wallet-btc/pickingstrategies/DeepFirst.js +100 -0
  430. package/lib/wallet-btc/pickingstrategies/DeepFirst.js.map +1 -0
  431. package/lib/wallet-btc/pickingstrategies/Merge.d.ts +17 -0
  432. package/lib/wallet-btc/pickingstrategies/Merge.d.ts.map +1 -0
  433. package/lib/wallet-btc/pickingstrategies/Merge.js +100 -0
  434. package/lib/wallet-btc/pickingstrategies/Merge.js.map +1 -0
  435. package/lib/wallet-btc/pickingstrategies/types.d.ts +27 -0
  436. package/lib/wallet-btc/pickingstrategies/types.d.ts.map +1 -0
  437. package/lib/wallet-btc/pickingstrategies/types.js +12 -0
  438. package/lib/wallet-btc/pickingstrategies/types.js.map +1 -0
  439. package/lib/wallet-btc/storage/index.d.ts +77 -0
  440. package/lib/wallet-btc/storage/index.d.ts.map +1 -0
  441. package/lib/wallet-btc/storage/index.js +236 -0
  442. package/lib/wallet-btc/storage/index.js.map +1 -0
  443. package/lib/wallet-btc/storage/types.d.ts +74 -0
  444. package/lib/wallet-btc/storage/types.d.ts.map +1 -0
  445. package/lib/wallet-btc/storage/types.js +3 -0
  446. package/lib/wallet-btc/storage/types.js.map +1 -0
  447. package/lib/wallet-btc/types.d.ts +25 -0
  448. package/lib/wallet-btc/types.d.ts.map +1 -0
  449. package/lib/wallet-btc/types.js +11 -0
  450. package/lib/wallet-btc/types.js.map +1 -0
  451. package/lib/wallet-btc/utils.d.ts +45 -0
  452. package/lib/wallet-btc/utils.d.ts.map +1 -0
  453. package/lib/wallet-btc/utils.js +189 -0
  454. package/lib/wallet-btc/utils.js.map +1 -0
  455. package/lib/wallet-btc/wallet.d.ts +80 -0
  456. package/lib/wallet-btc/wallet.d.ts.map +1 -0
  457. package/lib/wallet-btc/wallet.js +291 -0
  458. package/lib/wallet-btc/wallet.js.map +1 -0
  459. package/lib/wallet-btc/xpub.d.ts +52 -0
  460. package/lib/wallet-btc/xpub.d.ts.map +1 -0
  461. package/lib/wallet-btc/xpub.js +296 -0
  462. package/lib/wallet-btc/xpub.js.map +1 -0
  463. package/lib/xpub.txs.loadExport.unit.test.d.ts +2 -0
  464. package/lib/xpub.txs.loadExport.unit.test.d.ts.map +1 -0
  465. package/lib/xpub.txs.loadExport.unit.test.js +110 -0
  466. package/lib/xpub.txs.loadExport.unit.test.js.map +1 -0
  467. package/lib/xpub.txs.txNoOutput.unit.test.d.ts +2 -0
  468. package/lib/xpub.txs.txNoOutput.unit.test.d.ts.map +1 -0
  469. package/lib/xpub.txs.txNoOutput.unit.test.js +41 -0
  470. package/lib/xpub.txs.txNoOutput.unit.test.js.map +1 -0
  471. package/lib-es/account.d.ts +7 -0
  472. package/lib-es/account.d.ts.map +1 -0
  473. package/lib-es/account.js +11 -0
  474. package/lib-es/account.js.map +1 -0
  475. package/lib-es/bech32m.d.ts +16 -0
  476. package/lib-es/bech32m.d.ts.map +1 -0
  477. package/lib-es/bech32m.js +163 -0
  478. package/lib-es/bech32m.js.map +1 -0
  479. package/lib-es/bridge/js.d.ts +41 -0
  480. package/lib-es/bridge/js.d.ts.map +1 -0
  481. package/lib-es/bridge/js.js +85 -0
  482. package/lib-es/bridge/js.js.map +1 -0
  483. package/lib-es/bridge.integration.test.d.ts +4 -0
  484. package/lib-es/bridge.integration.test.d.ts.map +1 -0
  485. package/lib-es/bridge.integration.test.js +41 -0
  486. package/lib-es/bridge.integration.test.js.map +1 -0
  487. package/lib-es/cache.d.ts +17 -0
  488. package/lib-es/cache.d.ts.map +1 -0
  489. package/lib-es/cache.js +56 -0
  490. package/lib-es/cache.js.map +1 -0
  491. package/lib-es/cli-transaction.d.ts +30 -0
  492. package/lib-es/cli-transaction.d.ts.map +1 -0
  493. package/lib-es/cli-transaction.js +55 -0
  494. package/lib-es/cli-transaction.js.map +1 -0
  495. package/lib-es/crypto-util.d.ts +5 -0
  496. package/lib-es/crypto-util.d.ts.map +1 -0
  497. package/lib-es/crypto-util.js +15 -0
  498. package/lib-es/crypto-util.js.map +1 -0
  499. package/lib-es/datasets/bitcoin.d.ts +7 -0
  500. package/lib-es/datasets/bitcoin.d.ts.map +1 -0
  501. package/lib-es/datasets/bitcoin.js +312 -0
  502. package/lib-es/datasets/bitcoin.js.map +1 -0
  503. package/lib-es/datasets/bitcoin.scanAccounts.1.d.ts +6 -0
  504. package/lib-es/datasets/bitcoin.scanAccounts.1.d.ts.map +1 -0
  505. package/lib-es/datasets/bitcoin.scanAccounts.1.js +238 -0
  506. package/lib-es/datasets/bitcoin.scanAccounts.1.js.map +1 -0
  507. package/lib-es/datasets/bitcoin_cash.d.ts +5 -0
  508. package/lib-es/datasets/bitcoin_cash.d.ts.map +1 -0
  509. package/lib-es/datasets/bitcoin_cash.js +43 -0
  510. package/lib-es/datasets/bitcoin_cash.js.map +1 -0
  511. package/lib-es/datasets/bitcoin_gold.d.ts +5 -0
  512. package/lib-es/datasets/bitcoin_gold.d.ts.map +1 -0
  513. package/lib-es/datasets/bitcoin_gold.js +71 -0
  514. package/lib-es/datasets/bitcoin_gold.js.map +1 -0
  515. package/lib-es/datasets/dash.d.ts +5 -0
  516. package/lib-es/datasets/dash.d.ts.map +1 -0
  517. package/lib-es/datasets/dash.js +35 -0
  518. package/lib-es/datasets/dash.js.map +1 -0
  519. package/lib-es/datasets/decred.d.ts +5 -0
  520. package/lib-es/datasets/decred.d.ts.map +1 -0
  521. package/lib-es/datasets/decred.js +41 -0
  522. package/lib-es/datasets/decred.js.map +1 -0
  523. package/lib-es/datasets/digibyte.d.ts +5 -0
  524. package/lib-es/datasets/digibyte.d.ts.map +1 -0
  525. package/lib-es/datasets/digibyte.js +161 -0
  526. package/lib-es/datasets/digibyte.js.map +1 -0
  527. package/lib-es/datasets/digibyte.scanAccounts.1.d.ts +6 -0
  528. package/lib-es/datasets/digibyte.scanAccounts.1.d.ts.map +1 -0
  529. package/lib-es/datasets/digibyte.scanAccounts.1.js +54 -0
  530. package/lib-es/datasets/digibyte.scanAccounts.1.js.map +1 -0
  531. package/lib-es/datasets/dogecoin.d.ts +5 -0
  532. package/lib-es/datasets/dogecoin.d.ts.map +1 -0
  533. package/lib-es/datasets/dogecoin.js +35 -0
  534. package/lib-es/datasets/dogecoin.js.map +1 -0
  535. package/lib-es/datasets/komodo.d.ts +5 -0
  536. package/lib-es/datasets/komodo.d.ts.map +1 -0
  537. package/lib-es/datasets/komodo.js +41 -0
  538. package/lib-es/datasets/komodo.js.map +1 -0
  539. package/lib-es/datasets/litecoin.d.ts +5 -0
  540. package/lib-es/datasets/litecoin.d.ts.map +1 -0
  541. package/lib-es/datasets/litecoin.js +182 -0
  542. package/lib-es/datasets/litecoin.js.map +1 -0
  543. package/lib-es/datasets/litecoin.scanAccounts.1.d.ts +6 -0
  544. package/lib-es/datasets/litecoin.scanAccounts.1.d.ts.map +1 -0
  545. package/lib-es/datasets/litecoin.scanAccounts.1.js +54 -0
  546. package/lib-es/datasets/litecoin.scanAccounts.1.js.map +1 -0
  547. package/lib-es/datasets/peercoin.d.ts +5 -0
  548. package/lib-es/datasets/peercoin.d.ts.map +1 -0
  549. package/lib-es/datasets/peercoin.js +35 -0
  550. package/lib-es/datasets/peercoin.js.map +1 -0
  551. package/lib-es/datasets/pivx.d.ts +5 -0
  552. package/lib-es/datasets/pivx.d.ts.map +1 -0
  553. package/lib-es/datasets/pivx.js +35 -0
  554. package/lib-es/datasets/pivx.js.map +1 -0
  555. package/lib-es/datasets/qtum.d.ts +5 -0
  556. package/lib-es/datasets/qtum.d.ts.map +1 -0
  557. package/lib-es/datasets/qtum.js +55 -0
  558. package/lib-es/datasets/qtum.js.map +1 -0
  559. package/lib-es/datasets/vertcoin.d.ts +5 -0
  560. package/lib-es/datasets/vertcoin.d.ts.map +1 -0
  561. package/lib-es/datasets/vertcoin.js +67 -0
  562. package/lib-es/datasets/vertcoin.js.map +1 -0
  563. package/lib-es/datasets/viacoin.d.ts +5 -0
  564. package/lib-es/datasets/viacoin.d.ts.map +1 -0
  565. package/lib-es/datasets/viacoin.js +43 -0
  566. package/lib-es/datasets/viacoin.js.map +1 -0
  567. package/lib-es/datasets/zcash.d.ts +5 -0
  568. package/lib-es/datasets/zcash.d.ts.map +1 -0
  569. package/lib-es/datasets/zcash.js +41 -0
  570. package/lib-es/datasets/zcash.js.map +1 -0
  571. package/lib-es/datasets/zencash.d.ts +5 -0
  572. package/lib-es/datasets/zencash.d.ts.map +1 -0
  573. package/lib-es/datasets/zencash.js +35 -0
  574. package/lib-es/datasets/zencash.js.map +1 -0
  575. package/lib-es/descriptor.d.ts +19 -0
  576. package/lib-es/descriptor.d.ts.map +1 -0
  577. package/lib-es/descriptor.js +118 -0
  578. package/lib-es/descriptor.js.map +1 -0
  579. package/lib-es/descriptor.test.d.ts +2 -0
  580. package/lib-es/descriptor.test.d.ts.map +1 -0
  581. package/lib-es/descriptor.test.js +50 -0
  582. package/lib-es/descriptor.test.js.map +1 -0
  583. package/lib-es/deviceTransactionConfig.d.ts +11 -0
  584. package/lib-es/deviceTransactionConfig.d.ts.map +1 -0
  585. package/lib-es/deviceTransactionConfig.js +24 -0
  586. package/lib-es/deviceTransactionConfig.js.map +1 -0
  587. package/lib-es/errors.d.ts +7 -0
  588. package/lib-es/errors.d.ts.map +1 -0
  589. package/lib-es/errors.js +4 -0
  590. package/lib-es/errors.js.map +1 -0
  591. package/lib-es/explorer.d.ts +10 -0
  592. package/lib-es/explorer.d.ts.map +1 -0
  593. package/lib-es/explorer.js +30 -0
  594. package/lib-es/explorer.js.map +1 -0
  595. package/lib-es/formatters.d.ts +9 -0
  596. package/lib-es/formatters.d.ts.map +1 -0
  597. package/lib-es/formatters.js +46 -0
  598. package/lib-es/formatters.js.map +1 -0
  599. package/lib-es/getAccountNetworkInfo.d.ts +6 -0
  600. package/lib-es/getAccountNetworkInfo.d.ts.map +1 -0
  601. package/lib-es/getAccountNetworkInfo.js +61 -0
  602. package/lib-es/getAccountNetworkInfo.js.map +1 -0
  603. package/lib-es/getAccountNetworkInfo.test.d.ts +2 -0
  604. package/lib-es/getAccountNetworkInfo.test.d.ts.map +1 -0
  605. package/lib-es/getAccountNetworkInfo.test.js +47 -0
  606. package/lib-es/getAccountNetworkInfo.test.js.map +1 -0
  607. package/lib-es/hw-getAddress.d.ts +5 -0
  608. package/lib-es/hw-getAddress.d.ts.map +1 -0
  609. package/lib-es/hw-getAddress.js +43 -0
  610. package/lib-es/hw-getAddress.js.map +1 -0
  611. package/lib-es/hw-signMessage.d.ts +7 -0
  612. package/lib-es/hw-signMessage.d.ts.map +1 -0
  613. package/lib-es/hw-signMessage.js +23 -0
  614. package/lib-es/hw-signMessage.js.map +1 -0
  615. package/lib-es/js-broadcast.d.ts +11 -0
  616. package/lib-es/js-broadcast.d.ts.map +1 -0
  617. package/lib-es/js-broadcast.js +23 -0
  618. package/lib-es/js-broadcast.js.map +1 -0
  619. package/lib-es/js-buildTransaction.d.ts +5 -0
  620. package/lib-es/js-buildTransaction.d.ts.map +1 -0
  621. package/lib-es/js-buildTransaction.js +48 -0
  622. package/lib-es/js-buildTransaction.js.map +1 -0
  623. package/lib-es/js-createTransaction.d.ts +9 -0
  624. package/lib-es/js-createTransaction.d.ts.map +1 -0
  625. package/lib-es/js-createTransaction.js +24 -0
  626. package/lib-es/js-createTransaction.js.map +1 -0
  627. package/lib-es/js-estimateMaxSpendable.d.ts +15 -0
  628. package/lib-es/js-estimateMaxSpendable.d.ts.map +1 -0
  629. package/lib-es/js-estimateMaxSpendable.js +33 -0
  630. package/lib-es/js-estimateMaxSpendable.js.map +1 -0
  631. package/lib-es/js-getFeesForTransaction.d.ts +13 -0
  632. package/lib-es/js-getFeesForTransaction.d.ts.map +1 -0
  633. package/lib-es/js-getFeesForTransaction.js +50 -0
  634. package/lib-es/js-getFeesForTransaction.js.map +1 -0
  635. package/lib-es/js-getTransactionStatus.d.ts +5 -0
  636. package/lib-es/js-getTransactionStatus.d.ts.map +1 -0
  637. package/lib-es/js-getTransactionStatus.js +108 -0
  638. package/lib-es/js-getTransactionStatus.js.map +1 -0
  639. package/lib-es/js-prepareTransaction.d.ts +5 -0
  640. package/lib-es/js-prepareTransaction.d.ts.map +1 -0
  641. package/lib-es/js-prepareTransaction.js +30 -0
  642. package/lib-es/js-prepareTransaction.js.map +1 -0
  643. package/lib-es/js-signOperation.d.ts +6 -0
  644. package/lib-es/js-signOperation.d.ts.map +1 -0
  645. package/lib-es/js-signOperation.js +127 -0
  646. package/lib-es/js-signOperation.js.map +1 -0
  647. package/lib-es/js-synchronisation.d.ts +13 -0
  648. package/lib-es/js-synchronisation.d.ts.map +1 -0
  649. package/lib-es/js-synchronisation.js +190 -0
  650. package/lib-es/js-synchronisation.js.map +1 -0
  651. package/lib-es/logic.d.ts +36 -0
  652. package/lib-es/logic.d.ts.map +1 -0
  653. package/lib-es/logic.js +254 -0
  654. package/lib-es/logic.js.map +1 -0
  655. package/lib-es/logic.unit.test.d.ts +2 -0
  656. package/lib-es/logic.unit.test.d.ts.map +1 -0
  657. package/lib-es/logic.unit.test.js +33 -0
  658. package/lib-es/logic.unit.test.js.map +1 -0
  659. package/lib-es/mockBtcSigner.d.ts +20 -0
  660. package/lib-es/mockBtcSigner.d.ts.map +1 -0
  661. package/lib-es/mockBtcSigner.js +58 -0
  662. package/lib-es/mockBtcSigner.js.map +1 -0
  663. package/lib-es/networks.d.ts +3 -0
  664. package/lib-es/networks.d.ts.map +1 -0
  665. package/lib-es/networks.js +337 -0
  666. package/lib-es/networks.js.map +1 -0
  667. package/lib-es/publicAddresses.test.d.ts +2 -0
  668. package/lib-es/publicAddresses.test.d.ts.map +1 -0
  669. package/lib-es/publicAddresses.test.js +10 -0
  670. package/lib-es/publicAddresses.test.js.map +1 -0
  671. package/lib-es/serialization.d.ts +11 -0
  672. package/lib-es/serialization.d.ts.map +1 -0
  673. package/lib-es/serialization.js +51 -0
  674. package/lib-es/serialization.js.map +1 -0
  675. package/lib-es/serialization.test.d.ts +2 -0
  676. package/lib-es/serialization.test.d.ts.map +1 -0
  677. package/lib-es/serialization.test.js +103 -0
  678. package/lib-es/serialization.test.js.map +1 -0
  679. package/lib-es/signer.d.ts +70 -0
  680. package/lib-es/signer.d.ts.map +1 -0
  681. package/lib-es/signer.js +2 -0
  682. package/lib-es/signer.js.map +1 -0
  683. package/lib-es/specs.d.ts +23 -0
  684. package/lib-es/specs.d.ts.map +1 -0
  685. package/lib-es/specs.js +519 -0
  686. package/lib-es/specs.js.map +1 -0
  687. package/lib-es/speculos-deviceActions.d.ts +4 -0
  688. package/lib-es/speculos-deviceActions.d.ts.map +1 -0
  689. package/lib-es/speculos-deviceActions.js +58 -0
  690. package/lib-es/speculos-deviceActions.js.map +1 -0
  691. package/lib-es/transaction.d.ts +16 -0
  692. package/lib-es/transaction.d.ts.map +1 -0
  693. package/lib-es/transaction.js +107 -0
  694. package/lib-es/transaction.js.map +1 -0
  695. package/lib-es/types.d.ts +140 -0
  696. package/lib-es/types.d.ts.map +1 -0
  697. package/lib-es/types.js +20 -0
  698. package/lib-es/types.js.map +1 -0
  699. package/lib-es/wallet-btc/__tests__/bitcoin.test.d.ts +2 -0
  700. package/lib-es/wallet-btc/__tests__/bitcoin.test.d.ts.map +1 -0
  701. package/lib-es/wallet-btc/__tests__/bitcoin.test.js +304 -0
  702. package/lib-es/wallet-btc/__tests__/bitcoin.test.js.map +1 -0
  703. package/lib-es/wallet-btc/__tests__/logic.d.ts +2 -0
  704. package/lib-es/wallet-btc/__tests__/logic.d.ts.map +1 -0
  705. package/lib-es/wallet-btc/__tests__/logic.js +22 -0
  706. package/lib-es/wallet-btc/__tests__/logic.js.map +1 -0
  707. package/lib-es/wallet-btc/__tests__/utils.test.d.ts +2 -0
  708. package/lib-es/wallet-btc/__tests__/utils.test.d.ts.map +1 -0
  709. package/lib-es/wallet-btc/__tests__/utils.test.js +195 -0
  710. package/lib-es/wallet-btc/__tests__/utils.test.js.map +1 -0
  711. package/lib-es/wallet-btc/__tests__/wallet.errorpropagation.integration.test.d.ts +2 -0
  712. package/lib-es/wallet-btc/__tests__/wallet.errorpropagation.integration.test.d.ts.map +1 -0
  713. package/lib-es/wallet-btc/__tests__/wallet.errorpropagation.integration.test.js +41 -0
  714. package/lib-es/wallet-btc/__tests__/wallet.errorpropagation.integration.test.js.map +1 -0
  715. package/lib-es/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.d.ts +2 -0
  716. package/lib-es/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.d.ts.map +1 -0
  717. package/lib-es/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.js +50 -0
  718. package/lib-es/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.js.map +1 -0
  719. package/lib-es/wallet-btc/__tests__/wallet.explorer.integration.test.d.ts +2 -0
  720. package/lib-es/wallet-btc/__tests__/wallet.explorer.integration.test.d.ts.map +1 -0
  721. package/lib-es/wallet-btc/__tests__/wallet.explorer.integration.test.js +38 -0
  722. package/lib-es/wallet-btc/__tests__/wallet.explorer.integration.test.js.map +1 -0
  723. package/lib-es/wallet-btc/__tests__/wallet.explorer.unit.test.d.ts +2 -0
  724. package/lib-es/wallet-btc/__tests__/wallet.explorer.unit.test.d.ts.map +1 -0
  725. package/lib-es/wallet-btc/__tests__/wallet.explorer.unit.test.js +184 -0
  726. package/lib-es/wallet-btc/__tests__/wallet.explorer.unit.test.js.map +1 -0
  727. package/lib-es/wallet-btc/__tests__/wallet.integration.test.d.ts +2 -0
  728. package/lib-es/wallet-btc/__tests__/wallet.integration.test.d.ts.map +1 -0
  729. package/lib-es/wallet-btc/__tests__/wallet.integration.test.js +105 -0
  730. package/lib-es/wallet-btc/__tests__/wallet.integration.test.js.map +1 -0
  731. package/lib-es/wallet-btc/__tests__/wallet.storage.unit.test.d.ts +2 -0
  732. package/lib-es/wallet-btc/__tests__/wallet.storage.unit.test.d.ts.map +1 -0
  733. package/lib-es/wallet-btc/__tests__/wallet.storage.unit.test.js +171 -0
  734. package/lib-es/wallet-btc/__tests__/wallet.storage.unit.test.js.map +1 -0
  735. package/lib-es/wallet-btc/__tests__/xpub.getAddress.integration.test.d.ts +2 -0
  736. package/lib-es/wallet-btc/__tests__/xpub.getAddress.integration.test.d.ts.map +1 -0
  737. package/lib-es/wallet-btc/__tests__/xpub.getAddress.integration.test.js +72 -0
  738. package/lib-es/wallet-btc/__tests__/xpub.getAddress.integration.test.js.map +1 -0
  739. package/lib-es/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.d.ts +2 -0
  740. package/lib-es/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.d.ts.map +1 -0
  741. package/lib-es/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.js +297 -0
  742. package/lib-es/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.js.map +1 -0
  743. package/lib-es/wallet-btc/__tests__/xpub.reorg.integration.test.d.ts +2 -0
  744. package/lib-es/wallet-btc/__tests__/xpub.reorg.integration.test.d.ts.map +1 -0
  745. package/lib-es/wallet-btc/__tests__/xpub.reorg.integration.test.js +124 -0
  746. package/lib-es/wallet-btc/__tests__/xpub.reorg.integration.test.js.map +1 -0
  747. package/lib-es/wallet-btc/__tests__/xpub.synced.integration.test.d.ts +2 -0
  748. package/lib-es/wallet-btc/__tests__/xpub.synced.integration.test.d.ts.map +1 -0
  749. package/lib-es/wallet-btc/__tests__/xpub.synced.integration.test.js +69 -0
  750. package/lib-es/wallet-btc/__tests__/xpub.synced.integration.test.js.map +1 -0
  751. package/lib-es/wallet-btc/__tests__/xpub.syncing.integration.test.d.ts +2 -0
  752. package/lib-es/wallet-btc/__tests__/xpub.syncing.integration.test.d.ts.map +1 -0
  753. package/lib-es/wallet-btc/__tests__/xpub.syncing.integration.test.js +204 -0
  754. package/lib-es/wallet-btc/__tests__/xpub.syncing.integration.test.js.map +1 -0
  755. package/lib-es/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.d.ts +2 -0
  756. package/lib-es/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.d.ts.map +1 -0
  757. package/lib-es/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.js +158 -0
  758. package/lib-es/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.js.map +1 -0
  759. package/lib-es/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.d.ts +2 -0
  760. package/lib-es/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.d.ts.map +1 -0
  761. package/lib-es/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.js +150 -0
  762. package/lib-es/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.js.map +1 -0
  763. package/lib-es/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.d.ts +2 -0
  764. package/lib-es/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.d.ts.map +1 -0
  765. package/lib-es/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.js +95 -0
  766. package/lib-es/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.js.map +1 -0
  767. package/lib-es/wallet-btc/__tests__/xpub.txs.integration.test.d.ts +2 -0
  768. package/lib-es/wallet-btc/__tests__/xpub.txs.integration.test.d.ts.map +1 -0
  769. package/lib-es/wallet-btc/__tests__/xpub.txs.integration.test.js +287 -0
  770. package/lib-es/wallet-btc/__tests__/xpub.txs.integration.test.js.map +1 -0
  771. package/lib-es/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.d.ts +2 -0
  772. package/lib-es/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.d.ts.map +1 -0
  773. package/lib-es/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.js +143 -0
  774. package/lib-es/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.js.map +1 -0
  775. package/lib-es/wallet-btc/__tests__/xpub.utxo.unit.test.d.ts +2 -0
  776. package/lib-es/wallet-btc/__tests__/xpub.utxo.unit.test.d.ts.map +1 -0
  777. package/lib-es/wallet-btc/__tests__/xpub.utxo.unit.test.js +46 -0
  778. package/lib-es/wallet-btc/__tests__/xpub.utxo.unit.test.js.map +1 -0
  779. package/lib-es/wallet-btc/account.d.ts +27 -0
  780. package/lib-es/wallet-btc/account.d.ts.map +1 -0
  781. package/lib-es/wallet-btc/account.js +2 -0
  782. package/lib-es/wallet-btc/account.js.map +1 -0
  783. package/lib-es/wallet-btc/crypto/base.d.ts +33 -0
  784. package/lib-es/wallet-btc/crypto/base.d.ts.map +1 -0
  785. package/lib-es/wallet-btc/crypto/base.js +166 -0
  786. package/lib-es/wallet-btc/crypto/base.js.map +1 -0
  787. package/lib-es/wallet-btc/crypto/bip32.d.ts +11 -0
  788. package/lib-es/wallet-btc/crypto/bip32.d.ts.map +1 -0
  789. package/lib-es/wallet-btc/crypto/bip32.js +40 -0
  790. package/lib-es/wallet-btc/crypto/bip32.js.map +1 -0
  791. package/lib-es/wallet-btc/crypto/bitcoin.d.ts +13 -0
  792. package/lib-es/wallet-btc/crypto/bitcoin.d.ts.map +1 -0
  793. package/lib-es/wallet-btc/crypto/bitcoin.js +198 -0
  794. package/lib-es/wallet-btc/crypto/bitcoin.js.map +1 -0
  795. package/lib-es/wallet-btc/crypto/bitcoincash.d.ts +13 -0
  796. package/lib-es/wallet-btc/crypto/bitcoincash.d.ts.map +1 -0
  797. package/lib-es/wallet-btc/crypto/bitcoincash.js +50 -0
  798. package/lib-es/wallet-btc/crypto/bitcoincash.js.map +1 -0
  799. package/lib-es/wallet-btc/crypto/bitcoingold.d.ts +8 -0
  800. package/lib-es/wallet-btc/crypto/bitcoingold.d.ts.map +1 -0
  801. package/lib-es/wallet-btc/crypto/bitcoingold.js +12 -0
  802. package/lib-es/wallet-btc/crypto/bitcoingold.js.map +1 -0
  803. package/lib-es/wallet-btc/crypto/dash.d.ts +8 -0
  804. package/lib-es/wallet-btc/crypto/dash.d.ts.map +1 -0
  805. package/lib-es/wallet-btc/crypto/dash.js +20 -0
  806. package/lib-es/wallet-btc/crypto/dash.js.map +1 -0
  807. package/lib-es/wallet-btc/crypto/decred.d.ts +15 -0
  808. package/lib-es/wallet-btc/crypto/decred.d.ts.map +1 -0
  809. package/lib-es/wallet-btc/crypto/decred.js +93 -0
  810. package/lib-es/wallet-btc/crypto/decred.js.map +1 -0
  811. package/lib-es/wallet-btc/crypto/digibyte.d.ts +9 -0
  812. package/lib-es/wallet-btc/crypto/digibyte.d.ts.map +1 -0
  813. package/lib-es/wallet-btc/crypto/digibyte.js +30 -0
  814. package/lib-es/wallet-btc/crypto/digibyte.js.map +1 -0
  815. package/lib-es/wallet-btc/crypto/doge.d.ts +8 -0
  816. package/lib-es/wallet-btc/crypto/doge.d.ts.map +1 -0
  817. package/lib-es/wallet-btc/crypto/doge.js +14 -0
  818. package/lib-es/wallet-btc/crypto/doge.js.map +1 -0
  819. package/lib-es/wallet-btc/crypto/factory.d.ts +3 -0
  820. package/lib-es/wallet-btc/crypto/factory.d.ts.map +1 -0
  821. package/lib-es/wallet-btc/crypto/factory.js +103 -0
  822. package/lib-es/wallet-btc/crypto/factory.js.map +1 -0
  823. package/lib-es/wallet-btc/crypto/index.d.ts +19 -0
  824. package/lib-es/wallet-btc/crypto/index.d.ts.map +1 -0
  825. package/lib-es/wallet-btc/crypto/index.js +19 -0
  826. package/lib-es/wallet-btc/crypto/index.js.map +1 -0
  827. package/lib-es/wallet-btc/crypto/komodo.d.ts +8 -0
  828. package/lib-es/wallet-btc/crypto/komodo.d.ts.map +1 -0
  829. package/lib-es/wallet-btc/crypto/komodo.js +15 -0
  830. package/lib-es/wallet-btc/crypto/komodo.js.map +1 -0
  831. package/lib-es/wallet-btc/crypto/litecoin.d.ts +10 -0
  832. package/lib-es/wallet-btc/crypto/litecoin.d.ts.map +1 -0
  833. package/lib-es/wallet-btc/crypto/litecoin.js +28 -0
  834. package/lib-es/wallet-btc/crypto/litecoin.js.map +1 -0
  835. package/lib-es/wallet-btc/crypto/peercoin.d.ts +8 -0
  836. package/lib-es/wallet-btc/crypto/peercoin.d.ts.map +1 -0
  837. package/lib-es/wallet-btc/crypto/peercoin.js +14 -0
  838. package/lib-es/wallet-btc/crypto/peercoin.js.map +1 -0
  839. package/lib-es/wallet-btc/crypto/pivx.d.ts +8 -0
  840. package/lib-es/wallet-btc/crypto/pivx.d.ts.map +1 -0
  841. package/lib-es/wallet-btc/crypto/pivx.js +16 -0
  842. package/lib-es/wallet-btc/crypto/pivx.js.map +1 -0
  843. package/lib-es/wallet-btc/crypto/qtum.d.ts +8 -0
  844. package/lib-es/wallet-btc/crypto/qtum.d.ts.map +1 -0
  845. package/lib-es/wallet-btc/crypto/qtum.js +12 -0
  846. package/lib-es/wallet-btc/crypto/qtum.js.map +1 -0
  847. package/lib-es/wallet-btc/crypto/secp256k1.d.ts +16 -0
  848. package/lib-es/wallet-btc/crypto/secp256k1.d.ts.map +1 -0
  849. package/lib-es/wallet-btc/crypto/secp256k1.js +18 -0
  850. package/lib-es/wallet-btc/crypto/secp256k1.js.map +1 -0
  851. package/lib-es/wallet-btc/crypto/stealth.d.ts +8 -0
  852. package/lib-es/wallet-btc/crypto/stealth.d.ts.map +1 -0
  853. package/lib-es/wallet-btc/crypto/stealth.js +16 -0
  854. package/lib-es/wallet-btc/crypto/stealth.js.map +1 -0
  855. package/lib-es/wallet-btc/crypto/types.d.ts +11 -0
  856. package/lib-es/wallet-btc/crypto/types.d.ts.map +1 -0
  857. package/lib-es/wallet-btc/crypto/types.js +2 -0
  858. package/lib-es/wallet-btc/crypto/types.js.map +1 -0
  859. package/lib-es/wallet-btc/crypto/via.d.ts +8 -0
  860. package/lib-es/wallet-btc/crypto/via.d.ts.map +1 -0
  861. package/lib-es/wallet-btc/crypto/via.js +12 -0
  862. package/lib-es/wallet-btc/crypto/via.js.map +1 -0
  863. package/lib-es/wallet-btc/crypto/vtc.d.ts +8 -0
  864. package/lib-es/wallet-btc/crypto/vtc.d.ts.map +1 -0
  865. package/lib-es/wallet-btc/crypto/vtc.js +12 -0
  866. package/lib-es/wallet-btc/crypto/vtc.js.map +1 -0
  867. package/lib-es/wallet-btc/crypto/zec.d.ts +13 -0
  868. package/lib-es/wallet-btc/crypto/zec.d.ts.map +1 -0
  869. package/lib-es/wallet-btc/crypto/zec.js +67 -0
  870. package/lib-es/wallet-btc/crypto/zec.js.map +1 -0
  871. package/lib-es/wallet-btc/crypto/zen.d.ts +13 -0
  872. package/lib-es/wallet-btc/crypto/zen.d.ts.map +1 -0
  873. package/lib-es/wallet-btc/crypto/zen.js +88 -0
  874. package/lib-es/wallet-btc/crypto/zen.js.map +1 -0
  875. package/lib-es/wallet-btc/explorer/index.d.ts +47 -0
  876. package/lib-es/wallet-btc/explorer/index.d.ts.map +1 -0
  877. package/lib-es/wallet-btc/explorer/index.js +186 -0
  878. package/lib-es/wallet-btc/explorer/index.js.map +1 -0
  879. package/lib-es/wallet-btc/explorer/types.d.ts +18 -0
  880. package/lib-es/wallet-btc/explorer/types.d.ts.map +1 -0
  881. package/lib-es/wallet-btc/explorer/types.js +2 -0
  882. package/lib-es/wallet-btc/explorer/types.js.map +1 -0
  883. package/lib-es/wallet-btc/index.d.ts +16 -0
  884. package/lib-es/wallet-btc/index.d.ts.map +1 -0
  885. package/lib-es/wallet-btc/index.js +25 -0
  886. package/lib-es/wallet-btc/index.js.map +1 -0
  887. package/lib-es/wallet-btc/pickingstrategies/CoinSelect.d.ts +18 -0
  888. package/lib-es/wallet-btc/pickingstrategies/CoinSelect.d.ts.map +1 -0
  889. package/lib-es/wallet-btc/pickingstrategies/CoinSelect.js +156 -0
  890. package/lib-es/wallet-btc/pickingstrategies/CoinSelect.js.map +1 -0
  891. package/lib-es/wallet-btc/pickingstrategies/DeepFirst.d.ts +17 -0
  892. package/lib-es/wallet-btc/pickingstrategies/DeepFirst.d.ts.map +1 -0
  893. package/lib-es/wallet-btc/pickingstrategies/DeepFirst.js +70 -0
  894. package/lib-es/wallet-btc/pickingstrategies/DeepFirst.js.map +1 -0
  895. package/lib-es/wallet-btc/pickingstrategies/Merge.d.ts +17 -0
  896. package/lib-es/wallet-btc/pickingstrategies/Merge.d.ts.map +1 -0
  897. package/lib-es/wallet-btc/pickingstrategies/Merge.js +70 -0
  898. package/lib-es/wallet-btc/pickingstrategies/Merge.js.map +1 -0
  899. package/lib-es/wallet-btc/pickingstrategies/types.d.ts +27 -0
  900. package/lib-es/wallet-btc/pickingstrategies/types.d.ts.map +1 -0
  901. package/lib-es/wallet-btc/pickingstrategies/types.js +8 -0
  902. package/lib-es/wallet-btc/pickingstrategies/types.js.map +1 -0
  903. package/lib-es/wallet-btc/storage/index.d.ts +77 -0
  904. package/lib-es/wallet-btc/storage/index.d.ts.map +1 -0
  905. package/lib-es/wallet-btc/storage/index.js +231 -0
  906. package/lib-es/wallet-btc/storage/index.js.map +1 -0
  907. package/lib-es/wallet-btc/storage/types.d.ts +74 -0
  908. package/lib-es/wallet-btc/storage/types.d.ts.map +1 -0
  909. package/lib-es/wallet-btc/storage/types.js +2 -0
  910. package/lib-es/wallet-btc/storage/types.js.map +1 -0
  911. package/lib-es/wallet-btc/types.d.ts +25 -0
  912. package/lib-es/wallet-btc/types.d.ts.map +1 -0
  913. package/lib-es/wallet-btc/types.js +8 -0
  914. package/lib-es/wallet-btc/types.js.map +1 -0
  915. package/lib-es/wallet-btc/utils.d.ts +45 -0
  916. package/lib-es/wallet-btc/utils.d.ts.map +1 -0
  917. package/lib-es/wallet-btc/utils.js +175 -0
  918. package/lib-es/wallet-btc/utils.js.map +1 -0
  919. package/lib-es/wallet-btc/wallet.d.ts +80 -0
  920. package/lib-es/wallet-btc/wallet.d.ts.map +1 -0
  921. package/lib-es/wallet-btc/wallet.js +263 -0
  922. package/lib-es/wallet-btc/wallet.js.map +1 -0
  923. package/lib-es/wallet-btc/xpub.d.ts +52 -0
  924. package/lib-es/wallet-btc/xpub.d.ts.map +1 -0
  925. package/lib-es/wallet-btc/xpub.js +291 -0
  926. package/lib-es/wallet-btc/xpub.js.map +1 -0
  927. package/lib-es/xpub.txs.loadExport.unit.test.d.ts +2 -0
  928. package/lib-es/xpub.txs.loadExport.unit.test.d.ts.map +1 -0
  929. package/lib-es/xpub.txs.loadExport.unit.test.js +105 -0
  930. package/lib-es/xpub.txs.loadExport.unit.test.js.map +1 -0
  931. package/lib-es/xpub.txs.txNoOutput.unit.test.d.ts +2 -0
  932. package/lib-es/xpub.txs.txNoOutput.unit.test.d.ts.map +1 -0
  933. package/lib-es/xpub.txs.txNoOutput.unit.test.js +39 -0
  934. package/lib-es/xpub.txs.txNoOutput.unit.test.js.map +1 -0
  935. package/package.json +109 -0
  936. package/src/account.ts +14 -0
  937. package/src/bech32m.ts +187 -0
  938. package/src/bridge/js.ts +96 -0
  939. package/src/bridge.integration.test.ts +47 -0
  940. package/src/cache.ts +73 -0
  941. package/src/cli-transaction.ts +73 -0
  942. package/src/crypto-util.ts +15 -0
  943. package/src/datasets/bitcoin.scanAccounts.1.ts +237 -0
  944. package/src/datasets/bitcoin.ts +353 -0
  945. package/src/datasets/bitcoin_cash.ts +44 -0
  946. package/src/datasets/bitcoin_gold.ts +72 -0
  947. package/src/datasets/dash.ts +36 -0
  948. package/src/datasets/decred.ts +42 -0
  949. package/src/datasets/digibyte.scanAccounts.1.ts +53 -0
  950. package/src/datasets/digibyte.ts +164 -0
  951. package/src/datasets/dogecoin.ts +36 -0
  952. package/src/datasets/komodo.ts +42 -0
  953. package/src/datasets/litecoin.scanAccounts.1.ts +53 -0
  954. package/src/datasets/litecoin.ts +186 -0
  955. package/src/datasets/peercoin.ts +36 -0
  956. package/src/datasets/pivx.ts +36 -0
  957. package/src/datasets/qtum.ts +56 -0
  958. package/src/datasets/vertcoin.ts +68 -0
  959. package/src/datasets/viacoin.ts +44 -0
  960. package/src/datasets/zcash.ts +42 -0
  961. package/src/datasets/zencash.ts +36 -0
  962. package/src/descriptor.test.ts +63 -0
  963. package/src/descriptor.ts +205 -0
  964. package/src/deviceTransactionConfig.ts +39 -0
  965. package/src/errors.ts +5 -0
  966. package/src/explorer.ts +40 -0
  967. package/src/formatters.ts +52 -0
  968. package/src/getAccountNetworkInfo.test.ts +37 -0
  969. package/src/getAccountNetworkInfo.ts +54 -0
  970. package/src/hw-getAddress.ts +52 -0
  971. package/src/hw-signMessage.ts +23 -0
  972. package/src/js-broadcast.ts +22 -0
  973. package/src/js-buildTransaction.ts +68 -0
  974. package/src/js-createTransaction.ts +26 -0
  975. package/src/js-estimateMaxSpendable.ts +41 -0
  976. package/src/js-getFeesForTransaction.ts +59 -0
  977. package/src/js-getTransactionStatus.ts +127 -0
  978. package/src/js-prepareTransaction.ts +33 -0
  979. package/src/js-signOperation.ts +147 -0
  980. package/src/js-synchronisation.ts +256 -0
  981. package/src/logic.ts +318 -0
  982. package/src/logic.unit.test.ts +54 -0
  983. package/src/mockBtcSigner.ts +66 -0
  984. package/src/networks.ts +318 -0
  985. package/src/publicAddresses.test.ts +9 -0
  986. package/src/serialization.test.ts +143 -0
  987. package/src/serialization.ts +94 -0
  988. package/src/signer.ts +82 -0
  989. package/src/specs.ts +629 -0
  990. package/src/speculos-deviceActions.ts +66 -0
  991. package/src/transaction.ts +185 -0
  992. package/src/types.ts +174 -0
  993. package/src/wallet-btc/__tests__/bitcoin.test.ts +301 -0
  994. package/src/wallet-btc/__tests__/logic.ts +29 -0
  995. package/src/wallet-btc/__tests__/utils.test.ts +257 -0
  996. package/src/wallet-btc/__tests__/wallet.errorpropagation.integration.test.ts +37 -0
  997. package/src/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.ts +51 -0
  998. package/src/wallet-btc/__tests__/wallet.explorer.integration.test.ts +40 -0
  999. package/src/wallet-btc/__tests__/wallet.explorer.unit.test.ts +192 -0
  1000. package/src/wallet-btc/__tests__/wallet.integration.test.ts +120 -0
  1001. package/src/wallet-btc/__tests__/wallet.storage.unit.test.ts +168 -0
  1002. package/src/wallet-btc/__tests__/xpub.getAddress.integration.test.ts +79 -0
  1003. package/src/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.ts +312 -0
  1004. package/src/wallet-btc/__tests__/xpub.reorg.integration.test.ts +130 -0
  1005. package/src/wallet-btc/__tests__/xpub.synced.integration.test.ts +73 -0
  1006. package/src/wallet-btc/__tests__/xpub.syncing.integration.test.ts +203 -0
  1007. package/src/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.ts +174 -0
  1008. package/src/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.ts +166 -0
  1009. package/src/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.ts +92 -0
  1010. package/src/wallet-btc/__tests__/xpub.txs.integration.test.ts +342 -0
  1011. package/src/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.ts +150 -0
  1012. package/src/wallet-btc/__tests__/xpub.utxo.unit.test.ts +66 -0
  1013. package/src/wallet-btc/account.ts +30 -0
  1014. package/src/wallet-btc/crypto/base.ts +179 -0
  1015. package/src/wallet-btc/crypto/bip32.ts +40 -0
  1016. package/src/wallet-btc/crypto/bitcoin.ts +203 -0
  1017. package/src/wallet-btc/crypto/bitcoincash.ts +47 -0
  1018. package/src/wallet-btc/crypto/bitcoingold.ts +13 -0
  1019. package/src/wallet-btc/crypto/dash.ts +21 -0
  1020. package/src/wallet-btc/crypto/decred.ts +91 -0
  1021. package/src/wallet-btc/crypto/digibyte.ts +33 -0
  1022. package/src/wallet-btc/crypto/doge.ts +15 -0
  1023. package/src/wallet-btc/crypto/factory.ts +104 -0
  1024. package/src/wallet-btc/crypto/index.ts +18 -0
  1025. package/src/wallet-btc/crypto/komodo.ts +16 -0
  1026. package/src/wallet-btc/crypto/litecoin.ts +31 -0
  1027. package/src/wallet-btc/crypto/peercoin.ts +15 -0
  1028. package/src/wallet-btc/crypto/pivx.ts +17 -0
  1029. package/src/wallet-btc/crypto/qtum.ts +13 -0
  1030. package/src/wallet-btc/crypto/secp256k1.ts +29 -0
  1031. package/src/wallet-btc/crypto/stealth.ts +17 -0
  1032. package/src/wallet-btc/crypto/types.ts +35 -0
  1033. package/src/wallet-btc/crypto/via.ts +13 -0
  1034. package/src/wallet-btc/crypto/vtc.ts +13 -0
  1035. package/src/wallet-btc/crypto/zec.ts +66 -0
  1036. package/src/wallet-btc/crypto/zen.ts +88 -0
  1037. package/src/wallet-btc/explorer/index.ts +197 -0
  1038. package/src/wallet-btc/explorer/types.ts +19 -0
  1039. package/src/wallet-btc/index.ts +52 -0
  1040. package/src/wallet-btc/pickingstrategies/CoinSelect.ts +183 -0
  1041. package/src/wallet-btc/pickingstrategies/DeepFirst.ts +92 -0
  1042. package/src/wallet-btc/pickingstrategies/Merge.ts +92 -0
  1043. package/src/wallet-btc/pickingstrategies/types.ts +44 -0
  1044. package/src/wallet-btc/storage/index.ts +270 -0
  1045. package/src/wallet-btc/storage/types.ts +61 -0
  1046. package/src/wallet-btc/types.ts +28 -0
  1047. package/src/wallet-btc/utils.ts +195 -0
  1048. package/src/wallet-btc/wallet.ts +387 -0
  1049. package/src/wallet-btc/xpub.ts +394 -0
  1050. package/src/xpub.txs.loadExport.unit.test.ts +96 -0
  1051. package/src/xpub.txs.txNoOutput.unit.test.ts +30 -0
  1052. package/tsconfig.json +13 -0
  1053. package/types/blake-hash.d.ts +6 -0
  1054. package/types/bs58check/base.d.ts +1 -0
  1055. package/types/coininfo.d.ts +100 -0
@@ -0,0 +1,150 @@
1
+ import * as bip32 from "bip32";
2
+ import * as bip39 from "bip39";
3
+ import * as bitcoin from "bitcoinjs-lib";
4
+ import coininfo from "coininfo";
5
+ import axios from "axios";
6
+ import BigNumber from "bignumber.js";
7
+ import { DerivationModes } from "../types";
8
+ import Xpub from "../xpub";
9
+ import Litecoin from "../crypto/litecoin";
10
+ import BitcoinLikeExplorer from "../explorer";
11
+ import BitcoinLikeStorage from "../storage";
12
+ import { Merge } from "../pickingstrategies/Merge";
13
+ import { getCryptoCurrencyById } from "@ledgerhq/cryptoassets";
14
+
15
+ const sleep = (ms: number) => new Promise(resolve => setTimeout(resolve, ms));
16
+
17
+ /*
18
+ In order to launch this litecoin test locally
19
+ TICKER=ltc TAG=latest LOG_LEVEL=debug docker-compose -f ./environments/explorer-praline-btc.yml up -d
20
+ */
21
+ // FIXME Skipped because Praline required on CI
22
+ describe.skip("testing xpub legacy litecoin transactions", () => {
23
+ const explorer = new BitcoinLikeExplorer({
24
+ cryptoCurrency: getCryptoCurrencyById("litecoin"),
25
+ });
26
+
27
+ const network = coininfo.litecoin.test?.toBitcoinJS();
28
+ const crypto = new Litecoin({ network });
29
+
30
+ const xpubs = [1, 2, 3].map(i => {
31
+ const storage = new BitcoinLikeStorage();
32
+ const seed = bip39.mnemonicToSeedSync(`test${i} test${i} test${i}`);
33
+ const node = bip32.fromSeed(seed, network);
34
+ const signer = (account: number, index: number) =>
35
+ bitcoin.ECPair.fromWIF(node.derive(account).derive(index).toWIF(), network);
36
+ const xpub = new Xpub({
37
+ storage,
38
+ explorer,
39
+ crypto,
40
+ xpub: node.neutered().toBase58(),
41
+ derivationMode: DerivationModes.LEGACY,
42
+ });
43
+
44
+ return {
45
+ storage,
46
+ seed,
47
+ node,
48
+ signer,
49
+ xpub,
50
+ };
51
+ });
52
+
53
+ beforeAll(async () => {
54
+ const { address } = await xpubs[0].xpub.getNewAddress(0, 0);
55
+ try {
56
+ await axios.post("http://localhost:28443/chain/clear/all");
57
+ await axios.post(`http://localhost:28443/chain/mine/${address}/1`);
58
+ await axios.post(`http://localhost:28443/chain/faucet/${address}/7.0`);
59
+ } catch (e) {
60
+ // eslint-disable-next-line no-console
61
+ console.log("praline setup error", e);
62
+ }
63
+
64
+ // time for explorer to sync
65
+ await sleep(30000);
66
+
67
+ try {
68
+ await xpubs[0].xpub.sync();
69
+ } catch (e) {
70
+ // eslint-disable-next-line no-console
71
+ console.log("praline explorer setup error", e);
72
+ }
73
+ }, 70000);
74
+
75
+ it("should be setup correctly", async () => {
76
+ const balance1 = await xpubs[0].xpub.getXpubBalance();
77
+ expect(balance1.toNumber()).toEqual(5700000000);
78
+ });
79
+
80
+ let expectedFee1: number;
81
+ it("should send a 1 litecoin tx to xpubs[1].xpub", async () => {
82
+ const { address } = await xpubs[1].xpub.getNewAddress(0, 0);
83
+ const changeAddress = await xpubs[0].xpub.getNewAddress(1, 0);
84
+ const psbt = new bitcoin.Psbt({ network });
85
+
86
+ const utxoPickingStrategy = new Merge(xpubs[0].xpub.crypto, xpubs[0].xpub.derivationMode, []);
87
+
88
+ const { inputs, associatedDerivations, outputs } = await xpubs[0].xpub.buildTx({
89
+ destAddress: address,
90
+ amount: new BigNumber(100000000),
91
+ feePerByte: 100,
92
+ changeAddress,
93
+ utxoPickingStrategy,
94
+ sequence: 0,
95
+ });
96
+
97
+ inputs.forEach(input => {
98
+ const nonWitnessUtxo = Buffer.from(input.txHex, "hex");
99
+ const tx = bitcoin.Transaction.fromHex(input.txHex);
100
+
101
+ psbt.addInput({
102
+ hash: tx.getId(),
103
+ index: input.output_index,
104
+ nonWitnessUtxo,
105
+ });
106
+ });
107
+ outputs.forEach(output => {
108
+ psbt.addOutput({
109
+ script: output.script,
110
+ value: output.value.toNumber(),
111
+ });
112
+ });
113
+ expect(outputs.length).toEqual(2);
114
+ inputs.forEach((_, i) => {
115
+ psbt.signInput(i, xpubs[0].signer(associatedDerivations[i][0], associatedDerivations[i][1]));
116
+ psbt.validateSignaturesOfInput(i);
117
+ });
118
+ psbt.finalizeAllInputs();
119
+ const rawTxHex = psbt.extractTransaction().toHex();
120
+ //
121
+
122
+ try {
123
+ await xpubs[0].xpub.broadcastTx(rawTxHex);
124
+ } catch (e) {
125
+ // eslint-disable-next-line no-console
126
+ console.log("broadcast error", e);
127
+ }
128
+
129
+ // time for explorer to sync
130
+ await sleep(40000);
131
+
132
+ try {
133
+ const { address: mineAddress } = await xpubs[2].xpub.getNewAddress(0, 0);
134
+ await axios.post(`http://localhost:28443/chain/mine/${mineAddress}/1`);
135
+ } catch (e) {
136
+ // eslint-disable-next-line no-console
137
+ console.log("praline error");
138
+ }
139
+ await sleep(40000);
140
+ await xpubs[0].xpub.sync();
141
+ await xpubs[1].xpub.sync();
142
+
143
+ expectedFee1 = 10 * 100 + inputs.length * 100 * 180 + outputs.length * 34 * 100;
144
+
145
+ expect((await xpubs[0].xpub.getXpubBalance()).toNumber()).toEqual(
146
+ 5700000000 - 100000000 - expectedFee1,
147
+ );
148
+ expect((await xpubs[1].xpub.getXpubBalance()).toNumber()).toEqual(100000000);
149
+ }, 100000);
150
+ });
@@ -0,0 +1,66 @@
1
+ import coininfo from "coininfo";
2
+ import { script } from "bitcoinjs-lib";
3
+
4
+ import BTCCrypto from "../crypto/bitcoin";
5
+ import BTCCashCrypto from "../crypto/bitcoincash";
6
+ import DogeCrypto from "../crypto/doge";
7
+ import ZECCrypto from "../crypto/zec";
8
+ import ZENCrypto from "../crypto/zen";
9
+
10
+ describe("Transaction Output script", () => {
11
+ const btcCrypto = new BTCCrypto({
12
+ network: coininfo.bitcoin.main.toBitcoinJS(),
13
+ });
14
+
15
+ const zecCrypto = new ZECCrypto({
16
+ network: coininfo.zcash.main.toBitcoinJS(),
17
+ });
18
+
19
+ const zenCrypto = new ZENCrypto({
20
+ network: coininfo.zcash.main.toBitcoinJS(),
21
+ });
22
+
23
+ const btcCashCrypto = new BTCCashCrypto({
24
+ network: coininfo.bitcoincash.main.toBitcoinJS(),
25
+ });
26
+
27
+ const dogeCrypto = new DogeCrypto({
28
+ network: coininfo.dogecoin.main.toBitcoinJS(),
29
+ });
30
+
31
+ it("Test toOutputScript for btc, zcash and zen", () => {
32
+ expect(btcCrypto.toOutputScript("1F1tAaz5x1HUXrCNLbtMDqcw6o5GNn4xqX").toString("hex")).toEqual(
33
+ "76a91499bc78ba577a95a11f1a344d4d2ae55f2f857b9888ac",
34
+ );
35
+ // Legacy zcash address
36
+ expect(zecCrypto.toOutputScript("t1T5XJvzQhh2gTsi3c5Vn9x5SMhpSWLSnVy").toString("hex")).toEqual(
37
+ "76a91464fa33fb6f8d72455af2a4e73ae30412af2c97ba88ac",
38
+ );
39
+ // P2SH zcash address
40
+ expect(zecCrypto.toOutputScript("t3PU1j7YW3fJ67jUbkGhSRto8qK2qXCUiW3").toString("hex")).toEqual(
41
+ "a91435c929cb2ee32626e1f5c8d773ab4fe9d94686e087",
42
+ );
43
+ // Legacy zen address
44
+ expect(zenCrypto.toOutputScript("znjbHth4PxBJM8FmHgvXYHkuq99nKFkWvMg").toString("hex")).toEqual(
45
+ "76a914cb009bf12fc17d28e61527951101fdabfeaa187288ac209ec9845acb02fab24e1c0368b3b517c1a4488fba97f0e3459ac053ea0100000003c01f02b4",
46
+ );
47
+ // P2SH zen address
48
+ expect(zenCrypto.toOutputScript("zszpcLB6C5B8QvfDbF2dYWXsrpac5DL9WRk").toString("hex")).toEqual(
49
+ "a914df23c5eaba30b4d95798c5d5d0e2ecc2a3dc4ff287209ec9845acb02fab24e1c0368b3b517c1a4488fba97f0e3459ac053ea0100000003c01f02b4",
50
+ );
51
+ }, 30000);
52
+
53
+ it("should get correct output script for OP_RETURN opcode", () => {
54
+ [btcCrypto, btcCashCrypto, dogeCrypto].forEach(coin => {
55
+ const data = Buffer.from("charley loves heidi", "utf-8");
56
+
57
+ const output = coin.toOpReturnOutputScript(data);
58
+ const [opType, message] = script.decompile(output) as [number, Buffer];
59
+
60
+ expect(output.toString("hex")).toEqual("6a13636861726c6579206c6f766573206865696469");
61
+
62
+ expect(opType).toEqual(script.OPS.OP_RETURN);
63
+ expect(message.toString()).toEqual("charley loves heidi");
64
+ });
65
+ });
66
+ });
@@ -0,0 +1,30 @@
1
+ import { DerivationModes } from "./types";
2
+ import { Currency } from "./crypto/types";
3
+ import Xpub from "./xpub";
4
+
5
+ export interface Account {
6
+ params: {
7
+ path: string;
8
+ index: number;
9
+ currency: Currency;
10
+ network: "mainnet" | "testnet";
11
+ derivationMode: DerivationModes;
12
+ };
13
+
14
+ xpub: Xpub;
15
+ }
16
+
17
+ export interface SerializedAccount {
18
+ params: {
19
+ path: string;
20
+ index: number;
21
+ currency: Currency;
22
+ network: "mainnet" | "testnet";
23
+ derivationMode: DerivationModes;
24
+ };
25
+
26
+ xpub: {
27
+ xpub: string;
28
+ data: unknown;
29
+ };
30
+ }
@@ -0,0 +1,179 @@
1
+ // from https://github.com/LedgerHQ/xpub-scan/blob/master/src/actions/deriveAddresses.ts
2
+
3
+ import * as bjs from "bitcoinjs-lib";
4
+ import { address as btcAddress } from "bitcoinjs-lib";
5
+ import bs58check from "bs58check";
6
+ import { DerivationModes } from "../types";
7
+ import { ICrypto } from "./types";
8
+ import bs58 from "bs58";
9
+ import bech32 from "bech32";
10
+ import BIP32 from "./bip32";
11
+
12
+ // https://developer.bitcoin.org/devguide/transactions.html#null-data
13
+ export const OP_RETURN_DATA_SIZE_LIMIT = 83; // bytes
14
+
15
+ export function fallbackValidateAddress(address: string): boolean {
16
+ try {
17
+ bjs.address.fromBase58Check(address);
18
+ } catch {
19
+ // Not a valid Base58 address
20
+ try {
21
+ bjs.address.fromBech32(address);
22
+ } catch {
23
+ // Not a valid Bech32 address either
24
+ return false;
25
+ }
26
+ }
27
+ return true;
28
+ }
29
+
30
+ class Base implements ICrypto {
31
+ network: any;
32
+ private static bip32Cache: Map<string, Promise<BIP32>> = new Map(); // xpub + account + index to publicKey
33
+ public static addressCache: Record<string, Promise<string>> = {}; // derivationMode + xpub + account + index to address
34
+
35
+ constructor({ network }: { network: any }) {
36
+ this.network = network;
37
+ this.network.dustThreshold = 3000;
38
+ this.network.dustPolicy = "PER_KBYTE";
39
+ this.network.usesTimestampedTransaction = false;
40
+ }
41
+
42
+ protected async getPubkeyAt(xpub: string, account: number, index: number): Promise<Buffer> {
43
+ // a cache is stored in Base.bip32Cache to optimize the calculation
44
+ // at each step, we make sure the level has been calculated and calc if necessary
45
+
46
+ // 0: root level
47
+ const keyRoot = `${this.network.name}-${xpub}`;
48
+ let rootLevel = Base.bip32Cache.get(keyRoot);
49
+ if (!rootLevel) {
50
+ const buffer: Buffer = bs58.decode(xpub);
51
+ const depth: number = buffer[4];
52
+ const i: number = buffer.readUInt32BE(9);
53
+ const chainCode: Buffer = buffer.slice(13, 45);
54
+ const publicKey: Buffer = buffer.slice(45, 78);
55
+ rootLevel = Promise.resolve(new BIP32(publicKey, chainCode, this.network, depth, i));
56
+ Base.bip32Cache.set(keyRoot, rootLevel);
57
+ }
58
+
59
+ // 1: account level
60
+ const keyAccount = `${keyRoot}-${account}`;
61
+ let accountLevelP = Base.bip32Cache.get(keyAccount); // it's stored as promise
62
+ if (!accountLevelP) {
63
+ accountLevelP = rootLevel.then(root => root.derive(account));
64
+ // accountLevelP = await rootLevel.derive(account);
65
+ Base.bip32Cache.set(keyAccount, accountLevelP);
66
+ }
67
+
68
+ // 2: index level
69
+ const keyIndex = `${keyAccount}-${index}`;
70
+ let indexLevelP = Base.bip32Cache.get(keyIndex); // it's stored as promise
71
+ if (!indexLevelP) {
72
+ indexLevelP = accountLevelP.then(a => a.derive(index));
73
+ // indexLevelP = await accountLevelP.derive(index);
74
+ Base.bip32Cache.set(keyIndex, indexLevelP);
75
+ }
76
+
77
+ // We can finally return the publicKey. in most case, indexLevelP will be "resolved"
78
+ return (await indexLevelP).publicKey;
79
+ }
80
+
81
+ // derive legacy address at account and index positions
82
+ protected async getLegacyAddress(xpub: string, account: number, index: number): Promise<string> {
83
+ const publicKeyBuffer: Buffer = await this.getPubkeyAt(xpub, account, index);
84
+ const publicKeyHash160: Buffer = bjs.crypto.hash160(publicKeyBuffer);
85
+ return bjs.address.toBase58Check(publicKeyHash160, this.network.pubKeyHash);
86
+ }
87
+
88
+ // derive native SegWit at account and index positions
89
+ private async getNativeSegWitAddress(
90
+ xpub: string,
91
+ account: number,
92
+ index: number,
93
+ ): Promise<string> {
94
+ const publicKeyBuffer: Buffer = await this.getPubkeyAt(xpub, account, index);
95
+ const publicKeyHash160: Buffer = bjs.crypto.hash160(publicKeyBuffer);
96
+ const words: number[] = bech32.toWords(publicKeyHash160);
97
+ words.unshift(0x00);
98
+ return bech32.encode(this.network.bech32, words);
99
+ }
100
+
101
+ // derive SegWit at account and index positions
102
+ private async getSegWitAddress(xpub: string, account: number, index: number): Promise<string> {
103
+ const publicKeyBuffer: Buffer = await this.getPubkeyAt(xpub, account, index);
104
+ const redeemOutput: Buffer = bjs.script.compile([0, bjs.crypto.hash160(publicKeyBuffer)]);
105
+ const publicKeyHash160: Buffer = bjs.crypto.hash160(redeemOutput);
106
+ const payload: Buffer = Buffer.allocUnsafe(21);
107
+ payload.writeUInt8(this.network.scriptHash, 0);
108
+ publicKeyHash160.copy(payload, 1);
109
+ return bs58check.encode(payload);
110
+ }
111
+
112
+ // get address given an address type
113
+ async getAddress(
114
+ derivationMode: string,
115
+ xpub: string,
116
+ account: number,
117
+ index: number,
118
+ ): Promise<string> {
119
+ const addressCacheKey = `${this.network.name}-${derivationMode}-${xpub}-${account}-${index}`;
120
+ if (addressCacheKey in Base.addressCache) {
121
+ return Base.addressCache[addressCacheKey];
122
+ }
123
+ const res = this.customGetAddress(derivationMode, xpub, account, index);
124
+ Base.addressCache[addressCacheKey] = res;
125
+ return res;
126
+ }
127
+
128
+ async customGetAddress(
129
+ derivationMode: string,
130
+ xpub: string,
131
+ account: number,
132
+ index: number,
133
+ ): Promise<string> {
134
+ switch (derivationMode) {
135
+ case DerivationModes.LEGACY:
136
+ return await this.getLegacyAddress(xpub, account, index);
137
+ case DerivationModes.SEGWIT:
138
+ return await this.getSegWitAddress(xpub, account, index);
139
+ case DerivationModes.NATIVE_SEGWIT:
140
+ return await this.getNativeSegWitAddress(xpub, account, index);
141
+ default:
142
+ throw new Error(`Invalid derivation Mode: ${derivationMode}`);
143
+ }
144
+ }
145
+
146
+ /**
147
+ * The output script sets the conditions under which the amount can be spent.
148
+ * It is a crucial part of Bitcoin's scripting system, ensuring that only the rightful owner can spend the bitcoins
149
+ * This function returns the output script for a given address
150
+ * see https://developer.bitcoin.org/devguide/transactions.html for more details
151
+ */
152
+ toOutputScript(address: string): Buffer {
153
+ return btcAddress.toOutputScript(address, this.network);
154
+ }
155
+
156
+ /**
157
+ * OutputScript to with OP_RETURN data
158
+ * see https://developer.bitcoin.org/reference/transactions.html?highlight=op_return for more details
159
+ */
160
+ toOpReturnOutputScript(data: Buffer): Buffer {
161
+ const script = bjs.payments.embed({ data: [data] });
162
+ return script.output!;
163
+ }
164
+
165
+ validateAddress(address: string): boolean {
166
+ // bs58 address
167
+ const res = bs58check.decodeUnsafe(address);
168
+ if (!res) return false;
169
+ return (
170
+ res.length > 3 && (res[0] === this.network.pubKeyHash || res[0] === this.network.scriptHash)
171
+ );
172
+ }
173
+
174
+ isTaprootAddress(_address: string): boolean {
175
+ return false;
176
+ }
177
+ }
178
+
179
+ export default Base;
@@ -0,0 +1,40 @@
1
+ import invariant from "invariant";
2
+ import createHmac from "create-hmac";
3
+ import { getSecp256k1Instance } from "./secp256k1";
4
+
5
+ // the BIP32 class is inspired from https://github.com/bitcoinjs/bip32/blob/master/src/bip32.js
6
+ class BIP32 {
7
+ publicKey: Buffer;
8
+ chainCode: Buffer;
9
+ network: any;
10
+ depth: number;
11
+ index: number;
12
+ constructor(
13
+ publicKey: Buffer,
14
+ chainCode: Buffer,
15
+ // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
16
+ network: any,
17
+ depth = 0,
18
+ index = 0,
19
+ ) {
20
+ invariant(publicKey && publicKey.length > 0, "publicKey must not be empty");
21
+ invariant(chainCode && chainCode.length > 0, "chainCode must not be empty");
22
+ this.publicKey = publicKey;
23
+ this.chainCode = chainCode;
24
+ this.network = network;
25
+ this.depth = depth;
26
+ this.index = index;
27
+ }
28
+ async derive(index: number): Promise<BIP32> {
29
+ const data = Buffer.allocUnsafe(37);
30
+ this.publicKey.copy(data, 0);
31
+ data.writeUInt32BE(index, 33);
32
+ const I = createHmac("sha512", this.chainCode).update(data).digest();
33
+ const IL = I.slice(0, 32);
34
+ const IR = I.slice(32);
35
+ const Ki = Buffer.from(await getSecp256k1Instance().publicKeyTweakAdd(this.publicKey, IL));
36
+ return new BIP32(Ki, IR, this.network, this.depth + 1, index);
37
+ }
38
+ }
39
+
40
+ export default BIP32;
@@ -0,0 +1,203 @@
1
+ // from https://github.com/LedgerHQ/xpub-scan/blob/master/src/actions/deriveAddresses.ts
2
+
3
+ import * as bech32 from "bech32";
4
+ import { bech32m } from "../../bech32m";
5
+ import * as bjs from "bitcoinjs-lib";
6
+ import { getSecp256k1Instance } from "./secp256k1";
7
+ import { InvalidAddress } from "@ledgerhq/errors";
8
+ import { DerivationModes } from "../types";
9
+ import Base from "./base";
10
+
11
+ /**
12
+ * Temporarily copied fromBech32 and toBech32 from bitcoinjs-lib master branch (as of 2021-09-02,
13
+ * commit 7b753caad6a5bf13d40ffb6ae28c2b00f7f5f585) so that we can make use of the
14
+ * updated bech32 lib version 2.0.0 that supports bech32m. bitcoinjs-lib version 5.2.0
15
+ * as currently used by wallet-btc uses an older version of bech32 that lacks bech32m support.
16
+ *
17
+ * When a new version of bitcoinjs-lib that supports bech32m is released this function can
18
+ * be removed and calls should be directed to bitcoinjs-lib instead. Our direct dependency
19
+ * on bech32 lib should also be removed.
20
+ *
21
+ * TODO: Replace with bitcoinjs-lib call
22
+ */
23
+ /* eslint-disable */
24
+ function fromBech32(address: string): {
25
+ version: number;
26
+ prefix: string;
27
+ data: Buffer;
28
+ } {
29
+ let result;
30
+ let version;
31
+ try {
32
+ result = bech32.decode(address);
33
+ } catch (e) {}
34
+
35
+ if (result) {
36
+ version = result.words[0];
37
+ if (version !== 0) throw new TypeError(address + " uses wrong encoding");
38
+ } else {
39
+ result = bech32m.decode(address);
40
+ version = result.words[0];
41
+ if (version === 0) throw new TypeError(address + " uses wrong encoding");
42
+ }
43
+
44
+ const data = bech32.fromWords(result.words.slice(1));
45
+
46
+ return {
47
+ version,
48
+ prefix: result.prefix,
49
+ data: Buffer.from(data),
50
+ };
51
+ }
52
+
53
+ function toBech32(data: Buffer, version: number, prefix: string): string {
54
+ const words = bech32.toWords(data);
55
+ words.unshift(version);
56
+
57
+ return version === 0
58
+ ? bech32.encode(prefix, words)
59
+ : bech32m.encode(prefix, words);
60
+ }
61
+ /* eslint-enable */
62
+
63
+ // This function expects a valid base58check address or a valid
64
+ // bech32/bech32m address.
65
+ function toOutputScriptTemporary(validAddress: string, network: bjs.Network): Buffer {
66
+ try {
67
+ const decodeBase58 = bjs.address.fromBase58Check(validAddress);
68
+ if (decodeBase58.version === network.pubKeyHash)
69
+ return bjs.payments.p2pkh({ hash: decodeBase58.hash }).output as Buffer;
70
+ if (decodeBase58.version === network.scriptHash)
71
+ return bjs.payments.p2sh({ hash: decodeBase58.hash }).output as Buffer;
72
+ } catch (e) {
73
+ // It's not a base58 address, so it's a segwit address
74
+ }
75
+ const decodeBech32 = fromBech32(validAddress);
76
+ return bjs.script.compile([
77
+ // OP_0 is encoded as 0x00, but OP_1 through OP_16 are encoded as 0x51 though 0x60, see BIP173
78
+ decodeBech32.version + (decodeBech32.version > 0 ? 0x50 : 0),
79
+ decodeBech32.data,
80
+ ]);
81
+ }
82
+
83
+ class Bitcoin extends Base {
84
+ toOutputScript(address: string): Buffer {
85
+ // Make sure the address is valid on this network
86
+ // otherwise we can't call toOutputScriptTemporary.
87
+ if (!this.validateAddress(address)) {
88
+ throw new InvalidAddress();
89
+ }
90
+ // bitcoinjs-lib/src/address doesn't yet have released support for bech32m,
91
+ // so we'll implement our own version of toOutputScript while waiting.
92
+ // This implementation is highly inspired (stolen) from bitcoinjs-lib's
93
+ // master branch.
94
+ // One major difference is that our function requires an already
95
+ // valid address, whereas to bitcoinjs-lib version doesn't.
96
+ // TODO: Replace with bitcoinjs-lib call
97
+ return toOutputScriptTemporary(address, this.network);
98
+ }
99
+
100
+ validateAddress(address: string): boolean {
101
+ try {
102
+ // This prefix check is to avoid returning false in cases where a valid base58 address also happens
103
+ // to be a valid bech32(m) string (but invalid segwit address).
104
+ if (address.toLowerCase().startsWith(`${this.network.bech32}1`)) {
105
+ return this.tryBech32(address);
106
+ }
107
+ } catch {
108
+ /* Try base58 instead */
109
+ }
110
+ try {
111
+ return this.tryBase58(address);
112
+ } catch {
113
+ return false;
114
+ }
115
+ }
116
+
117
+ // get address given an address type
118
+ async customGetAddress(
119
+ derivationMode: string,
120
+ xpub: string,
121
+ account: number,
122
+ index: number,
123
+ ): Promise<string> {
124
+ switch (derivationMode) {
125
+ case DerivationModes.TAPROOT:
126
+ return await this.getTaprootAddress(xpub, account, index);
127
+ default:
128
+ return super.customGetAddress(derivationMode, xpub, account, index);
129
+ }
130
+ }
131
+
132
+ private tryBech32(address: string): boolean {
133
+ const result = fromBech32(address);
134
+ if (this.network.bech32 !== result.prefix) {
135
+ // Address doesn't use the expected human-readable part ${network.bech32}
136
+ return false;
137
+ }
138
+ if (result.version > 16 || result.version < 0) {
139
+ // Address has invalid version
140
+ return false;
141
+ }
142
+ if (result.data.length < 2 || result.data.length > 40) {
143
+ // Address has invalid data length
144
+ return false;
145
+ }
146
+ if (result.version === 0 && result.data.length !== 20 && result.data.length !== 32) {
147
+ // Version 0 address uses an invalid witness program length
148
+ return false;
149
+ }
150
+ return true;
151
+ }
152
+
153
+ private tryBase58(address: string): boolean {
154
+ const result = bjs.address.fromBase58Check(address);
155
+ if (this.network.pubKeyHash === result.version || this.network.scriptHash === result.version) {
156
+ return true;
157
+ }
158
+ return false;
159
+ }
160
+
161
+ private hashTapTweak(x: Buffer): Buffer {
162
+ // hash_tag(x) = SHA256(SHA256(tag) || SHA256(tag) || x), see BIP340
163
+ // See https://github.com/bitcoin/bips/blob/master/bip-0340.mediawiki#specification
164
+ const h = bjs.crypto.sha256(Buffer.from("TapTweak", "utf-8"));
165
+ return bjs.crypto.sha256(Buffer.concat([h, h, x]));
166
+ }
167
+
168
+ private async getTaprootAddress(xpub: string, account: number, index: number): Promise<string> {
169
+ const ecdsaPubkey = await this.getPubkeyAt(xpub, account, index);
170
+ // A BIP32 derived key can be converted to a schnorr pubkey by dropping
171
+ // the first byte, which represent the oddness/evenness. In schnorr all
172
+ // pubkeys are even.
173
+ // https://github.com/bitcoin/bips/blob/master/bip-0340.mediawiki#public-key-conversion
174
+ const schnorrInternalPubkey = ecdsaPubkey.slice(1);
175
+
176
+ const evenEcdsaPubkey = Buffer.concat([Buffer.from([0x02]), schnorrInternalPubkey]);
177
+ const tweak = this.hashTapTweak(schnorrInternalPubkey);
178
+
179
+ // Q = P + int(hash_TapTweak(bytes(P)))G
180
+ const outputEcdsaKey = Buffer.from(
181
+ await getSecp256k1Instance().publicKeyTweakAdd(evenEcdsaPubkey, tweak),
182
+ );
183
+ // Convert to schnorr.
184
+ const outputSchnorrKey = outputEcdsaKey.slice(1);
185
+ // Create address
186
+ return toBech32(outputSchnorrKey, 1, this.network.bech32);
187
+ }
188
+
189
+ isTaprootAddress(address: string): boolean {
190
+ // This prefix check is to avoid returning false in cases where a valid base58 address also happens
191
+ // to be a valid bech32(m) string (but invalid segwit address).
192
+ if (address.toLowerCase().startsWith(`${this.network.bech32}1`)) {
193
+ try {
194
+ bjs.address.fromBech32(address);
195
+ } catch {
196
+ return true;
197
+ }
198
+ }
199
+ return false;
200
+ }
201
+ }
202
+
203
+ export default Bitcoin;