@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,126 @@
|
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
import { toSuiResourcesRaw, fromSuiResourcesRaw, assignToAccountRaw, assignFromAccountRaw, } from "./serialization";
|
|
3
|
+
const account = {
|
|
4
|
+
type: "Account",
|
|
5
|
+
id: "js:2:sui:0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0:sui",
|
|
6
|
+
used: true,
|
|
7
|
+
seedIdentifier: "99807c4b6e1b8b25120f633f5f7816a393e4d3e7f84bdf24bd8afe725911be91",
|
|
8
|
+
derivationMode: "sui",
|
|
9
|
+
index: 0,
|
|
10
|
+
freshAddress: "0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0",
|
|
11
|
+
freshAddressPath: "44'/784'/0'/0'/0'",
|
|
12
|
+
blockHeight: 10,
|
|
13
|
+
creationDate: new Date(),
|
|
14
|
+
balance: BigNumber(9998990120),
|
|
15
|
+
spendableBalance: BigNumber(9998990120),
|
|
16
|
+
operations: [
|
|
17
|
+
{
|
|
18
|
+
id: "js:2:sui:0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0:sui-DhKLpX5kwuKuyRa71RGqpX5EY2M8Efw535ZVXYXsRiDt-IN",
|
|
19
|
+
hash: "DhKLpX5kwuKuyRa71RGqpX5EY2M8Efw535ZVXYXsRiDt",
|
|
20
|
+
type: "IN",
|
|
21
|
+
senders: ["0x65449f57946938c84c512732f1d69405d1fce417d9c9894696ddf4522f479e24"],
|
|
22
|
+
recipients: ["0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0"],
|
|
23
|
+
accountId: "js:2:sui:0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0:sui",
|
|
24
|
+
blockHash: "DhKLpX5kwuKuyRa71RGqpX5EY2M8Efw535ZVXYXsRiDt",
|
|
25
|
+
blockHeight: 5,
|
|
26
|
+
date: new Date(),
|
|
27
|
+
value: BigNumber(9998990120),
|
|
28
|
+
fee: BigNumber(1009880),
|
|
29
|
+
extra: {},
|
|
30
|
+
hasFailed: false,
|
|
31
|
+
},
|
|
32
|
+
],
|
|
33
|
+
operationsCount: 1,
|
|
34
|
+
pendingOperations: [],
|
|
35
|
+
currency: {
|
|
36
|
+
type: "CryptoCurrency",
|
|
37
|
+
id: "sui",
|
|
38
|
+
coinType: 784,
|
|
39
|
+
name: "Sui",
|
|
40
|
+
managerAppName: "Sui",
|
|
41
|
+
ticker: "SUI",
|
|
42
|
+
scheme: "sui",
|
|
43
|
+
color: "#000",
|
|
44
|
+
family: "sui",
|
|
45
|
+
units: [{ name: "Sui", code: "SUI", magnitude: 9 }],
|
|
46
|
+
explorerViews: [
|
|
47
|
+
{
|
|
48
|
+
tx: "https://suiscan.xyz/mainnet/tx/$hash",
|
|
49
|
+
address: "https://suiscan.xyz/mainnet/account/$address",
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
tx: "https://suivision.xyz/txblock/$hash",
|
|
53
|
+
address: "https://suivision.xyz/account/$address",
|
|
54
|
+
},
|
|
55
|
+
],
|
|
56
|
+
},
|
|
57
|
+
lastSyncDate: new Date(),
|
|
58
|
+
swapHistory: [],
|
|
59
|
+
balanceHistoryCache: {
|
|
60
|
+
HOUR: { balances: [0, 9998990120, 9998990120, 9998990120], latestDate: 1742302800000 },
|
|
61
|
+
DAY: { balances: [0], latestDate: 1742245200000 },
|
|
62
|
+
WEEK: { balances: [0], latestDate: 1742072400000 },
|
|
63
|
+
},
|
|
64
|
+
suiResources: {},
|
|
65
|
+
};
|
|
66
|
+
const accountRaw = {
|
|
67
|
+
id: "js:2:sui:0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0:sui",
|
|
68
|
+
seedIdentifier: "99807c4b6e1b8b25120f633f5f7816a393e4d3e7f84bdf24bd8afe725911be91",
|
|
69
|
+
used: true,
|
|
70
|
+
derivationMode: "sui",
|
|
71
|
+
index: 0,
|
|
72
|
+
freshAddress: "0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0",
|
|
73
|
+
freshAddressPath: "44'/784'/0'/0'/0'",
|
|
74
|
+
blockHeight: 10,
|
|
75
|
+
creationDate: "2025-03-18T10:40:54.878Z",
|
|
76
|
+
operationsCount: 1,
|
|
77
|
+
operations: [
|
|
78
|
+
{
|
|
79
|
+
id: "js:2:sui:0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0:sui-DhKLpX5kwuKuyRa71RGqpX5EY2M8Efw535ZVXYXsRiDt-IN",
|
|
80
|
+
hash: "DhKLpX5kwuKuyRa71RGqpX5EY2M8Efw535ZVXYXsRiDt",
|
|
81
|
+
type: "IN",
|
|
82
|
+
senders: ["0x65449f57946938c84c512732f1d69405d1fce417d9c9894696ddf4522f479e24"],
|
|
83
|
+
recipients: ["0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0"],
|
|
84
|
+
accountId: "js:2:sui:0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0:sui",
|
|
85
|
+
blockHash: "DhKLpX5kwuKuyRa71RGqpX5EY2M8Efw535ZVXYXsRiDt",
|
|
86
|
+
blockHeight: 5,
|
|
87
|
+
extra: {},
|
|
88
|
+
date: "2025-03-18T10:40:54.878Z",
|
|
89
|
+
value: "9998990120",
|
|
90
|
+
fee: "1009880",
|
|
91
|
+
hasFailed: false,
|
|
92
|
+
},
|
|
93
|
+
],
|
|
94
|
+
pendingOperations: [],
|
|
95
|
+
currencyId: "sui",
|
|
96
|
+
lastSyncDate: "2025-03-18T10:40:54.878Z",
|
|
97
|
+
balance: "9998990120",
|
|
98
|
+
spendableBalance: "9998990120",
|
|
99
|
+
balanceHistoryCache: {
|
|
100
|
+
HOUR: { balances: [0, 9998990120, 9998990120, 9998990120], latestDate: 1742302800000 },
|
|
101
|
+
DAY: { balances: [0], latestDate: 1742245200000 },
|
|
102
|
+
WEEK: { balances: [0], latestDate: 1742072400000 },
|
|
103
|
+
},
|
|
104
|
+
suiResources: {},
|
|
105
|
+
};
|
|
106
|
+
describe("serialization", () => {
|
|
107
|
+
test("toSuiResourcesRaw should convert SuiResources to SuiResourcesRaw", () => {
|
|
108
|
+
const resources = {};
|
|
109
|
+
const result = toSuiResourcesRaw(resources);
|
|
110
|
+
expect(result).toEqual({});
|
|
111
|
+
});
|
|
112
|
+
test("fromSuiResourcesRaw should convert SuiResourcesRaw to SuiResources", () => {
|
|
113
|
+
const resourcesRaw = {};
|
|
114
|
+
const result = fromSuiResourcesRaw(resourcesRaw);
|
|
115
|
+
expect(result).toEqual({});
|
|
116
|
+
});
|
|
117
|
+
test("assignToAccountRaw should assign SuiResources to AccountRaw", () => {
|
|
118
|
+
assignToAccountRaw(account, accountRaw);
|
|
119
|
+
expect(accountRaw.suiResources).toBeDefined();
|
|
120
|
+
});
|
|
121
|
+
test("assignFromAccountRaw should assign SuiResourcesRaw to Account", () => {
|
|
122
|
+
assignFromAccountRaw(accountRaw, account);
|
|
123
|
+
expect(account.suiResources).toBeDefined();
|
|
124
|
+
});
|
|
125
|
+
});
|
|
126
|
+
//# sourceMappingURL=serialization.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serialization.test.js","sourceRoot":"","sources":["../../src/bridge/serialization.test.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EACL,iBAAiB,EACjB,mBAAmB,EACnB,kBAAkB,EAClB,oBAAoB,GACrB,MAAM,iBAAiB,CAAC;AAEzB,MAAM,OAAO,GAAG;IACd,IAAI,EAAE,SAAkB;IACxB,EAAE,EAAE,iFAAiF;IACrF,IAAI,EAAE,IAAI;IACV,cAAc,EAAE,kEAAkE;IAClF,cAAc,EAAE,KAAc;IAC9B,KAAK,EAAE,CAAC;IACR,YAAY,EAAE,oEAAoE;IAClF,gBAAgB,EAAE,mBAAmB;IACrC,WAAW,EAAE,EAAE;IACf,YAAY,EAAE,IAAI,IAAI,EAAE;IACxB,OAAO,EAAE,SAAS,CAAC,UAAU,CAAC;IAC9B,gBAAgB,EAAE,SAAS,CAAC,UAAU,CAAC;IACvC,UAAU,EAAE;QACV;YACE,EAAE,EAAE,iIAAiI;YACrI,IAAI,EAAE,8CAA8C;YACpD,IAAI,EAAE,IAAa;YACnB,OAAO,EAAE,CAAC,oEAAoE,CAAC;YAC/E,UAAU,EAAE,CAAC,oEAAoE,CAAC;YAClF,SAAS,EAAE,iFAAiF;YAC5F,SAAS,EAAE,8CAA8C;YACzD,WAAW,EAAE,CAAC;YACd,IAAI,EAAE,IAAI,IAAI,EAAE;YAChB,KAAK,EAAE,SAAS,CAAC,UAAU,CAAC;YAC5B,GAAG,EAAE,SAAS,CAAC,OAAO,CAAC;YACvB,KAAK,EAAE,EAAE;YACT,SAAS,EAAE,KAAK;SACjB;KACF;IACD,eAAe,EAAE,CAAC;IAClB,iBAAiB,EAAE,EAAE;IACrB,QAAQ,EAAE;QACR,IAAI,EAAE,gBAAyB;QAC/B,EAAE,EAAE,KAAc;QAClB,QAAQ,EAAE,GAAG;QACb,IAAI,EAAE,KAAK;QACX,cAAc,EAAE,KAAK;QACrB,MAAM,EAAE,KAAK;QACb,MAAM,EAAE,KAAK;QACb,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,KAAK;QACb,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,EAAE,CAAC;QACnD,aAAa,EAAE;YACb;gBACE,EAAE,EAAE,sCAAsC;gBAC1C,OAAO,EAAE,8CAA8C;aACxD;YACD;gBACE,EAAE,EAAE,qCAAqC;gBACzC,OAAO,EAAE,wCAAwC;aAClD;SACF;KACF;IACD,YAAY,EAAE,IAAI,IAAI,EAAE;IACxB,WAAW,EAAE,EAAE;IACf,mBAAmB,EAAE;QACnB,IAAI,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,CAAC,EAAE,UAAU,EAAE,aAAa,EAAE;QACtF,GAAG,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,aAAa,EAAE;QACjD,IAAI,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,aAAa,EAAE;KACnD;IACD,YAAY,EAAE,EAAE;CACjB,CAAC;AACF,MAAM,UAAU,GAAG;IACjB,EAAE,EAAE,iFAAiF;IACrF,cAAc,EAAE,kEAAkE;IAClF,IAAI,EAAE,IAAI;IACV,cAAc,EAAE,KAAc;IAC9B,KAAK,EAAE,CAAC;IACR,YAAY,EAAE,oEAAoE;IAClF,gBAAgB,EAAE,mBAAmB;IACrC,WAAW,EAAE,EAAE;IACf,YAAY,EAAE,0BAA0B;IACxC,eAAe,EAAE,CAAC;IAClB,UAAU,EAAE;QACV;YACE,EAAE,EAAE,iIAAiI;YACrI,IAAI,EAAE,8CAA8C;YACpD,IAAI,EAAE,IAAa;YACnB,OAAO,EAAE,CAAC,oEAAoE,CAAC;YAC/E,UAAU,EAAE,CAAC,oEAAoE,CAAC;YAClF,SAAS,EAAE,iFAAiF;YAC5F,SAAS,EAAE,8CAA8C;YACzD,WAAW,EAAE,CAAC;YACd,KAAK,EAAE,EAAE;YACT,IAAI,EAAE,0BAA0B;YAChC,KAAK,EAAE,YAAY;YACnB,GAAG,EAAE,SAAS;YACd,SAAS,EAAE,KAAK;SACjB;KACF;IACD,iBAAiB,EAAE,EAAE;IACrB,UAAU,EAAE,KAAK;IACjB,YAAY,EAAE,0BAA0B;IACxC,OAAO,EAAE,YAAY;IACrB,gBAAgB,EAAE,YAAY;IAC9B,mBAAmB,EAAE;QACnB,IAAI,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,CAAC,EAAE,UAAU,EAAE,aAAa,EAAE;QACtF,GAAG,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,aAAa,EAAE;QACjD,IAAI,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,aAAa,EAAE;KACnD;IACD,YAAY,EAAE,EAAE;CACjB,CAAC;AAEF,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,IAAI,CAAC,kEAAkE,EAAE,GAAG,EAAE;QAC5E,MAAM,SAAS,GAAG,EAAE,CAAC;QACrB,MAAM,MAAM,GAAG,iBAAiB,CAAC,SAAS,CAAC,CAAC;QAC5C,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,oEAAoE,EAAE,GAAG,EAAE;QAC9E,MAAM,YAAY,GAAG,EAAE,CAAC;QACxB,MAAM,MAAM,GAAG,mBAAmB,CAAC,YAAY,CAAC,CAAC;QACjD,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,6DAA6D,EAAE,GAAG,EAAE;QACvE,kBAAkB,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;QACxC,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,WAAW,EAAE,CAAC;IAChD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,+DAA+D,EAAE,GAAG,EAAE;QACzE,oBAAoB,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QAC1C,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,WAAW,EAAE,CAAC;IAC7C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { SignerContext } from "@ledgerhq/coin-framework/signer";
|
|
2
|
+
import type { AccountBridge } from "@ledgerhq/types-live";
|
|
3
|
+
import type { SuiAccount, SuiSigner, Transaction } from "../types";
|
|
4
|
+
/**
|
|
5
|
+
* Sign Transaction with Ledger hardware
|
|
6
|
+
*/
|
|
7
|
+
export declare const buildSignOperation: (signerContext: SignerContext<SuiSigner>) => AccountBridge<Transaction, SuiAccount>["signOperation"];
|
|
8
|
+
export default buildSignOperation;
|
|
9
|
+
//# sourceMappingURL=signOperation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAEhE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAO1D,OAAO,KAAK,EAAsB,UAAU,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAGvF;;GAEG;AACH,eAAO,MAAM,kBAAkB,kBAEZ,cAAc,SAAS,CAAC,KACtC,cAAc,WAAW,EAAE,UAAU,CAAC,CAAC,eAAe,CA8ErD,CAAC;AAEP,eAAe,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { BigNumber } from "bignumber.js";
|
|
2
|
+
import { Observable } from "rxjs";
|
|
3
|
+
import { FeeNotLoaded } from "@ledgerhq/errors";
|
|
4
|
+
import { messageWithIntent, toSerializedSignature } from "@mysten/sui/cryptography";
|
|
5
|
+
import { Ed25519PublicKey } from "@mysten/sui/keypairs/ed25519";
|
|
6
|
+
import { verifyTransactionSignature } from "@mysten/sui/verify";
|
|
7
|
+
import { buildOptimisticOperation } from "./buildOptimisticOperation";
|
|
8
|
+
import { buildTransaction } from "./buildTransaction";
|
|
9
|
+
import { calculateAmount } from "./utils";
|
|
10
|
+
import { ensureAddressFormat } from "../utils";
|
|
11
|
+
/**
|
|
12
|
+
* Sign Transaction with Ledger hardware
|
|
13
|
+
*/
|
|
14
|
+
export const buildSignOperation = (signerContext) => ({ account, deviceId, transaction }) => new Observable(subscriber => {
|
|
15
|
+
async function main() {
|
|
16
|
+
subscriber.next({
|
|
17
|
+
type: "device-signature-requested",
|
|
18
|
+
});
|
|
19
|
+
if (!transaction.fees) {
|
|
20
|
+
throw new FeeNotLoaded();
|
|
21
|
+
}
|
|
22
|
+
// Ensure amount is filled when useAllAmount
|
|
23
|
+
const transactionToSign = {
|
|
24
|
+
...transaction,
|
|
25
|
+
amount: calculateAmount({
|
|
26
|
+
account,
|
|
27
|
+
transaction,
|
|
28
|
+
}),
|
|
29
|
+
};
|
|
30
|
+
const { unsigned } = await buildTransaction(account, transactionToSign);
|
|
31
|
+
const signData = messageWithIntent("TransactionData", unsigned);
|
|
32
|
+
const { signature } = await signerContext(deviceId, signer => signer.signTransaction(account.freshAddressPath, signData));
|
|
33
|
+
const publicKeyResult = await signerContext(deviceId, signer => signer.getPublicKey(account.freshAddressPath));
|
|
34
|
+
const publicKey = new Ed25519PublicKey(publicKeyResult.publicKey);
|
|
35
|
+
const serializedSignature = toSerializedSignature({
|
|
36
|
+
signature,
|
|
37
|
+
signatureScheme: "ED25519",
|
|
38
|
+
publicKey,
|
|
39
|
+
});
|
|
40
|
+
if (!transaction.skipVerify) {
|
|
41
|
+
const verify = await verifyTransactionSignature(unsigned, serializedSignature, {
|
|
42
|
+
address: ensureAddressFormat(account.freshAddress),
|
|
43
|
+
});
|
|
44
|
+
if (!verify) {
|
|
45
|
+
throw new Error("verifyTransactionSignature failed");
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
subscriber.next({
|
|
49
|
+
type: "device-signature-granted",
|
|
50
|
+
});
|
|
51
|
+
const operation = buildOptimisticOperation(account, transactionToSign, transactionToSign.fees ?? new BigNumber(0));
|
|
52
|
+
const signedOperation = {
|
|
53
|
+
operation,
|
|
54
|
+
signature: Buffer.from(signature).toString("base64"),
|
|
55
|
+
rawData: {
|
|
56
|
+
serializedSignature,
|
|
57
|
+
unsigned: Buffer.from(unsigned).toString("base64"),
|
|
58
|
+
},
|
|
59
|
+
};
|
|
60
|
+
subscriber.next({
|
|
61
|
+
type: "signed",
|
|
62
|
+
signedOperation,
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
main().then(() => subscriber.complete(), e => subscriber.error(e));
|
|
66
|
+
});
|
|
67
|
+
export default buildSignOperation;
|
|
68
|
+
//# sourceMappingURL=signOperation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signOperation.js","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signOperation.test.d.ts","sourceRoot":"","sources":["../../src/bridge/signOperation.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import buildSignOperation from "./signOperation";
|
|
2
|
+
import { createFixtureAccount, createFixtureTransaction } from "../types/bridge.fixture";
|
|
3
|
+
import coinConfig from "../config";
|
|
4
|
+
jest.mock("../config");
|
|
5
|
+
const mockGetConfig = jest.mocked(coinConfig.getCoinConfig);
|
|
6
|
+
describe("signOperation", () => {
|
|
7
|
+
const fakeSignature = new Uint8Array(64).fill(0x42);
|
|
8
|
+
const fakeSigner = {
|
|
9
|
+
getPublicKey: jest.fn().mockResolvedValue({
|
|
10
|
+
publicKey: new Uint8Array(32).fill(0x01),
|
|
11
|
+
address: "0x1234567890abcdef",
|
|
12
|
+
}),
|
|
13
|
+
signTransaction: jest.fn().mockResolvedValue({
|
|
14
|
+
signature: fakeSignature,
|
|
15
|
+
}),
|
|
16
|
+
getVersion: jest.fn().mockResolvedValue({ major: 0, minor: 1, patch: 0 }),
|
|
17
|
+
transport: {},
|
|
18
|
+
};
|
|
19
|
+
const signerContext = (_deviceId, fn) => fn(fakeSigner);
|
|
20
|
+
const signOperation = buildSignOperation(signerContext);
|
|
21
|
+
const deviceId = "dummyDeviceId";
|
|
22
|
+
beforeAll(() => {
|
|
23
|
+
mockGetConfig.mockImplementation(() => {
|
|
24
|
+
return {};
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
it("returns events in the right order", done => {
|
|
28
|
+
// GIVEN
|
|
29
|
+
const account = createFixtureAccount();
|
|
30
|
+
const transaction = createFixtureTransaction();
|
|
31
|
+
// WHEN & THEN
|
|
32
|
+
const expectedEvent = [
|
|
33
|
+
{
|
|
34
|
+
type: "device-signature-requested",
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
type: "device-signature-granted",
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
type: "signed",
|
|
41
|
+
},
|
|
42
|
+
];
|
|
43
|
+
let eventIdx = 0;
|
|
44
|
+
signOperation({ account, deviceId, transaction }).forEach((e) => {
|
|
45
|
+
try {
|
|
46
|
+
expect(e.type).toEqual(expectedEvent[eventIdx].type);
|
|
47
|
+
eventIdx++;
|
|
48
|
+
if (eventIdx === expectedEvent.length) {
|
|
49
|
+
done();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
catch (err) {
|
|
53
|
+
done(err);
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
it("throws an error of transaction has no fees", done => {
|
|
58
|
+
// GIVEN
|
|
59
|
+
const account = createFixtureAccount();
|
|
60
|
+
const transaction = createFixtureTransaction({ fees: undefined });
|
|
61
|
+
// WHEN & THEN
|
|
62
|
+
const observer = {
|
|
63
|
+
error: (e) => {
|
|
64
|
+
expect(e.name).toMatch("FeeNotLoaded");
|
|
65
|
+
done();
|
|
66
|
+
},
|
|
67
|
+
};
|
|
68
|
+
signOperation({ account, deviceId, transaction }).subscribe(observer);
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
//# sourceMappingURL=signOperation.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signOperation.test.js","sourceRoot":"","sources":["../../src/bridge/signOperation.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { type GetAccountShape } from "@ledgerhq/coin-framework/bridge/jsHelpers";
|
|
2
|
+
import { SuiAccount } from "../types";
|
|
3
|
+
/**
|
|
4
|
+
* Get the shape of the account including its operations and balance.
|
|
5
|
+
* @function getAccountShape
|
|
6
|
+
* @param {Object} info - The information needed to retrieve the account shape.
|
|
7
|
+
* @param {string} info.address - The address of the account.
|
|
8
|
+
* @param {SuiAccount} info.initialAccount - The initial account data.
|
|
9
|
+
* @param {Object} info.currency - The currency information.
|
|
10
|
+
* @param {string} info.derivationMode - The derivation mode for the account.
|
|
11
|
+
* @returns {Promise<Object>} A promise that resolves to the account shape including balance and operations.
|
|
12
|
+
*/
|
|
13
|
+
export declare const getAccountShape: GetAccountShape<SuiAccount>;
|
|
14
|
+
/**
|
|
15
|
+
* Synchronise the account with the latest operations and balance.
|
|
16
|
+
* @function sync
|
|
17
|
+
* @param {Object} params - The parameters for synchronisation.
|
|
18
|
+
* @returns {Promise<void>} A promise that resolves when synchronisation is complete.
|
|
19
|
+
*/
|
|
20
|
+
export declare const sync: (initialAccount: SuiAccount, syncConfig: import("@ledgerhq/types-live").SyncConfig) => import("rxjs").Observable<(arg0: SuiAccount) => SuiAccount>;
|
|
21
|
+
//# sourceMappingURL=synchronisation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"synchronisation.d.ts","sourceRoot":"","sources":["../../src/bridge/synchronisation.ts"],"names":[],"mappings":"AAEA,OAAO,EAGL,KAAK,eAAe,EACrB,MAAM,2CAA2C,CAAC;AAEnD,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAGtC;;;;;;;;;GASG;AACH,eAAO,MAAM,eAAe,EAAE,eAAe,CAAC,UAAU,CAyCvD,CAAC;AAEF;;;;;GAKG;AACH,eAAO,MAAM,IAAI,oJAAgC,CAAC"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { encodeAccountId } from "@ledgerhq/coin-framework/account/index";
|
|
2
|
+
import { log } from "@ledgerhq/logs";
|
|
3
|
+
import { makeSync, mergeOps, } from "@ledgerhq/coin-framework/bridge/jsHelpers";
|
|
4
|
+
import { getAccount, getOperations } from "../network";
|
|
5
|
+
/**
|
|
6
|
+
* Get the shape of the account including its operations and balance.
|
|
7
|
+
* @function getAccountShape
|
|
8
|
+
* @param {Object} info - The information needed to retrieve the account shape.
|
|
9
|
+
* @param {string} info.address - The address of the account.
|
|
10
|
+
* @param {SuiAccount} info.initialAccount - The initial account data.
|
|
11
|
+
* @param {Object} info.currency - The currency information.
|
|
12
|
+
* @param {string} info.derivationMode - The derivation mode for the account.
|
|
13
|
+
* @returns {Promise<Object>} A promise that resolves to the account shape including balance and operations.
|
|
14
|
+
*/
|
|
15
|
+
export const getAccountShape = async (info) => {
|
|
16
|
+
const { address, initialAccount, currency, derivationMode } = info;
|
|
17
|
+
const oldOperations = initialAccount?.operations || [];
|
|
18
|
+
const accountId = encodeAccountId({
|
|
19
|
+
type: "js",
|
|
20
|
+
version: "2",
|
|
21
|
+
currencyId: currency.id,
|
|
22
|
+
xpubOrAddress: address,
|
|
23
|
+
derivationMode,
|
|
24
|
+
});
|
|
25
|
+
const { blockHeight, balance } = await getAccount(address);
|
|
26
|
+
// Merge new operations with the previously synced ones
|
|
27
|
+
let operations = [];
|
|
28
|
+
try {
|
|
29
|
+
// Needed for incremental synchronisation
|
|
30
|
+
const startAtIn = latestHash(oldOperations, "IN");
|
|
31
|
+
const startAtOut = latestHash(oldOperations, "OUT");
|
|
32
|
+
const newOperations = await getOperations(accountId, address, startAtIn, startAtOut);
|
|
33
|
+
operations = mergeOps(oldOperations, newOperations);
|
|
34
|
+
}
|
|
35
|
+
catch (e) {
|
|
36
|
+
log("sui/getAccountShape", "failed to sync with incremental strategy, falling back to full resync", { error: e });
|
|
37
|
+
// if we could NOT sync with existing transaction - we start from the beggining, rewritting transaction history
|
|
38
|
+
operations = await getOperations(accountId, address);
|
|
39
|
+
}
|
|
40
|
+
operations.sort((a, b) => b.date.valueOf() - a.date.valueOf());
|
|
41
|
+
const shape = {
|
|
42
|
+
id: accountId,
|
|
43
|
+
balance,
|
|
44
|
+
spendableBalance: balance,
|
|
45
|
+
operationsCount: operations.length,
|
|
46
|
+
blockHeight,
|
|
47
|
+
suiResources: {},
|
|
48
|
+
};
|
|
49
|
+
return { ...shape, operations };
|
|
50
|
+
};
|
|
51
|
+
/**
|
|
52
|
+
* Synchronise the account with the latest operations and balance.
|
|
53
|
+
* @function sync
|
|
54
|
+
* @param {Object} params - The parameters for synchronisation.
|
|
55
|
+
* @returns {Promise<void>} A promise that resolves when synchronisation is complete.
|
|
56
|
+
*/
|
|
57
|
+
export const sync = makeSync({ getAccountShape });
|
|
58
|
+
function latestHash(operations, type) {
|
|
59
|
+
return operations.find(el => type === el.type)?.blockHash ?? null;
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=synchronisation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"synchronisation.js","sourceRoot":"","sources":["../../src/bridge/synchronisation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,wCAAwC,CAAC;AACzE,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EACL,QAAQ,EACR,QAAQ,GAET,MAAM,2CAA2C,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAIvD;;;;;;;;;GASG;AACH,MAAM,CAAC,MAAM,eAAe,GAAgC,KAAK,EAAC,IAAI,EAAC,EAAE;IACvE,MAAM,EAAE,OAAO,EAAE,cAAc,EAAE,QAAQ,EAAE,cAAc,EAAE,GAAG,IAAI,CAAC;IACnE,MAAM,aAAa,GAAG,cAAc,EAAE,UAAU,IAAI,EAAE,CAAC;IACvD,MAAM,SAAS,GAAG,eAAe,CAAC;QAChC,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,GAAG;QACZ,UAAU,EAAE,QAAQ,CAAC,EAAE;QACvB,aAAa,EAAE,OAAO;QACtB,cAAc;KACf,CAAC,CAAC;IAEH,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC,CAAC;IAE3D,uDAAuD;IACvD,IAAI,UAAU,GAAgB,EAAE,CAAC;IACjC,IAAI,CAAC;QACH,yCAAyC;QACzC,MAAM,SAAS,GAAG,UAAU,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;QAClD,MAAM,UAAU,GAAG,UAAU,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;QACpD,MAAM,aAAa,GAAG,MAAM,aAAa,CAAC,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;QACrF,UAAU,GAAG,QAAQ,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;IACtD,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,GAAG,CACD,qBAAqB,EACrB,uEAAuE,EACvE,EAAE,KAAK,EAAE,CAAC,EAAE,CACb,CAAC;QACF,+GAA+G;QAC/G,UAAU,GAAG,MAAM,aAAa,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;IACvD,CAAC;IAED,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IAC/D,MAAM,KAAK,GAAG;QACZ,EAAE,EAAE,SAAS;QACb,OAAO;QACP,gBAAgB,EAAE,OAAO;QACzB,eAAe,EAAE,UAAU,CAAC,MAAM;QAClC,WAAW;QACX,YAAY,EAAE,EAAE;KACjB,CAAC;IACF,OAAO,EAAE,GAAG,KAAK,EAAE,UAAU,EAAE,CAAC;AAClC,CAAC,CAAC;AAEF;;;;;GAKG;AACH,MAAM,CAAC,MAAM,IAAI,GAAG,QAAQ,CAAC,EAAE,eAAe,EAAE,CAAC,CAAC;AAElD,SAAS,UAAU,CAAC,UAAuB,EAAE,IAAmB;IAC9D,OAAO,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,KAAK,EAAE,CAAC,IAAI,CAAC,EAAE,SAAS,IAAI,IAAI,CAAC;AACpE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"synchronisation.test.d.ts","sourceRoot":"","sources":["../../src/bridge/synchronisation.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { getCryptoCurrencyById } from "@ledgerhq/cryptoassets/currencies";
|
|
2
|
+
import BigNumber from "bignumber.js";
|
|
3
|
+
import { faker } from "@faker-js/faker";
|
|
4
|
+
import { createFixtureAccount, createFixtureOperation } from "../types/bridge.fixture";
|
|
5
|
+
import { getAccountShape } from "./synchronisation";
|
|
6
|
+
const mockGetAccount = jest.fn();
|
|
7
|
+
const mockGetOperations = jest.fn();
|
|
8
|
+
jest.mock("../network", () => ({
|
|
9
|
+
getAccount: () => mockGetAccount(),
|
|
10
|
+
getOperations: () => mockGetOperations(),
|
|
11
|
+
}));
|
|
12
|
+
describe("getAccountShape", () => {
|
|
13
|
+
beforeEach(() => {
|
|
14
|
+
mockGetAccount.mockClear();
|
|
15
|
+
mockGetOperations.mockClear();
|
|
16
|
+
});
|
|
17
|
+
it("calls getAccount and getOperations", async () => {
|
|
18
|
+
// GIVEN
|
|
19
|
+
const initialAccount = undefined;
|
|
20
|
+
const accountInfo = createAccountInfo();
|
|
21
|
+
mockGetAccount.mockResolvedValue(accountInfo);
|
|
22
|
+
mockGetOperations.mockResolvedValue([]);
|
|
23
|
+
// WHEN
|
|
24
|
+
await getAccountShape({
|
|
25
|
+
index: -1, // not used but mandatory
|
|
26
|
+
derivationPath: "not used",
|
|
27
|
+
currency: getCryptoCurrencyById("sui"),
|
|
28
|
+
address: "0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0",
|
|
29
|
+
initialAccount,
|
|
30
|
+
derivationMode: "sui",
|
|
31
|
+
}, { paginationConfig: {} });
|
|
32
|
+
// THEN
|
|
33
|
+
expect(mockGetAccount).toHaveBeenCalledTimes(1);
|
|
34
|
+
expect(mockGetOperations).toHaveBeenCalledTimes(1);
|
|
35
|
+
});
|
|
36
|
+
it("returns an AccountShapeInfo based on getAccount API", async () => {
|
|
37
|
+
// GIVEN
|
|
38
|
+
const initialAccount = undefined;
|
|
39
|
+
const accountInfo = createAccountInfo();
|
|
40
|
+
mockGetAccount.mockResolvedValue(accountInfo);
|
|
41
|
+
mockGetOperations.mockResolvedValue([]);
|
|
42
|
+
// WHEN
|
|
43
|
+
const shape = await getAccountShape({
|
|
44
|
+
index: -1, // not used but mandatory
|
|
45
|
+
derivationPath: "not used",
|
|
46
|
+
currency: getCryptoCurrencyById("sui"),
|
|
47
|
+
address: "0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0",
|
|
48
|
+
initialAccount,
|
|
49
|
+
derivationMode: "sui",
|
|
50
|
+
}, { paginationConfig: {} });
|
|
51
|
+
// THEN
|
|
52
|
+
expect(shape).toEqual({
|
|
53
|
+
id: "js:2:sui:0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0:sui",
|
|
54
|
+
balance: accountInfo.balance,
|
|
55
|
+
spendableBalance: accountInfo.balance,
|
|
56
|
+
blockHeight: accountInfo.blockHeight,
|
|
57
|
+
operations: [],
|
|
58
|
+
operationsCount: 0,
|
|
59
|
+
suiResources: {},
|
|
60
|
+
});
|
|
61
|
+
});
|
|
62
|
+
it("returns an AccountShapeInfo with operations from initialAccount", async () => {
|
|
63
|
+
// GIVEN
|
|
64
|
+
const initialOperations = [createFixtureOperation({ id: faker.string.uuid() })];
|
|
65
|
+
const initialAccount = createFixtureAccount({ operations: initialOperations });
|
|
66
|
+
const accountInfo = createAccountInfo();
|
|
67
|
+
mockGetAccount.mockResolvedValue(accountInfo);
|
|
68
|
+
mockGetOperations.mockResolvedValue([]);
|
|
69
|
+
// WHEN
|
|
70
|
+
const shape = await getAccountShape({
|
|
71
|
+
index: -1, // not used but mandatory
|
|
72
|
+
derivationPath: "not used",
|
|
73
|
+
currency: getCryptoCurrencyById("sui"),
|
|
74
|
+
address: "0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0",
|
|
75
|
+
initialAccount,
|
|
76
|
+
derivationMode: "sui",
|
|
77
|
+
}, { paginationConfig: {} });
|
|
78
|
+
// THEN
|
|
79
|
+
expect(shape.operationsCount).toEqual(1);
|
|
80
|
+
expect(shape.operations).toEqual(expect.arrayContaining(initialOperations));
|
|
81
|
+
});
|
|
82
|
+
it("returns an AccountShapeInfo with operations from getOperations API", async () => {
|
|
83
|
+
// GIVEN
|
|
84
|
+
const initialAccount = createFixtureAccount();
|
|
85
|
+
const accountInfo = createAccountInfo();
|
|
86
|
+
mockGetAccount.mockResolvedValue(accountInfo);
|
|
87
|
+
const apiOperations = [
|
|
88
|
+
createFixtureOperation({ id: faker.string.uuid() }),
|
|
89
|
+
createFixtureOperation({ id: faker.string.uuid() }),
|
|
90
|
+
];
|
|
91
|
+
mockGetOperations.mockResolvedValue(apiOperations);
|
|
92
|
+
// WHEN
|
|
93
|
+
const shape = await getAccountShape({
|
|
94
|
+
index: -1, // not used but mandatory
|
|
95
|
+
derivationPath: "not used",
|
|
96
|
+
currency: getCryptoCurrencyById("sui"),
|
|
97
|
+
address: "0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0",
|
|
98
|
+
initialAccount,
|
|
99
|
+
derivationMode: "sui",
|
|
100
|
+
}, { paginationConfig: {} });
|
|
101
|
+
// THEN
|
|
102
|
+
expect(shape.operationsCount).toEqual(initialAccount.operations.length + apiOperations.length);
|
|
103
|
+
expect(shape.operations).toEqual(expect.arrayContaining(apiOperations));
|
|
104
|
+
});
|
|
105
|
+
});
|
|
106
|
+
function createAccountInfo() {
|
|
107
|
+
return {
|
|
108
|
+
blockHeight: 10,
|
|
109
|
+
balance: new BigNumber(faker.string.numeric()),
|
|
110
|
+
spendableBalance: new BigNumber(faker.string.numeric()),
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=synchronisation.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"synchronisation.test.js","sourceRoot":"","sources":["../../src/bridge/synchronisation.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAAE,oBAAoB,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAC;AAEvF,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAEpD,MAAM,cAAc,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AACjC,MAAM,iBAAiB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AACpC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,CAAC;IAC7B,UAAU,EAAE,GAAG,EAAE,CAAC,cAAc,EAAE;IAClC,aAAa,EAAE,GAAG,EAAE,CAAC,iBAAiB,EAAE;CACzC,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,UAAU,CAAC,GAAG,EAAE;QACd,cAAc,CAAC,SAAS,EAAE,CAAC;QAC3B,iBAAiB,CAAC,SAAS,EAAE,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,KAAK,IAAI,EAAE;QAClD,QAAQ;QACR,MAAM,cAAc,GAAG,SAAS,CAAC;QACjC,MAAM,WAAW,GAAG,iBAAiB,EAAE,CAAC;QACxC,cAAc,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QAC9C,iBAAiB,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;QAExC,OAAO;QACP,MAAM,eAAe,CACnB;YACE,KAAK,EAAE,CAAC,CAAC,EAAE,yBAAyB;YACpC,cAAc,EAAE,UAAU;YAC1B,QAAQ,EAAE,qBAAqB,CAAC,KAAK,CAAC;YACtC,OAAO,EAAE,oEAAoE;YAC7E,cAAc;YACd,cAAc,EAAE,KAAK;SACtB,EACD,EAAE,gBAAgB,EAAE,EAAE,EAAE,CACzB,CAAC;QAEF,OAAO;QACP,MAAM,CAAC,cAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,CAAC,iBAAiB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE,KAAK,IAAI,EAAE;QACnE,QAAQ;QACR,MAAM,cAAc,GAAG,SAAS,CAAC;QACjC,MAAM,WAAW,GAAG,iBAAiB,EAAE,CAAC;QACxC,cAAc,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QAC9C,iBAAiB,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;QAExC,OAAO;QACP,MAAM,KAAK,GAAG,MAAM,eAAe,CACjC;YACE,KAAK,EAAE,CAAC,CAAC,EAAE,yBAAyB;YACpC,cAAc,EAAE,UAAU;YAC1B,QAAQ,EAAE,qBAAqB,CAAC,KAAK,CAAC;YACtC,OAAO,EAAE,oEAAoE;YAC7E,cAAc;YACd,cAAc,EAAE,KAAK;SACtB,EACD,EAAE,gBAAgB,EAAE,EAAE,EAAE,CACzB,CAAC;QAEF,OAAO;QACP,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;YACpB,EAAE,EAAE,iFAAiF;YACrF,OAAO,EAAE,WAAW,CAAC,OAAO;YAC5B,gBAAgB,EAAE,WAAW,CAAC,OAAO;YACrC,WAAW,EAAE,WAAW,CAAC,WAAW;YACpC,UAAU,EAAE,EAAE;YACd,eAAe,EAAE,CAAC;YAClB,YAAY,EAAE,EAAE;SACjB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iEAAiE,EAAE,KAAK,IAAI,EAAE;QAC/E,QAAQ;QACR,MAAM,iBAAiB,GAAG,CAAC,sBAAsB,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;QAChF,MAAM,cAAc,GAAG,oBAAoB,CAAC,EAAE,UAAU,EAAE,iBAAiB,EAAE,CAAC,CAAC;QAC/E,MAAM,WAAW,GAAG,iBAAiB,EAAE,CAAC;QACxC,cAAc,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QAC9C,iBAAiB,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;QAExC,OAAO;QACP,MAAM,KAAK,GAAG,MAAM,eAAe,CACjC;YACE,KAAK,EAAE,CAAC,CAAC,EAAE,yBAAyB;YACpC,cAAc,EAAE,UAAU;YAC1B,QAAQ,EAAE,qBAAqB,CAAC,KAAK,CAAC;YACtC,OAAO,EAAE,oEAAoE;YAC7E,cAAc;YACd,cAAc,EAAE,KAAK;SACtB,EACD,EAAE,gBAAgB,EAAE,EAAE,EAAE,CACzB,CAAC;QAEF,OAAO;QACP,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC,CAAC;IAC9E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oEAAoE,EAAE,KAAK,IAAI,EAAE;QAClF,QAAQ;QACR,MAAM,cAAc,GAAG,oBAAoB,EAAE,CAAC;QAC9C,MAAM,WAAW,GAAG,iBAAiB,EAAE,CAAC;QACxC,cAAc,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QAC9C,MAAM,aAAa,GAAG;YACpB,sBAAsB,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC;YACnD,sBAAsB,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC;SACpD,CAAC;QACF,iBAAiB,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC;QAEnD,OAAO;QACP,MAAM,KAAK,GAAG,MAAM,eAAe,CACjC;YACE,KAAK,EAAE,CAAC,CAAC,EAAE,yBAAyB;YACpC,cAAc,EAAE,UAAU;YAC1B,QAAQ,EAAE,qBAAqB,CAAC,KAAK,CAAC;YACtC,OAAO,EAAE,oEAAoE;YAC7E,cAAc;YACd,cAAc,EAAE,KAAK;SACtB,EACD,EAAE,gBAAgB,EAAE,EAAE,EAAE,CACzB,CAAC;QAEF,OAAO;QACP,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,UAAU,CAAC,MAAM,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;QAC/F,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,CAAC;IAC1E,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,SAAS,iBAAiB;IACxB,OAAO;QACL,WAAW,EAAE,EAAE;QACf,OAAO,EAAE,IAAI,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QAC9C,gBAAgB,EAAE,IAAI,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;KACxD,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { Account } from "@ledgerhq/types-live";
|
|
2
|
+
import type { Transaction, TransactionRaw } from "../types";
|
|
3
|
+
export declare const formatTransaction: (transaction: Transaction, account: Account) => string;
|
|
4
|
+
export declare const fromTransactionRaw: (transaction: TransactionRaw) => Transaction;
|
|
5
|
+
export declare const toTransactionRaw: (transaction: Transaction) => TransactionRaw;
|
|
6
|
+
declare const _default: {
|
|
7
|
+
formatTransaction: (transaction: Transaction, account: Account) => string;
|
|
8
|
+
fromTransactionRaw: (transaction: TransactionRaw) => Transaction;
|
|
9
|
+
toTransactionRaw: (transaction: Transaction) => TransactionRaw;
|
|
10
|
+
formatTransactionStatus: (t: import("@ledgerhq/types-live").TransactionCommon, { errors, warnings, estimatedFees, amount, totalSpent }: import("@ledgerhq/types-live").TransactionStatusCommon, mainAccount: Account) => string;
|
|
11
|
+
fromTransactionStatusRaw: (ts: import("@ledgerhq/types-live").TransactionStatusCommonRaw) => import("@ledgerhq/types-live").TransactionStatusCommon;
|
|
12
|
+
toTransactionStatusRaw: (ts: import("@ledgerhq/types-live").TransactionStatusCommon) => import("@ledgerhq/types-live").TransactionStatusCommonRaw;
|
|
13
|
+
};
|
|
14
|
+
export default _default;
|
|
15
|
+
//# sourceMappingURL=transaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../src/bridge/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAWpD,OAAO,KAAK,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAE5D,eAAO,MAAM,iBAAiB,gBAAiB,WAAW,WAAW,OAAO,KAAG,MAc9E,CAAC;AAEF,eAAO,MAAM,kBAAkB,gBAAiB,cAAc,KAAG,WAYhE,CAAC;AAEF,eAAO,MAAM,gBAAgB,gBAAiB,WAAW,KAAG,cAQ3D,CAAC;;;;;;;;;AAEF,wBAOE"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { formatCurrencyUnit } from "@ledgerhq/coin-framework/currencies";
|
|
2
|
+
import { formatTransactionStatus } from "@ledgerhq/coin-framework/formatters";
|
|
3
|
+
import { fromTransactionCommonRaw, toTransactionCommonRaw, fromTransactionStatusRawCommon as fromTransactionStatusRaw, toTransactionStatusRawCommon as toTransactionStatusRaw, } from "@ledgerhq/coin-framework/serialization";
|
|
4
|
+
import { BigNumber } from "bignumber.js";
|
|
5
|
+
import { getAccountUnit } from "./utils";
|
|
6
|
+
export const formatTransaction = (transaction, account) => {
|
|
7
|
+
const { mode, amount, recipient, useAllAmount } = transaction;
|
|
8
|
+
return `
|
|
9
|
+
${mode.toUpperCase()} ${useAllAmount
|
|
10
|
+
? "MAX"
|
|
11
|
+
: amount.isZero()
|
|
12
|
+
? ""
|
|
13
|
+
: " " +
|
|
14
|
+
formatCurrencyUnit(getAccountUnit(account), amount, {
|
|
15
|
+
showCode: true,
|
|
16
|
+
disableRounding: true,
|
|
17
|
+
})}${recipient ? `\nTO ${recipient}` : ""}`;
|
|
18
|
+
};
|
|
19
|
+
export const fromTransactionRaw = (transaction) => {
|
|
20
|
+
if (!transaction.amount) {
|
|
21
|
+
transaction.amount = "0";
|
|
22
|
+
}
|
|
23
|
+
const common = fromTransactionCommonRaw(transaction);
|
|
24
|
+
return {
|
|
25
|
+
...common,
|
|
26
|
+
family: transaction.family,
|
|
27
|
+
mode: transaction.mode,
|
|
28
|
+
fees: transaction.fees ? BigNumber(transaction.fees) : null,
|
|
29
|
+
errors: {},
|
|
30
|
+
};
|
|
31
|
+
};
|
|
32
|
+
export const toTransactionRaw = (transaction) => {
|
|
33
|
+
const common = toTransactionCommonRaw(transaction);
|
|
34
|
+
return {
|
|
35
|
+
...common,
|
|
36
|
+
family: transaction.family,
|
|
37
|
+
mode: transaction.mode,
|
|
38
|
+
fees: transaction.fees?.toString() || "",
|
|
39
|
+
};
|
|
40
|
+
};
|
|
41
|
+
export default {
|
|
42
|
+
formatTransaction,
|
|
43
|
+
fromTransactionRaw,
|
|
44
|
+
toTransactionRaw,
|
|
45
|
+
formatTransactionStatus,
|
|
46
|
+
fromTransactionStatusRaw,
|
|
47
|
+
toTransactionStatusRaw,
|
|
48
|
+
};
|
|
49
|
+
//# sourceMappingURL=transaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../src/bridge/transaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AACzE,OAAO,EAAE,uBAAuB,EAAE,MAAM,qCAAqC,CAAC;AAC9E,OAAO,EACL,wBAAwB,EACxB,sBAAsB,EACtB,8BAA8B,IAAI,wBAAwB,EAC1D,4BAA4B,IAAI,sBAAsB,GACvD,MAAM,wCAAwC,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAGzC,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,WAAwB,EAAE,OAAgB,EAAU,EAAE;IACtF,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,GAAG,WAAW,CAAC;IAC9D,OAAO;EACP,IAAI,CAAC,WAAW,EAAE,IAChB,YAAY;QACV,CAAC,CAAC,KAAK;QACP,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE;YACf,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC,GAAG;gBACH,kBAAkB,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE;oBAClD,QAAQ,EAAE,IAAI;oBACd,eAAe,EAAE,IAAI;iBACtB,CACT,GAAG,SAAS,CAAC,CAAC,CAAC,QAAQ,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;AAC5C,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,WAA2B,EAAe,EAAE;IAC7E,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;QACxB,WAAW,CAAC,MAAM,GAAG,GAAG,CAAC;IAC3B,CAAC;IACD,MAAM,MAAM,GAAG,wBAAwB,CAAC,WAAW,CAAC,CAAC;IACrD,OAAO;QACL,GAAG,MAAM;QACT,MAAM,EAAE,WAAW,CAAC,MAAM;QAC1B,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI;QAC3D,MAAM,EAAE,EAAE;KACX,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,WAAwB,EAAkB,EAAE;IAC3E,MAAM,MAAM,GAAG,sBAAsB,CAAC,WAAW,CAAC,CAAC;IACnD,OAAO;QACL,GAAG,MAAM;QACT,MAAM,EAAE,WAAW,CAAC,MAAM;QAC1B,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,IAAI,EAAE,WAAW,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE;KACzC,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe;IACb,iBAAiB;IACjB,kBAAkB;IAClB,gBAAgB;IAChB,uBAAuB;IACvB,wBAAwB;IACxB,sBAAsB;CACvB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.test.d.ts","sourceRoot":"","sources":["../../src/bridge/transaction.test.ts"],"names":[],"mappings":""}
|