@ledgerhq/coin-sui 0.2.0-nightly.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.js +23 -0
- package/.turbo/turbo-build.log +4 -0
- package/.unimportedrc.json +19 -0
- package/CHANGELOG.md +16 -0
- package/LICENSE.txt +21 -0
- package/jest.config.js +9 -0
- package/jest.integ.config.js +7 -0
- package/lib/api/chain/index.d.ts +16 -0
- package/lib/api/chain/index.d.ts.map +1 -0
- package/lib/api/chain/index.js +3 -0
- package/lib/api/chain/index.js.map +1 -0
- package/lib/bridge/bridge.integration.test.d.ts +4 -0
- package/lib/bridge/bridge.integration.test.d.ts.map +1 -0
- package/lib/bridge/bridge.integration.test.js +136 -0
- package/lib/bridge/bridge.integration.test.js.map +1 -0
- package/lib/bridge/broadcast.d.ts +12 -0
- package/lib/bridge/broadcast.d.ts.map +1 -0
- package/lib/bridge/broadcast.js +20 -0
- package/lib/bridge/broadcast.js.map +1 -0
- package/lib/bridge/broadcast.test.d.ts +2 -0
- package/lib/bridge/broadcast.test.d.ts.map +1 -0
- package/lib/bridge/broadcast.test.js +48 -0
- package/lib/bridge/broadcast.test.js.map +1 -0
- package/lib/bridge/buildOptimisticOperation.d.ts +4 -0
- package/lib/bridge/buildOptimisticOperation.d.ts.map +1 -0
- package/lib/bridge/buildOptimisticOperation.js +76 -0
- package/lib/bridge/buildOptimisticOperation.js.map +1 -0
- package/lib/bridge/buildOptimisticOperation.test.d.ts +2 -0
- package/lib/bridge/buildOptimisticOperation.test.d.ts.map +1 -0
- package/lib/bridge/buildOptimisticOperation.test.js +52 -0
- package/lib/bridge/buildOptimisticOperation.test.js.map +1 -0
- package/lib/bridge/buildTransaction.d.ts +9 -0
- package/lib/bridge/buildTransaction.d.ts.map +1 -0
- package/lib/bridge/buildTransaction.js +19 -0
- package/lib/bridge/buildTransaction.js.map +1 -0
- package/lib/bridge/buildTransaction.test.d.ts +2 -0
- package/lib/bridge/buildTransaction.test.d.ts.map +1 -0
- package/lib/bridge/buildTransaction.test.js +17 -0
- package/lib/bridge/buildTransaction.test.js.map +1 -0
- package/lib/bridge/createTransaction.d.ts +10 -0
- package/lib/bridge/createTransaction.d.ts.map +1 -0
- package/lib/bridge/createTransaction.js +24 -0
- package/lib/bridge/createTransaction.js.map +1 -0
- package/lib/bridge/estimateMaxSpendable.d.ts +14 -0
- package/lib/bridge/estimateMaxSpendable.d.ts.map +1 -0
- package/lib/bridge/estimateMaxSpendable.js +44 -0
- package/lib/bridge/estimateMaxSpendable.js.map +1 -0
- package/lib/bridge/estimateMaxSpendable.test.d.ts +2 -0
- package/lib/bridge/estimateMaxSpendable.test.d.ts.map +1 -0
- package/lib/bridge/estimateMaxSpendable.test.js +25 -0
- package/lib/bridge/estimateMaxSpendable.test.js.map +1 -0
- package/lib/bridge/formatters.d.ts +10 -0
- package/lib/bridge/formatters.d.ts.map +1 -0
- package/lib/bridge/formatters.js +24 -0
- package/lib/bridge/formatters.js.map +1 -0
- package/lib/bridge/formatters.test.d.ts +2 -0
- package/lib/bridge/formatters.test.d.ts.map +1 -0
- package/lib/bridge/formatters.test.js +18 -0
- package/lib/bridge/formatters.test.js.map +1 -0
- package/lib/bridge/getFeesForTransaction.d.ts +15 -0
- package/lib/bridge/getFeesForTransaction.d.ts.map +1 -0
- package/lib/bridge/getFeesForTransaction.js +32 -0
- package/lib/bridge/getFeesForTransaction.js.map +1 -0
- package/lib/bridge/getFeesForTransaction.test.d.ts +2 -0
- package/lib/bridge/getFeesForTransaction.test.d.ts.map +1 -0
- package/lib/bridge/getFeesForTransaction.test.js +35 -0
- package/lib/bridge/getFeesForTransaction.test.js.map +1 -0
- package/lib/bridge/getTransactionStatus.d.ts +12 -0
- package/lib/bridge/getTransactionStatus.d.ts.map +1 -0
- package/lib/bridge/getTransactionStatus.js +59 -0
- package/lib/bridge/getTransactionStatus.js.map +1 -0
- package/lib/bridge/getTransactionStatus.test.d.ts +2 -0
- package/lib/bridge/getTransactionStatus.test.d.ts.map +1 -0
- package/lib/bridge/getTransactionStatus.test.js +48 -0
- package/lib/bridge/getTransactionStatus.test.js.map +1 -0
- package/lib/bridge/index.d.ts +10 -0
- package/lib/bridge/index.d.ts.map +1 -0
- package/lib/bridge/index.js +63 -0
- package/lib/bridge/index.js.map +1 -0
- package/lib/bridge/preload.d.ts +11 -0
- package/lib/bridge/preload.d.ts.map +1 -0
- package/lib/bridge/preload.js +41 -0
- package/lib/bridge/preload.js.map +1 -0
- package/lib/bridge/prepareTransaction.d.ts +13 -0
- package/lib/bridge/prepareTransaction.d.ts.map +1 -0
- package/lib/bridge/prepareTransaction.js +43 -0
- package/lib/bridge/prepareTransaction.js.map +1 -0
- package/lib/bridge/prepareTransaction.test.d.ts +2 -0
- package/lib/bridge/prepareTransaction.test.d.ts.map +1 -0
- package/lib/bridge/prepareTransaction.test.js +45 -0
- package/lib/bridge/prepareTransaction.test.js.map +1 -0
- package/lib/bridge/serialization.d.ts +7 -0
- package/lib/bridge/serialization.d.ts.map +1 -0
- package/lib/bridge/serialization.js +27 -0
- package/lib/bridge/serialization.js.map +1 -0
- package/lib/bridge/serialization.test.d.ts +2 -0
- package/lib/bridge/serialization.test.d.ts.map +1 -0
- package/lib/bridge/serialization.test.js +131 -0
- package/lib/bridge/serialization.test.js.map +1 -0
- package/lib/bridge/signOperation.d.ts +9 -0
- package/lib/bridge/signOperation.d.ts.map +1 -0
- package/lib/bridge/signOperation.js +72 -0
- package/lib/bridge/signOperation.js.map +1 -0
- package/lib/bridge/signOperation.test.d.ts +2 -0
- package/lib/bridge/signOperation.test.d.ts.map +1 -0
- package/lib/bridge/signOperation.test.js +76 -0
- package/lib/bridge/signOperation.test.js.map +1 -0
- package/lib/bridge/synchronisation.d.ts +21 -0
- package/lib/bridge/synchronisation.d.ts.map +1 -0
- package/lib/bridge/synchronisation.js +65 -0
- package/lib/bridge/synchronisation.js.map +1 -0
- package/lib/bridge/synchronisation.test.d.ts +2 -0
- package/lib/bridge/synchronisation.test.d.ts.map +1 -0
- package/lib/bridge/synchronisation.test.js +118 -0
- package/lib/bridge/synchronisation.test.js.map +1 -0
- package/lib/bridge/transaction.d.ts +15 -0
- package/lib/bridge/transaction.d.ts.map +1 -0
- package/lib/bridge/transaction.js +55 -0
- package/lib/bridge/transaction.js.map +1 -0
- package/lib/bridge/transaction.test.d.ts +2 -0
- package/lib/bridge/transaction.test.d.ts.map +1 -0
- package/lib/bridge/transaction.test.js +65 -0
- package/lib/bridge/transaction.test.js.map +1 -0
- package/lib/bridge/utils.d.ts +27 -0
- package/lib/bridge/utils.d.ts.map +1 -0
- package/lib/bridge/utils.js +57 -0
- package/lib/bridge/utils.js.map +1 -0
- package/lib/config.d.ts +15 -0
- package/lib/config.d.ts.map +1 -0
- package/lib/config.js +9 -0
- package/lib/config.js.map +1 -0
- package/lib/index.d.ts +3 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +21 -0
- package/lib/index.js.map +1 -0
- package/lib/logic/broadcast.d.ts +9 -0
- package/lib/logic/broadcast.d.ts.map +1 -0
- package/lib/logic/broadcast.js +26 -0
- package/lib/logic/broadcast.js.map +1 -0
- package/lib/logic/craftTransaction.d.ts +17 -0
- package/lib/logic/craftTransaction.d.ts.map +1 -0
- package/lib/logic/craftTransaction.js +22 -0
- package/lib/logic/craftTransaction.js.map +1 -0
- package/lib/logic/estimateFees.d.ts +10 -0
- package/lib/logic/estimateFees.d.ts.map +1 -0
- package/lib/logic/estimateFees.js +20 -0
- package/lib/logic/estimateFees.js.map +1 -0
- package/lib/logic/index.d.ts +4 -0
- package/lib/logic/index.d.ts.map +1 -0
- package/lib/logic/index.js +10 -0
- package/lib/logic/index.js.map +1 -0
- package/lib/network/index.d.ts +18 -0
- package/lib/network/index.d.ts.map +1 -0
- package/lib/network/index.js +17 -0
- package/lib/network/index.js.map +1 -0
- package/lib/network/sdk.d.ts +61 -0
- package/lib/network/sdk.d.ts.map +1 -0
- package/lib/network/sdk.integration.test.d.ts +2 -0
- package/lib/network/sdk.integration.test.d.ts.map +1 -0
- package/lib/network/sdk.integration.test.js +70 -0
- package/lib/network/sdk.integration.test.js.map +1 -0
- package/lib/network/sdk.js +205 -0
- package/lib/network/sdk.js.map +1 -0
- package/lib/network/sdk.test.d.ts +2 -0
- package/lib/network/sdk.test.d.ts.map +1 -0
- package/lib/network/sdk.test.js +166 -0
- package/lib/network/sdk.test.js.map +1 -0
- package/lib/signer/getAddress.d.ts +6 -0
- package/lib/signer/getAddress.d.ts.map +1 -0
- package/lib/signer/getAddress.js +20 -0
- package/lib/signer/getAddress.js.map +1 -0
- package/lib/signer/getAddress.test.d.ts +2 -0
- package/lib/signer/getAddress.test.d.ts.map +1 -0
- package/lib/signer/getAddress.test.js +106 -0
- package/lib/signer/getAddress.test.js.map +1 -0
- package/lib/signer/index.d.ts +6 -0
- package/lib/signer/index.d.ts.map +1 -0
- package/lib/signer/index.js +11 -0
- package/lib/signer/index.js.map +1 -0
- package/lib/test/cli.d.ts +16 -0
- package/lib/test/cli.d.ts.map +1 -0
- package/lib/test/cli.js +16 -0
- package/lib/test/cli.js.map +1 -0
- package/lib/types/bridge.d.ts +72 -0
- package/lib/types/bridge.d.ts.map +1 -0
- package/lib/types/bridge.fixture.d.ts +30 -0
- package/lib/types/bridge.fixture.d.ts.map +1 -0
- package/lib/types/bridge.fixture.js +86 -0
- package/lib/types/bridge.fixture.js.map +1 -0
- package/lib/types/bridge.js +3 -0
- package/lib/types/bridge.js.map +1 -0
- package/lib/types/index.d.ts +4 -0
- package/lib/types/index.d.ts.map +1 -0
- package/lib/types/index.js +20 -0
- package/lib/types/index.js.map +1 -0
- package/lib/types/model.d.ts +6 -0
- package/lib/types/model.d.ts.map +1 -0
- package/lib/types/model.js +3 -0
- package/lib/types/model.js.map +1 -0
- package/lib/types/signer.d.ts +13 -0
- package/lib/types/signer.d.ts.map +1 -0
- package/lib/types/signer.js +3 -0
- package/lib/types/signer.js.map +1 -0
- package/lib/utils.d.ts +7 -0
- package/lib/utils.d.ts.map +1 -0
- package/lib/utils.js +13 -0
- package/lib/utils.js.map +1 -0
- package/lib-es/api/chain/index.d.ts +16 -0
- package/lib-es/api/chain/index.d.ts.map +1 -0
- package/lib-es/api/chain/index.js +2 -0
- package/lib-es/api/chain/index.js.map +1 -0
- package/lib-es/bridge/bridge.integration.test.d.ts +4 -0
- package/lib-es/bridge/bridge.integration.test.d.ts.map +1 -0
- package/lib-es/bridge/bridge.integration.test.js +130 -0
- package/lib-es/bridge/bridge.integration.test.js.map +1 -0
- package/lib-es/bridge/broadcast.d.ts +12 -0
- package/lib-es/bridge/broadcast.d.ts.map +1 -0
- package/lib-es/bridge/broadcast.js +16 -0
- package/lib-es/bridge/broadcast.js.map +1 -0
- package/lib-es/bridge/broadcast.test.d.ts +2 -0
- package/lib-es/bridge/broadcast.test.d.ts.map +1 -0
- package/lib-es/bridge/broadcast.test.js +46 -0
- package/lib-es/bridge/broadcast.test.js.map +1 -0
- package/lib-es/bridge/buildOptimisticOperation.d.ts +4 -0
- package/lib-es/bridge/buildOptimisticOperation.d.ts.map +1 -0
- package/lib-es/bridge/buildOptimisticOperation.js +69 -0
- package/lib-es/bridge/buildOptimisticOperation.js.map +1 -0
- package/lib-es/bridge/buildOptimisticOperation.test.d.ts +2 -0
- package/lib-es/bridge/buildOptimisticOperation.test.d.ts.map +1 -0
- package/lib-es/bridge/buildOptimisticOperation.test.js +47 -0
- package/lib-es/bridge/buildOptimisticOperation.test.js.map +1 -0
- package/lib-es/bridge/buildTransaction.d.ts +9 -0
- package/lib-es/bridge/buildTransaction.d.ts.map +1 -0
- package/lib-es/bridge/buildTransaction.js +11 -0
- package/lib-es/bridge/buildTransaction.js.map +1 -0
- package/lib-es/bridge/buildTransaction.test.d.ts +2 -0
- package/lib-es/bridge/buildTransaction.test.d.ts.map +1 -0
- package/lib-es/bridge/buildTransaction.test.js +15 -0
- package/lib-es/bridge/buildTransaction.test.js.map +1 -0
- package/lib-es/bridge/createTransaction.d.ts +10 -0
- package/lib-es/bridge/createTransaction.d.ts.map +1 -0
- package/lib-es/bridge/createTransaction.js +20 -0
- package/lib-es/bridge/createTransaction.js.map +1 -0
- package/lib-es/bridge/estimateMaxSpendable.d.ts +14 -0
- package/lib-es/bridge/estimateMaxSpendable.d.ts.map +1 -0
- package/lib-es/bridge/estimateMaxSpendable.js +37 -0
- package/lib-es/bridge/estimateMaxSpendable.js.map +1 -0
- package/lib-es/bridge/estimateMaxSpendable.test.d.ts +2 -0
- package/lib-es/bridge/estimateMaxSpendable.test.d.ts.map +1 -0
- package/lib-es/bridge/estimateMaxSpendable.test.js +23 -0
- package/lib-es/bridge/estimateMaxSpendable.test.js.map +1 -0
- package/lib-es/bridge/formatters.d.ts +10 -0
- package/lib-es/bridge/formatters.d.ts.map +1 -0
- package/lib-es/bridge/formatters.js +19 -0
- package/lib-es/bridge/formatters.js.map +1 -0
- package/lib-es/bridge/formatters.test.d.ts +2 -0
- package/lib-es/bridge/formatters.test.d.ts.map +1 -0
- package/lib-es/bridge/formatters.test.js +16 -0
- package/lib-es/bridge/formatters.test.js.map +1 -0
- package/lib-es/bridge/getFeesForTransaction.d.ts +15 -0
- package/lib-es/bridge/getFeesForTransaction.d.ts.map +1 -0
- package/lib-es/bridge/getFeesForTransaction.js +29 -0
- package/lib-es/bridge/getFeesForTransaction.js.map +1 -0
- package/lib-es/bridge/getFeesForTransaction.test.d.ts +2 -0
- package/lib-es/bridge/getFeesForTransaction.test.d.ts.map +1 -0
- package/lib-es/bridge/getFeesForTransaction.test.js +30 -0
- package/lib-es/bridge/getFeesForTransaction.test.js.map +1 -0
- package/lib-es/bridge/getTransactionStatus.d.ts +12 -0
- package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -0
- package/lib-es/bridge/getTransactionStatus.js +55 -0
- package/lib-es/bridge/getTransactionStatus.js.map +1 -0
- package/lib-es/bridge/getTransactionStatus.test.d.ts +2 -0
- package/lib-es/bridge/getTransactionStatus.test.d.ts.map +1 -0
- package/lib-es/bridge/getTransactionStatus.test.js +43 -0
- package/lib-es/bridge/getTransactionStatus.test.js.map +1 -0
- package/lib-es/bridge/index.d.ts +10 -0
- package/lib-es/bridge/index.d.ts.map +1 -0
- package/lib-es/bridge/index.js +56 -0
- package/lib-es/bridge/index.js.map +1 -0
- package/lib-es/bridge/preload.d.ts +11 -0
- package/lib-es/bridge/preload.d.ts.map +1 -0
- package/lib-es/bridge/preload.js +32 -0
- package/lib-es/bridge/preload.js.map +1 -0
- package/lib-es/bridge/prepareTransaction.d.ts +13 -0
- package/lib-es/bridge/prepareTransaction.d.ts.map +1 -0
- package/lib-es/bridge/prepareTransaction.js +36 -0
- package/lib-es/bridge/prepareTransaction.js.map +1 -0
- package/lib-es/bridge/prepareTransaction.test.d.ts +2 -0
- package/lib-es/bridge/prepareTransaction.test.d.ts.map +1 -0
- package/lib-es/bridge/prepareTransaction.test.js +40 -0
- package/lib-es/bridge/prepareTransaction.test.js.map +1 -0
- package/lib-es/bridge/serialization.d.ts +7 -0
- package/lib-es/bridge/serialization.d.ts.map +1 -0
- package/lib-es/bridge/serialization.js +20 -0
- package/lib-es/bridge/serialization.js.map +1 -0
- package/lib-es/bridge/serialization.test.d.ts +2 -0
- package/lib-es/bridge/serialization.test.d.ts.map +1 -0
- package/lib-es/bridge/serialization.test.js +126 -0
- package/lib-es/bridge/serialization.test.js.map +1 -0
- package/lib-es/bridge/signOperation.d.ts +9 -0
- package/lib-es/bridge/signOperation.d.ts.map +1 -0
- package/lib-es/bridge/signOperation.js +68 -0
- package/lib-es/bridge/signOperation.js.map +1 -0
- package/lib-es/bridge/signOperation.test.d.ts +2 -0
- package/lib-es/bridge/signOperation.test.d.ts.map +1 -0
- package/lib-es/bridge/signOperation.test.js +71 -0
- package/lib-es/bridge/signOperation.test.js.map +1 -0
- package/lib-es/bridge/synchronisation.d.ts +21 -0
- package/lib-es/bridge/synchronisation.d.ts.map +1 -0
- package/lib-es/bridge/synchronisation.js +61 -0
- package/lib-es/bridge/synchronisation.js.map +1 -0
- package/lib-es/bridge/synchronisation.test.d.ts +2 -0
- package/lib-es/bridge/synchronisation.test.d.ts.map +1 -0
- package/lib-es/bridge/synchronisation.test.js +113 -0
- package/lib-es/bridge/synchronisation.test.js.map +1 -0
- package/lib-es/bridge/transaction.d.ts +15 -0
- package/lib-es/bridge/transaction.d.ts.map +1 -0
- package/lib-es/bridge/transaction.js +49 -0
- package/lib-es/bridge/transaction.js.map +1 -0
- package/lib-es/bridge/transaction.test.d.ts +2 -0
- package/lib-es/bridge/transaction.test.d.ts.map +1 -0
- package/lib-es/bridge/transaction.test.js +63 -0
- package/lib-es/bridge/transaction.test.js.map +1 -0
- package/lib-es/bridge/utils.d.ts +27 -0
- package/lib-es/bridge/utils.d.ts.map +1 -0
- package/lib-es/bridge/utils.js +51 -0
- package/lib-es/bridge/utils.js.map +1 -0
- package/lib-es/config.d.ts +15 -0
- package/lib-es/config.d.ts.map +1 -0
- package/lib-es/config.js +4 -0
- package/lib-es/config.js.map +1 -0
- package/lib-es/index.d.ts +3 -0
- package/lib-es/index.d.ts.map +1 -0
- package/lib-es/index.js +3 -0
- package/lib-es/index.js.map +1 -0
- package/lib-es/logic/broadcast.d.ts +9 -0
- package/lib-es/logic/broadcast.d.ts.map +1 -0
- package/lib-es/logic/broadcast.js +19 -0
- package/lib-es/logic/broadcast.js.map +1 -0
- package/lib-es/logic/craftTransaction.d.ts +17 -0
- package/lib-es/logic/craftTransaction.d.ts.map +1 -0
- package/lib-es/logic/craftTransaction.js +15 -0
- package/lib-es/logic/craftTransaction.js.map +1 -0
- package/lib-es/logic/estimateFees.d.ts +10 -0
- package/lib-es/logic/estimateFees.d.ts.map +1 -0
- package/lib-es/logic/estimateFees.js +13 -0
- package/lib-es/logic/estimateFees.js.map +1 -0
- package/lib-es/logic/index.d.ts +4 -0
- package/lib-es/logic/index.d.ts.map +1 -0
- package/lib-es/logic/index.js +4 -0
- package/lib-es/logic/index.js.map +1 -0
- package/lib-es/network/index.d.ts +18 -0
- package/lib-es/network/index.d.ts.map +1 -0
- package/lib-es/network/index.js +10 -0
- package/lib-es/network/index.js.map +1 -0
- package/lib-es/network/sdk.d.ts +61 -0
- package/lib-es/network/sdk.d.ts.map +1 -0
- package/lib-es/network/sdk.integration.test.d.ts +2 -0
- package/lib-es/network/sdk.integration.test.d.ts.map +1 -0
- package/lib-es/network/sdk.integration.test.js +65 -0
- package/lib-es/network/sdk.integration.test.js.map +1 -0
- package/lib-es/network/sdk.js +189 -0
- package/lib-es/network/sdk.js.map +1 -0
- package/lib-es/network/sdk.test.d.ts +2 -0
- package/lib-es/network/sdk.test.d.ts.map +1 -0
- package/lib-es/network/sdk.test.js +164 -0
- package/lib-es/network/sdk.test.js.map +1 -0
- package/lib-es/signer/getAddress.d.ts +6 -0
- package/lib-es/signer/getAddress.d.ts.map +1 -0
- package/lib-es/signer/getAddress.js +18 -0
- package/lib-es/signer/getAddress.js.map +1 -0
- package/lib-es/signer/getAddress.test.d.ts +2 -0
- package/lib-es/signer/getAddress.test.d.ts.map +1 -0
- package/lib-es/signer/getAddress.test.js +101 -0
- package/lib-es/signer/getAddress.test.js.map +1 -0
- package/lib-es/signer/index.d.ts +6 -0
- package/lib-es/signer/index.d.ts.map +1 -0
- package/lib-es/signer/index.js +6 -0
- package/lib-es/signer/index.js.map +1 -0
- package/lib-es/test/cli.d.ts +16 -0
- package/lib-es/test/cli.d.ts.map +1 -0
- package/lib-es/test/cli.js +13 -0
- package/lib-es/test/cli.js.map +1 -0
- package/lib-es/types/bridge.d.ts +72 -0
- package/lib-es/types/bridge.d.ts.map +1 -0
- package/lib-es/types/bridge.fixture.d.ts +30 -0
- package/lib-es/types/bridge.fixture.d.ts.map +1 -0
- package/lib-es/types/bridge.fixture.js +80 -0
- package/lib-es/types/bridge.fixture.js.map +1 -0
- package/lib-es/types/bridge.js +2 -0
- package/lib-es/types/bridge.js.map +1 -0
- package/lib-es/types/index.d.ts +4 -0
- package/lib-es/types/index.d.ts.map +1 -0
- package/lib-es/types/index.js +4 -0
- package/lib-es/types/index.js.map +1 -0
- package/lib-es/types/model.d.ts +6 -0
- package/lib-es/types/model.d.ts.map +1 -0
- package/lib-es/types/model.js +2 -0
- package/lib-es/types/model.js.map +1 -0
- package/lib-es/types/signer.d.ts +13 -0
- package/lib-es/types/signer.d.ts.map +1 -0
- package/lib-es/types/signer.js +2 -0
- package/lib-es/types/signer.js.map +1 -0
- package/lib-es/utils.d.ts +7 -0
- package/lib-es/utils.d.ts.map +1 -0
- package/lib-es/utils.js +9 -0
- package/lib-es/utils.js.map +1 -0
- package/package.json +152 -0
- package/src/api/chain/index.ts +17 -0
- package/src/bridge/bridge.integration.test.ts +140 -0
- package/src/bridge/broadcast.test.ts +52 -0
- package/src/bridge/broadcast.ts +21 -0
- package/src/bridge/buildOptimisticOperation.test.ts +53 -0
- package/src/bridge/buildOptimisticOperation.ts +105 -0
- package/src/bridge/buildTransaction.test.ts +17 -0
- package/src/bridge/buildTransaction.ts +14 -0
- package/src/bridge/createTransaction.ts +23 -0
- package/src/bridge/estimateMaxSpendable.test.ts +27 -0
- package/src/bridge/estimateMaxSpendable.ts +46 -0
- package/src/bridge/formatters.test.ts +17 -0
- package/src/bridge/formatters.ts +26 -0
- package/src/bridge/getFeesForTransaction.test.ts +36 -0
- package/src/bridge/getFeesForTransaction.ts +37 -0
- package/src/bridge/getTransactionStatus.test.ts +57 -0
- package/src/bridge/getTransactionStatus.ts +73 -0
- package/src/bridge/index.ts +77 -0
- package/src/bridge/preload.ts +46 -0
- package/src/bridge/prepareTransaction.test.ts +47 -0
- package/src/bridge/prepareTransaction.ts +44 -0
- package/src/bridge/serialization.test.ts +135 -0
- package/src/bridge/serialization.ts +24 -0
- package/src/bridge/signOperation.test.ts +80 -0
- package/src/bridge/signOperation.ts +101 -0
- package/src/bridge/synchronisation.test.ts +140 -0
- package/src/bridge/synchronisation.ts +75 -0
- package/src/bridge/transaction.test.ts +73 -0
- package/src/bridge/transaction.ts +61 -0
- package/src/bridge/utils.ts +69 -0
- package/src/config.ts +19 -0
- package/src/index.ts +3 -0
- package/src/logic/broadcast.ts +19 -0
- package/src/logic/craftTransaction.ts +28 -0
- package/src/logic/estimateFees.ts +14 -0
- package/src/logic/index.ts +3 -0
- package/src/network/index.ts +17 -0
- package/src/network/sdk.integration.test.ts +75 -0
- package/src/network/sdk.test.ts +203 -0
- package/src/network/sdk.ts +262 -0
- package/src/signer/getAddress.test.ts +119 -0
- package/src/signer/getAddress.ts +26 -0
- package/src/signer/index.ts +7 -0
- package/src/test/cli.ts +21 -0
- package/src/types/bridge.fixture.ts +84 -0
- package/src/types/bridge.ts +95 -0
- package/src/types/index.ts +3 -0
- package/src/types/model.ts +7 -0
- package/src/types/signer.ts +12 -0
- package/src/utils.ts +8 -0
- package/tsconfig.json +14 -0
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { NotEnoughBalance, RecipientRequired, InvalidAddressBecauseDestinationIsAlsoSource, AmountRequired, } from "@ledgerhq/errors";
|
|
2
|
+
import BigNumber from "bignumber.js";
|
|
3
|
+
import { fromTransactionRaw } from "./transaction";
|
|
4
|
+
const OWNER = "0xba7080172a6d957b9ed2e3eb643529860be963cf4af896fb84f1cde00f46b561";
|
|
5
|
+
const RECIPIENT = "0x117527fdcf2f5f6e82fa499c0398def2643550d63f7e8311245d75f4635f0435";
|
|
6
|
+
const DEFAULT_AMOUNT = "10";
|
|
7
|
+
const suiAccount1 = {
|
|
8
|
+
id: `js:2:sui:${OWNER}:`,
|
|
9
|
+
seedIdentifier: OWNER,
|
|
10
|
+
name: `Sui ${OWNER}`,
|
|
11
|
+
derivationMode: "",
|
|
12
|
+
index: 0,
|
|
13
|
+
freshAddress: OWNER,
|
|
14
|
+
freshAddressPath: "44'/784'/0'/0'/0'",
|
|
15
|
+
pendingOperations: [],
|
|
16
|
+
operations: [],
|
|
17
|
+
currencyId: "sui",
|
|
18
|
+
balance: "0",
|
|
19
|
+
blockHeight: 0,
|
|
20
|
+
lastSyncDate: "",
|
|
21
|
+
xpub: "",
|
|
22
|
+
};
|
|
23
|
+
const sui = {
|
|
24
|
+
scanAccounts: [
|
|
25
|
+
{
|
|
26
|
+
name: "sui seed 1",
|
|
27
|
+
apdus: `
|
|
28
|
+
=> 0002000021001b7cf66fe039a16326933b3fe94627a7ddc4d18539b925bdb80f9294f88df4af
|
|
29
|
+
<= 021b7cf66fe039a16326933b3fe94627a7ddc4d18539b925bdb80f9294f88df4af9000
|
|
30
|
+
=> 000200003a010000000000000000000000000000000000000000000000000000000000000000062c0000801003008000000080000000800000008000000080
|
|
31
|
+
<= 0120e5fb8c817b97e9e9aec677b9e822e8a60c7471624f36b701c94560b88195a8e720eba97be74a8e66a2a423d18d4d73b6866503c406b376fb49f6bf0aacb6d508279000
|
|
32
|
+
=> 0002000021007cfea3aa1e07cc4b500c237a8bf8dcb31d5cb855f29dfdeb92f9e4df9493a6cd
|
|
33
|
+
<= 027cfea3aa1e07cc4b500c237a8bf8dcb31d5cb855f29dfdeb92f9e4df9493a6cd9000
|
|
34
|
+
=> 0002000036010000000000000000000000000000000000000000000000000000000000000000052c00008010030080000000800000008000000080
|
|
35
|
+
<= 0120e95d14c7b906d66090556e0fce65ed3b71167b37e0c19136857d35b44f082ba720117527fdcf2f5f6e82fa499c0398def2643550d63f7e8311245d75f4635f04359000
|
|
36
|
+
`,
|
|
37
|
+
},
|
|
38
|
+
],
|
|
39
|
+
accounts: [
|
|
40
|
+
{
|
|
41
|
+
raw: suiAccount1,
|
|
42
|
+
transactions: [
|
|
43
|
+
{
|
|
44
|
+
name: "recipient and sender must not be the same",
|
|
45
|
+
transaction: fromTransactionRaw({
|
|
46
|
+
family: "sui",
|
|
47
|
+
recipient: OWNER,
|
|
48
|
+
amount: DEFAULT_AMOUNT,
|
|
49
|
+
mode: "send",
|
|
50
|
+
}),
|
|
51
|
+
expectedStatus: {
|
|
52
|
+
amount: new BigNumber(DEFAULT_AMOUNT),
|
|
53
|
+
errors: { recipient: new InvalidAddressBecauseDestinationIsAlsoSource() },
|
|
54
|
+
warnings: {},
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
name: "send tx",
|
|
59
|
+
transaction: fromTransactionRaw({
|
|
60
|
+
amount: "2000000",
|
|
61
|
+
recipient: RECIPIENT,
|
|
62
|
+
useAllAmount: false,
|
|
63
|
+
family: "sui",
|
|
64
|
+
mode: "send",
|
|
65
|
+
fees: "0",
|
|
66
|
+
}),
|
|
67
|
+
expectedStatus: {
|
|
68
|
+
errors: {},
|
|
69
|
+
warnings: {},
|
|
70
|
+
estimatedFees: BigNumber("0"),
|
|
71
|
+
amount: BigNumber("2000000"),
|
|
72
|
+
totalSpent: BigNumber("2000000"),
|
|
73
|
+
},
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
name: "not enough balance",
|
|
77
|
+
transaction: fromTransactionRaw({
|
|
78
|
+
family: "sui",
|
|
79
|
+
recipient: RECIPIENT,
|
|
80
|
+
amount: "10000000000000000000",
|
|
81
|
+
mode: "send",
|
|
82
|
+
}),
|
|
83
|
+
expectedStatus: {
|
|
84
|
+
errors: {
|
|
85
|
+
amount: new NotEnoughBalance(),
|
|
86
|
+
},
|
|
87
|
+
warnings: {},
|
|
88
|
+
},
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
name: "recipient is required",
|
|
92
|
+
transaction: fromTransactionRaw({
|
|
93
|
+
family: "sui",
|
|
94
|
+
recipient: "",
|
|
95
|
+
amount: "1000000",
|
|
96
|
+
mode: "send",
|
|
97
|
+
}),
|
|
98
|
+
expectedStatus: {
|
|
99
|
+
errors: {
|
|
100
|
+
recipient: new RecipientRequired(),
|
|
101
|
+
},
|
|
102
|
+
warnings: {},
|
|
103
|
+
},
|
|
104
|
+
},
|
|
105
|
+
{
|
|
106
|
+
name: "amount is required",
|
|
107
|
+
transaction: fromTransactionRaw({
|
|
108
|
+
family: "sui",
|
|
109
|
+
recipient: RECIPIENT,
|
|
110
|
+
amount: "0",
|
|
111
|
+
mode: "send",
|
|
112
|
+
}),
|
|
113
|
+
expectedStatus: {
|
|
114
|
+
errors: {
|
|
115
|
+
amount: new AmountRequired(),
|
|
116
|
+
},
|
|
117
|
+
warnings: {},
|
|
118
|
+
},
|
|
119
|
+
},
|
|
120
|
+
],
|
|
121
|
+
},
|
|
122
|
+
],
|
|
123
|
+
};
|
|
124
|
+
export const dataset = {
|
|
125
|
+
implementations: ["js"],
|
|
126
|
+
currencies: {
|
|
127
|
+
sui,
|
|
128
|
+
},
|
|
129
|
+
};
|
|
130
|
+
//# sourceMappingURL=bridge.integration.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bridge.integration.test.js","sourceRoot":"","sources":["../../src/bridge/bridge.integration.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { AccountBridge } from "@ledgerhq/types-live";
|
|
2
|
+
import { Transaction } from "../types";
|
|
3
|
+
/**
|
|
4
|
+
* Broadcast the signed transaction
|
|
5
|
+
* @param {Object} params - The parameters for broadcasting the transaction.
|
|
6
|
+
* @param {Object} params.signedOperation - The signed operation to be broadcasted.
|
|
7
|
+
* @param {Object} params.signedOperation.operation - The operation details.
|
|
8
|
+
* @param {Object} params.signedOperation.rawData - The raw data of the signed operation.
|
|
9
|
+
* @returns {Promise<Object>} The operation with the hash of the transaction.
|
|
10
|
+
*/
|
|
11
|
+
export declare const broadcast: AccountBridge<Transaction>["broadcast"];
|
|
12
|
+
//# sourceMappingURL=broadcast.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAG1D,OAAO,EAAsB,WAAW,EAAE,MAAM,UAAU,CAAC;AAE3D;;;;;;;GAOG;AACH,eAAO,MAAM,SAAS,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,WAAW,CAO7D,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { patchOperationWithHash } from "@ledgerhq/coin-framework/operation";
|
|
2
|
+
import { broadcast as logicBroadcast } from "../logic";
|
|
3
|
+
/**
|
|
4
|
+
* Broadcast the signed transaction
|
|
5
|
+
* @param {Object} params - The parameters for broadcasting the transaction.
|
|
6
|
+
* @param {Object} params.signedOperation - The signed operation to be broadcasted.
|
|
7
|
+
* @param {Object} params.signedOperation.operation - The operation details.
|
|
8
|
+
* @param {Object} params.signedOperation.rawData - The raw data of the signed operation.
|
|
9
|
+
* @returns {Promise<Object>} The operation with the hash of the transaction.
|
|
10
|
+
*/
|
|
11
|
+
export const broadcast = async ({ signedOperation }) => {
|
|
12
|
+
const { operation, rawData: { unsigned, serializedSignature }, } = signedOperation;
|
|
13
|
+
const hash = await logicBroadcast(unsigned, serializedSignature);
|
|
14
|
+
return patchOperationWithHash(operation, hash);
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=broadcast.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAC5E,OAAO,EAAE,SAAS,IAAI,cAAc,EAAE,MAAM,UAAU,CAAC;AAGvD;;;;;;;GAOG;AACH,MAAM,CAAC,MAAM,SAAS,GAA4C,KAAK,EAAE,EAAE,eAAe,EAAE,EAAE,EAAE;IAC9F,MAAM,EACJ,SAAS,EACT,OAAO,EAAE,EAAE,QAAQ,EAAE,mBAAmB,EAAE,GAC3C,GAAG,eAAgD,CAAC;IACrD,MAAM,IAAI,GAAG,MAAM,cAAc,CAAC,QAAQ,EAAE,mBAAmB,CAAC,CAAC;IACjE,OAAO,sBAAsB,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;AACjD,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.test.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { createFixtureOperation } from "../types/bridge.fixture";
|
|
2
|
+
import { broadcast } from "./broadcast";
|
|
3
|
+
const executeTransactionBlock = jest.fn();
|
|
4
|
+
jest.mock("../network", () => {
|
|
5
|
+
return {
|
|
6
|
+
executeTransactionBlock: (arg) => executeTransactionBlock(arg),
|
|
7
|
+
};
|
|
8
|
+
});
|
|
9
|
+
describe("broadcast", () => {
|
|
10
|
+
it("calls explorer for broadcast operation", async () => {
|
|
11
|
+
// WHEN
|
|
12
|
+
await broadcast({
|
|
13
|
+
account: {},
|
|
14
|
+
signedOperation: {
|
|
15
|
+
signature: "SIGNATURE",
|
|
16
|
+
operation: createFixtureOperation(),
|
|
17
|
+
rawData: {
|
|
18
|
+
serializedSignature: new Uint8Array(64).fill(0x42),
|
|
19
|
+
unsigned: Buffer.from(new Uint8Array(64).fill(0x42)).toString("base64"),
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
});
|
|
23
|
+
// THEN
|
|
24
|
+
expect(executeTransactionBlock).toHaveBeenCalledTimes(1);
|
|
25
|
+
expect(executeTransactionBlock.mock.lastCall[0]).toHaveProperty("signature");
|
|
26
|
+
});
|
|
27
|
+
it("updates the signed operation", async () => {
|
|
28
|
+
// GIVEN
|
|
29
|
+
const operation = createFixtureOperation();
|
|
30
|
+
// WHEN
|
|
31
|
+
const result = await broadcast({
|
|
32
|
+
account: {},
|
|
33
|
+
signedOperation: {
|
|
34
|
+
signature: "SIGNATURE",
|
|
35
|
+
operation,
|
|
36
|
+
rawData: {
|
|
37
|
+
serializedSignature: new Uint8Array(64).fill(0x42),
|
|
38
|
+
unsigned: Buffer.from(new Uint8Array(64).fill(0x42)).toString("base64"),
|
|
39
|
+
},
|
|
40
|
+
},
|
|
41
|
+
});
|
|
42
|
+
// THEN
|
|
43
|
+
expect(result.hash).not.toEqual(operation.hash);
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
//# sourceMappingURL=broadcast.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.test.js","sourceRoot":"","sources":["../../src/bridge/broadcast.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,MAAM,uBAAuB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AAE1C,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,GAAG,EAAE;IAC3B,OAAO;QACL,uBAAuB,EAAE,CAAC,GAAQ,EAAE,EAAE,CAAC,uBAAuB,CAAC,GAAG,CAAC;KACpE,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,OAAO;QACP,MAAM,SAAS,CAAC;YACd,OAAO,EAAE,EAAS;YAClB,eAAe,EAAE;gBACf,SAAS,EAAE,WAAW;gBACtB,SAAS,EAAE,sBAAsB,EAAE;gBACnC,OAAO,EAAE;oBACP,mBAAmB,EAAE,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;oBAClD,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;iBACxE;aACF;SACF,CAAC,CAAC;QAEH,OAAO;QACP,MAAM,CAAC,uBAAuB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACzD,MAAM,CAAC,uBAAuB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;IAC/E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,KAAK,IAAI,EAAE;QAC5C,QAAQ;QACR,MAAM,SAAS,GAAG,sBAAsB,EAAE,CAAC;QAE3C,OAAO;QACP,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC;YAC7B,OAAO,EAAE,EAAS;YAClB,eAAe,EAAE;gBACf,SAAS,EAAE,WAAW;gBACtB,SAAS;gBACT,OAAO,EAAE;oBACP,mBAAmB,EAAE,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;oBAClD,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;iBACxE;aACF;SACF,CAAC,CAAC;QAEH,OAAO;QACP,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAClD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
import { SuiAccount, SuiOperation, Transaction } from "../types";
|
|
3
|
+
export declare const buildOptimisticOperation: (account: SuiAccount, transaction: Transaction, fee: BigNumber) => SuiOperation;
|
|
4
|
+
//# sourceMappingURL=buildOptimisticOperation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildOptimisticOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AAGrC,OAAO,EAEL,UAAU,EACV,YAAY,EAGZ,WAAW,EACZ,MAAM,UAAU,CAAC;AAmBlB,eAAO,MAAM,wBAAwB,YAC1B,UAAU,eACN,WAAW,OACnB,SAAS,KACb,YAoBF,CAAC"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
import { encodeOperationId } from "@ledgerhq/coin-framework/operation";
|
|
3
|
+
import { assertUnreachable } from "./utils";
|
|
4
|
+
const MODE_TO_TYPE = {
|
|
5
|
+
send: "OUT",
|
|
6
|
+
default: "OUT",
|
|
7
|
+
};
|
|
8
|
+
const getExtra = (type, transaction) => {
|
|
9
|
+
const extra = {};
|
|
10
|
+
switch (type) {
|
|
11
|
+
case "OUT":
|
|
12
|
+
return { ...extra, transferAmount: new BigNumber(transaction.amount) };
|
|
13
|
+
}
|
|
14
|
+
return extra;
|
|
15
|
+
};
|
|
16
|
+
export const buildOptimisticOperation = (account, transaction, fee) => {
|
|
17
|
+
const commandDescriptor = {
|
|
18
|
+
command: {
|
|
19
|
+
kind: "transfer",
|
|
20
|
+
sender: account.freshAddress,
|
|
21
|
+
recipient: transaction.recipient,
|
|
22
|
+
amount: transaction.amount.toNumber(),
|
|
23
|
+
},
|
|
24
|
+
fee: fee.toNumber(),
|
|
25
|
+
warnings: {},
|
|
26
|
+
errors: {},
|
|
27
|
+
};
|
|
28
|
+
const optimisticOperation = buildOptimisticOperationForCommand(account, transaction, commandDescriptor);
|
|
29
|
+
return optimisticOperation;
|
|
30
|
+
};
|
|
31
|
+
function buildOptimisticOperationForCommand(account, transaction, commandDescriptor) {
|
|
32
|
+
const { command } = commandDescriptor;
|
|
33
|
+
switch (command.kind) {
|
|
34
|
+
case "transfer":
|
|
35
|
+
return optimisticOpForTransfer(account, transaction, commandDescriptor);
|
|
36
|
+
default:
|
|
37
|
+
// @ts-expect-error Seem like a bug in TS, remove once more commands are added
|
|
38
|
+
return assertUnreachable(command);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
function optimisticOpForTransfer(account, transaction, commandDescriptor) {
|
|
42
|
+
const type = MODE_TO_TYPE.default;
|
|
43
|
+
const value = type === "OUT"
|
|
44
|
+
? new BigNumber(transaction.amount).plus(commandDescriptor.fee)
|
|
45
|
+
: new BigNumber(commandDescriptor.fee);
|
|
46
|
+
const extra = getExtra(type, transaction);
|
|
47
|
+
const commons = optimisticOpcommons(commandDescriptor);
|
|
48
|
+
return {
|
|
49
|
+
...commons,
|
|
50
|
+
id: encodeOperationId(account.id, "", type),
|
|
51
|
+
type,
|
|
52
|
+
value,
|
|
53
|
+
senders: [account.freshAddress],
|
|
54
|
+
recipients: [transaction.recipient].filter(Boolean),
|
|
55
|
+
accountId: account.id,
|
|
56
|
+
date: new Date(),
|
|
57
|
+
extra,
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
function optimisticOpcommons(commandDescriptor) {
|
|
61
|
+
return {
|
|
62
|
+
hash: "",
|
|
63
|
+
fee: new BigNumber(commandDescriptor.fee),
|
|
64
|
+
blockHash: null,
|
|
65
|
+
blockHeight: null,
|
|
66
|
+
extra: {},
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
//# sourceMappingURL=buildOptimisticOperation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildOptimisticOperation.js","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildOptimisticOperation.test.d.ts","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
import { createFixtureAccount, createFixtureTransaction } from "../types/bridge.fixture";
|
|
3
|
+
import { buildOptimisticOperation } from "./buildOptimisticOperation";
|
|
4
|
+
describe("buildOptimisticOperation", () => {
|
|
5
|
+
it("should build optimistic operation for transfer", () => {
|
|
6
|
+
// GIVEN
|
|
7
|
+
const account = createFixtureAccount();
|
|
8
|
+
const transaction = createFixtureTransaction();
|
|
9
|
+
const fee = new BigNumber(10);
|
|
10
|
+
// WHEN
|
|
11
|
+
const result = buildOptimisticOperation(account, transaction, fee);
|
|
12
|
+
// THEN
|
|
13
|
+
expect(result).toEqual({
|
|
14
|
+
id: "js:2:sui:0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0:sui--OUT",
|
|
15
|
+
hash: "",
|
|
16
|
+
type: "OUT",
|
|
17
|
+
value: transaction.amount.plus(fee), // amount + fee
|
|
18
|
+
fee: new BigNumber(10),
|
|
19
|
+
senders: ["0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0"],
|
|
20
|
+
recipients: ["0x65449f57946938c84c512732f1d69405d1fce417d9c9894696ddf4522f479e24"],
|
|
21
|
+
accountId: "js:2:sui:0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0:sui",
|
|
22
|
+
date: expect.any(Date),
|
|
23
|
+
blockHash: null,
|
|
24
|
+
blockHeight: null,
|
|
25
|
+
extra: {
|
|
26
|
+
transferAmount: new BigNumber(3000000000),
|
|
27
|
+
},
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
it("should calculate correct value for OUT type", () => {
|
|
31
|
+
// GIVEN
|
|
32
|
+
const account = createFixtureAccount();
|
|
33
|
+
const transaction = createFixtureTransaction();
|
|
34
|
+
const amount = new BigNumber(500);
|
|
35
|
+
const fee = new BigNumber(50);
|
|
36
|
+
const tx = {
|
|
37
|
+
...transaction,
|
|
38
|
+
amount,
|
|
39
|
+
};
|
|
40
|
+
// WHEN
|
|
41
|
+
const result = buildOptimisticOperation(account, tx, fee);
|
|
42
|
+
// THEN
|
|
43
|
+
expect(result.value).toEqual(amount.plus(fee));
|
|
44
|
+
expect(result.fee).toEqual(fee);
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
//# sourceMappingURL=buildOptimisticOperation.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildOptimisticOperation.test.js","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.test.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,oBAAoB,EAAE,wBAAwB,EAAE,MAAM,yBAAyB,CAAC;AACzF,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AAGtE,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;IACxC,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;QACxD,QAAQ;QACR,MAAM,OAAO,GAAe,oBAAoB,EAAE,CAAC;QACnD,MAAM,WAAW,GAAgB,wBAAwB,EAAE,CAAC;QAC5D,MAAM,GAAG,GAAG,IAAI,SAAS,CAAC,EAAE,CAAC,CAAC;QAE9B,OAAO;QACP,MAAM,MAAM,GAAG,wBAAwB,CAAC,OAAO,EAAE,WAAW,EAAE,GAAG,CAAC,CAAC;QAEnE,OAAO;QACP,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACrB,EAAE,EAAE,sFAAsF;YAC1F,IAAI,EAAE,EAAE;YACR,IAAI,EAAE,KAAK;YACX,KAAK,EAAE,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,eAAe;YACpD,GAAG,EAAE,IAAI,SAAS,CAAC,EAAE,CAAC;YACtB,OAAO,EAAE,CAAC,oEAAoE,CAAC;YAC/E,UAAU,EAAE,CAAC,oEAAoE,CAAC;YAClF,SAAS,EAAE,iFAAiF;YAC5F,IAAI,EAAE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC;YACtB,SAAS,EAAE,IAAI;YACf,WAAW,EAAE,IAAI;YACjB,KAAK,EAAE;gBACL,cAAc,EAAE,IAAI,SAAS,CAAC,UAAU,CAAC;aAC1C;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,QAAQ;QACR,MAAM,OAAO,GAAe,oBAAoB,EAAE,CAAC;QACnD,MAAM,WAAW,GAAgB,wBAAwB,EAAE,CAAC;QAC5D,MAAM,MAAM,GAAG,IAAI,SAAS,CAAC,GAAG,CAAC,CAAC;QAClC,MAAM,GAAG,GAAG,IAAI,SAAS,CAAC,EAAE,CAAC,CAAC;QAC9B,MAAM,EAAE,GAAG;YACT,GAAG,WAAW;YACd,MAAM;SACP,CAAC;QAEF,OAAO;QACP,MAAM,MAAM,GAAG,wBAAwB,CAAC,OAAO,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC;QAE1D,OAAO;QACP,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;QAC/C,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { SuiAccount, Transaction } from "../types";
|
|
2
|
+
import { type CreateExtrinsicArg } from "../logic";
|
|
3
|
+
export declare const extractExtrinsicArg: (transaction: Transaction) => CreateExtrinsicArg;
|
|
4
|
+
/**
|
|
5
|
+
* @param {Account} account
|
|
6
|
+
* @param {Transaction} transaction
|
|
7
|
+
*/
|
|
8
|
+
export declare const buildTransaction: (account: SuiAccount, transaction: Transaction) => Promise<import("../types").CoreTransaction>;
|
|
9
|
+
//# sourceMappingURL=buildTransaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/buildTransaction.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACxD,OAAO,EAAoB,KAAK,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAErE,eAAO,MAAM,mBAAmB,gBAAiB,WAAW,KAAG,kBACK,CAAC;AAErE;;;GAGG;AACH,eAAO,MAAM,gBAAgB,YAAmB,UAAU,eAAe,WAAW,gDAEnF,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import pick from "lodash/pick";
|
|
2
|
+
import { craftTransaction } from "../logic";
|
|
3
|
+
export const extractExtrinsicArg = (transaction) => pick(transaction, ["mode", "amount", "recipient", "useAllAmount"]);
|
|
4
|
+
/**
|
|
5
|
+
* @param {Account} account
|
|
6
|
+
* @param {Transaction} transaction
|
|
7
|
+
*/
|
|
8
|
+
export const buildTransaction = async (account, transaction) => {
|
|
9
|
+
return craftTransaction(account.freshAddress, extractExtrinsicArg(transaction));
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=buildTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildTransaction.js","sourceRoot":"","sources":["../../src/bridge/buildTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,aAAa,CAAC;AAE/B,OAAO,EAAE,gBAAgB,EAA2B,MAAM,UAAU,CAAC;AAErE,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,WAAwB,EAAsB,EAAE,CAClF,IAAI,CAAC,WAAW,EAAE,CAAC,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,cAAc,CAAC,CAAC,CAAC;AAErE;;;GAGG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EAAE,OAAmB,EAAE,WAAwB,EAAE,EAAE;IACtF,OAAO,gBAAgB,CAAC,OAAO,CAAC,YAAY,EAAE,mBAAmB,CAAC,WAAW,CAAC,CAAC,CAAC;AAClF,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildTransaction.test.d.ts","sourceRoot":"","sources":["../../src/bridge/buildTransaction.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { buildTransaction } from "./buildTransaction";
|
|
2
|
+
import { createFixtureAccount, createFixtureTransaction } from "../types/bridge.fixture";
|
|
3
|
+
describe("buildTransaction", () => {
|
|
4
|
+
it("returns unsigned tx bytes for given tx", async () => {
|
|
5
|
+
// GIVEN
|
|
6
|
+
const account = createFixtureAccount();
|
|
7
|
+
const transaction = createFixtureTransaction();
|
|
8
|
+
// WHEN
|
|
9
|
+
const result = await buildTransaction(account, transaction);
|
|
10
|
+
// THEN
|
|
11
|
+
expect(result).not.toBeNull();
|
|
12
|
+
expect(result.unsigned).toBeInstanceOf(Uint8Array);
|
|
13
|
+
});
|
|
14
|
+
});
|
|
15
|
+
//# sourceMappingURL=buildTransaction.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildTransaction.test.js","sourceRoot":"","sources":["../../src/bridge/buildTransaction.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,wBAAwB,EAAE,MAAM,yBAAyB,CAAC;AAEzF,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,QAAQ;QACR,MAAM,OAAO,GAAG,oBAAoB,EAAE,CAAC;QACvC,MAAM,WAAW,GAAG,wBAAwB,EAAE,CAAC;QAE/C,OAAO;QACP,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAE5D,OAAO;QACP,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QAC9B,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Transaction } from "../types";
|
|
2
|
+
import { AccountBridge } from "@ledgerhq/types-live";
|
|
3
|
+
/**
|
|
4
|
+
* Create an empty transaction
|
|
5
|
+
*
|
|
6
|
+
* @returns {Transaction}
|
|
7
|
+
*/
|
|
8
|
+
export declare const createTransaction: AccountBridge<Transaction>["createTransaction"];
|
|
9
|
+
export default createTransaction;
|
|
10
|
+
//# sourceMappingURL=createTransaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD;;;;GAIG;AACH,eAAO,MAAM,iBAAiB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,mBAAmB,CAW7E,CAAC;AAEF,eAAe,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { BigNumber } from "bignumber.js";
|
|
2
|
+
/**
|
|
3
|
+
* Create an empty transaction
|
|
4
|
+
*
|
|
5
|
+
* @returns {Transaction}
|
|
6
|
+
*/
|
|
7
|
+
export const createTransaction = () => {
|
|
8
|
+
const transaction = {
|
|
9
|
+
family: "sui",
|
|
10
|
+
mode: "send",
|
|
11
|
+
amount: new BigNumber(0),
|
|
12
|
+
recipient: "",
|
|
13
|
+
useAllAmount: false,
|
|
14
|
+
fees: null,
|
|
15
|
+
errors: {},
|
|
16
|
+
};
|
|
17
|
+
return transaction;
|
|
18
|
+
};
|
|
19
|
+
export default createTransaction;
|
|
20
|
+
//# sourceMappingURL=createTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createTransaction.js","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAIzC;;;;GAIG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAoD,GAAG,EAAE;IACrF,MAAM,WAAW,GAAgB;QAC/B,MAAM,EAAE,KAAc;QACtB,IAAI,EAAE,MAAM;QACZ,MAAM,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC;QACxB,SAAS,EAAE,EAAE;QACb,YAAY,EAAE,KAAK;QACnB,IAAI,EAAE,IAAI;QACV,MAAM,EAAE,EAAE;KACX,CAAC;IACF,OAAO,WAAW,CAAC;AACrB,CAAC,CAAC;AAEF,eAAe,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { AccountBridge } from "@ledgerhq/types-live";
|
|
2
|
+
import type { Transaction } from "../types";
|
|
3
|
+
/**
|
|
4
|
+
* Returns the maximum possible amount for transaction
|
|
5
|
+
* @typedef {Object} EstimateMaxSpendableParams
|
|
6
|
+
* @property {SuiAccount} account - The account from which to estimate the maximum spendable amount.
|
|
7
|
+
* @property {SuiAccount} [parentAccount] - The parent account, if applicable.
|
|
8
|
+
* @property {Transaction} transaction - The transaction details for which to estimate the maximum spendable amount.
|
|
9
|
+
*
|
|
10
|
+
* @returns {Promise<BigNumber>} The estimated maximum spendable amount.
|
|
11
|
+
*/
|
|
12
|
+
export declare const estimateMaxSpendable: AccountBridge<Transaction>["estimateMaxSpendable"];
|
|
13
|
+
export default estimateMaxSpendable;
|
|
14
|
+
//# sourceMappingURL=estimateMaxSpendable.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estimateMaxSpendable.d.ts","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAE1D,OAAO,KAAK,EAAc,WAAW,EAAE,MAAM,UAAU,CAAC;AAKxD;;;;;;;;GAQG;AACH,eAAO,MAAM,oBAAoB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,sBAAsB,CA2BnF,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { getMainAccount } from "@ledgerhq/coin-framework/account/index";
|
|
2
|
+
import getFeesForTransaction from "./getFeesForTransaction";
|
|
3
|
+
import createTransaction from "./createTransaction";
|
|
4
|
+
import { BigNumber } from "bignumber.js";
|
|
5
|
+
/**
|
|
6
|
+
* Returns the maximum possible amount for transaction
|
|
7
|
+
* @typedef {Object} EstimateMaxSpendableParams
|
|
8
|
+
* @property {SuiAccount} account - The account from which to estimate the maximum spendable amount.
|
|
9
|
+
* @property {SuiAccount} [parentAccount] - The parent account, if applicable.
|
|
10
|
+
* @property {Transaction} transaction - The transaction details for which to estimate the maximum spendable amount.
|
|
11
|
+
*
|
|
12
|
+
* @returns {Promise<BigNumber>} The estimated maximum spendable amount.
|
|
13
|
+
*/
|
|
14
|
+
export const estimateMaxSpendable = async ({ account, parentAccount, transaction, }) => {
|
|
15
|
+
try {
|
|
16
|
+
const mainAccount = getMainAccount(account, parentAccount);
|
|
17
|
+
const estimatedTransaction = {
|
|
18
|
+
...createTransaction(account),
|
|
19
|
+
...transaction,
|
|
20
|
+
useAllAmount: true,
|
|
21
|
+
};
|
|
22
|
+
const fees = await getFeesForTransaction({
|
|
23
|
+
account: mainAccount,
|
|
24
|
+
transaction: estimatedTransaction,
|
|
25
|
+
});
|
|
26
|
+
let spendableBalance = mainAccount.spendableBalance;
|
|
27
|
+
if (fees) {
|
|
28
|
+
spendableBalance = BigNumber.max(spendableBalance.minus(fees), 0);
|
|
29
|
+
}
|
|
30
|
+
return spendableBalance;
|
|
31
|
+
}
|
|
32
|
+
catch (e) {
|
|
33
|
+
return new BigNumber(0);
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
export default estimateMaxSpendable;
|
|
37
|
+
//# sourceMappingURL=estimateMaxSpendable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estimateMaxSpendable.js","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,wCAAwC,CAAC;AAExE,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC;;;;;;;;GAQG;AACH,MAAM,CAAC,MAAM,oBAAoB,GAAuD,KAAK,EAAE,EAC7F,OAAO,EACP,aAAa,EACb,WAAW,GACZ,EAAE,EAAE;IACH,IAAI,CAAC;QACH,MAAM,WAAW,GAAG,cAAc,CAAC,OAAO,EAAE,aAAa,CAAe,CAAC;QAEzE,MAAM,oBAAoB,GAAG;YAC3B,GAAG,iBAAiB,CAAC,OAAO,CAAC;YAC7B,GAAG,WAAW;YACd,YAAY,EAAE,IAAI;SACnB,CAAC;QACF,MAAM,IAAI,GAAG,MAAM,qBAAqB,CAAC;YACvC,OAAO,EAAE,WAAW;YACpB,WAAW,EAAE,oBAAoB;SAClC,CAAC,CAAC;QAEH,IAAI,gBAAgB,GAAG,WAAW,CAAC,gBAAgB,CAAC;QACpD,IAAI,IAAI,EAAE,CAAC;YACT,gBAAgB,GAAG,SAAS,CAAC,GAAG,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QACpE,CAAC;QAED,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;AACH,CAAC,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estimateMaxSpendable.test.d.ts","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { BigNumber } from "bignumber.js";
|
|
2
|
+
import { estimateMaxSpendable } from "./estimateMaxSpendable";
|
|
3
|
+
import { createFixtureAccount, createFixtureTransaction } from "../types/bridge.fixture";
|
|
4
|
+
const mockEstimateFees = jest.fn();
|
|
5
|
+
jest.mock("../logic", () => ({
|
|
6
|
+
estimateFees: () => mockEstimateFees(),
|
|
7
|
+
}));
|
|
8
|
+
describe("estimateMaxSpendable", () => {
|
|
9
|
+
it("should return the correct spendable amount when fees are deducted", async () => {
|
|
10
|
+
// GIVEN
|
|
11
|
+
const balance = new BigNumber(100);
|
|
12
|
+
const account = createFixtureAccount({ spendableBalance: balance });
|
|
13
|
+
const transaction = createFixtureTransaction();
|
|
14
|
+
const fees = new BigNumber(10);
|
|
15
|
+
mockEstimateFees.mockResolvedValue(fees);
|
|
16
|
+
// WHEN
|
|
17
|
+
const result = await estimateMaxSpendable({ account, transaction });
|
|
18
|
+
// THEN
|
|
19
|
+
expect(mockEstimateFees).toHaveBeenCalledTimes(1);
|
|
20
|
+
expect(result).toEqual(balance.minus(fees));
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
//# sourceMappingURL=estimateMaxSpendable.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estimateMaxSpendable.test.js","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,oBAAoB,EAAE,wBAAwB,EAAE,MAAM,yBAAyB,CAAC;AAGzF,MAAM,gBAAgB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AACnC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,CAAC;IAC3B,YAAY,EAAE,GAAG,EAAE,CAAC,gBAAgB,EAAE;CACvC,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,EAAE,CAAC,mEAAmE,EAAE,KAAK,IAAI,EAAE;QACjF,QAAQ;QACR,MAAM,OAAO,GAAG,IAAI,SAAS,CAAC,GAAG,CAAC,CAAC;QACnC,MAAM,OAAO,GAAe,oBAAoB,CAAC,EAAE,gBAAgB,EAAE,OAAO,EAAE,CAAC,CAAC;QAChF,MAAM,WAAW,GAAgB,wBAAwB,EAAE,CAAC;QAC5D,MAAM,IAAI,GAAG,IAAI,SAAS,CAAC,EAAE,CAAC,CAAC;QAC/B,gBAAgB,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAEzC,OAAO;QACP,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,EAAE,OAAO,EAAE,WAAW,EAAE,CAAC,CAAC;QAEpE,OAAO;QACP,MAAM,CAAC,gBAAgB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { OperationExtra, OperationExtraRaw } from "@ledgerhq/types-live";
|
|
2
|
+
import type { SuiOperationExtra, SuiOperationExtraRaw } from "../types";
|
|
3
|
+
export declare function fromOperationExtraRaw(extraRaw: OperationExtraRaw): SuiOperationExtra;
|
|
4
|
+
export declare function toOperationExtraRaw(extra: OperationExtra): SuiOperationExtraRaw;
|
|
5
|
+
declare const _default: {
|
|
6
|
+
fromOperationExtraRaw: typeof fromOperationExtraRaw;
|
|
7
|
+
toOperationExtraRaw: typeof toOperationExtraRaw;
|
|
8
|
+
};
|
|
9
|
+
export default _default;
|
|
10
|
+
//# sourceMappingURL=formatters.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"formatters.d.ts","sourceRoot":"","sources":["../../src/bridge/formatters.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzE,OAAO,KAAK,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,MAAM,UAAU,CAAC;AAExE,wBAAgB,qBAAqB,CAAC,QAAQ,EAAE,iBAAiB,qBAQhE;AAED,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,cAAc,wBAOxD;;;;;AAED,wBAGE"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export function fromOperationExtraRaw(extraRaw) {
|
|
2
|
+
if (extraRaw) {
|
|
3
|
+
// reserved for future use
|
|
4
|
+
}
|
|
5
|
+
const extra = {};
|
|
6
|
+
return extra;
|
|
7
|
+
}
|
|
8
|
+
export function toOperationExtraRaw(extra) {
|
|
9
|
+
if (extra) {
|
|
10
|
+
// reserved for future use
|
|
11
|
+
}
|
|
12
|
+
const extraRaw = {};
|
|
13
|
+
return extraRaw;
|
|
14
|
+
}
|
|
15
|
+
export default {
|
|
16
|
+
fromOperationExtraRaw,
|
|
17
|
+
toOperationExtraRaw,
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=formatters.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"formatters.js","sourceRoot":"","sources":["../../src/bridge/formatters.ts"],"names":[],"mappings":"AAGA,MAAM,UAAU,qBAAqB,CAAC,QAA2B;IAC/D,IAAI,QAAQ,EAAE,CAAC;QACb,0BAA0B;IAC5B,CAAC;IAED,MAAM,KAAK,GAAsB,EAAE,CAAC;IAEpC,OAAO,KAAK,CAAC;AACf,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,KAAqB;IACvD,IAAI,KAAK,EAAE,CAAC;QACV,0BAA0B;IAC5B,CAAC;IACD,MAAM,QAAQ,GAAyB,EAAE,CAAC;IAE1C,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,eAAe;IACb,qBAAqB;IACrB,mBAAmB;CACpB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"formatters.test.d.ts","sourceRoot":"","sources":["../../src/bridge/formatters.test.ts"],"names":[],"mappings":""}
|