@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,118 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const currencies_1 = require("@ledgerhq/cryptoassets/currencies");
|
|
7
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
8
|
+
const faker_1 = require("@faker-js/faker");
|
|
9
|
+
const bridge_fixture_1 = require("../types/bridge.fixture");
|
|
10
|
+
const synchronisation_1 = require("./synchronisation");
|
|
11
|
+
const mockGetAccount = jest.fn();
|
|
12
|
+
const mockGetOperations = jest.fn();
|
|
13
|
+
jest.mock("../network", () => ({
|
|
14
|
+
getAccount: () => mockGetAccount(),
|
|
15
|
+
getOperations: () => mockGetOperations(),
|
|
16
|
+
}));
|
|
17
|
+
describe("getAccountShape", () => {
|
|
18
|
+
beforeEach(() => {
|
|
19
|
+
mockGetAccount.mockClear();
|
|
20
|
+
mockGetOperations.mockClear();
|
|
21
|
+
});
|
|
22
|
+
it("calls getAccount and getOperations", async () => {
|
|
23
|
+
// GIVEN
|
|
24
|
+
const initialAccount = undefined;
|
|
25
|
+
const accountInfo = createAccountInfo();
|
|
26
|
+
mockGetAccount.mockResolvedValue(accountInfo);
|
|
27
|
+
mockGetOperations.mockResolvedValue([]);
|
|
28
|
+
// WHEN
|
|
29
|
+
await (0, synchronisation_1.getAccountShape)({
|
|
30
|
+
index: -1, // not used but mandatory
|
|
31
|
+
derivationPath: "not used",
|
|
32
|
+
currency: (0, currencies_1.getCryptoCurrencyById)("sui"),
|
|
33
|
+
address: "0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0",
|
|
34
|
+
initialAccount,
|
|
35
|
+
derivationMode: "sui",
|
|
36
|
+
}, { paginationConfig: {} });
|
|
37
|
+
// THEN
|
|
38
|
+
expect(mockGetAccount).toHaveBeenCalledTimes(1);
|
|
39
|
+
expect(mockGetOperations).toHaveBeenCalledTimes(1);
|
|
40
|
+
});
|
|
41
|
+
it("returns an AccountShapeInfo based on getAccount API", async () => {
|
|
42
|
+
// GIVEN
|
|
43
|
+
const initialAccount = undefined;
|
|
44
|
+
const accountInfo = createAccountInfo();
|
|
45
|
+
mockGetAccount.mockResolvedValue(accountInfo);
|
|
46
|
+
mockGetOperations.mockResolvedValue([]);
|
|
47
|
+
// WHEN
|
|
48
|
+
const shape = await (0, synchronisation_1.getAccountShape)({
|
|
49
|
+
index: -1, // not used but mandatory
|
|
50
|
+
derivationPath: "not used",
|
|
51
|
+
currency: (0, currencies_1.getCryptoCurrencyById)("sui"),
|
|
52
|
+
address: "0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0",
|
|
53
|
+
initialAccount,
|
|
54
|
+
derivationMode: "sui",
|
|
55
|
+
}, { paginationConfig: {} });
|
|
56
|
+
// THEN
|
|
57
|
+
expect(shape).toEqual({
|
|
58
|
+
id: "js:2:sui:0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0:sui",
|
|
59
|
+
balance: accountInfo.balance,
|
|
60
|
+
spendableBalance: accountInfo.balance,
|
|
61
|
+
blockHeight: accountInfo.blockHeight,
|
|
62
|
+
operations: [],
|
|
63
|
+
operationsCount: 0,
|
|
64
|
+
suiResources: {},
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
it("returns an AccountShapeInfo with operations from initialAccount", async () => {
|
|
68
|
+
// GIVEN
|
|
69
|
+
const initialOperations = [(0, bridge_fixture_1.createFixtureOperation)({ id: faker_1.faker.string.uuid() })];
|
|
70
|
+
const initialAccount = (0, bridge_fixture_1.createFixtureAccount)({ operations: initialOperations });
|
|
71
|
+
const accountInfo = createAccountInfo();
|
|
72
|
+
mockGetAccount.mockResolvedValue(accountInfo);
|
|
73
|
+
mockGetOperations.mockResolvedValue([]);
|
|
74
|
+
// WHEN
|
|
75
|
+
const shape = await (0, synchronisation_1.getAccountShape)({
|
|
76
|
+
index: -1, // not used but mandatory
|
|
77
|
+
derivationPath: "not used",
|
|
78
|
+
currency: (0, currencies_1.getCryptoCurrencyById)("sui"),
|
|
79
|
+
address: "0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0",
|
|
80
|
+
initialAccount,
|
|
81
|
+
derivationMode: "sui",
|
|
82
|
+
}, { paginationConfig: {} });
|
|
83
|
+
// THEN
|
|
84
|
+
expect(shape.operationsCount).toEqual(1);
|
|
85
|
+
expect(shape.operations).toEqual(expect.arrayContaining(initialOperations));
|
|
86
|
+
});
|
|
87
|
+
it("returns an AccountShapeInfo with operations from getOperations API", async () => {
|
|
88
|
+
// GIVEN
|
|
89
|
+
const initialAccount = (0, bridge_fixture_1.createFixtureAccount)();
|
|
90
|
+
const accountInfo = createAccountInfo();
|
|
91
|
+
mockGetAccount.mockResolvedValue(accountInfo);
|
|
92
|
+
const apiOperations = [
|
|
93
|
+
(0, bridge_fixture_1.createFixtureOperation)({ id: faker_1.faker.string.uuid() }),
|
|
94
|
+
(0, bridge_fixture_1.createFixtureOperation)({ id: faker_1.faker.string.uuid() }),
|
|
95
|
+
];
|
|
96
|
+
mockGetOperations.mockResolvedValue(apiOperations);
|
|
97
|
+
// WHEN
|
|
98
|
+
const shape = await (0, synchronisation_1.getAccountShape)({
|
|
99
|
+
index: -1, // not used but mandatory
|
|
100
|
+
derivationPath: "not used",
|
|
101
|
+
currency: (0, currencies_1.getCryptoCurrencyById)("sui"),
|
|
102
|
+
address: "0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0",
|
|
103
|
+
initialAccount,
|
|
104
|
+
derivationMode: "sui",
|
|
105
|
+
}, { paginationConfig: {} });
|
|
106
|
+
// THEN
|
|
107
|
+
expect(shape.operationsCount).toEqual(initialAccount.operations.length + apiOperations.length);
|
|
108
|
+
expect(shape.operations).toEqual(expect.arrayContaining(apiOperations));
|
|
109
|
+
});
|
|
110
|
+
});
|
|
111
|
+
function createAccountInfo() {
|
|
112
|
+
return {
|
|
113
|
+
blockHeight: 10,
|
|
114
|
+
balance: new bignumber_js_1.default(faker_1.faker.string.numeric()),
|
|
115
|
+
spendableBalance: new bignumber_js_1.default(faker_1.faker.string.numeric()),
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
//# sourceMappingURL=synchronisation.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"synchronisation.test.js","sourceRoot":"","sources":["../../src/bridge/synchronisation.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -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,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.toTransactionRaw = exports.fromTransactionRaw = exports.formatTransaction = void 0;
|
|
4
|
+
const currencies_1 = require("@ledgerhq/coin-framework/currencies");
|
|
5
|
+
const formatters_1 = require("@ledgerhq/coin-framework/formatters");
|
|
6
|
+
const serialization_1 = require("@ledgerhq/coin-framework/serialization");
|
|
7
|
+
const bignumber_js_1 = require("bignumber.js");
|
|
8
|
+
const utils_1 = require("./utils");
|
|
9
|
+
const formatTransaction = (transaction, account) => {
|
|
10
|
+
const { mode, amount, recipient, useAllAmount } = transaction;
|
|
11
|
+
return `
|
|
12
|
+
${mode.toUpperCase()} ${useAllAmount
|
|
13
|
+
? "MAX"
|
|
14
|
+
: amount.isZero()
|
|
15
|
+
? ""
|
|
16
|
+
: " " +
|
|
17
|
+
(0, currencies_1.formatCurrencyUnit)((0, utils_1.getAccountUnit)(account), amount, {
|
|
18
|
+
showCode: true,
|
|
19
|
+
disableRounding: true,
|
|
20
|
+
})}${recipient ? `\nTO ${recipient}` : ""}`;
|
|
21
|
+
};
|
|
22
|
+
exports.formatTransaction = formatTransaction;
|
|
23
|
+
const fromTransactionRaw = (transaction) => {
|
|
24
|
+
if (!transaction.amount) {
|
|
25
|
+
transaction.amount = "0";
|
|
26
|
+
}
|
|
27
|
+
const common = (0, serialization_1.fromTransactionCommonRaw)(transaction);
|
|
28
|
+
return {
|
|
29
|
+
...common,
|
|
30
|
+
family: transaction.family,
|
|
31
|
+
mode: transaction.mode,
|
|
32
|
+
fees: transaction.fees ? (0, bignumber_js_1.BigNumber)(transaction.fees) : null,
|
|
33
|
+
errors: {},
|
|
34
|
+
};
|
|
35
|
+
};
|
|
36
|
+
exports.fromTransactionRaw = fromTransactionRaw;
|
|
37
|
+
const toTransactionRaw = (transaction) => {
|
|
38
|
+
const common = (0, serialization_1.toTransactionCommonRaw)(transaction);
|
|
39
|
+
return {
|
|
40
|
+
...common,
|
|
41
|
+
family: transaction.family,
|
|
42
|
+
mode: transaction.mode,
|
|
43
|
+
fees: transaction.fees?.toString() || "",
|
|
44
|
+
};
|
|
45
|
+
};
|
|
46
|
+
exports.toTransactionRaw = toTransactionRaw;
|
|
47
|
+
exports.default = {
|
|
48
|
+
formatTransaction: exports.formatTransaction,
|
|
49
|
+
fromTransactionRaw: exports.fromTransactionRaw,
|
|
50
|
+
toTransactionRaw: exports.toTransactionRaw,
|
|
51
|
+
formatTransactionStatus: formatters_1.formatTransactionStatus,
|
|
52
|
+
fromTransactionStatusRaw: serialization_1.fromTransactionStatusRawCommon,
|
|
53
|
+
toTransactionStatusRaw: serialization_1.toTransactionStatusRawCommon,
|
|
54
|
+
};
|
|
55
|
+
//# sourceMappingURL=transaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../src/bridge/transaction.ts"],"names":[],"mappings":";;;AACA,oEAAyE;AACzE,oEAA8E;AAC9E,0EAKgD;AAChD,+CAAyC;AACzC,mCAAyC;AAGlC,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,IAAA,+BAAkB,EAAC,IAAA,sBAAc,EAAC,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;AAdW,QAAA,iBAAiB,qBAc5B;AAEK,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,IAAA,wCAAwB,EAAC,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,IAAA,wBAAS,EAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI;QAC3D,MAAM,EAAE,EAAE;KACX,CAAC;AACJ,CAAC,CAAC;AAZW,QAAA,kBAAkB,sBAY7B;AAEK,MAAM,gBAAgB,GAAG,CAAC,WAAwB,EAAkB,EAAE;IAC3E,MAAM,MAAM,GAAG,IAAA,sCAAsB,EAAC,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;AARW,QAAA,gBAAgB,oBAQ3B;AAEF,kBAAe;IACb,iBAAiB,EAAjB,yBAAiB;IACjB,kBAAkB,EAAlB,0BAAkB;IAClB,gBAAgB,EAAhB,wBAAgB;IAChB,uBAAuB,EAAvB,oCAAuB;IACvB,wBAAwB,EAAxB,8CAAwB;IACxB,sBAAsB,EAAtB,4CAAsB;CACvB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.test.d.ts","sourceRoot":"","sources":["../../src/bridge/transaction.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const bignumber_js_1 = require("bignumber.js");
|
|
4
|
+
const bridge_fixture_1 = require("../types/bridge.fixture");
|
|
5
|
+
const transaction_1 = require("./transaction");
|
|
6
|
+
describe("transaction", () => {
|
|
7
|
+
const account = (0, bridge_fixture_1.createFixtureAccount)();
|
|
8
|
+
describe("formatTransaction", () => {
|
|
9
|
+
it("should format a basic transaction", () => {
|
|
10
|
+
const transaction = (0, bridge_fixture_1.createFixtureTransaction)({
|
|
11
|
+
amount: new bignumber_js_1.BigNumber(500000000),
|
|
12
|
+
recipient: "0x456",
|
|
13
|
+
});
|
|
14
|
+
const formatted = (0, transaction_1.formatTransaction)(transaction, account);
|
|
15
|
+
expect(formatted).toBe("\nSEND 0.5 SUI\nTO 0x456");
|
|
16
|
+
});
|
|
17
|
+
it("should format a transaction with useAllAmount", () => {
|
|
18
|
+
const transaction = (0, bridge_fixture_1.createFixtureTransaction)({ useAllAmount: true, recipient: "0x456" });
|
|
19
|
+
const formatted = (0, transaction_1.formatTransaction)(transaction, account);
|
|
20
|
+
expect(formatted).toBe("\nSEND MAX\nTO 0x456");
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
describe("fromTransactionRaw", () => {
|
|
24
|
+
it("should convert from raw transaction", () => {
|
|
25
|
+
const rawTransaction = {
|
|
26
|
+
family: "sui",
|
|
27
|
+
mode: "send",
|
|
28
|
+
amount: "500000000",
|
|
29
|
+
recipient: "0x456",
|
|
30
|
+
useAllAmount: false,
|
|
31
|
+
fees: "1000000",
|
|
32
|
+
};
|
|
33
|
+
const transaction = (0, transaction_1.fromTransactionRaw)(rawTransaction);
|
|
34
|
+
expect(transaction).toEqual({
|
|
35
|
+
family: "sui",
|
|
36
|
+
mode: "send",
|
|
37
|
+
amount: new bignumber_js_1.BigNumber("500000000"),
|
|
38
|
+
recipient: "0x456",
|
|
39
|
+
useAllAmount: false,
|
|
40
|
+
fees: new bignumber_js_1.BigNumber("1000000"),
|
|
41
|
+
errors: {},
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
describe("toTransactionRaw", () => {
|
|
46
|
+
it("should convert to raw transaction", () => {
|
|
47
|
+
const transaction = (0, bridge_fixture_1.createFixtureTransaction)();
|
|
48
|
+
const rawTransaction = (0, transaction_1.toTransactionRaw)(transaction);
|
|
49
|
+
expect(rawTransaction).toEqual({
|
|
50
|
+
family: "sui",
|
|
51
|
+
mode: "send",
|
|
52
|
+
amount: "3000000000",
|
|
53
|
+
recipient: "0x65449f57946938c84c512732f1d69405d1fce417d9c9894696ddf4522f479e24",
|
|
54
|
+
useAllAmount: false,
|
|
55
|
+
fees: "3976000",
|
|
56
|
+
});
|
|
57
|
+
});
|
|
58
|
+
it("should handle null fees", () => {
|
|
59
|
+
const transaction = (0, bridge_fixture_1.createFixtureTransaction)({ fees: null });
|
|
60
|
+
const rawTransaction = (0, transaction_1.toTransactionRaw)(transaction);
|
|
61
|
+
expect(rawTransaction.fees).toBe("");
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
//# sourceMappingURL=transaction.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.test.js","sourceRoot":"","sources":["../../src/bridge/transaction.test.ts"],"names":[],"mappings":";;AAAA,+CAAyC;AACzC,4DAAyF;AACzF,+CAAwF;AAExF,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,MAAM,OAAO,GAAG,IAAA,qCAAoB,GAAE,CAAC;IAEvC,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;QACjC,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;YAC3C,MAAM,WAAW,GAAG,IAAA,yCAAwB,EAAC;gBAC3C,MAAM,EAAE,IAAI,wBAAS,CAAC,SAAS,CAAC;gBAChC,SAAS,EAAE,OAAO;aACnB,CAAC,CAAC;YAEH,MAAM,SAAS,GAAG,IAAA,+BAAiB,EAAC,WAAW,EAAE,OAAO,CAAC,CAAC;YAC1D,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;YACvD,MAAM,WAAW,GAAG,IAAA,yCAAwB,EAAC,EAAE,YAAY,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,CAAC;YAEzF,MAAM,SAAS,GAAG,IAAA,+BAAiB,EAAC,WAAW,EAAE,OAAO,CAAC,CAAC;YAC1D,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;QAClC,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;YAC7C,MAAM,cAAc,GAAG;gBACrB,MAAM,EAAE,KAAc;gBACtB,IAAI,EAAE,MAAM;gBACZ,MAAM,EAAE,WAAW;gBACnB,SAAS,EAAE,OAAO;gBAClB,YAAY,EAAE,KAAK;gBACnB,IAAI,EAAE,SAAS;aAChB,CAAC;YAEF,MAAM,WAAW,GAAG,IAAA,gCAAkB,EAAC,cAAc,CAAC,CAAC;YACvD,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC;gBAC1B,MAAM,EAAE,KAAK;gBACb,IAAI,EAAE,MAAM;gBACZ,MAAM,EAAE,IAAI,wBAAS,CAAC,WAAW,CAAC;gBAClC,SAAS,EAAE,OAAO;gBAClB,YAAY,EAAE,KAAK;gBACnB,IAAI,EAAE,IAAI,wBAAS,CAAC,SAAS,CAAC;gBAC9B,MAAM,EAAE,EAAE;aACX,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;QAChC,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;YAC3C,MAAM,WAAW,GAAG,IAAA,yCAAwB,GAAE,CAAC;YAE/C,MAAM,cAAc,GAAG,IAAA,8BAAgB,EAAC,WAAW,CAAC,CAAC;YACrD,MAAM,CAAC,cAAc,CAAC,CAAC,OAAO,CAAC;gBAC7B,MAAM,EAAE,KAAc;gBACtB,IAAI,EAAE,MAAM;gBACZ,MAAM,EAAE,YAAY;gBACpB,SAAS,EAAE,oEAAoE;gBAC/E,YAAY,EAAE,KAAK;gBACnB,IAAI,EAAE,SAAS;aAChB,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,yBAAyB,EAAE,GAAG,EAAE;YACjC,MAAM,WAAW,GAAG,IAAA,yCAAwB,EAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;YAE7D,MAAM,cAAc,GAAG,IAAA,8BAAgB,EAAC,WAAW,CAAC,CAAC;YACrD,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { BigNumber } from "bignumber.js";
|
|
2
|
+
import { AccountLike } from "@ledgerhq/types-live";
|
|
3
|
+
import type { SuiAccount, Transaction } from "../types";
|
|
4
|
+
export declare const MAX_AMOUNT_INPUT = 18446744073709552000;
|
|
5
|
+
export declare enum AccountType {
|
|
6
|
+
Account = "Account",
|
|
7
|
+
TokenAccount = "TokenAccount"
|
|
8
|
+
}
|
|
9
|
+
export declare function getAccountUnit(account: AccountLike): {
|
|
10
|
+
name: string;
|
|
11
|
+
code: string;
|
|
12
|
+
magnitude: number;
|
|
13
|
+
};
|
|
14
|
+
/**
|
|
15
|
+
* Calculates the amount to be sent in a transaction based on the account's balance and transaction details.
|
|
16
|
+
*
|
|
17
|
+
* @param {Object} params - The parameters for the calculation.
|
|
18
|
+
* @param {SuiAccount} params.account - The account from which the amount is being sent.
|
|
19
|
+
* @param {Transaction} params.transaction - The transaction details including the amount and fees.
|
|
20
|
+
* @returns {BigNumber} - The calculated amount that can be sent, ensuring it does not exceed the maximum allowed or fall below zero.
|
|
21
|
+
*/
|
|
22
|
+
export declare const calculateAmount: ({ account, transaction, }: {
|
|
23
|
+
account: SuiAccount;
|
|
24
|
+
transaction: Transaction;
|
|
25
|
+
}) => BigNumber;
|
|
26
|
+
export declare const assertUnreachable: (_: never) => never;
|
|
27
|
+
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/bridge/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAGxD,eAAO,MAAM,gBAAgB,uBAAqB,CAAC;AAEnD,oBAAY,WAAW;IACrB,OAAO,YAAY;IACnB,YAAY,iBAAiB;CAC9B;AAED,wBAAgB,cAAc,CAAC,OAAO,EAAE,WAAW,GAAG;IACpD,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;CACnB,CAMA;AAcD;;;;;;;GAOG;AACH,eAAO,MAAM,eAAe;aAIjB,UAAU;iBACN,WAAW;MACtB,SAcH,CAAC;AAEF,eAAO,MAAM,iBAAiB,MAAO,KAAK,KAAG,KAE5C,CAAC"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.assertUnreachable = exports.calculateAmount = exports.getAccountUnit = exports.AccountType = exports.MAX_AMOUNT_INPUT = void 0;
|
|
4
|
+
const bignumber_js_1 = require("bignumber.js");
|
|
5
|
+
// eslint-disable-next-line @typescript-eslint/no-loss-of-precision
|
|
6
|
+
exports.MAX_AMOUNT_INPUT = 0xffffffffffffffff;
|
|
7
|
+
var AccountType;
|
|
8
|
+
(function (AccountType) {
|
|
9
|
+
AccountType["Account"] = "Account";
|
|
10
|
+
AccountType["TokenAccount"] = "TokenAccount";
|
|
11
|
+
})(AccountType || (exports.AccountType = AccountType = {}));
|
|
12
|
+
function getAccountUnit(account) {
|
|
13
|
+
if (account.type === AccountType.TokenAccount) {
|
|
14
|
+
return account.token.units[0];
|
|
15
|
+
}
|
|
16
|
+
return account.currency.units[0];
|
|
17
|
+
}
|
|
18
|
+
exports.getAccountUnit = getAccountUnit;
|
|
19
|
+
/**
|
|
20
|
+
* Calculate the maximum amount that can be sent from the account after deducting fees.
|
|
21
|
+
*
|
|
22
|
+
* @param {SuiAccount} account - The account from which the amount is being sent.
|
|
23
|
+
* @param {Transaction} transaction - The transaction details including fees.
|
|
24
|
+
* @returns {BigNumber} - The maximum amount that can be sent, or 0 if insufficient balance.
|
|
25
|
+
*/
|
|
26
|
+
const calculateMaxSend = (account, transaction) => {
|
|
27
|
+
const amount = account.spendableBalance.minus(transaction.fees || 0);
|
|
28
|
+
return amount.lt(0) ? new bignumber_js_1.BigNumber(0) : amount;
|
|
29
|
+
};
|
|
30
|
+
/**
|
|
31
|
+
* Calculates the amount to be sent in a transaction based on the account's balance and transaction details.
|
|
32
|
+
*
|
|
33
|
+
* @param {Object} params - The parameters for the calculation.
|
|
34
|
+
* @param {SuiAccount} params.account - The account from which the amount is being sent.
|
|
35
|
+
* @param {Transaction} params.transaction - The transaction details including the amount and fees.
|
|
36
|
+
* @returns {BigNumber} - The calculated amount that can be sent, ensuring it does not exceed the maximum allowed or fall below zero.
|
|
37
|
+
*/
|
|
38
|
+
const calculateAmount = ({ account, transaction, }) => {
|
|
39
|
+
let amount = transaction.amount;
|
|
40
|
+
if (transaction.useAllAmount) {
|
|
41
|
+
switch (transaction.mode) {
|
|
42
|
+
case "send":
|
|
43
|
+
amount = calculateMaxSend(account, transaction);
|
|
44
|
+
break;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
else if (transaction.amount.gt(exports.MAX_AMOUNT_INPUT)) {
|
|
48
|
+
return new bignumber_js_1.BigNumber(exports.MAX_AMOUNT_INPUT);
|
|
49
|
+
}
|
|
50
|
+
return amount.lt(0) ? new bignumber_js_1.BigNumber(0) : amount;
|
|
51
|
+
};
|
|
52
|
+
exports.calculateAmount = calculateAmount;
|
|
53
|
+
const assertUnreachable = (_) => {
|
|
54
|
+
throw new Error("unreachable assertion failed");
|
|
55
|
+
};
|
|
56
|
+
exports.assertUnreachable = assertUnreachable;
|
|
57
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/bridge/utils.ts"],"names":[],"mappings":";;;AAAA,+CAAyC;AAIzC,mEAAmE;AACtD,QAAA,gBAAgB,GAAG,kBAAkB,CAAC;AAEnD,IAAY,WAGX;AAHD,WAAY,WAAW;IACrB,kCAAmB,CAAA;IACnB,4CAA6B,CAAA;AAC/B,CAAC,EAHW,WAAW,2BAAX,WAAW,QAGtB;AAED,SAAgB,cAAc,CAAC,OAAoB;IAKjD,IAAI,OAAO,CAAC,IAAI,KAAK,WAAW,CAAC,YAAY,EAAE,CAAC;QAC9C,OAAO,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAChC,CAAC;IAED,OAAO,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACnC,CAAC;AAVD,wCAUC;AAED;;;;;;GAMG;AACH,MAAM,gBAAgB,GAAG,CAAC,OAAmB,EAAE,WAAwB,EAAa,EAAE;IACpF,MAAM,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC;IACrE,OAAO,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,wBAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;AAClD,CAAC,CAAC;AAEF;;;;;;;GAOG;AACI,MAAM,eAAe,GAAG,CAAC,EAC9B,OAAO,EACP,WAAW,GAIZ,EAAa,EAAE;IACd,IAAI,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC;IAEhC,IAAI,WAAW,CAAC,YAAY,EAAE,CAAC;QAC7B,QAAQ,WAAW,CAAC,IAAI,EAAE,CAAC;YACzB,KAAK,MAAM;gBACT,MAAM,GAAG,gBAAgB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;gBAChD,MAAM;QACV,CAAC;IACH,CAAC;SAAM,IAAI,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,wBAAgB,CAAC,EAAE,CAAC;QACnD,OAAO,IAAI,wBAAS,CAAC,wBAAgB,CAAC,CAAC;IACzC,CAAC;IAED,OAAO,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,wBAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;AAClD,CAAC,CAAC;AApBW,QAAA,eAAe,mBAoB1B;AAEK,MAAM,iBAAiB,GAAG,CAAC,CAAQ,EAAS,EAAE;IACnD,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;AAClD,CAAC,CAAC;AAFW,QAAA,iBAAiB,qBAE5B"}
|
package/lib/config.d.ts
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { CryptoCurrency } from "@ledgerhq/types-cryptoassets";
|
|
2
|
+
import { type CurrencyConfig } from "@ledgerhq/coin-framework/config";
|
|
3
|
+
export type SuiConfig = {
|
|
4
|
+
status: {
|
|
5
|
+
type: "active";
|
|
6
|
+
};
|
|
7
|
+
};
|
|
8
|
+
export type SuiCoinConfig = CurrencyConfig & SuiConfig;
|
|
9
|
+
type CoinConfigType = {
|
|
10
|
+
setCoinConfig: (config: (currency?: CryptoCurrency) => SuiCoinConfig) => void;
|
|
11
|
+
getCoinConfig: (currency?: CryptoCurrency) => SuiCoinConfig;
|
|
12
|
+
};
|
|
13
|
+
declare const coinConfig: CoinConfigType;
|
|
14
|
+
export default coinConfig;
|
|
15
|
+
//# sourceMappingURL=config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAC9D,OAAuB,EAAE,KAAK,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAEtF,MAAM,MAAM,SAAS,GAAG;IACtB,MAAM,EAAE;QACN,IAAI,EAAE,QAAQ,CAAC;KAChB,CAAC;CACH,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG,cAAc,GAAG,SAAS,CAAC;AAEvD,KAAK,cAAc,GAAG;IACpB,aAAa,EAAE,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,cAAc,KAAK,aAAa,KAAK,IAAI,CAAC;IAC9E,aAAa,EAAE,CAAC,QAAQ,CAAC,EAAE,cAAc,KAAK,aAAa,CAAC;CAC7D,CAAC;AAEF,QAAA,MAAM,UAAU,EAAE,cAAgD,CAAC;AAEnE,eAAe,UAAU,CAAC"}
|
package/lib/config.js
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const config_1 = __importDefault(require("@ledgerhq/coin-framework/config"));
|
|
7
|
+
const coinConfig = (0, config_1.default)();
|
|
8
|
+
exports.default = coinConfig;
|
|
9
|
+
//# sourceMappingURL=config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":";;;;;AACA,6EAAsF;AAetF,MAAM,UAAU,GAAmB,IAAA,gBAAc,GAAiB,CAAC;AAEnE,kBAAe,UAAU,CAAC"}
|
package/lib/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AAExB,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC"}
|
package/lib/index.js
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.createBridges = void 0;
|
|
18
|
+
__exportStar(require("./types"), exports);
|
|
19
|
+
var index_1 = require("./bridge/index");
|
|
20
|
+
Object.defineProperty(exports, "createBridges", { enumerable: true, get: function () { return index_1.createBridges; } });
|
|
21
|
+
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,0CAAwB;AAExB,wCAA+C;AAAtC,sGAAA,aAAa,OAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Broadcasts a transaction to the Sui network.
|
|
3
|
+
*
|
|
4
|
+
* @param {string} unsigned - The unsigned transaction block to be broadcasted.
|
|
5
|
+
* @param {string} serializedSignature - The serialized signature for the transaction.
|
|
6
|
+
* @returns {Promise<string>} A promise that resolves to the transaction digest.
|
|
7
|
+
*/
|
|
8
|
+
export declare function broadcast(unsigned: string, serializedSignature: string): Promise<string>;
|
|
9
|
+
//# sourceMappingURL=broadcast.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/logic/broadcast.ts"],"names":[],"mappings":"AAEA;;;;;;GAMG;AACH,wBAAsB,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,mBAAmB,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAS9F"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.broadcast = void 0;
|
|
7
|
+
const network_1 = __importDefault(require("../network"));
|
|
8
|
+
/**
|
|
9
|
+
* Broadcasts a transaction to the Sui network.
|
|
10
|
+
*
|
|
11
|
+
* @param {string} unsigned - The unsigned transaction block to be broadcasted.
|
|
12
|
+
* @param {string} serializedSignature - The serialized signature for the transaction.
|
|
13
|
+
* @returns {Promise<string>} A promise that resolves to the transaction digest.
|
|
14
|
+
*/
|
|
15
|
+
async function broadcast(unsigned, serializedSignature) {
|
|
16
|
+
const result = await network_1.default.executeTransactionBlock({
|
|
17
|
+
transactionBlock: unsigned,
|
|
18
|
+
signature: serializedSignature,
|
|
19
|
+
options: {
|
|
20
|
+
showEffects: true,
|
|
21
|
+
},
|
|
22
|
+
});
|
|
23
|
+
return result?.digest ?? "";
|
|
24
|
+
}
|
|
25
|
+
exports.broadcast = broadcast;
|
|
26
|
+
//# sourceMappingURL=broadcast.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/logic/broadcast.ts"],"names":[],"mappings":";;;;;;AAAA,yDAAgC;AAEhC;;;;;;GAMG;AACI,KAAK,UAAU,SAAS,CAAC,QAAgB,EAAE,mBAA2B;IAC3E,MAAM,MAAM,GAAG,MAAM,iBAAM,CAAC,uBAAuB,CAAC;QAClD,gBAAgB,EAAE,QAAQ;QAC1B,SAAS,EAAE,mBAAmB;QAC9B,OAAO,EAAE;YACP,WAAW,EAAE,IAAI;SAClB;KACF,CAAC,CAAC;IACH,OAAO,MAAM,EAAE,MAAM,IAAI,EAAE,CAAC;AAC9B,CAAC;AATD,8BASC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
import type { CoreTransaction } from "../types";
|
|
3
|
+
export type CreateExtrinsicArg = {
|
|
4
|
+
mode: string;
|
|
5
|
+
amount: BigNumber;
|
|
6
|
+
recipient: string;
|
|
7
|
+
useAllAmount?: boolean | undefined;
|
|
8
|
+
};
|
|
9
|
+
/**
|
|
10
|
+
* Crafts a transaction
|
|
11
|
+
*
|
|
12
|
+
* @param {string} address - The address of the sender.
|
|
13
|
+
* @param {CreateExtrinsicArg} extractExtrinsicArg - The arguments for creating the transaction, including mode, amount, recipient, and optional useAllAmount.
|
|
14
|
+
* @returns {Promise<CoreTransaction>} A promise that resolves to the crafted CoreTransaction containing the unsigned transaction.
|
|
15
|
+
*/
|
|
16
|
+
export declare function craftTransaction(address: string, extractExtrinsicArg: CreateExtrinsicArg): Promise<CoreTransaction>;
|
|
17
|
+
//# sourceMappingURL=craftTransaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"craftTransaction.d.ts","sourceRoot":"","sources":["../../src/logic/craftTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAGhD,MAAM,MAAM,kBAAkB,GAAG;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,SAAS,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;CACpC,CAAC;AAEF;;;;;;GAMG;AACH,wBAAsB,gBAAgB,CACpC,OAAO,EAAE,MAAM,EACf,mBAAmB,EAAE,kBAAkB,GACtC,OAAO,CAAC,eAAe,CAAC,CAM1B"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.craftTransaction = void 0;
|
|
7
|
+
const network_1 = __importDefault(require("../network"));
|
|
8
|
+
/**
|
|
9
|
+
* Crafts a transaction
|
|
10
|
+
*
|
|
11
|
+
* @param {string} address - The address of the sender.
|
|
12
|
+
* @param {CreateExtrinsicArg} extractExtrinsicArg - The arguments for creating the transaction, including mode, amount, recipient, and optional useAllAmount.
|
|
13
|
+
* @returns {Promise<CoreTransaction>} A promise that resolves to the crafted CoreTransaction containing the unsigned transaction.
|
|
14
|
+
*/
|
|
15
|
+
async function craftTransaction(address, extractExtrinsicArg) {
|
|
16
|
+
const unsigned = await network_1.default.createTransaction(address, extractExtrinsicArg);
|
|
17
|
+
return {
|
|
18
|
+
unsigned,
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
exports.craftTransaction = craftTransaction;
|
|
22
|
+
//# sourceMappingURL=craftTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"craftTransaction.js","sourceRoot":"","sources":["../../src/logic/craftTransaction.ts"],"names":[],"mappings":";;;;;;AAEA,yDAAgC;AAShC;;;;;;GAMG;AACI,KAAK,UAAU,gBAAgB,CACpC,OAAe,EACf,mBAAuC;IAEvC,MAAM,QAAQ,GAAG,MAAM,iBAAM,CAAC,iBAAiB,CAAC,OAAO,EAAE,mBAAmB,CAAC,CAAC;IAE9E,OAAO;QACL,QAAQ;KACT,CAAC;AACJ,CAAC;AATD,4CASC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Transaction } from "../types";
|
|
2
|
+
/**
|
|
3
|
+
* Estimates the fees for a transaction
|
|
4
|
+
*
|
|
5
|
+
* @param {string} sender - The address of the sender for whom the fees are being estimated.
|
|
6
|
+
* @param {Transaction} transaction - The transaction details for which the fees are to be estimated.
|
|
7
|
+
* @returns {Promise<bigint>} A promise that resolves to the estimated fees in bigint format.
|
|
8
|
+
*/
|
|
9
|
+
export declare function estimateFees(sender: string, transaction: Transaction): Promise<bigint>;
|
|
10
|
+
//# sourceMappingURL=estimateFees.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estimateFees.d.ts","sourceRoot":"","sources":["../../src/logic/estimateFees.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAE5C;;;;;;GAMG;AACH,wBAAsB,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC,CAG5F"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.estimateFees = void 0;
|
|
7
|
+
const network_1 = __importDefault(require("../network"));
|
|
8
|
+
/**
|
|
9
|
+
* Estimates the fees for a transaction
|
|
10
|
+
*
|
|
11
|
+
* @param {string} sender - The address of the sender for whom the fees are being estimated.
|
|
12
|
+
* @param {Transaction} transaction - The transaction details for which the fees are to be estimated.
|
|
13
|
+
* @returns {Promise<bigint>} A promise that resolves to the estimated fees in bigint format.
|
|
14
|
+
*/
|
|
15
|
+
async function estimateFees(sender, transaction) {
|
|
16
|
+
const { gasBudget } = await network_1.default.paymentInfo(sender, transaction);
|
|
17
|
+
return BigInt(gasBudget);
|
|
18
|
+
}
|
|
19
|
+
exports.estimateFees = estimateFees;
|
|
20
|
+
//# sourceMappingURL=estimateFees.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estimateFees.js","sourceRoot":"","sources":["../../src/logic/estimateFees.ts"],"names":[],"mappings":";;;;;;AAAA,yDAAgC;AAGhC;;;;;;GAMG;AACI,KAAK,UAAU,YAAY,CAAC,MAAc,EAAE,WAAwB;IACzE,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,iBAAM,CAAC,WAAW,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IACpE,OAAO,MAAM,CAAC,SAAS,CAAC,CAAC;AAC3B,CAAC;AAHD,oCAGC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/logic/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,KAAK,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAC/E,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.broadcast = exports.estimateFees = exports.craftTransaction = void 0;
|
|
4
|
+
var craftTransaction_1 = require("./craftTransaction");
|
|
5
|
+
Object.defineProperty(exports, "craftTransaction", { enumerable: true, get: function () { return craftTransaction_1.craftTransaction; } });
|
|
6
|
+
var estimateFees_1 = require("./estimateFees");
|
|
7
|
+
Object.defineProperty(exports, "estimateFees", { enumerable: true, get: function () { return estimateFees_1.estimateFees; } });
|
|
8
|
+
var broadcast_1 = require("./broadcast");
|
|
9
|
+
Object.defineProperty(exports, "broadcast", { enumerable: true, get: function () { return broadcast_1.broadcast; } });
|
|
10
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/logic/index.ts"],"names":[],"mappings":";;;AAAA,uDAA+E;AAAtE,oHAAA,gBAAgB,OAAA;AACzB,+CAA8C;AAArC,4GAAA,YAAY,OAAA;AACrB,yCAAwC;AAA/B,sGAAA,SAAS,OAAA"}
|