@ledgerhq/coin-bitcoin 0.4.0-next.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.
- package/.eslintrc.js +20 -0
- package/.turbo/turbo-build.log +4 -0
- package/.unimportedrc.json +43 -0
- package/CHANGELOG.md +18 -0
- package/LICENSE.txt +21 -0
- package/jest.config.js +10 -0
- package/lib/account.d.ts +7 -0
- package/lib/account.d.ts.map +1 -0
- package/lib/account.js +13 -0
- package/lib/account.js.map +1 -0
- package/lib/bech32m.d.ts +16 -0
- package/lib/bech32m.d.ts.map +1 -0
- package/lib/bech32m.js +166 -0
- package/lib/bech32m.js.map +1 -0
- package/lib/bridge/js.d.ts +41 -0
- package/lib/bridge/js.d.ts.map +1 -0
- package/lib/bridge/js.js +92 -0
- package/lib/bridge/js.js.map +1 -0
- package/lib/bridge.integration.test.d.ts +4 -0
- package/lib/bridge.integration.test.d.ts.map +1 -0
- package/lib/bridge.integration.test.js +47 -0
- package/lib/bridge.integration.test.js.map +1 -0
- package/lib/cache.d.ts +17 -0
- package/lib/cache.d.ts.map +1 -0
- package/lib/cache.js +62 -0
- package/lib/cache.js.map +1 -0
- package/lib/cli-transaction.d.ts +30 -0
- package/lib/cli-transaction.d.ts.map +1 -0
- package/lib/cli-transaction.js +61 -0
- package/lib/cli-transaction.js.map +1 -0
- package/lib/crypto-util.d.ts +5 -0
- package/lib/crypto-util.d.ts.map +1 -0
- package/lib/crypto-util.js +25 -0
- package/lib/crypto-util.js.map +1 -0
- package/lib/datasets/bitcoin.d.ts +7 -0
- package/lib/datasets/bitcoin.d.ts.map +1 -0
- package/lib/datasets/bitcoin.js +318 -0
- package/lib/datasets/bitcoin.js.map +1 -0
- package/lib/datasets/bitcoin.scanAccounts.1.d.ts +6 -0
- package/lib/datasets/bitcoin.scanAccounts.1.d.ts.map +1 -0
- package/lib/datasets/bitcoin.scanAccounts.1.js +240 -0
- package/lib/datasets/bitcoin.scanAccounts.1.js.map +1 -0
- package/lib/datasets/bitcoin_cash.d.ts +5 -0
- package/lib/datasets/bitcoin_cash.d.ts.map +1 -0
- package/lib/datasets/bitcoin_cash.js +45 -0
- package/lib/datasets/bitcoin_cash.js.map +1 -0
- package/lib/datasets/bitcoin_gold.d.ts +5 -0
- package/lib/datasets/bitcoin_gold.d.ts.map +1 -0
- package/lib/datasets/bitcoin_gold.js +73 -0
- package/lib/datasets/bitcoin_gold.js.map +1 -0
- package/lib/datasets/dash.d.ts +5 -0
- package/lib/datasets/dash.d.ts.map +1 -0
- package/lib/datasets/dash.js +37 -0
- package/lib/datasets/dash.js.map +1 -0
- package/lib/datasets/decred.d.ts +5 -0
- package/lib/datasets/decred.d.ts.map +1 -0
- package/lib/datasets/decred.js +43 -0
- package/lib/datasets/decred.js.map +1 -0
- package/lib/datasets/digibyte.d.ts +5 -0
- package/lib/datasets/digibyte.d.ts.map +1 -0
- package/lib/datasets/digibyte.js +166 -0
- package/lib/datasets/digibyte.js.map +1 -0
- package/lib/datasets/digibyte.scanAccounts.1.d.ts +6 -0
- package/lib/datasets/digibyte.scanAccounts.1.d.ts.map +1 -0
- package/lib/datasets/digibyte.scanAccounts.1.js +56 -0
- package/lib/datasets/digibyte.scanAccounts.1.js.map +1 -0
- package/lib/datasets/dogecoin.d.ts +5 -0
- package/lib/datasets/dogecoin.d.ts.map +1 -0
- package/lib/datasets/dogecoin.js +37 -0
- package/lib/datasets/dogecoin.js.map +1 -0
- package/lib/datasets/komodo.d.ts +5 -0
- package/lib/datasets/komodo.d.ts.map +1 -0
- package/lib/datasets/komodo.js +43 -0
- package/lib/datasets/komodo.js.map +1 -0
- package/lib/datasets/litecoin.d.ts +5 -0
- package/lib/datasets/litecoin.d.ts.map +1 -0
- package/lib/datasets/litecoin.js +187 -0
- package/lib/datasets/litecoin.js.map +1 -0
- package/lib/datasets/litecoin.scanAccounts.1.d.ts +6 -0
- package/lib/datasets/litecoin.scanAccounts.1.d.ts.map +1 -0
- package/lib/datasets/litecoin.scanAccounts.1.js +56 -0
- package/lib/datasets/litecoin.scanAccounts.1.js.map +1 -0
- package/lib/datasets/peercoin.d.ts +5 -0
- package/lib/datasets/peercoin.d.ts.map +1 -0
- package/lib/datasets/peercoin.js +37 -0
- package/lib/datasets/peercoin.js.map +1 -0
- package/lib/datasets/pivx.d.ts +5 -0
- package/lib/datasets/pivx.d.ts.map +1 -0
- package/lib/datasets/pivx.js +37 -0
- package/lib/datasets/pivx.js.map +1 -0
- package/lib/datasets/qtum.d.ts +5 -0
- package/lib/datasets/qtum.d.ts.map +1 -0
- package/lib/datasets/qtum.js +57 -0
- package/lib/datasets/qtum.js.map +1 -0
- package/lib/datasets/vertcoin.d.ts +5 -0
- package/lib/datasets/vertcoin.d.ts.map +1 -0
- package/lib/datasets/vertcoin.js +69 -0
- package/lib/datasets/vertcoin.js.map +1 -0
- package/lib/datasets/viacoin.d.ts +5 -0
- package/lib/datasets/viacoin.d.ts.map +1 -0
- package/lib/datasets/viacoin.js +45 -0
- package/lib/datasets/viacoin.js.map +1 -0
- package/lib/datasets/zcash.d.ts +5 -0
- package/lib/datasets/zcash.d.ts.map +1 -0
- package/lib/datasets/zcash.js +43 -0
- package/lib/datasets/zcash.js.map +1 -0
- package/lib/datasets/zencash.d.ts +5 -0
- package/lib/datasets/zencash.d.ts.map +1 -0
- package/lib/datasets/zencash.js +37 -0
- package/lib/datasets/zencash.js.map +1 -0
- package/lib/descriptor.d.ts +19 -0
- package/lib/descriptor.d.ts.map +1 -0
- package/lib/descriptor.js +127 -0
- package/lib/descriptor.js.map +1 -0
- package/lib/descriptor.test.d.ts +2 -0
- package/lib/descriptor.test.d.ts.map +1 -0
- package/lib/descriptor.test.js +55 -0
- package/lib/descriptor.test.js.map +1 -0
- package/lib/deviceTransactionConfig.d.ts +11 -0
- package/lib/deviceTransactionConfig.d.ts.map +1 -0
- package/lib/deviceTransactionConfig.js +26 -0
- package/lib/deviceTransactionConfig.js.map +1 -0
- package/lib/errors.d.ts +7 -0
- package/lib/errors.d.ts.map +1 -0
- package/lib/errors.js +7 -0
- package/lib/errors.js.map +1 -0
- package/lib/explorer.d.ts +10 -0
- package/lib/explorer.d.ts.map +1 -0
- package/lib/explorer.js +38 -0
- package/lib/explorer.js.map +1 -0
- package/lib/formatters.d.ts +9 -0
- package/lib/formatters.d.ts.map +1 -0
- package/lib/formatters.js +51 -0
- package/lib/formatters.js.map +1 -0
- package/lib/getAccountNetworkInfo.d.ts +6 -0
- package/lib/getAccountNetworkInfo.d.ts.map +1 -0
- package/lib/getAccountNetworkInfo.js +69 -0
- package/lib/getAccountNetworkInfo.js.map +1 -0
- package/lib/getAccountNetworkInfo.test.d.ts +2 -0
- package/lib/getAccountNetworkInfo.test.d.ts.map +1 -0
- package/lib/getAccountNetworkInfo.test.js +49 -0
- package/lib/getAccountNetworkInfo.test.js.map +1 -0
- package/lib/hw-getAddress.d.ts +5 -0
- package/lib/hw-getAddress.d.ts.map +1 -0
- package/lib/hw-getAddress.js +45 -0
- package/lib/hw-getAddress.js.map +1 -0
- package/lib/hw-signMessage.d.ts +7 -0
- package/lib/hw-signMessage.d.ts.map +1 -0
- package/lib/hw-signMessage.js +27 -0
- package/lib/hw-signMessage.js.map +1 -0
- package/lib/hw-signMessage.test.d.ts +2 -0
- package/lib/hw-signMessage.test.d.ts.map +1 -0
- package/lib/hw-signMessage.test.js +97 -0
- package/lib/hw-signMessage.test.js.map +1 -0
- package/lib/js-broadcast.d.ts +11 -0
- package/lib/js-broadcast.d.ts.map +1 -0
- package/lib/js-broadcast.js +48 -0
- package/lib/js-broadcast.js.map +1 -0
- package/lib/js-buildTransaction.d.ts +5 -0
- package/lib/js-buildTransaction.d.ts.map +1 -0
- package/lib/js-buildTransaction.js +75 -0
- package/lib/js-buildTransaction.js.map +1 -0
- package/lib/js-createTransaction.d.ts +9 -0
- package/lib/js-createTransaction.d.ts.map +1 -0
- package/lib/js-createTransaction.js +26 -0
- package/lib/js-createTransaction.js.map +1 -0
- package/lib/js-estimateMaxSpendable.d.ts +15 -0
- package/lib/js-estimateMaxSpendable.d.ts.map +1 -0
- package/lib/js-estimateMaxSpendable.js +58 -0
- package/lib/js-estimateMaxSpendable.js.map +1 -0
- package/lib/js-getFeesForTransaction.d.ts +13 -0
- package/lib/js-getFeesForTransaction.d.ts.map +1 -0
- package/lib/js-getFeesForTransaction.js +52 -0
- package/lib/js-getFeesForTransaction.js.map +1 -0
- package/lib/js-getTransactionStatus.d.ts +5 -0
- package/lib/js-getTransactionStatus.d.ts.map +1 -0
- package/lib/js-getTransactionStatus.js +113 -0
- package/lib/js-getTransactionStatus.js.map +1 -0
- package/lib/js-prepareTransaction.d.ts +5 -0
- package/lib/js-prepareTransaction.d.ts.map +1 -0
- package/lib/js-prepareTransaction.js +35 -0
- package/lib/js-prepareTransaction.js.map +1 -0
- package/lib/js-signOperation.d.ts +6 -0
- package/lib/js-signOperation.d.ts.map +1 -0
- package/lib/js-signOperation.js +152 -0
- package/lib/js-signOperation.js.map +1 -0
- package/lib/js-synchronisation.d.ts +13 -0
- package/lib/js-synchronisation.d.ts.map +1 -0
- package/lib/js-synchronisation.js +198 -0
- package/lib/js-synchronisation.js.map +1 -0
- package/lib/logic.d.ts +36 -0
- package/lib/logic.d.ts.map +1 -0
- package/lib/logic.js +266 -0
- package/lib/logic.js.map +1 -0
- package/lib/logic.unit.test.d.ts +2 -0
- package/lib/logic.unit.test.d.ts.map +1 -0
- package/lib/logic.unit.test.js +35 -0
- package/lib/logic.unit.test.js.map +1 -0
- package/lib/mockBtcSigner.d.ts +20 -0
- package/lib/mockBtcSigner.d.ts.map +1 -0
- package/lib/mockBtcSigner.js +63 -0
- package/lib/mockBtcSigner.js.map +1 -0
- package/lib/networks.d.ts +3 -0
- package/lib/networks.d.ts.map +1 -0
- package/lib/networks.js +341 -0
- package/lib/networks.js.map +1 -0
- package/lib/publicAddresses.test.d.ts +2 -0
- package/lib/publicAddresses.test.d.ts.map +1 -0
- package/lib/publicAddresses.test.js +12 -0
- package/lib/publicAddresses.test.js.map +1 -0
- package/lib/serialization.d.ts +11 -0
- package/lib/serialization.d.ts.map +1 -0
- package/lib/serialization.js +65 -0
- package/lib/serialization.js.map +1 -0
- package/lib/serialization.test.d.ts +2 -0
- package/lib/serialization.test.d.ts.map +1 -0
- package/lib/serialization.test.js +108 -0
- package/lib/serialization.test.js.map +1 -0
- package/lib/signer.d.ts +70 -0
- package/lib/signer.d.ts.map +1 -0
- package/lib/signer.js +3 -0
- package/lib/signer.js.map +1 -0
- package/lib/specs.d.ts +23 -0
- package/lib/specs.d.ts.map +1 -0
- package/lib/specs.js +524 -0
- package/lib/specs.js.map +1 -0
- package/lib/speculos-deviceActions.d.ts +4 -0
- package/lib/speculos-deviceActions.d.ts.map +1 -0
- package/lib/speculos-deviceActions.js +61 -0
- package/lib/speculos-deviceActions.js.map +1 -0
- package/lib/transaction.d.ts +16 -0
- package/lib/transaction.d.ts.map +1 -0
- package/lib/transaction.js +114 -0
- package/lib/transaction.js.map +1 -0
- package/lib/types.d.ts +140 -0
- package/lib/types.d.ts.map +1 -0
- package/lib/types.js +23 -0
- package/lib/types.js.map +1 -0
- package/lib/wallet-btc/__tests__/bitcoin.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/bitcoin.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/bitcoin.test.js +309 -0
- package/lib/wallet-btc/__tests__/bitcoin.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/logic.d.ts +2 -0
- package/lib/wallet-btc/__tests__/logic.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/logic.js +24 -0
- package/lib/wallet-btc/__tests__/logic.js.map +1 -0
- package/lib/wallet-btc/__tests__/utils.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/utils.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/utils.test.js +223 -0
- package/lib/wallet-btc/__tests__/utils.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/wallet.errorpropagation.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/wallet.errorpropagation.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/wallet.errorpropagation.integration.test.js +46 -0
- package/lib/wallet-btc/__tests__/wallet.errorpropagation.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.js +78 -0
- package/lib/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/wallet.explorer.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/wallet.explorer.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/wallet.explorer.integration.test.js +43 -0
- package/lib/wallet-btc/__tests__/wallet.explorer.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/wallet.explorer.unit.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/wallet.explorer.unit.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/wallet.explorer.unit.test.js +189 -0
- package/lib/wallet-btc/__tests__/wallet.explorer.unit.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/wallet.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/wallet.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/wallet.integration.test.js +110 -0
- package/lib/wallet-btc/__tests__/wallet.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/wallet.storage.unit.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/wallet.storage.unit.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/wallet.storage.unit.test.js +176 -0
- package/lib/wallet-btc/__tests__/wallet.storage.unit.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.getAddress.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/xpub.getAddress.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.getAddress.integration.test.js +77 -0
- package/lib/wallet-btc/__tests__/xpub.getAddress.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.js +325 -0
- package/lib/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.reorg.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/xpub.reorg.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.reorg.integration.test.js +152 -0
- package/lib/wallet-btc/__tests__/xpub.reorg.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.synced.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/xpub.synced.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.synced.integration.test.js +74 -0
- package/lib/wallet-btc/__tests__/xpub.synced.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.syncing.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/xpub.syncing.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.syncing.integration.test.js +209 -0
- package/lib/wallet-btc/__tests__/xpub.syncing.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.js +186 -0
- package/lib/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.js +178 -0
- package/lib/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.js +100 -0
- package/lib/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.txs.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/xpub.txs.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.txs.integration.test.js +315 -0
- package/lib/wallet-btc/__tests__/xpub.txs.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.js +171 -0
- package/lib/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.js.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.utxo.unit.test.d.ts +2 -0
- package/lib/wallet-btc/__tests__/xpub.utxo.unit.test.d.ts.map +1 -0
- package/lib/wallet-btc/__tests__/xpub.utxo.unit.test.js +51 -0
- package/lib/wallet-btc/__tests__/xpub.utxo.unit.test.js.map +1 -0
- package/lib/wallet-btc/account.d.ts +27 -0
- package/lib/wallet-btc/account.d.ts.map +1 -0
- package/lib/wallet-btc/account.js +3 -0
- package/lib/wallet-btc/account.js.map +1 -0
- package/lib/wallet-btc/crypto/base.d.ts +33 -0
- package/lib/wallet-btc/crypto/base.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/base.js +196 -0
- package/lib/wallet-btc/crypto/base.js.map +1 -0
- package/lib/wallet-btc/crypto/bip32.d.ts +11 -0
- package/lib/wallet-btc/crypto/bip32.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/bip32.js +45 -0
- package/lib/wallet-btc/crypto/bip32.js.map +1 -0
- package/lib/wallet-btc/crypto/bitcoin.d.ts +13 -0
- package/lib/wallet-btc/crypto/bitcoin.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/bitcoin.js +226 -0
- package/lib/wallet-btc/crypto/bitcoin.js.map +1 -0
- package/lib/wallet-btc/crypto/bitcoincash.d.ts +13 -0
- package/lib/wallet-btc/crypto/bitcoincash.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/bitcoincash.js +55 -0
- package/lib/wallet-btc/crypto/bitcoincash.js.map +1 -0
- package/lib/wallet-btc/crypto/bitcoingold.d.ts +8 -0
- package/lib/wallet-btc/crypto/bitcoingold.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/bitcoingold.js +17 -0
- package/lib/wallet-btc/crypto/bitcoingold.js.map +1 -0
- package/lib/wallet-btc/crypto/dash.d.ts +8 -0
- package/lib/wallet-btc/crypto/dash.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/dash.js +25 -0
- package/lib/wallet-btc/crypto/dash.js.map +1 -0
- package/lib/wallet-btc/crypto/decred.d.ts +15 -0
- package/lib/wallet-btc/crypto/decred.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/decred.js +121 -0
- package/lib/wallet-btc/crypto/decred.js.map +1 -0
- package/lib/wallet-btc/crypto/digibyte.d.ts +9 -0
- package/lib/wallet-btc/crypto/digibyte.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/digibyte.js +58 -0
- package/lib/wallet-btc/crypto/digibyte.js.map +1 -0
- package/lib/wallet-btc/crypto/doge.d.ts +8 -0
- package/lib/wallet-btc/crypto/doge.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/doge.js +19 -0
- package/lib/wallet-btc/crypto/doge.js.map +1 -0
- package/lib/wallet-btc/crypto/factory.d.ts +3 -0
- package/lib/wallet-btc/crypto/factory.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/factory.js +132 -0
- package/lib/wallet-btc/crypto/factory.js.map +1 -0
- package/lib/wallet-btc/crypto/index.d.ts +19 -0
- package/lib/wallet-btc/crypto/index.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/index.js +44 -0
- package/lib/wallet-btc/crypto/index.js.map +1 -0
- package/lib/wallet-btc/crypto/komodo.d.ts +8 -0
- package/lib/wallet-btc/crypto/komodo.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/komodo.js +20 -0
- package/lib/wallet-btc/crypto/komodo.js.map +1 -0
- package/lib/wallet-btc/crypto/litecoin.d.ts +10 -0
- package/lib/wallet-btc/crypto/litecoin.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/litecoin.js +56 -0
- package/lib/wallet-btc/crypto/litecoin.js.map +1 -0
- package/lib/wallet-btc/crypto/peercoin.d.ts +8 -0
- package/lib/wallet-btc/crypto/peercoin.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/peercoin.js +19 -0
- package/lib/wallet-btc/crypto/peercoin.js.map +1 -0
- package/lib/wallet-btc/crypto/pivx.d.ts +8 -0
- package/lib/wallet-btc/crypto/pivx.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/pivx.js +21 -0
- package/lib/wallet-btc/crypto/pivx.js.map +1 -0
- package/lib/wallet-btc/crypto/qtum.d.ts +8 -0
- package/lib/wallet-btc/crypto/qtum.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/qtum.js +17 -0
- package/lib/wallet-btc/crypto/qtum.js.map +1 -0
- package/lib/wallet-btc/crypto/secp256k1.d.ts +16 -0
- package/lib/wallet-btc/crypto/secp256k1.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/secp256k1.js +26 -0
- package/lib/wallet-btc/crypto/secp256k1.js.map +1 -0
- package/lib/wallet-btc/crypto/stealth.d.ts +8 -0
- package/lib/wallet-btc/crypto/stealth.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/stealth.js +21 -0
- package/lib/wallet-btc/crypto/stealth.js.map +1 -0
- package/lib/wallet-btc/crypto/types.d.ts +11 -0
- package/lib/wallet-btc/crypto/types.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/types.js +3 -0
- package/lib/wallet-btc/crypto/types.js.map +1 -0
- package/lib/wallet-btc/crypto/via.d.ts +8 -0
- package/lib/wallet-btc/crypto/via.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/via.js +17 -0
- package/lib/wallet-btc/crypto/via.js.map +1 -0
- package/lib/wallet-btc/crypto/vtc.d.ts +8 -0
- package/lib/wallet-btc/crypto/vtc.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/vtc.js +17 -0
- package/lib/wallet-btc/crypto/vtc.js.map +1 -0
- package/lib/wallet-btc/crypto/zec.d.ts +13 -0
- package/lib/wallet-btc/crypto/zec.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/zec.js +95 -0
- package/lib/wallet-btc/crypto/zec.js.map +1 -0
- package/lib/wallet-btc/crypto/zen.d.ts +13 -0
- package/lib/wallet-btc/crypto/zen.d.ts.map +1 -0
- package/lib/wallet-btc/crypto/zen.js +116 -0
- package/lib/wallet-btc/crypto/zen.js.map +1 -0
- package/lib/wallet-btc/explorer/index.d.ts +47 -0
- package/lib/wallet-btc/explorer/index.d.ts.map +1 -0
- package/lib/wallet-btc/explorer/index.js +191 -0
- package/lib/wallet-btc/explorer/index.js.map +1 -0
- package/lib/wallet-btc/explorer/types.d.ts +18 -0
- package/lib/wallet-btc/explorer/types.d.ts.map +1 -0
- package/lib/wallet-btc/explorer/types.js +3 -0
- package/lib/wallet-btc/explorer/types.js.map +1 -0
- package/lib/wallet-btc/index.d.ts +16 -0
- package/lib/wallet-btc/index.d.ts.map +1 -0
- package/lib/wallet-btc/index.js +38 -0
- package/lib/wallet-btc/index.js.map +1 -0
- package/lib/wallet-btc/pickingstrategies/CoinSelect.d.ts +18 -0
- package/lib/wallet-btc/pickingstrategies/CoinSelect.d.ts.map +1 -0
- package/lib/wallet-btc/pickingstrategies/CoinSelect.js +186 -0
- package/lib/wallet-btc/pickingstrategies/CoinSelect.js.map +1 -0
- package/lib/wallet-btc/pickingstrategies/DeepFirst.d.ts +17 -0
- package/lib/wallet-btc/pickingstrategies/DeepFirst.d.ts.map +1 -0
- package/lib/wallet-btc/pickingstrategies/DeepFirst.js +100 -0
- package/lib/wallet-btc/pickingstrategies/DeepFirst.js.map +1 -0
- package/lib/wallet-btc/pickingstrategies/Merge.d.ts +17 -0
- package/lib/wallet-btc/pickingstrategies/Merge.d.ts.map +1 -0
- package/lib/wallet-btc/pickingstrategies/Merge.js +100 -0
- package/lib/wallet-btc/pickingstrategies/Merge.js.map +1 -0
- package/lib/wallet-btc/pickingstrategies/types.d.ts +27 -0
- package/lib/wallet-btc/pickingstrategies/types.d.ts.map +1 -0
- package/lib/wallet-btc/pickingstrategies/types.js +12 -0
- package/lib/wallet-btc/pickingstrategies/types.js.map +1 -0
- package/lib/wallet-btc/storage/index.d.ts +77 -0
- package/lib/wallet-btc/storage/index.d.ts.map +1 -0
- package/lib/wallet-btc/storage/index.js +237 -0
- package/lib/wallet-btc/storage/index.js.map +1 -0
- package/lib/wallet-btc/storage/types.d.ts +74 -0
- package/lib/wallet-btc/storage/types.d.ts.map +1 -0
- package/lib/wallet-btc/storage/types.js +3 -0
- package/lib/wallet-btc/storage/types.js.map +1 -0
- package/lib/wallet-btc/types.d.ts +25 -0
- package/lib/wallet-btc/types.d.ts.map +1 -0
- package/lib/wallet-btc/types.js +11 -0
- package/lib/wallet-btc/types.js.map +1 -0
- package/lib/wallet-btc/utils.d.ts +45 -0
- package/lib/wallet-btc/utils.d.ts.map +1 -0
- package/lib/wallet-btc/utils.js +189 -0
- package/lib/wallet-btc/utils.js.map +1 -0
- package/lib/wallet-btc/wallet.d.ts +80 -0
- package/lib/wallet-btc/wallet.d.ts.map +1 -0
- package/lib/wallet-btc/wallet.js +291 -0
- package/lib/wallet-btc/wallet.js.map +1 -0
- package/lib/wallet-btc/xpub.d.ts +52 -0
- package/lib/wallet-btc/xpub.d.ts.map +1 -0
- package/lib/wallet-btc/xpub.js +296 -0
- package/lib/wallet-btc/xpub.js.map +1 -0
- package/lib/xpub.txs.loadExport.unit.test.d.ts +2 -0
- package/lib/xpub.txs.loadExport.unit.test.d.ts.map +1 -0
- package/lib/xpub.txs.loadExport.unit.test.js +110 -0
- package/lib/xpub.txs.loadExport.unit.test.js.map +1 -0
- package/lib/xpub.txs.txNoOutput.unit.test.d.ts +2 -0
- package/lib/xpub.txs.txNoOutput.unit.test.d.ts.map +1 -0
- package/lib/xpub.txs.txNoOutput.unit.test.js +41 -0
- package/lib/xpub.txs.txNoOutput.unit.test.js.map +1 -0
- package/lib-es/account.d.ts +7 -0
- package/lib-es/account.d.ts.map +1 -0
- package/lib-es/account.js +11 -0
- package/lib-es/account.js.map +1 -0
- package/lib-es/bech32m.d.ts +16 -0
- package/lib-es/bech32m.d.ts.map +1 -0
- package/lib-es/bech32m.js +163 -0
- package/lib-es/bech32m.js.map +1 -0
- package/lib-es/bridge/js.d.ts +41 -0
- package/lib-es/bridge/js.d.ts.map +1 -0
- package/lib-es/bridge/js.js +85 -0
- package/lib-es/bridge/js.js.map +1 -0
- package/lib-es/bridge.integration.test.d.ts +4 -0
- package/lib-es/bridge.integration.test.d.ts.map +1 -0
- package/lib-es/bridge.integration.test.js +41 -0
- package/lib-es/bridge.integration.test.js.map +1 -0
- package/lib-es/cache.d.ts +17 -0
- package/lib-es/cache.d.ts.map +1 -0
- package/lib-es/cache.js +56 -0
- package/lib-es/cache.js.map +1 -0
- package/lib-es/cli-transaction.d.ts +30 -0
- package/lib-es/cli-transaction.d.ts.map +1 -0
- package/lib-es/cli-transaction.js +55 -0
- package/lib-es/cli-transaction.js.map +1 -0
- package/lib-es/crypto-util.d.ts +5 -0
- package/lib-es/crypto-util.d.ts.map +1 -0
- package/lib-es/crypto-util.js +15 -0
- package/lib-es/crypto-util.js.map +1 -0
- package/lib-es/datasets/bitcoin.d.ts +7 -0
- package/lib-es/datasets/bitcoin.d.ts.map +1 -0
- package/lib-es/datasets/bitcoin.js +312 -0
- package/lib-es/datasets/bitcoin.js.map +1 -0
- package/lib-es/datasets/bitcoin.scanAccounts.1.d.ts +6 -0
- package/lib-es/datasets/bitcoin.scanAccounts.1.d.ts.map +1 -0
- package/lib-es/datasets/bitcoin.scanAccounts.1.js +238 -0
- package/lib-es/datasets/bitcoin.scanAccounts.1.js.map +1 -0
- package/lib-es/datasets/bitcoin_cash.d.ts +5 -0
- package/lib-es/datasets/bitcoin_cash.d.ts.map +1 -0
- package/lib-es/datasets/bitcoin_cash.js +43 -0
- package/lib-es/datasets/bitcoin_cash.js.map +1 -0
- package/lib-es/datasets/bitcoin_gold.d.ts +5 -0
- package/lib-es/datasets/bitcoin_gold.d.ts.map +1 -0
- package/lib-es/datasets/bitcoin_gold.js +71 -0
- package/lib-es/datasets/bitcoin_gold.js.map +1 -0
- package/lib-es/datasets/dash.d.ts +5 -0
- package/lib-es/datasets/dash.d.ts.map +1 -0
- package/lib-es/datasets/dash.js +35 -0
- package/lib-es/datasets/dash.js.map +1 -0
- package/lib-es/datasets/decred.d.ts +5 -0
- package/lib-es/datasets/decred.d.ts.map +1 -0
- package/lib-es/datasets/decred.js +41 -0
- package/lib-es/datasets/decred.js.map +1 -0
- package/lib-es/datasets/digibyte.d.ts +5 -0
- package/lib-es/datasets/digibyte.d.ts.map +1 -0
- package/lib-es/datasets/digibyte.js +161 -0
- package/lib-es/datasets/digibyte.js.map +1 -0
- package/lib-es/datasets/digibyte.scanAccounts.1.d.ts +6 -0
- package/lib-es/datasets/digibyte.scanAccounts.1.d.ts.map +1 -0
- package/lib-es/datasets/digibyte.scanAccounts.1.js +54 -0
- package/lib-es/datasets/digibyte.scanAccounts.1.js.map +1 -0
- package/lib-es/datasets/dogecoin.d.ts +5 -0
- package/lib-es/datasets/dogecoin.d.ts.map +1 -0
- package/lib-es/datasets/dogecoin.js +35 -0
- package/lib-es/datasets/dogecoin.js.map +1 -0
- package/lib-es/datasets/komodo.d.ts +5 -0
- package/lib-es/datasets/komodo.d.ts.map +1 -0
- package/lib-es/datasets/komodo.js +41 -0
- package/lib-es/datasets/komodo.js.map +1 -0
- package/lib-es/datasets/litecoin.d.ts +5 -0
- package/lib-es/datasets/litecoin.d.ts.map +1 -0
- package/lib-es/datasets/litecoin.js +182 -0
- package/lib-es/datasets/litecoin.js.map +1 -0
- package/lib-es/datasets/litecoin.scanAccounts.1.d.ts +6 -0
- package/lib-es/datasets/litecoin.scanAccounts.1.d.ts.map +1 -0
- package/lib-es/datasets/litecoin.scanAccounts.1.js +54 -0
- package/lib-es/datasets/litecoin.scanAccounts.1.js.map +1 -0
- package/lib-es/datasets/peercoin.d.ts +5 -0
- package/lib-es/datasets/peercoin.d.ts.map +1 -0
- package/lib-es/datasets/peercoin.js +35 -0
- package/lib-es/datasets/peercoin.js.map +1 -0
- package/lib-es/datasets/pivx.d.ts +5 -0
- package/lib-es/datasets/pivx.d.ts.map +1 -0
- package/lib-es/datasets/pivx.js +35 -0
- package/lib-es/datasets/pivx.js.map +1 -0
- package/lib-es/datasets/qtum.d.ts +5 -0
- package/lib-es/datasets/qtum.d.ts.map +1 -0
- package/lib-es/datasets/qtum.js +55 -0
- package/lib-es/datasets/qtum.js.map +1 -0
- package/lib-es/datasets/vertcoin.d.ts +5 -0
- package/lib-es/datasets/vertcoin.d.ts.map +1 -0
- package/lib-es/datasets/vertcoin.js +67 -0
- package/lib-es/datasets/vertcoin.js.map +1 -0
- package/lib-es/datasets/viacoin.d.ts +5 -0
- package/lib-es/datasets/viacoin.d.ts.map +1 -0
- package/lib-es/datasets/viacoin.js +43 -0
- package/lib-es/datasets/viacoin.js.map +1 -0
- package/lib-es/datasets/zcash.d.ts +5 -0
- package/lib-es/datasets/zcash.d.ts.map +1 -0
- package/lib-es/datasets/zcash.js +41 -0
- package/lib-es/datasets/zcash.js.map +1 -0
- package/lib-es/datasets/zencash.d.ts +5 -0
- package/lib-es/datasets/zencash.d.ts.map +1 -0
- package/lib-es/datasets/zencash.js +35 -0
- package/lib-es/datasets/zencash.js.map +1 -0
- package/lib-es/descriptor.d.ts +19 -0
- package/lib-es/descriptor.d.ts.map +1 -0
- package/lib-es/descriptor.js +118 -0
- package/lib-es/descriptor.js.map +1 -0
- package/lib-es/descriptor.test.d.ts +2 -0
- package/lib-es/descriptor.test.d.ts.map +1 -0
- package/lib-es/descriptor.test.js +50 -0
- package/lib-es/descriptor.test.js.map +1 -0
- package/lib-es/deviceTransactionConfig.d.ts +11 -0
- package/lib-es/deviceTransactionConfig.d.ts.map +1 -0
- package/lib-es/deviceTransactionConfig.js +24 -0
- package/lib-es/deviceTransactionConfig.js.map +1 -0
- package/lib-es/errors.d.ts +7 -0
- package/lib-es/errors.d.ts.map +1 -0
- package/lib-es/errors.js +4 -0
- package/lib-es/errors.js.map +1 -0
- package/lib-es/explorer.d.ts +10 -0
- package/lib-es/explorer.d.ts.map +1 -0
- package/lib-es/explorer.js +30 -0
- package/lib-es/explorer.js.map +1 -0
- package/lib-es/formatters.d.ts +9 -0
- package/lib-es/formatters.d.ts.map +1 -0
- package/lib-es/formatters.js +46 -0
- package/lib-es/formatters.js.map +1 -0
- package/lib-es/getAccountNetworkInfo.d.ts +6 -0
- package/lib-es/getAccountNetworkInfo.d.ts.map +1 -0
- package/lib-es/getAccountNetworkInfo.js +61 -0
- package/lib-es/getAccountNetworkInfo.js.map +1 -0
- package/lib-es/getAccountNetworkInfo.test.d.ts +2 -0
- package/lib-es/getAccountNetworkInfo.test.d.ts.map +1 -0
- package/lib-es/getAccountNetworkInfo.test.js +47 -0
- package/lib-es/getAccountNetworkInfo.test.js.map +1 -0
- package/lib-es/hw-getAddress.d.ts +5 -0
- package/lib-es/hw-getAddress.d.ts.map +1 -0
- package/lib-es/hw-getAddress.js +43 -0
- package/lib-es/hw-getAddress.js.map +1 -0
- package/lib-es/hw-signMessage.d.ts +7 -0
- package/lib-es/hw-signMessage.d.ts.map +1 -0
- package/lib-es/hw-signMessage.js +23 -0
- package/lib-es/hw-signMessage.js.map +1 -0
- package/lib-es/hw-signMessage.test.d.ts +2 -0
- package/lib-es/hw-signMessage.test.d.ts.map +1 -0
- package/lib-es/hw-signMessage.test.js +92 -0
- package/lib-es/hw-signMessage.test.js.map +1 -0
- package/lib-es/js-broadcast.d.ts +11 -0
- package/lib-es/js-broadcast.d.ts.map +1 -0
- package/lib-es/js-broadcast.js +23 -0
- package/lib-es/js-broadcast.js.map +1 -0
- package/lib-es/js-buildTransaction.d.ts +5 -0
- package/lib-es/js-buildTransaction.d.ts.map +1 -0
- package/lib-es/js-buildTransaction.js +48 -0
- package/lib-es/js-buildTransaction.js.map +1 -0
- package/lib-es/js-createTransaction.d.ts +9 -0
- package/lib-es/js-createTransaction.d.ts.map +1 -0
- package/lib-es/js-createTransaction.js +24 -0
- package/lib-es/js-createTransaction.js.map +1 -0
- package/lib-es/js-estimateMaxSpendable.d.ts +15 -0
- package/lib-es/js-estimateMaxSpendable.d.ts.map +1 -0
- package/lib-es/js-estimateMaxSpendable.js +33 -0
- package/lib-es/js-estimateMaxSpendable.js.map +1 -0
- package/lib-es/js-getFeesForTransaction.d.ts +13 -0
- package/lib-es/js-getFeesForTransaction.d.ts.map +1 -0
- package/lib-es/js-getFeesForTransaction.js +50 -0
- package/lib-es/js-getFeesForTransaction.js.map +1 -0
- package/lib-es/js-getTransactionStatus.d.ts +5 -0
- package/lib-es/js-getTransactionStatus.d.ts.map +1 -0
- package/lib-es/js-getTransactionStatus.js +108 -0
- package/lib-es/js-getTransactionStatus.js.map +1 -0
- package/lib-es/js-prepareTransaction.d.ts +5 -0
- package/lib-es/js-prepareTransaction.d.ts.map +1 -0
- package/lib-es/js-prepareTransaction.js +30 -0
- package/lib-es/js-prepareTransaction.js.map +1 -0
- package/lib-es/js-signOperation.d.ts +6 -0
- package/lib-es/js-signOperation.d.ts.map +1 -0
- package/lib-es/js-signOperation.js +127 -0
- package/lib-es/js-signOperation.js.map +1 -0
- package/lib-es/js-synchronisation.d.ts +13 -0
- package/lib-es/js-synchronisation.d.ts.map +1 -0
- package/lib-es/js-synchronisation.js +190 -0
- package/lib-es/js-synchronisation.js.map +1 -0
- package/lib-es/logic.d.ts +36 -0
- package/lib-es/logic.d.ts.map +1 -0
- package/lib-es/logic.js +254 -0
- package/lib-es/logic.js.map +1 -0
- package/lib-es/logic.unit.test.d.ts +2 -0
- package/lib-es/logic.unit.test.d.ts.map +1 -0
- package/lib-es/logic.unit.test.js +33 -0
- package/lib-es/logic.unit.test.js.map +1 -0
- package/lib-es/mockBtcSigner.d.ts +20 -0
- package/lib-es/mockBtcSigner.d.ts.map +1 -0
- package/lib-es/mockBtcSigner.js +58 -0
- package/lib-es/mockBtcSigner.js.map +1 -0
- package/lib-es/networks.d.ts +3 -0
- package/lib-es/networks.d.ts.map +1 -0
- package/lib-es/networks.js +337 -0
- package/lib-es/networks.js.map +1 -0
- package/lib-es/publicAddresses.test.d.ts +2 -0
- package/lib-es/publicAddresses.test.d.ts.map +1 -0
- package/lib-es/publicAddresses.test.js +10 -0
- package/lib-es/publicAddresses.test.js.map +1 -0
- package/lib-es/serialization.d.ts +11 -0
- package/lib-es/serialization.d.ts.map +1 -0
- package/lib-es/serialization.js +51 -0
- package/lib-es/serialization.js.map +1 -0
- package/lib-es/serialization.test.d.ts +2 -0
- package/lib-es/serialization.test.d.ts.map +1 -0
- package/lib-es/serialization.test.js +103 -0
- package/lib-es/serialization.test.js.map +1 -0
- package/lib-es/signer.d.ts +70 -0
- package/lib-es/signer.d.ts.map +1 -0
- package/lib-es/signer.js +2 -0
- package/lib-es/signer.js.map +1 -0
- package/lib-es/specs.d.ts +23 -0
- package/lib-es/specs.d.ts.map +1 -0
- package/lib-es/specs.js +519 -0
- package/lib-es/specs.js.map +1 -0
- package/lib-es/speculos-deviceActions.d.ts +4 -0
- package/lib-es/speculos-deviceActions.d.ts.map +1 -0
- package/lib-es/speculos-deviceActions.js +58 -0
- package/lib-es/speculos-deviceActions.js.map +1 -0
- package/lib-es/transaction.d.ts +16 -0
- package/lib-es/transaction.d.ts.map +1 -0
- package/lib-es/transaction.js +107 -0
- package/lib-es/transaction.js.map +1 -0
- package/lib-es/types.d.ts +140 -0
- package/lib-es/types.d.ts.map +1 -0
- package/lib-es/types.js +20 -0
- package/lib-es/types.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/bitcoin.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/bitcoin.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/bitcoin.test.js +304 -0
- package/lib-es/wallet-btc/__tests__/bitcoin.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/logic.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/logic.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/logic.js +22 -0
- package/lib-es/wallet-btc/__tests__/logic.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/utils.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/utils.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/utils.test.js +195 -0
- package/lib-es/wallet-btc/__tests__/utils.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/wallet.errorpropagation.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/wallet.errorpropagation.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/wallet.errorpropagation.integration.test.js +41 -0
- package/lib-es/wallet-btc/__tests__/wallet.errorpropagation.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.js +50 -0
- package/lib-es/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/wallet.explorer.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/wallet.explorer.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/wallet.explorer.integration.test.js +38 -0
- package/lib-es/wallet-btc/__tests__/wallet.explorer.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/wallet.explorer.unit.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/wallet.explorer.unit.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/wallet.explorer.unit.test.js +184 -0
- package/lib-es/wallet-btc/__tests__/wallet.explorer.unit.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/wallet.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/wallet.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/wallet.integration.test.js +105 -0
- package/lib-es/wallet-btc/__tests__/wallet.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/wallet.storage.unit.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/wallet.storage.unit.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/wallet.storage.unit.test.js +171 -0
- package/lib-es/wallet-btc/__tests__/wallet.storage.unit.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.getAddress.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/xpub.getAddress.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.getAddress.integration.test.js +72 -0
- package/lib-es/wallet-btc/__tests__/xpub.getAddress.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.js +297 -0
- package/lib-es/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.reorg.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/xpub.reorg.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.reorg.integration.test.js +124 -0
- package/lib-es/wallet-btc/__tests__/xpub.reorg.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.synced.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/xpub.synced.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.synced.integration.test.js +69 -0
- package/lib-es/wallet-btc/__tests__/xpub.synced.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.syncing.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/xpub.syncing.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.syncing.integration.test.js +204 -0
- package/lib-es/wallet-btc/__tests__/xpub.syncing.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.js +158 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.js +150 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.js +95 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.integration.test.js +287 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.js +143 -0
- package/lib-es/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.js.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.utxo.unit.test.d.ts +2 -0
- package/lib-es/wallet-btc/__tests__/xpub.utxo.unit.test.d.ts.map +1 -0
- package/lib-es/wallet-btc/__tests__/xpub.utxo.unit.test.js +46 -0
- package/lib-es/wallet-btc/__tests__/xpub.utxo.unit.test.js.map +1 -0
- package/lib-es/wallet-btc/account.d.ts +27 -0
- package/lib-es/wallet-btc/account.d.ts.map +1 -0
- package/lib-es/wallet-btc/account.js +2 -0
- package/lib-es/wallet-btc/account.js.map +1 -0
- package/lib-es/wallet-btc/crypto/base.d.ts +33 -0
- package/lib-es/wallet-btc/crypto/base.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/base.js +166 -0
- package/lib-es/wallet-btc/crypto/base.js.map +1 -0
- package/lib-es/wallet-btc/crypto/bip32.d.ts +11 -0
- package/lib-es/wallet-btc/crypto/bip32.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/bip32.js +40 -0
- package/lib-es/wallet-btc/crypto/bip32.js.map +1 -0
- package/lib-es/wallet-btc/crypto/bitcoin.d.ts +13 -0
- package/lib-es/wallet-btc/crypto/bitcoin.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/bitcoin.js +198 -0
- package/lib-es/wallet-btc/crypto/bitcoin.js.map +1 -0
- package/lib-es/wallet-btc/crypto/bitcoincash.d.ts +13 -0
- package/lib-es/wallet-btc/crypto/bitcoincash.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/bitcoincash.js +50 -0
- package/lib-es/wallet-btc/crypto/bitcoincash.js.map +1 -0
- package/lib-es/wallet-btc/crypto/bitcoingold.d.ts +8 -0
- package/lib-es/wallet-btc/crypto/bitcoingold.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/bitcoingold.js +12 -0
- package/lib-es/wallet-btc/crypto/bitcoingold.js.map +1 -0
- package/lib-es/wallet-btc/crypto/dash.d.ts +8 -0
- package/lib-es/wallet-btc/crypto/dash.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/dash.js +20 -0
- package/lib-es/wallet-btc/crypto/dash.js.map +1 -0
- package/lib-es/wallet-btc/crypto/decred.d.ts +15 -0
- package/lib-es/wallet-btc/crypto/decred.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/decred.js +93 -0
- package/lib-es/wallet-btc/crypto/decred.js.map +1 -0
- package/lib-es/wallet-btc/crypto/digibyte.d.ts +9 -0
- package/lib-es/wallet-btc/crypto/digibyte.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/digibyte.js +30 -0
- package/lib-es/wallet-btc/crypto/digibyte.js.map +1 -0
- package/lib-es/wallet-btc/crypto/doge.d.ts +8 -0
- package/lib-es/wallet-btc/crypto/doge.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/doge.js +14 -0
- package/lib-es/wallet-btc/crypto/doge.js.map +1 -0
- package/lib-es/wallet-btc/crypto/factory.d.ts +3 -0
- package/lib-es/wallet-btc/crypto/factory.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/factory.js +103 -0
- package/lib-es/wallet-btc/crypto/factory.js.map +1 -0
- package/lib-es/wallet-btc/crypto/index.d.ts +19 -0
- package/lib-es/wallet-btc/crypto/index.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/index.js +19 -0
- package/lib-es/wallet-btc/crypto/index.js.map +1 -0
- package/lib-es/wallet-btc/crypto/komodo.d.ts +8 -0
- package/lib-es/wallet-btc/crypto/komodo.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/komodo.js +15 -0
- package/lib-es/wallet-btc/crypto/komodo.js.map +1 -0
- package/lib-es/wallet-btc/crypto/litecoin.d.ts +10 -0
- package/lib-es/wallet-btc/crypto/litecoin.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/litecoin.js +28 -0
- package/lib-es/wallet-btc/crypto/litecoin.js.map +1 -0
- package/lib-es/wallet-btc/crypto/peercoin.d.ts +8 -0
- package/lib-es/wallet-btc/crypto/peercoin.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/peercoin.js +14 -0
- package/lib-es/wallet-btc/crypto/peercoin.js.map +1 -0
- package/lib-es/wallet-btc/crypto/pivx.d.ts +8 -0
- package/lib-es/wallet-btc/crypto/pivx.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/pivx.js +16 -0
- package/lib-es/wallet-btc/crypto/pivx.js.map +1 -0
- package/lib-es/wallet-btc/crypto/qtum.d.ts +8 -0
- package/lib-es/wallet-btc/crypto/qtum.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/qtum.js +12 -0
- package/lib-es/wallet-btc/crypto/qtum.js.map +1 -0
- package/lib-es/wallet-btc/crypto/secp256k1.d.ts +16 -0
- package/lib-es/wallet-btc/crypto/secp256k1.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/secp256k1.js +18 -0
- package/lib-es/wallet-btc/crypto/secp256k1.js.map +1 -0
- package/lib-es/wallet-btc/crypto/stealth.d.ts +8 -0
- package/lib-es/wallet-btc/crypto/stealth.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/stealth.js +16 -0
- package/lib-es/wallet-btc/crypto/stealth.js.map +1 -0
- package/lib-es/wallet-btc/crypto/types.d.ts +11 -0
- package/lib-es/wallet-btc/crypto/types.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/types.js +2 -0
- package/lib-es/wallet-btc/crypto/types.js.map +1 -0
- package/lib-es/wallet-btc/crypto/via.d.ts +8 -0
- package/lib-es/wallet-btc/crypto/via.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/via.js +12 -0
- package/lib-es/wallet-btc/crypto/via.js.map +1 -0
- package/lib-es/wallet-btc/crypto/vtc.d.ts +8 -0
- package/lib-es/wallet-btc/crypto/vtc.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/vtc.js +12 -0
- package/lib-es/wallet-btc/crypto/vtc.js.map +1 -0
- package/lib-es/wallet-btc/crypto/zec.d.ts +13 -0
- package/lib-es/wallet-btc/crypto/zec.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/zec.js +67 -0
- package/lib-es/wallet-btc/crypto/zec.js.map +1 -0
- package/lib-es/wallet-btc/crypto/zen.d.ts +13 -0
- package/lib-es/wallet-btc/crypto/zen.d.ts.map +1 -0
- package/lib-es/wallet-btc/crypto/zen.js +88 -0
- package/lib-es/wallet-btc/crypto/zen.js.map +1 -0
- package/lib-es/wallet-btc/explorer/index.d.ts +47 -0
- package/lib-es/wallet-btc/explorer/index.d.ts.map +1 -0
- package/lib-es/wallet-btc/explorer/index.js +186 -0
- package/lib-es/wallet-btc/explorer/index.js.map +1 -0
- package/lib-es/wallet-btc/explorer/types.d.ts +18 -0
- package/lib-es/wallet-btc/explorer/types.d.ts.map +1 -0
- package/lib-es/wallet-btc/explorer/types.js +2 -0
- package/lib-es/wallet-btc/explorer/types.js.map +1 -0
- package/lib-es/wallet-btc/index.d.ts +16 -0
- package/lib-es/wallet-btc/index.d.ts.map +1 -0
- package/lib-es/wallet-btc/index.js +25 -0
- package/lib-es/wallet-btc/index.js.map +1 -0
- package/lib-es/wallet-btc/pickingstrategies/CoinSelect.d.ts +18 -0
- package/lib-es/wallet-btc/pickingstrategies/CoinSelect.d.ts.map +1 -0
- package/lib-es/wallet-btc/pickingstrategies/CoinSelect.js +156 -0
- package/lib-es/wallet-btc/pickingstrategies/CoinSelect.js.map +1 -0
- package/lib-es/wallet-btc/pickingstrategies/DeepFirst.d.ts +17 -0
- package/lib-es/wallet-btc/pickingstrategies/DeepFirst.d.ts.map +1 -0
- package/lib-es/wallet-btc/pickingstrategies/DeepFirst.js +70 -0
- package/lib-es/wallet-btc/pickingstrategies/DeepFirst.js.map +1 -0
- package/lib-es/wallet-btc/pickingstrategies/Merge.d.ts +17 -0
- package/lib-es/wallet-btc/pickingstrategies/Merge.d.ts.map +1 -0
- package/lib-es/wallet-btc/pickingstrategies/Merge.js +70 -0
- package/lib-es/wallet-btc/pickingstrategies/Merge.js.map +1 -0
- package/lib-es/wallet-btc/pickingstrategies/types.d.ts +27 -0
- package/lib-es/wallet-btc/pickingstrategies/types.d.ts.map +1 -0
- package/lib-es/wallet-btc/pickingstrategies/types.js +8 -0
- package/lib-es/wallet-btc/pickingstrategies/types.js.map +1 -0
- package/lib-es/wallet-btc/storage/index.d.ts +77 -0
- package/lib-es/wallet-btc/storage/index.d.ts.map +1 -0
- package/lib-es/wallet-btc/storage/index.js +232 -0
- package/lib-es/wallet-btc/storage/index.js.map +1 -0
- package/lib-es/wallet-btc/storage/types.d.ts +74 -0
- package/lib-es/wallet-btc/storage/types.d.ts.map +1 -0
- package/lib-es/wallet-btc/storage/types.js +2 -0
- package/lib-es/wallet-btc/storage/types.js.map +1 -0
- package/lib-es/wallet-btc/types.d.ts +25 -0
- package/lib-es/wallet-btc/types.d.ts.map +1 -0
- package/lib-es/wallet-btc/types.js +8 -0
- package/lib-es/wallet-btc/types.js.map +1 -0
- package/lib-es/wallet-btc/utils.d.ts +45 -0
- package/lib-es/wallet-btc/utils.d.ts.map +1 -0
- package/lib-es/wallet-btc/utils.js +175 -0
- package/lib-es/wallet-btc/utils.js.map +1 -0
- package/lib-es/wallet-btc/wallet.d.ts +80 -0
- package/lib-es/wallet-btc/wallet.d.ts.map +1 -0
- package/lib-es/wallet-btc/wallet.js +263 -0
- package/lib-es/wallet-btc/wallet.js.map +1 -0
- package/lib-es/wallet-btc/xpub.d.ts +52 -0
- package/lib-es/wallet-btc/xpub.d.ts.map +1 -0
- package/lib-es/wallet-btc/xpub.js +291 -0
- package/lib-es/wallet-btc/xpub.js.map +1 -0
- package/lib-es/xpub.txs.loadExport.unit.test.d.ts +2 -0
- package/lib-es/xpub.txs.loadExport.unit.test.d.ts.map +1 -0
- package/lib-es/xpub.txs.loadExport.unit.test.js +105 -0
- package/lib-es/xpub.txs.loadExport.unit.test.js.map +1 -0
- package/lib-es/xpub.txs.txNoOutput.unit.test.d.ts +2 -0
- package/lib-es/xpub.txs.txNoOutput.unit.test.d.ts.map +1 -0
- package/lib-es/xpub.txs.txNoOutput.unit.test.js +39 -0
- package/lib-es/xpub.txs.txNoOutput.unit.test.js.map +1 -0
- package/package.json +109 -0
- package/src/account.ts +14 -0
- package/src/bech32m.ts +187 -0
- package/src/bridge/js.ts +96 -0
- package/src/bridge.integration.test.ts +47 -0
- package/src/cache.ts +73 -0
- package/src/cli-transaction.ts +73 -0
- package/src/crypto-util.ts +15 -0
- package/src/datasets/bitcoin.scanAccounts.1.ts +237 -0
- package/src/datasets/bitcoin.ts +353 -0
- package/src/datasets/bitcoin_cash.ts +44 -0
- package/src/datasets/bitcoin_gold.ts +72 -0
- package/src/datasets/dash.ts +36 -0
- package/src/datasets/decred.ts +42 -0
- package/src/datasets/digibyte.scanAccounts.1.ts +53 -0
- package/src/datasets/digibyte.ts +164 -0
- package/src/datasets/dogecoin.ts +36 -0
- package/src/datasets/komodo.ts +42 -0
- package/src/datasets/litecoin.scanAccounts.1.ts +53 -0
- package/src/datasets/litecoin.ts +186 -0
- package/src/datasets/peercoin.ts +36 -0
- package/src/datasets/pivx.ts +36 -0
- package/src/datasets/qtum.ts +56 -0
- package/src/datasets/vertcoin.ts +68 -0
- package/src/datasets/viacoin.ts +44 -0
- package/src/datasets/zcash.ts +42 -0
- package/src/datasets/zencash.ts +36 -0
- package/src/descriptor.test.ts +63 -0
- package/src/descriptor.ts +205 -0
- package/src/deviceTransactionConfig.ts +39 -0
- package/src/errors.ts +5 -0
- package/src/explorer.ts +40 -0
- package/src/formatters.ts +52 -0
- package/src/getAccountNetworkInfo.test.ts +37 -0
- package/src/getAccountNetworkInfo.ts +54 -0
- package/src/hw-getAddress.ts +52 -0
- package/src/hw-signMessage.test.ts +99 -0
- package/src/hw-signMessage.ts +23 -0
- package/src/js-broadcast.ts +22 -0
- package/src/js-buildTransaction.ts +68 -0
- package/src/js-createTransaction.ts +26 -0
- package/src/js-estimateMaxSpendable.ts +41 -0
- package/src/js-getFeesForTransaction.ts +59 -0
- package/src/js-getTransactionStatus.ts +127 -0
- package/src/js-prepareTransaction.ts +33 -0
- package/src/js-signOperation.ts +147 -0
- package/src/js-synchronisation.ts +256 -0
- package/src/logic.ts +318 -0
- package/src/logic.unit.test.ts +54 -0
- package/src/mockBtcSigner.ts +66 -0
- package/src/networks.ts +318 -0
- package/src/publicAddresses.test.ts +9 -0
- package/src/serialization.test.ts +143 -0
- package/src/serialization.ts +94 -0
- package/src/signer.ts +82 -0
- package/src/specs.ts +629 -0
- package/src/speculos-deviceActions.ts +66 -0
- package/src/transaction.ts +185 -0
- package/src/types.ts +174 -0
- package/src/wallet-btc/__tests__/bitcoin.test.ts +301 -0
- package/src/wallet-btc/__tests__/logic.ts +29 -0
- package/src/wallet-btc/__tests__/utils.test.ts +257 -0
- package/src/wallet-btc/__tests__/wallet.errorpropagation.integration.test.ts +37 -0
- package/src/wallet-btc/__tests__/wallet.estimateMaxSpendable.integration.test.ts +51 -0
- package/src/wallet-btc/__tests__/wallet.explorer.integration.test.ts +40 -0
- package/src/wallet-btc/__tests__/wallet.explorer.unit.test.ts +192 -0
- package/src/wallet-btc/__tests__/wallet.integration.test.ts +120 -0
- package/src/wallet-btc/__tests__/wallet.storage.unit.test.ts +168 -0
- package/src/wallet-btc/__tests__/xpub.getAddress.integration.test.ts +79 -0
- package/src/wallet-btc/__tests__/xpub.pickingStrategies.integration.test.ts +312 -0
- package/src/wallet-btc/__tests__/xpub.reorg.integration.test.ts +130 -0
- package/src/wallet-btc/__tests__/xpub.synced.integration.test.ts +73 -0
- package/src/wallet-btc/__tests__/xpub.syncing.integration.test.ts +203 -0
- package/src/wallet-btc/__tests__/xpub.txs.NP2WPKH.integration.test.ts +174 -0
- package/src/wallet-btc/__tests__/xpub.txs.P2WPKH.integration.test.ts +166 -0
- package/src/wallet-btc/__tests__/xpub.txs.dogecoin.integration.test.ts +92 -0
- package/src/wallet-btc/__tests__/xpub.txs.integration.test.ts +342 -0
- package/src/wallet-btc/__tests__/xpub.txs.litecoin.integration.test.ts +150 -0
- package/src/wallet-btc/__tests__/xpub.utxo.unit.test.ts +66 -0
- package/src/wallet-btc/account.ts +30 -0
- package/src/wallet-btc/crypto/base.ts +179 -0
- package/src/wallet-btc/crypto/bip32.ts +40 -0
- package/src/wallet-btc/crypto/bitcoin.ts +203 -0
- package/src/wallet-btc/crypto/bitcoincash.ts +47 -0
- package/src/wallet-btc/crypto/bitcoingold.ts +13 -0
- package/src/wallet-btc/crypto/dash.ts +21 -0
- package/src/wallet-btc/crypto/decred.ts +91 -0
- package/src/wallet-btc/crypto/digibyte.ts +33 -0
- package/src/wallet-btc/crypto/doge.ts +15 -0
- package/src/wallet-btc/crypto/factory.ts +104 -0
- package/src/wallet-btc/crypto/index.ts +18 -0
- package/src/wallet-btc/crypto/komodo.ts +16 -0
- package/src/wallet-btc/crypto/litecoin.ts +31 -0
- package/src/wallet-btc/crypto/peercoin.ts +15 -0
- package/src/wallet-btc/crypto/pivx.ts +17 -0
- package/src/wallet-btc/crypto/qtum.ts +13 -0
- package/src/wallet-btc/crypto/secp256k1.ts +29 -0
- package/src/wallet-btc/crypto/stealth.ts +17 -0
- package/src/wallet-btc/crypto/types.ts +35 -0
- package/src/wallet-btc/crypto/via.ts +13 -0
- package/src/wallet-btc/crypto/vtc.ts +13 -0
- package/src/wallet-btc/crypto/zec.ts +66 -0
- package/src/wallet-btc/crypto/zen.ts +88 -0
- package/src/wallet-btc/explorer/index.ts +197 -0
- package/src/wallet-btc/explorer/types.ts +19 -0
- package/src/wallet-btc/index.ts +52 -0
- package/src/wallet-btc/pickingstrategies/CoinSelect.ts +183 -0
- package/src/wallet-btc/pickingstrategies/DeepFirst.ts +92 -0
- package/src/wallet-btc/pickingstrategies/Merge.ts +92 -0
- package/src/wallet-btc/pickingstrategies/types.ts +44 -0
- package/src/wallet-btc/storage/index.ts +282 -0
- package/src/wallet-btc/storage/types.ts +61 -0
- package/src/wallet-btc/types.ts +28 -0
- package/src/wallet-btc/utils.ts +195 -0
- package/src/wallet-btc/wallet.ts +387 -0
- package/src/wallet-btc/xpub.ts +394 -0
- package/src/xpub.txs.loadExport.unit.test.ts +96 -0
- package/src/xpub.txs.txNoOutput.unit.test.ts +30 -0
- package/tsconfig.json +13 -0
- package/types/blake-hash.d.ts +6 -0
- package/types/bs58check/base.d.ts +1 -0
- package/types/coininfo.d.ts +100 -0
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import invariant from "invariant";
|
|
2
|
+
import { getCryptoCurrencyById, setSupportedCurrencies, } from "@ledgerhq/coin-framework/currencies/index";
|
|
3
|
+
import { fromAccountRaw } from "@ledgerhq/coin-framework/serialization/index";
|
|
4
|
+
import { inferDescriptorFromDeviceInfo, inferDescriptorFromAccount } from "./descriptor";
|
|
5
|
+
import bitcoinDatasets from "./datasets/bitcoin";
|
|
6
|
+
import { assignFromAccountRaw } from "./serialization";
|
|
7
|
+
setSupportedCurrencies(["bitcoin"]);
|
|
8
|
+
describe("inferDescriptorFromAccount", () => {
|
|
9
|
+
invariant(bitcoinDatasets.accounts, "bitcoin datasets have accounts");
|
|
10
|
+
// FIXME: migrate away from invariant for more type guard
|
|
11
|
+
const [bitcoin1, bitcoin2] = bitcoinDatasets.accounts.map(a => fromAccountRaw(a.raw, { assignFromAccountRaw }));
|
|
12
|
+
it("should work on bitcoin account 1", () => {
|
|
13
|
+
expect(inferDescriptorFromAccount(bitcoin1)).toEqual({
|
|
14
|
+
external: "pkh([224b6226/44'/0'/0']xpub6BuPWhjLqutPV8SF4RMrrn8c3t7uBZbz4CBbThpbg9GYjqRMncra9mjgSfWSK7uMDz37hhzJ8wvkbDDQQJt6VgwLoszvmPiSBtLA1bPLLSn/0/*)",
|
|
15
|
+
internal: "pkh([224b6226/44'/0'/0']xpub6BuPWhjLqutPV8SF4RMrrn8c3t7uBZbz4CBbThpbg9GYjqRMncra9mjgSfWSK7uMDz37hhzJ8wvkbDDQQJt6VgwLoszvmPiSBtLA1bPLLSn/1/*)",
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
it("should work on bitcoin account 2", () => {
|
|
19
|
+
expect(inferDescriptorFromAccount(bitcoin2)).toEqual({
|
|
20
|
+
external: "wpkh([d6a9e45e/84'/0'/1']xpub6DEHKg8fgKcb9at2u9Xhjtx4tXGyWqUPQAx2zNCzr41gQRyCqpCn7onSoJU4VS96GXyCtAhhFxErnG2pGVvVexaqF7DEfqGGnGk7Havn7C2/0/*)",
|
|
21
|
+
internal: "wpkh([d6a9e45e/84'/0'/1']xpub6DEHKg8fgKcb9at2u9Xhjtx4tXGyWqUPQAx2zNCzr41gQRyCqpCn7onSoJU4VS96GXyCtAhhFxErnG2pGVvVexaqF7DEfqGGnGk7Havn7C2/1/*)",
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
describe("inferDescriptorFromDeviceInfo", () => {
|
|
26
|
+
it("should work on a first Bitcoin legacy derivation", () => {
|
|
27
|
+
const descriptor = inferDescriptorFromDeviceInfo({
|
|
28
|
+
derivationMode: "",
|
|
29
|
+
currency: getCryptoCurrencyById("bitcoin"),
|
|
30
|
+
index: 0,
|
|
31
|
+
parentDerivation: {
|
|
32
|
+
address: "148LHFgQkoPKHUFeVzFNmUjKT7ZwB47fTR",
|
|
33
|
+
path: "44'/0'",
|
|
34
|
+
publicKey: "041caa3a42db5bdd125b2530c47cfbe829539b5a20a5562ec839d241c67d1862f2980d26ebffee25e4f924410c3316b397f34bd572543e72c59a7569ef9032f498",
|
|
35
|
+
chainCode: "9f819c7d45eb9eb1e9bd5fa695158cca9e493182f95068b22c8c440ae6eb0720",
|
|
36
|
+
},
|
|
37
|
+
accountDerivation: {
|
|
38
|
+
address: "15o6uBtRzKojbxqBe4Kni66BSvXfKYT2GY",
|
|
39
|
+
path: "44'/0'/0'",
|
|
40
|
+
publicKey: "04238878d371ce61cdd04d22ccab50c542e94ffa7a27d02d6bcefaa22e4fcee6db4c2029fd4de0b595e98002c0be01fc1fbd3568671e394c97a6d52c3d4c113fb5",
|
|
41
|
+
chainCode: "44728146118df8d18d38c2615154eaffcdd53829957f4e26863344f35653364e",
|
|
42
|
+
},
|
|
43
|
+
});
|
|
44
|
+
expect(descriptor).toEqual({
|
|
45
|
+
external: "pkh([224b6226/44'/0'/0']xpub6BuPWhjLqutPV8SF4RMrrn8c3t7uBZbz4CBbThpbg9GYjqRMncra9mjgSfWSK7uMDz37hhzJ8wvkbDDQQJt6VgwLoszvmPiSBtLA1bPLLSn/0/*)",
|
|
46
|
+
internal: "pkh([224b6226/44'/0'/0']xpub6BuPWhjLqutPV8SF4RMrrn8c3t7uBZbz4CBbThpbg9GYjqRMncra9mjgSfWSK7uMDz37hhzJ8wvkbDDQQJt6VgwLoszvmPiSBtLA1bPLLSn/1/*)",
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
});
|
|
50
|
+
//# sourceMappingURL=descriptor.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"descriptor.test.js","sourceRoot":"","sources":["../src/descriptor.test.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,WAAW,CAAC;AAClC,OAAO,EACL,qBAAqB,EACrB,sBAAsB,GACvB,MAAM,2CAA2C,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,8CAA8C,CAAC;AAC9E,OAAO,EAAE,6BAA6B,EAAE,0BAA0B,EAAE,MAAM,cAAc,CAAC;AACzF,OAAO,eAAe,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AAEvD,sBAAsB,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;AACpC,QAAQ,CAAC,4BAA4B,EAAE,GAAG,EAAE;IAC1C,SAAS,CAAC,eAAe,CAAC,QAAQ,EAAE,gCAAgC,CAAC,CAAC;IACtE,yDAAyD;IACzD,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,GAAG,eAAe,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAC5D,cAAc,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,oBAAoB,EAAE,CAAC,CAChD,CAAC;IACF,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,MAAM,CAAC,0BAA0B,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC;YACnD,QAAQ,EACN,8IAA8I;YAChJ,QAAQ,EACN,8IAA8I;SACjJ,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,MAAM,CAAC,0BAA0B,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC;YACnD,QAAQ,EACN,+IAA+I;YACjJ,QAAQ,EACN,+IAA+I;SAClJ,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AACH,QAAQ,CAAC,+BAA+B,EAAE,GAAG,EAAE;IAC7C,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;QAC1D,MAAM,UAAU,GAAG,6BAA6B,CAAC;YAC/C,cAAc,EAAE,EAAE;YAClB,QAAQ,EAAE,qBAAqB,CAAC,SAAS,CAAC;YAC1C,KAAK,EAAE,CAAC;YACR,gBAAgB,EAAE;gBAChB,OAAO,EAAE,oCAAoC;gBAC7C,IAAI,EAAE,QAAQ;gBACd,SAAS,EACP,oIAAoI;gBACtI,SAAS,EAAE,kEAAkE;aAC9E;YACD,iBAAiB,EAAE;gBACjB,OAAO,EAAE,oCAAoC;gBAC7C,IAAI,EAAE,WAAW;gBACjB,SAAS,EACP,oIAAoI;gBACtI,SAAS,EAAE,kEAAkE;aAC9E;SACF,CAAC,CAAC;QACH,MAAM,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC;YACzB,QAAQ,EACN,8IAA8I;YAChJ,QAAQ,EACN,8IAA8I;SACjJ,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Transaction, TransactionStatus } from "./types";
|
|
2
|
+
import type { CommonDeviceTransactionField as DeviceTransactionField } from "@ledgerhq/coin-framework/transaction/common";
|
|
3
|
+
import type { Account, AccountLike } from "@ledgerhq/types-live";
|
|
4
|
+
declare function getDeviceTransactionConfig({ status: { amount, estimatedFees, opReturnData }, }: {
|
|
5
|
+
account: AccountLike;
|
|
6
|
+
parentAccount: Account | null | undefined;
|
|
7
|
+
transaction: Transaction;
|
|
8
|
+
status: TransactionStatus;
|
|
9
|
+
}): Array<DeviceTransactionField>;
|
|
10
|
+
export default getDeviceTransactionConfig;
|
|
11
|
+
//# sourceMappingURL=deviceTransactionConfig.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deviceTransactionConfig.d.ts","sourceRoot":"","sources":["../src/deviceTransactionConfig.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAC9D,OAAO,KAAK,EAAE,4BAA4B,IAAI,sBAAsB,EAAE,MAAM,6CAA6C,CAAC;AAC1H,OAAO,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAEjE,iBAAS,0BAA0B,CAAC,EAClC,MAAM,EAAE,EAAE,MAAM,EAAE,aAAa,EAAE,YAAY,EAAE,GAChD,EAAE;IACD,OAAO,EAAE,WAAW,CAAC;IACrB,aAAa,EAAE,OAAO,GAAG,IAAI,GAAG,SAAS,CAAC;IAC1C,WAAW,EAAE,WAAW,CAAC;IACzB,MAAM,EAAE,iBAAiB,CAAC;CAC3B,GAAG,KAAK,CAAC,sBAAsB,CAAC,CAyBhC;AAED,eAAe,0BAA0B,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
function getDeviceTransactionConfig({ status: { amount, estimatedFees, opReturnData }, }) {
|
|
2
|
+
const fields = [];
|
|
3
|
+
if (!amount.isZero()) {
|
|
4
|
+
fields.push({
|
|
5
|
+
type: "amount",
|
|
6
|
+
label: "Amount",
|
|
7
|
+
});
|
|
8
|
+
}
|
|
9
|
+
if (estimatedFees && !estimatedFees.isZero()) {
|
|
10
|
+
fields.push({
|
|
11
|
+
type: "fees",
|
|
12
|
+
label: "Fees",
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
if (opReturnData) {
|
|
16
|
+
fields.push({
|
|
17
|
+
type: "opReturnData",
|
|
18
|
+
label: "OP_RETURN",
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
return fields;
|
|
22
|
+
}
|
|
23
|
+
export default getDeviceTransactionConfig;
|
|
24
|
+
//# sourceMappingURL=deviceTransactionConfig.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deviceTransactionConfig.js","sourceRoot":"","sources":["../src/deviceTransactionConfig.ts"],"names":[],"mappings":"AAIA,SAAS,0BAA0B,CAAC,EAClC,MAAM,EAAE,EAAE,MAAM,EAAE,aAAa,EAAE,YAAY,EAAE,GAMhD;IACC,MAAM,MAAM,GAA2C,EAAE,CAAC;IAE1D,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE;QACpB,MAAM,CAAC,IAAI,CAAC;YACV,IAAI,EAAE,QAAQ;YACd,KAAK,EAAE,QAAQ;SAChB,CAAC,CAAC;KACJ;IAED,IAAI,aAAa,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,EAAE;QAC5C,MAAM,CAAC,IAAI,CAAC;YACV,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE,MAAM;SACd,CAAC,CAAC;KACJ;IAED,IAAI,YAAY,EAAE;QAChB,MAAM,CAAC,IAAI,CAAC;YACV,IAAI,EAAE,cAAc;YACpB,KAAK,EAAE,WAAW;SACnB,CAAC,CAAC;KACJ;IAED,OAAO,MAAuC,CAAC;AACjD,CAAC;AAED,eAAe,0BAA0B,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export declare const AccountNeedResync: import("@ledgerhq/errors/lib/helpers").LedgerErrorConstructor<{
|
|
2
|
+
[key: string]: unknown;
|
|
3
|
+
}>;
|
|
4
|
+
export declare const TaprootNotActivated: import("@ledgerhq/errors/lib/helpers").LedgerErrorConstructor<{
|
|
5
|
+
[key: string]: unknown;
|
|
6
|
+
}>;
|
|
7
|
+
//# sourceMappingURL=errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,iBAAiB;;EAA8C,CAAC;AAE7E,eAAO,MAAM,mBAAmB;;EAAgD,CAAC"}
|
package/lib-es/errors.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,kBAAkB,CAAC;AAE1D,MAAM,CAAC,MAAM,iBAAiB,GAAG,sBAAsB,CAAC,mBAAmB,CAAC,CAAC;AAE7E,MAAM,CAAC,MAAM,mBAAmB,GAAG,sBAAsB,CAAC,qBAAqB,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { CryptoCurrency } from "@ledgerhq/types-cryptoassets";
|
|
2
|
+
type LedgerExplorer = {
|
|
3
|
+
version: string;
|
|
4
|
+
id: string;
|
|
5
|
+
endpoint: string;
|
|
6
|
+
};
|
|
7
|
+
export declare const getCurrencyExplorer: (currency: CryptoCurrency) => LedgerExplorer;
|
|
8
|
+
export declare const blockchainBaseURL: (currency: CryptoCurrency) => string;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=explorer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"explorer.d.ts","sourceRoot":"","sources":["../src/explorer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAI9D,KAAK,cAAc,GAAG;IACpB,OAAO,EAAE,MAAM,CAAC;IAChB,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,MAAM,CAAC;CAClB,CAAC;AAsBF,eAAO,MAAM,mBAAmB,aAAc,cAAc,KAAG,cAI9D,CAAC;AAEF,eAAO,MAAM,iBAAiB,aAAc,cAAc,KAAG,MAG5D,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import invariant from "invariant";
|
|
2
|
+
import { getEnv } from "@ledgerhq/live-env";
|
|
3
|
+
const findCurrencyExplorer = (currency) => {
|
|
4
|
+
var _a;
|
|
5
|
+
if (getEnv("SATSTACK") && currency.id === "bitcoin") {
|
|
6
|
+
return {
|
|
7
|
+
endpoint: getEnv("EXPLORER_SATSTACK"),
|
|
8
|
+
id: "btc",
|
|
9
|
+
version: "v3",
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
if (currency.explorerId == null) {
|
|
13
|
+
console.warn("no explorerId for", currency.id);
|
|
14
|
+
}
|
|
15
|
+
return {
|
|
16
|
+
endpoint: getEnv("EXPLORER"),
|
|
17
|
+
id: (_a = currency.explorerId) !== null && _a !== void 0 ? _a : currency.id,
|
|
18
|
+
version: "v4",
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
export const getCurrencyExplorer = (currency) => {
|
|
22
|
+
const res = findCurrencyExplorer(currency);
|
|
23
|
+
invariant(res, `no Ledger explorer for ${currency.id}`);
|
|
24
|
+
return res;
|
|
25
|
+
};
|
|
26
|
+
export const blockchainBaseURL = (currency) => {
|
|
27
|
+
const { id, version, endpoint } = getCurrencyExplorer(currency);
|
|
28
|
+
return `${endpoint}/blockchain/${version}/${id}`;
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=explorer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"explorer.js","sourceRoot":"","sources":["../src/explorer.ts"],"names":[],"mappings":"AACA,OAAO,SAAS,MAAM,WAAW,CAAC;AAClC,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAQ5C,MAAM,oBAAoB,GAAG,CAAC,QAAwB,EAAqC,EAAE;;IAC3F,IAAI,MAAM,CAAC,UAAU,CAAC,IAAI,QAAQ,CAAC,EAAE,KAAK,SAAS,EAAE;QACnD,OAAO;YACL,QAAQ,EAAE,MAAM,CAAC,mBAAmB,CAAC;YACrC,EAAE,EAAE,KAAK;YACT,OAAO,EAAE,IAAI;SACd,CAAC;KACH;IAED,IAAI,QAAQ,CAAC,UAAU,IAAI,IAAI,EAAE;QAC/B,OAAO,CAAC,IAAI,CAAC,mBAAmB,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC;KAChD;IAED,OAAO;QACL,QAAQ,EAAE,MAAM,CAAC,UAAU,CAAC;QAC5B,EAAE,EAAE,MAAA,QAAQ,CAAC,UAAU,mCAAI,QAAQ,CAAC,EAAE;QACtC,OAAO,EAAE,IAAI;KACd,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,QAAwB,EAAkB,EAAE;IAC9E,MAAM,GAAG,GAAG,oBAAoB,CAAC,QAAQ,CAAC,CAAC;IAC3C,SAAS,CAAC,GAAG,EAAE,0BAA0B,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC;IACxD,OAAuB,GAAG,CAAC;AAC7B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,QAAwB,EAAU,EAAE;IACpE,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,mBAAmB,CAAC,QAAQ,CAAC,CAAC;IAChE,OAAO,GAAG,QAAQ,eAAe,OAAO,IAAI,EAAE,EAAE,CAAC;AACnD,CAAC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { BitcoinAccount, BitcoinInput, BitcoinOutput } from "./types";
|
|
2
|
+
export declare function formatInput(account: BitcoinAccount, input: BitcoinInput): string;
|
|
3
|
+
export declare function formatOutput(account: BitcoinAccount, o: BitcoinOutput): string;
|
|
4
|
+
declare function formatAccountSpecifics(account: BitcoinAccount): string;
|
|
5
|
+
declare const _default: {
|
|
6
|
+
formatAccountSpecifics: typeof formatAccountSpecifics;
|
|
7
|
+
};
|
|
8
|
+
export default _default;
|
|
9
|
+
//# sourceMappingURL=formatters.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"formatters.d.ts","sourceRoot":"","sources":["../src/formatters.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAK3E,wBAAgB,WAAW,CAAC,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,YAAY,GAAG,MAAM,CAOhF;AACD,wBAAgB,YAAY,CAAC,OAAO,EAAE,cAAc,EAAE,CAAC,EAAE,aAAa,GAAG,MAAM,CAa9E;AAED,iBAAS,sBAAsB,CAAC,OAAO,EAAE,cAAc,GAAG,MAAM,CAkB/D;;;;AAED,wBAEE"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { getEnv } from "@ledgerhq/live-env";
|
|
2
|
+
import { formatCurrencyUnit } from "@ledgerhq/coin-framework/currencies/index";
|
|
3
|
+
const sortUTXO = (a, b) => b.value.minus(a.value).toNumber();
|
|
4
|
+
export function formatInput(account, input) {
|
|
5
|
+
return `${(input.value
|
|
6
|
+
? formatCurrencyUnit(account.unit, input.value, {
|
|
7
|
+
showCode: false,
|
|
8
|
+
})
|
|
9
|
+
: "").padEnd(12)} ${input.address || ""} ${input.previousTxHash || ""}@${input.previousOutputIndex}`;
|
|
10
|
+
}
|
|
11
|
+
export function formatOutput(account, o) {
|
|
12
|
+
return [
|
|
13
|
+
formatCurrencyUnit(account.unit, o.value, {
|
|
14
|
+
showCode: false,
|
|
15
|
+
}).padEnd(12),
|
|
16
|
+
o.address,
|
|
17
|
+
o.isChange ? "(change)" : "",
|
|
18
|
+
o.rbf ? "rbf" : "",
|
|
19
|
+
o.hash,
|
|
20
|
+
`@${o.outputIndex} (${o.blockHeight ? account.blockHeight - o.blockHeight : 0})`,
|
|
21
|
+
]
|
|
22
|
+
.filter(Boolean)
|
|
23
|
+
.join(" ");
|
|
24
|
+
}
|
|
25
|
+
function formatAccountSpecifics(account) {
|
|
26
|
+
if (!account.bitcoinResources)
|
|
27
|
+
return "";
|
|
28
|
+
const { utxos } = account.bitcoinResources;
|
|
29
|
+
let str = `\n${utxos.length} UTXOs`;
|
|
30
|
+
const n = getEnv("DEBUG_UTXO_DISPLAY");
|
|
31
|
+
const displayAll = utxos.length <= n;
|
|
32
|
+
str += utxos
|
|
33
|
+
.slice(0)
|
|
34
|
+
.sort(sortUTXO)
|
|
35
|
+
.slice(0, displayAll ? utxos.length : n)
|
|
36
|
+
.map(utxo => `\n${formatOutput(account, utxo)}`)
|
|
37
|
+
.join("");
|
|
38
|
+
if (!displayAll) {
|
|
39
|
+
str += "\n...";
|
|
40
|
+
}
|
|
41
|
+
return str;
|
|
42
|
+
}
|
|
43
|
+
export default {
|
|
44
|
+
formatAccountSpecifics,
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=formatters.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"formatters.js","sourceRoot":"","sources":["../src/formatters.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,2CAA2C,CAAC;AAE/E,MAAM,QAAQ,GAAG,CAAC,CAAgB,EAAE,CAAgB,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAC;AAE3F,MAAM,UAAU,WAAW,CAAC,OAAuB,EAAE,KAAmB;IACtE,OAAO,GAAG,CAAC,KAAK,CAAC,KAAK;QACpB,CAAC,CAAC,kBAAkB,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,EAAE;YAC5C,QAAQ,EAAE,KAAK;SAChB,CAAC;QACJ,CAAC,CAAC,EAAE,CACL,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,KAAK,CAAC,OAAO,IAAI,EAAE,IAAI,KAAK,CAAC,cAAc,IAAI,EAAE,IAAI,KAAK,CAAC,mBAAmB,EAAE,CAAC;AACnG,CAAC;AACD,MAAM,UAAU,YAAY,CAAC,OAAuB,EAAE,CAAgB;IACpE,OAAO;QACL,kBAAkB,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC,KAAK,EAAE;YACxC,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC;QACb,CAAC,CAAC,OAAO;QACT,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE;QAC5B,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE;QAClB,CAAC,CAAC,IAAI;QACN,IAAI,CAAC,CAAC,WAAW,KAAK,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,GAAG,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,GAAG;KACjF;SACE,MAAM,CAAC,OAAO,CAAC;SACf,IAAI,CAAC,GAAG,CAAC,CAAC;AACf,CAAC;AAED,SAAS,sBAAsB,CAAC,OAAuB;IACrD,IAAI,CAAC,OAAO,CAAC,gBAAgB;QAAE,OAAO,EAAE,CAAC;IACzC,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAC3C,IAAI,GAAG,GAAG,KAAK,KAAK,CAAC,MAAM,QAAQ,CAAC;IACpC,MAAM,CAAC,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;IACvC,MAAM,UAAU,GAAG,KAAK,CAAC,MAAM,IAAI,CAAC,CAAC;IACrC,GAAG,IAAI,KAAK;SACT,KAAK,CAAC,CAAC,CAAC;SACR,IAAI,CAAC,QAAQ,CAAC;SACd,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;SACvC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,YAAY,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC;SAC/C,IAAI,CAAC,EAAE,CAAC,CAAC;IAEZ,IAAI,CAAC,UAAU,EAAE;QACf,GAAG,IAAI,OAAO,CAAC;KAChB;IAED,OAAO,GAAG,CAAC;AACb,CAAC;AAED,eAAe;IACb,sBAAsB;CACvB,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { BigNumber } from "bignumber.js";
|
|
2
|
+
import type { NetworkInfo } from "./types";
|
|
3
|
+
import { Account } from "@ledgerhq/types-live";
|
|
4
|
+
export declare function avoidDups(nums: Array<BigNumber>): Array<BigNumber>;
|
|
5
|
+
export declare function getAccountNetworkInfo(account: Account): Promise<NetworkInfo>;
|
|
6
|
+
//# sourceMappingURL=getAccountNetworkInfo.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getAccountNetworkInfo.d.ts","sourceRoot":"","sources":["../src/getAccountNetworkInfo.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAE/C,wBAAgB,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,CAAC,GAAG,KAAK,CAAC,SAAS,CAAC,CAUlE;AACD,wBAAsB,qBAAqB,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,WAAW,CAAC,CAoClF"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import flow from "lodash/flow";
|
|
11
|
+
import { BigNumber } from "bignumber.js";
|
|
12
|
+
import { getWalletAccount } from "./wallet-btc";
|
|
13
|
+
const speeds = ["fast", "medium", "slow"];
|
|
14
|
+
export function avoidDups(nums) {
|
|
15
|
+
nums = nums.slice(0);
|
|
16
|
+
for (let i = nums.length - 2; i >= 0; i--) {
|
|
17
|
+
if (nums[i + 1].gte(nums[i])) {
|
|
18
|
+
nums[i] = nums[i + 1].plus(1);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return nums;
|
|
22
|
+
}
|
|
23
|
+
export function getAccountNetworkInfo(account) {
|
|
24
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
25
|
+
const walletAccount = getWalletAccount(account);
|
|
26
|
+
const rawFees = yield walletAccount.xpub.explorer.getFees();
|
|
27
|
+
// Convoluted logic to convert from:
|
|
28
|
+
// { "2": 2435, "3": 1241, "6": 1009, "last_updated": 1627973170 }
|
|
29
|
+
// to:
|
|
30
|
+
// { 2435, 1241, 1009 }
|
|
31
|
+
const feesPerByte = flow([
|
|
32
|
+
// Remove the 'last_updated' key
|
|
33
|
+
Object.entries,
|
|
34
|
+
entries => entries.filter(([key]) => !isNaN(Number(key))),
|
|
35
|
+
// Reconstruct the array with only the values
|
|
36
|
+
Object.fromEntries,
|
|
37
|
+
Object.values,
|
|
38
|
+
// Safety against invalid data
|
|
39
|
+
f => f.filter((f) => f != null && typeof f === "number"),
|
|
40
|
+
// Normalize values
|
|
41
|
+
f => f.map((f) => new BigNumber(f).div(1000).integerValue(BigNumber.ROUND_CEIL)),
|
|
42
|
+
avoidDups,
|
|
43
|
+
])(rawFees);
|
|
44
|
+
if (feesPerByte.length !== 3) {
|
|
45
|
+
throw new Error("cardinality of feesPerByte should be exactly 3");
|
|
46
|
+
}
|
|
47
|
+
const feeItems = {
|
|
48
|
+
items: feesPerByte.map((feePerByte, i) => ({
|
|
49
|
+
key: String(i),
|
|
50
|
+
speed: speeds[i],
|
|
51
|
+
feePerByte,
|
|
52
|
+
})),
|
|
53
|
+
defaultFeePerByte: feesPerByte[Math.floor(feesPerByte.length / 2)] || new BigNumber(0),
|
|
54
|
+
};
|
|
55
|
+
return {
|
|
56
|
+
family: "bitcoin",
|
|
57
|
+
feeItems,
|
|
58
|
+
};
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=getAccountNetworkInfo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getAccountNetworkInfo.js","sourceRoot":"","sources":["../src/getAccountNetworkInfo.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,IAAI,MAAM,aAAa,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAEhD,MAAM,MAAM,GAAG,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;AAC1C,MAAM,UAAU,SAAS,CAAC,IAAsB;IAC9C,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAErB,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;QACzC,IAAI,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE;YAC5B,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SAC/B;KACF;IAED,OAAO,IAAI,CAAC;AACd,CAAC;AACD,MAAM,UAAgB,qBAAqB,CAAC,OAAgB;;QAC1D,MAAM,aAAa,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC;QAChD,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;QAC5D,oCAAoC;QACpC,kEAAkE;QAClE,MAAM;QACN,uBAAuB;QACvB,MAAM,WAAW,GAAgB,IAAI,CAAC;YACpC,gCAAgC;YAChC,MAAM,CAAC,OAAO;YACd,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAW,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;YACnE,6CAA6C;YAC7C,MAAM,CAAC,WAAW;YAClB,MAAM,CAAC,MAAM;YACb,8BAA8B;YAC9B,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAU,EAAE,EAAE,CAAC,CAAC,IAAI,IAAI,IAAI,OAAO,CAAC,KAAK,QAAQ,CAAC;YACjE,mBAAmB;YACnB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;YACxF,SAAS;SACV,CAAC,CAAC,OAAO,CAAC,CAAC;QAEZ,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;YAC5B,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC;SACnE;QACD,MAAM,QAAQ,GAAG;YACf,KAAK,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,CAAS,EAAE,EAAE,CAAC,CAAC;gBACjD,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC;gBACd,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;gBAChB,UAAU;aACX,CAAC,CAAC;YACH,iBAAiB,EAAE,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,IAAI,IAAI,SAAS,CAAC,CAAC,CAAC;SACvF,CAAC;QACF,OAAO;YACL,MAAM,EAAE,SAAS;YACjB,QAAQ;SACT,CAAC;IACJ,CAAC;CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getAccountNetworkInfo.test.d.ts","sourceRoot":"","sources":["../src/getAccountNetworkInfo.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import { BigNumber } from "bignumber.js";
|
|
11
|
+
import { avoidDups } from "./getAccountNetworkInfo";
|
|
12
|
+
test("avoidFeeDupsInFeePerByte [3,2,2] => [4,3,2]", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
13
|
+
expect(avoidDups([new BigNumber(3), new BigNumber(3), new BigNumber(2)])).toEqual([
|
|
14
|
+
new BigNumber(4),
|
|
15
|
+
new BigNumber(3),
|
|
16
|
+
new BigNumber(2),
|
|
17
|
+
]);
|
|
18
|
+
}));
|
|
19
|
+
test("avoidFeeDupsInFeePerByte [2,2,1] => [3,2,1]", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
20
|
+
expect(avoidDups([new BigNumber(2), new BigNumber(2), new BigNumber(1)])).toEqual([
|
|
21
|
+
new BigNumber(3),
|
|
22
|
+
new BigNumber(2),
|
|
23
|
+
new BigNumber(1),
|
|
24
|
+
]);
|
|
25
|
+
}));
|
|
26
|
+
test("avoidFeeDupsInFeePerByte [3,3,3] => [5,4,3]", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
27
|
+
expect(avoidDups([new BigNumber(3), new BigNumber(3), new BigNumber(3)])).toEqual([
|
|
28
|
+
new BigNumber(5),
|
|
29
|
+
new BigNumber(4),
|
|
30
|
+
new BigNumber(3),
|
|
31
|
+
]);
|
|
32
|
+
}));
|
|
33
|
+
test("avoidFeeDupsInFeePerByte [3,2,1] => [3,2,1]", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
34
|
+
expect(avoidDups([new BigNumber(3), new BigNumber(2), new BigNumber(1)])).toEqual([
|
|
35
|
+
new BigNumber(3),
|
|
36
|
+
new BigNumber(2),
|
|
37
|
+
new BigNumber(1),
|
|
38
|
+
]);
|
|
39
|
+
}));
|
|
40
|
+
test("avoidFeeDupsInFeePerByte [100,100,1] => [101,100,1]", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
41
|
+
expect(avoidDups([new BigNumber(100), new BigNumber(100), new BigNumber(1)])).toEqual([
|
|
42
|
+
new BigNumber(101),
|
|
43
|
+
new BigNumber(100),
|
|
44
|
+
new BigNumber(1),
|
|
45
|
+
]);
|
|
46
|
+
}));
|
|
47
|
+
//# sourceMappingURL=getAccountNetworkInfo.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getAccountNetworkInfo.test.js","sourceRoot":"","sources":["../src/getAccountNetworkInfo.test.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,IAAI,CAAC,6CAA6C,EAAE,GAAS,EAAE;IAC7D,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QAChF,IAAI,SAAS,CAAC,CAAC,CAAC;QAChB,IAAI,SAAS,CAAC,CAAC,CAAC;QAChB,IAAI,SAAS,CAAC,CAAC,CAAC;KACjB,CAAC,CAAC;AACL,CAAC,CAAA,CAAC,CAAC;AACH,IAAI,CAAC,6CAA6C,EAAE,GAAS,EAAE;IAC7D,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QAChF,IAAI,SAAS,CAAC,CAAC,CAAC;QAChB,IAAI,SAAS,CAAC,CAAC,CAAC;QAChB,IAAI,SAAS,CAAC,CAAC,CAAC;KACjB,CAAC,CAAC;AACL,CAAC,CAAA,CAAC,CAAC;AACH,IAAI,CAAC,6CAA6C,EAAE,GAAS,EAAE;IAC7D,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QAChF,IAAI,SAAS,CAAC,CAAC,CAAC;QAChB,IAAI,SAAS,CAAC,CAAC,CAAC;QAChB,IAAI,SAAS,CAAC,CAAC,CAAC;KACjB,CAAC,CAAC;AACL,CAAC,CAAA,CAAC,CAAC;AACH,IAAI,CAAC,6CAA6C,EAAE,GAAS,EAAE;IAC7D,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QAChF,IAAI,SAAS,CAAC,CAAC,CAAC;QAChB,IAAI,SAAS,CAAC,CAAC,CAAC;QAChB,IAAI,SAAS,CAAC,CAAC,CAAC;KACjB,CAAC,CAAC;AACL,CAAC,CAAA,CAAC,CAAC;AACH,IAAI,CAAC,qDAAqD,EAAE,GAAS,EAAE;IACrE,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC,EAAE,IAAI,SAAS,CAAC,GAAG,CAAC,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QACpF,IAAI,SAAS,CAAC,GAAG,CAAC;QAClB,IAAI,SAAS,CAAC,GAAG,CAAC;QAClB,IAAI,SAAS,CAAC,CAAC,CAAC;KACjB,CAAC,CAAC;AACL,CAAC,CAAA,CAAC,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { SignerContext } from "./signer";
|
|
2
|
+
import { GetAddressFn } from "@ledgerhq/coin-framework/bridge/getAddressWrapper";
|
|
3
|
+
declare const resolver: (signerContext: SignerContext) => GetAddressFn;
|
|
4
|
+
export default resolver;
|
|
5
|
+
//# sourceMappingURL=hw-getAddress.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hw-getAddress.d.ts","sourceRoot":"","sources":["../src/hw-getAddress.ts"],"names":[],"mappings":"AAMA,OAAO,EAAiC,aAAa,EAAE,MAAM,UAAU,CAAC;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,mDAAmD,CAAC;AAEjF,QAAA,MAAM,QAAQ,kBAAmB,aAAa,KAAG,YAwChD,CAAC;AAEF,eAAe,QAAQ,CAAC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import { log } from "@ledgerhq/logs";
|
|
11
|
+
import { getAddressFormatDerivationMode, } from "@ledgerhq/coin-framework/derivation";
|
|
12
|
+
import { UnsupportedDerivation } from "@ledgerhq/coin-framework/errors";
|
|
13
|
+
const resolver = (signerContext) => {
|
|
14
|
+
return (deviceId, { currency, path, verify, derivationMode, forceFormat }) => __awaiter(void 0, void 0, void 0, function* () {
|
|
15
|
+
const format = forceFormat || getAddressFormatDerivationMode(derivationMode);
|
|
16
|
+
let result;
|
|
17
|
+
try {
|
|
18
|
+
result = (yield signerContext(deviceId, currency, signer => signer.getWalletPublicKey(path, {
|
|
19
|
+
verify,
|
|
20
|
+
format: format,
|
|
21
|
+
})));
|
|
22
|
+
}
|
|
23
|
+
catch (e) {
|
|
24
|
+
// TODO Should normalize error returned from ledgerjs
|
|
25
|
+
if (e &&
|
|
26
|
+
e.message &&
|
|
27
|
+
(e.message.includes("invalid format") || e.message.includes("Unsupported address format"))) {
|
|
28
|
+
throw new UnsupportedDerivation();
|
|
29
|
+
}
|
|
30
|
+
throw e;
|
|
31
|
+
}
|
|
32
|
+
const { bitcoinAddress, publicKey, chainCode } = result;
|
|
33
|
+
log("hw", `getAddress ${currency.id} path=${path} address=${bitcoinAddress} publicKey=${publicKey} chainCode=${chainCode}`);
|
|
34
|
+
return {
|
|
35
|
+
address: bitcoinAddress,
|
|
36
|
+
path,
|
|
37
|
+
publicKey,
|
|
38
|
+
chainCode,
|
|
39
|
+
};
|
|
40
|
+
});
|
|
41
|
+
};
|
|
42
|
+
export default resolver;
|
|
43
|
+
//# sourceMappingURL=hw-getAddress.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hw-getAddress.js","sourceRoot":"","sources":["../src/hw-getAddress.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EACL,8BAA8B,GAE/B,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AAIxE,MAAM,QAAQ,GAAG,CAAC,aAA4B,EAAgB,EAAE;IAC9D,OAAO,CACL,QAAgB,EAChB,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,cAAc,EAAE,WAAW,EAAqB,EAC1E,EAAE;QACF,MAAM,MAAM,GAAG,WAAW,IAAI,8BAA8B,CAAC,cAAc,CAAC,CAAC;QAE7E,IAAI,MAAM,CAAC;QACX,IAAI;YACF,MAAM,GAAG,CAAC,MAAM,aAAa,CAAC,QAAQ,EAAE,QAAQ,EAAE,MAAM,CAAC,EAAE,CACzD,MAAM,CAAC,kBAAkB,CAAC,IAAI,EAAE;gBAC9B,MAAM;gBACN,MAAM,EAAE,MAAuB;aAChC,CAAC,CACH,CAAmB,CAAC;SACtB;QAAC,OAAO,CAAM,EAAE;YACf,qDAAqD;YACrD,IACE,CAAC;gBACD,CAAC,CAAC,OAAO;gBACT,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,4BAA4B,CAAC,CAAC,EAC1F;gBACA,MAAM,IAAI,qBAAqB,EAAE,CAAC;aACnC;YACD,MAAM,CAAC,CAAC;SACT;QAED,MAAM,EAAE,cAAc,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAExD,GAAG,CACD,IAAI,EACJ,cAAc,QAAQ,CAAC,EAAE,SAAS,IAAI,YAAY,cAAc,cAAc,SAAS,cAAc,SAAS,EAAE,CACjH,CAAC;QACF,OAAO;YACL,OAAO,EAAE,cAAc;YACvB,IAAI;YACJ,SAAS;YACT,SAAS;SACV,CAAC;IACJ,CAAC,CAAA,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,QAAQ,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Account, AnyMessage } from "@ledgerhq/types-live";
|
|
2
|
+
import { BitcoinSignature, SignerContext } from "./signer";
|
|
3
|
+
export declare const signMessage: (signerContext: SignerContext) => (deviceId: string, account: Account, { message }: AnyMessage) => Promise<{
|
|
4
|
+
rsv: BitcoinSignature;
|
|
5
|
+
signature: string;
|
|
6
|
+
}>;
|
|
7
|
+
//# sourceMappingURL=hw-signMessage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hw-signMessage.d.ts","sourceRoot":"","sources":["../src/hw-signMessage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAE3D,eAAO,MAAM,WAAW,kBACN,aAAa,gBACZ,MAAM,WAAW,OAAO,eAAe,UAAU;;;EAiBjE,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
export const signMessage = (signerContext) => (deviceId, account, { message }) => __awaiter(void 0, void 0, void 0, function* () {
|
|
11
|
+
if (typeof message !== "string") {
|
|
12
|
+
throw new Error("Invalid message type");
|
|
13
|
+
}
|
|
14
|
+
const hexMessage = Buffer.from(message).toString("hex");
|
|
15
|
+
const result = (yield signerContext(deviceId, account.currency, signer => signer.signMessage(account.freshAddressPath, hexMessage)));
|
|
16
|
+
const v = result["v"] + 27 + 4;
|
|
17
|
+
const signature = Buffer.from(`${v.toString(16)}${result["r"]}${result["s"]}`, "hex").toString("base64");
|
|
18
|
+
return {
|
|
19
|
+
rsv: result,
|
|
20
|
+
signature,
|
|
21
|
+
};
|
|
22
|
+
});
|
|
23
|
+
//# sourceMappingURL=hw-signMessage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hw-signMessage.js","sourceRoot":"","sources":["../src/hw-signMessage.ts"],"names":[],"mappings":";;;;;;;;;AAGA,MAAM,CAAC,MAAM,WAAW,GACtB,CAAC,aAA4B,EAAE,EAAE,CACjC,CAAO,QAAgB,EAAE,OAAgB,EAAE,EAAE,OAAO,EAAc,EAAE,EAAE;IACpE,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE;QAC/B,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;KACzC;IAED,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxD,MAAM,MAAM,GAAG,CAAC,MAAM,aAAa,CAAC,QAAQ,EAAE,OAAO,CAAC,QAAQ,EAAE,MAAM,CAAC,EAAE,CACvE,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,gBAAgB,EAAE,UAAU,CAAC,CACzD,CAAqB,CAAC;IACvB,MAAM,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;IAC/B,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC,QAAQ,CAC5F,QAAQ,CACT,CAAC;IACF,OAAO;QACL,GAAG,EAAE,MAAM;QACX,SAAS;KACV,CAAC;AACJ,CAAC,CAAA,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hw-signMessage.test.d.ts","sourceRoot":"","sources":["../src/hw-signMessage.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import { signMessage } from "./hw-signMessage";
|
|
11
|
+
import { listCryptoCurrencies } from "@ledgerhq/cryptoassets/index";
|
|
12
|
+
import BigNumber from "bignumber.js";
|
|
13
|
+
describe("signMessage", () => {
|
|
14
|
+
it("returns a base64 format string", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
15
|
+
const signerFake = {
|
|
16
|
+
getWalletXpub: jest.fn(),
|
|
17
|
+
getWalletPublicKey: jest.fn(),
|
|
18
|
+
signMessage: jest.fn().mockResolvedValue({
|
|
19
|
+
v: 1,
|
|
20
|
+
r: "RRRRRSSSSSRRRRRSSSSS",
|
|
21
|
+
s: "SSSSSRRRRRSSSSSRRRRR",
|
|
22
|
+
}),
|
|
23
|
+
splitTransaction: jest.fn(),
|
|
24
|
+
createPaymentTransaction: jest.fn(),
|
|
25
|
+
};
|
|
26
|
+
const signerContext = (_deviceId, _crypto, fn) => fn(signerFake);
|
|
27
|
+
const account = createFixtureAccount();
|
|
28
|
+
const signature = yield signMessage(signerContext)("deviceId", account, {
|
|
29
|
+
message: "MESSAGE_TO_SIGN",
|
|
30
|
+
});
|
|
31
|
+
expect(signerFake.signMessage).toHaveBeenCalledTimes(1);
|
|
32
|
+
expect(signature).toEqual({
|
|
33
|
+
rsv: {
|
|
34
|
+
v: 1,
|
|
35
|
+
r: "RRRRRSSSSSRRRRRSSSSS",
|
|
36
|
+
s: "SSSSSRRRRRSSSSSRRRRR",
|
|
37
|
+
},
|
|
38
|
+
signature: "IA==",
|
|
39
|
+
});
|
|
40
|
+
}));
|
|
41
|
+
});
|
|
42
|
+
function createFixtureAccount(account) {
|
|
43
|
+
const currency = listCryptoCurrencies(true).find(c => c.id === "bitcoin");
|
|
44
|
+
const bitcoinResources = (account === null || account === void 0 ? void 0 : account.bitcoinResources) || {
|
|
45
|
+
utxos: [],
|
|
46
|
+
};
|
|
47
|
+
const freshAddress = {
|
|
48
|
+
address: "1fMK6i7CMDES1GNGDEMX5ddDaxbkjWPw1M",
|
|
49
|
+
derivationPath: "derivation_path",
|
|
50
|
+
};
|
|
51
|
+
return {
|
|
52
|
+
type: "Account",
|
|
53
|
+
id: "E0A538D5-5EE7-4E37-BB57-F373B08B8580",
|
|
54
|
+
seedIdentifier: "FD5EAFE3-8C7F-4565-ADFA-2A1A2067322A",
|
|
55
|
+
derivationMode: "",
|
|
56
|
+
index: 0,
|
|
57
|
+
freshAddress: freshAddress.address,
|
|
58
|
+
freshAddressPath: freshAddress.derivationPath,
|
|
59
|
+
freshAddresses: [freshAddress],
|
|
60
|
+
name: "bitcoin account name",
|
|
61
|
+
starred: false,
|
|
62
|
+
used: true,
|
|
63
|
+
balance: (account === null || account === void 0 ? void 0 : account.balance) || new BigNumber(0),
|
|
64
|
+
spendableBalance: (account === null || account === void 0 ? void 0 : account.spendableBalance) || new BigNumber(0),
|
|
65
|
+
creationDate: new Date(),
|
|
66
|
+
blockHeight: 100000,
|
|
67
|
+
currency,
|
|
68
|
+
unit: currency.units[0],
|
|
69
|
+
operationsCount: 0,
|
|
70
|
+
operations: [],
|
|
71
|
+
pendingOperations: [],
|
|
72
|
+
lastSyncDate: new Date(),
|
|
73
|
+
balanceHistoryCache: emptyHistoryCache,
|
|
74
|
+
swapHistory: [],
|
|
75
|
+
bitcoinResources,
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
const emptyHistoryCache = {
|
|
79
|
+
HOUR: {
|
|
80
|
+
latestDate: null,
|
|
81
|
+
balances: [],
|
|
82
|
+
},
|
|
83
|
+
DAY: {
|
|
84
|
+
latestDate: null,
|
|
85
|
+
balances: [],
|
|
86
|
+
},
|
|
87
|
+
WEEK: {
|
|
88
|
+
latestDate: null,
|
|
89
|
+
balances: [],
|
|
90
|
+
},
|
|
91
|
+
};
|
|
92
|
+
//# sourceMappingURL=hw-signMessage.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hw-signMessage.test.js","sourceRoot":"","sources":["../src/hw-signMessage.test.ts"],"names":[],"mappings":";;;;;;;;;AACA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AAEpE,OAAO,SAAS,MAAM,cAAc,CAAC;AAErC,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,EAAE,CAAC,gCAAgC,EAAE,GAAS,EAAE;QAC9C,MAAM,UAAU,GAAG;YACjB,aAAa,EAAE,IAAI,CAAC,EAAE,EAAE;YACxB,kBAAkB,EAAE,IAAI,CAAC,EAAE,EAAE;YAC7B,WAAW,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC;gBACvC,CAAC,EAAE,CAAC;gBACJ,CAAC,EAAE,sBAAsB;gBACzB,CAAC,EAAE,sBAAsB;aAC1B,CAAC;YACF,gBAAgB,EAAE,IAAI,CAAC,EAAE,EAAE;YAC3B,wBAAwB,EAAE,IAAI,CAAC,EAAE,EAAE;SACpC,CAAC;QACF,MAAM,aAAa,GAAG,CACpB,SAAiB,EACjB,OAAuB,EACvB,EAAyC,EAC7B,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC;QAEhC,MAAM,OAAO,GAAG,oBAAoB,EAAE,CAAC;QAEvC,MAAM,SAAS,GAAG,MAAM,WAAW,CAAC,aAAa,CAAC,CAAC,UAAU,EAAE,OAAO,EAAE;YACtE,OAAO,EAAE,iBAAiB;SAC3B,CAAC,CAAC;QAEH,MAAM,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACxD,MAAM,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC;YACxB,GAAG,EAAE;gBACH,CAAC,EAAE,CAAC;gBACJ,CAAC,EAAE,sBAAsB;gBACzB,CAAC,EAAE,sBAAsB;aAC1B;YACD,SAAS,EAAE,MAAM;SAClB,CAAC,CAAC;IACL,CAAC,CAAA,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,SAAS,oBAAoB,CAAC,OAAiC;IAC7D,MAAM,QAAQ,GAAG,oBAAoB,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,SAAS,CAAE,CAAC;IAE3E,MAAM,gBAAgB,GAAqB,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,gBAAgB,KAAI;QACtE,KAAK,EAAE,EAAE;KACV,CAAC;IAEF,MAAM,YAAY,GAAG;QACnB,OAAO,EAAE,oCAAoC;QAC7C,cAAc,EAAE,iBAAiB;KAClC,CAAC;IAEF,OAAO;QACL,IAAI,EAAE,SAAS;QACf,EAAE,EAAE,sCAAsC;QAC1C,cAAc,EAAE,sCAAsC;QACtD,cAAc,EAAE,EAAE;QAClB,KAAK,EAAE,CAAC;QACR,YAAY,EAAE,YAAY,CAAC,OAAO;QAClC,gBAAgB,EAAE,YAAY,CAAC,cAAc;QAC7C,cAAc,EAAE,CAAC,YAAY,CAAC;QAC9B,IAAI,EAAE,sBAAsB;QAC5B,OAAO,EAAE,KAAK;QACd,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,OAAO,KAAI,IAAI,SAAS,CAAC,CAAC,CAAC;QAC7C,gBAAgB,EAAE,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,gBAAgB,KAAI,IAAI,SAAS,CAAC,CAAC,CAAC;QAC/D,YAAY,EAAE,IAAI,IAAI,EAAE;QACxB,WAAW,EAAE,MAAO;QACpB,QAAQ;QACR,IAAI,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QACvB,eAAe,EAAE,CAAC;QAClB,UAAU,EAAE,EAAE;QACd,iBAAiB,EAAE,EAAE;QACrB,YAAY,EAAE,IAAI,IAAI,EAAE;QACxB,mBAAmB,EAAE,iBAAiB;QACtC,WAAW,EAAE,EAAE;QAEf,gBAAgB;KACjB,CAAC;AACJ,CAAC;AAED,MAAM,iBAAiB,GAAG;IACxB,IAAI,EAAE;QACJ,UAAU,EAAE,IAAI;QAChB,QAAQ,EAAE,EAAE;KACb;IACD,GAAG,EAAE;QACH,UAAU,EAAE,IAAI;QAChB,QAAQ,EAAE,EAAE;KACb;IACD,IAAI,EAAE;QACJ,UAAU,EAAE,IAAI;QAChB,QAAQ,EAAE,EAAE;KACb;CACF,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Account, Operation, SignedOperation } from "@ledgerhq/types-live";
|
|
2
|
+
/**
|
|
3
|
+
* Broadcast a signed transaction
|
|
4
|
+
* @param {signature: string, operation: string} signedOperation
|
|
5
|
+
*/
|
|
6
|
+
declare const broadcast: ({ account, signedOperation, }: {
|
|
7
|
+
account: Account;
|
|
8
|
+
signedOperation: SignedOperation;
|
|
9
|
+
}) => Promise<Operation>;
|
|
10
|
+
export default broadcast;
|
|
11
|
+
//# sourceMappingURL=js-broadcast.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"js-broadcast.d.ts","sourceRoot":"","sources":["../src/js-broadcast.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAIhF;;;GAGG;AACH,QAAA,MAAM,SAAS;aAIJ,OAAO;qBACC,eAAe;MAC9B,QAAQ,SAAS,CAKpB,CAAC;AAEF,eAAe,SAAS,CAAC"}
|