@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
package/.eslintrc.js
ADDED
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
module.exports = {
|
|
2
|
+
env: {
|
|
3
|
+
browser: true,
|
|
4
|
+
es6: true,
|
|
5
|
+
},
|
|
6
|
+
rules: {
|
|
7
|
+
"no-console": ["error", { allow: ["warn", "error"] }],
|
|
8
|
+
"@typescript-eslint/no-empty-function": "off",
|
|
9
|
+
"@typescript-eslint/no-explicit-any": "warn",
|
|
10
|
+
},
|
|
11
|
+
overrides: [
|
|
12
|
+
{
|
|
13
|
+
files: ["src/test/**/*.{ts,tsx}"],
|
|
14
|
+
env: {
|
|
15
|
+
"jest/globals": true,
|
|
16
|
+
},
|
|
17
|
+
plugins: ["jest"],
|
|
18
|
+
rules: {
|
|
19
|
+
"no-console": "off",
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
],
|
|
23
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
{
|
|
2
|
+
"entry": [
|
|
3
|
+
"src/api/chain/index.ts",
|
|
4
|
+
"src/bridge/index.ts",
|
|
5
|
+
"src/signer/index.ts",
|
|
6
|
+
"src/index.ts",
|
|
7
|
+
"src/bridge/transaction.ts",
|
|
8
|
+
"src/test/cli.ts"
|
|
9
|
+
],
|
|
10
|
+
"ignorePatterns": [
|
|
11
|
+
"**/node_modules/**",
|
|
12
|
+
"**/*.fixture.ts",
|
|
13
|
+
"**/*.mock.ts",
|
|
14
|
+
"**/*.test.{js,jsx,ts,tsx}"
|
|
15
|
+
],
|
|
16
|
+
"ignoreUnresolved": [],
|
|
17
|
+
"ignoreUnimported": [],
|
|
18
|
+
"ignoreUnused": []
|
|
19
|
+
}
|
package/CHANGELOG.md
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
# @ledgerhq/coin-sui
|
|
2
|
+
|
|
3
|
+
## 0.2.0-nightly.0
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- [#9611](https://github.com/LedgerHQ/ledger-live/pull/9611) [`a656e47`](https://github.com/LedgerHQ/ledger-live/commit/a656e47c1dc3ac8b578debf9cf80eab370c7086f) Thanks [@hedi-edelbloute](https://github.com/hedi-edelbloute)! - Add SUI coin send and receive abilities
|
|
8
|
+
|
|
9
|
+
### Patch Changes
|
|
10
|
+
|
|
11
|
+
- Updated dependencies [[`1ec6a03`](https://github.com/LedgerHQ/ledger-live/commit/1ec6a03580ea1136dab22747721942056506d589), [`2effe04`](https://github.com/LedgerHQ/ledger-live/commit/2effe04d9d4b3e407ed25da3b9f11324a82126d3), [`a656e47`](https://github.com/LedgerHQ/ledger-live/commit/a656e47c1dc3ac8b578debf9cf80eab370c7086f)]:
|
|
12
|
+
- @ledgerhq/types-live@6.64.0-nightly.1
|
|
13
|
+
- @ledgerhq/types-cryptoassets@7.21.0-nightly.0
|
|
14
|
+
- @ledgerhq/cryptoassets@13.14.0-nightly.1
|
|
15
|
+
- @ledgerhq/hw-app-sui@1.1.0-nightly.0
|
|
16
|
+
- @ledgerhq/coin-framework@2.4.0-nightly.3
|
package/LICENSE.txt
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
The MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2017-present Ledger https://www.ledger.com/
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in
|
|
13
|
+
all copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
21
|
+
THE SOFTWARE.
|
package/jest.config.js
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/** @type {import('ts-jest/dist/types').JestConfigWithTsJest} */
|
|
2
|
+
module.exports = {
|
|
3
|
+
collectCoverageFrom: ["src/**/*.ts"],
|
|
4
|
+
coveragePathIgnorePatterns: ["test/cli.ts", ".*\\.integration\\.test\\.[tj]s"],
|
|
5
|
+
coverageDirectory: "coverage",
|
|
6
|
+
preset: "ts-jest",
|
|
7
|
+
testEnvironment: "node",
|
|
8
|
+
testPathIgnorePatterns: ["lib/", "lib-es/", ".*\\.integration\\.test\\.[tj]s"],
|
|
9
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { Transaction } from "@mysten/sui/transactions";
|
|
2
|
+
import type { TransactionStatusCommon } from "@ledgerhq/types-live";
|
|
3
|
+
import type { AccountInfoResponse } from "../../types";
|
|
4
|
+
export type Config = {
|
|
5
|
+
readonly endpoint: string;
|
|
6
|
+
};
|
|
7
|
+
export type ChainAPI = Readonly<{
|
|
8
|
+
getBalance: (address: string) => Promise<number>;
|
|
9
|
+
getLatestBlockhash: () => Promise<string>;
|
|
10
|
+
getFeeForMessage: (message: Transaction) => Promise<number | null>;
|
|
11
|
+
getAccountInfo: (address: string) => Promise<AccountInfoResponse>;
|
|
12
|
+
sendRawTransaction: (transaction: Transaction) => Promise<string>;
|
|
13
|
+
getTransactionStatus: (signature: string) => Promise<TransactionStatusCommon>;
|
|
14
|
+
config: Config;
|
|
15
|
+
}>;
|
|
16
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/api/chain/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AACpE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAEvD,MAAM,MAAM,MAAM,GAAG;IACnB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;CAC3B,CAAC;AAEF,MAAM,MAAM,QAAQ,GAAG,QAAQ,CAAC;IAC9B,UAAU,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;IACjD,kBAAkB,EAAE,MAAM,OAAO,CAAC,MAAM,CAAC,CAAC;IAC1C,gBAAgB,EAAE,CAAC,OAAO,EAAE,WAAW,KAAK,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;IACnE,cAAc,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,OAAO,CAAC,mBAAmB,CAAC,CAAC;IAClE,kBAAkB,EAAE,CAAC,WAAW,EAAE,WAAW,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;IAClE,oBAAoB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,uBAAuB,CAAC,CAAC;IAC9E,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/api/chain/index.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bridge.integration.test.d.ts","sourceRoot":"","sources":["../../src/bridge/bridge.integration.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAA8B,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC/E,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAqIvC,eAAO,MAAM,OAAO,EAAE,WAAW,CAAC,WAAW,CAK5C,CAAC"}
|
|
@@ -0,0 +1,136 @@
|
|
|
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.dataset = void 0;
|
|
7
|
+
const errors_1 = require("@ledgerhq/errors");
|
|
8
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
9
|
+
const transaction_1 = require("./transaction");
|
|
10
|
+
const OWNER = "0xba7080172a6d957b9ed2e3eb643529860be963cf4af896fb84f1cde00f46b561";
|
|
11
|
+
const RECIPIENT = "0x117527fdcf2f5f6e82fa499c0398def2643550d63f7e8311245d75f4635f0435";
|
|
12
|
+
const DEFAULT_AMOUNT = "10";
|
|
13
|
+
const suiAccount1 = {
|
|
14
|
+
id: `js:2:sui:${OWNER}:`,
|
|
15
|
+
seedIdentifier: OWNER,
|
|
16
|
+
name: `Sui ${OWNER}`,
|
|
17
|
+
derivationMode: "",
|
|
18
|
+
index: 0,
|
|
19
|
+
freshAddress: OWNER,
|
|
20
|
+
freshAddressPath: "44'/784'/0'/0'/0'",
|
|
21
|
+
pendingOperations: [],
|
|
22
|
+
operations: [],
|
|
23
|
+
currencyId: "sui",
|
|
24
|
+
balance: "0",
|
|
25
|
+
blockHeight: 0,
|
|
26
|
+
lastSyncDate: "",
|
|
27
|
+
xpub: "",
|
|
28
|
+
};
|
|
29
|
+
const sui = {
|
|
30
|
+
scanAccounts: [
|
|
31
|
+
{
|
|
32
|
+
name: "sui seed 1",
|
|
33
|
+
apdus: `
|
|
34
|
+
=> 0002000021001b7cf66fe039a16326933b3fe94627a7ddc4d18539b925bdb80f9294f88df4af
|
|
35
|
+
<= 021b7cf66fe039a16326933b3fe94627a7ddc4d18539b925bdb80f9294f88df4af9000
|
|
36
|
+
=> 000200003a010000000000000000000000000000000000000000000000000000000000000000062c0000801003008000000080000000800000008000000080
|
|
37
|
+
<= 0120e5fb8c817b97e9e9aec677b9e822e8a60c7471624f36b701c94560b88195a8e720eba97be74a8e66a2a423d18d4d73b6866503c406b376fb49f6bf0aacb6d508279000
|
|
38
|
+
=> 0002000021007cfea3aa1e07cc4b500c237a8bf8dcb31d5cb855f29dfdeb92f9e4df9493a6cd
|
|
39
|
+
<= 027cfea3aa1e07cc4b500c237a8bf8dcb31d5cb855f29dfdeb92f9e4df9493a6cd9000
|
|
40
|
+
=> 0002000036010000000000000000000000000000000000000000000000000000000000000000052c00008010030080000000800000008000000080
|
|
41
|
+
<= 0120e95d14c7b906d66090556e0fce65ed3b71167b37e0c19136857d35b44f082ba720117527fdcf2f5f6e82fa499c0398def2643550d63f7e8311245d75f4635f04359000
|
|
42
|
+
`,
|
|
43
|
+
},
|
|
44
|
+
],
|
|
45
|
+
accounts: [
|
|
46
|
+
{
|
|
47
|
+
raw: suiAccount1,
|
|
48
|
+
transactions: [
|
|
49
|
+
{
|
|
50
|
+
name: "recipient and sender must not be the same",
|
|
51
|
+
transaction: (0, transaction_1.fromTransactionRaw)({
|
|
52
|
+
family: "sui",
|
|
53
|
+
recipient: OWNER,
|
|
54
|
+
amount: DEFAULT_AMOUNT,
|
|
55
|
+
mode: "send",
|
|
56
|
+
}),
|
|
57
|
+
expectedStatus: {
|
|
58
|
+
amount: new bignumber_js_1.default(DEFAULT_AMOUNT),
|
|
59
|
+
errors: { recipient: new errors_1.InvalidAddressBecauseDestinationIsAlsoSource() },
|
|
60
|
+
warnings: {},
|
|
61
|
+
},
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
name: "send tx",
|
|
65
|
+
transaction: (0, transaction_1.fromTransactionRaw)({
|
|
66
|
+
amount: "2000000",
|
|
67
|
+
recipient: RECIPIENT,
|
|
68
|
+
useAllAmount: false,
|
|
69
|
+
family: "sui",
|
|
70
|
+
mode: "send",
|
|
71
|
+
fees: "0",
|
|
72
|
+
}),
|
|
73
|
+
expectedStatus: {
|
|
74
|
+
errors: {},
|
|
75
|
+
warnings: {},
|
|
76
|
+
estimatedFees: (0, bignumber_js_1.default)("0"),
|
|
77
|
+
amount: (0, bignumber_js_1.default)("2000000"),
|
|
78
|
+
totalSpent: (0, bignumber_js_1.default)("2000000"),
|
|
79
|
+
},
|
|
80
|
+
},
|
|
81
|
+
{
|
|
82
|
+
name: "not enough balance",
|
|
83
|
+
transaction: (0, transaction_1.fromTransactionRaw)({
|
|
84
|
+
family: "sui",
|
|
85
|
+
recipient: RECIPIENT,
|
|
86
|
+
amount: "10000000000000000000",
|
|
87
|
+
mode: "send",
|
|
88
|
+
}),
|
|
89
|
+
expectedStatus: {
|
|
90
|
+
errors: {
|
|
91
|
+
amount: new errors_1.NotEnoughBalance(),
|
|
92
|
+
},
|
|
93
|
+
warnings: {},
|
|
94
|
+
},
|
|
95
|
+
},
|
|
96
|
+
{
|
|
97
|
+
name: "recipient is required",
|
|
98
|
+
transaction: (0, transaction_1.fromTransactionRaw)({
|
|
99
|
+
family: "sui",
|
|
100
|
+
recipient: "",
|
|
101
|
+
amount: "1000000",
|
|
102
|
+
mode: "send",
|
|
103
|
+
}),
|
|
104
|
+
expectedStatus: {
|
|
105
|
+
errors: {
|
|
106
|
+
recipient: new errors_1.RecipientRequired(),
|
|
107
|
+
},
|
|
108
|
+
warnings: {},
|
|
109
|
+
},
|
|
110
|
+
},
|
|
111
|
+
{
|
|
112
|
+
name: "amount is required",
|
|
113
|
+
transaction: (0, transaction_1.fromTransactionRaw)({
|
|
114
|
+
family: "sui",
|
|
115
|
+
recipient: RECIPIENT,
|
|
116
|
+
amount: "0",
|
|
117
|
+
mode: "send",
|
|
118
|
+
}),
|
|
119
|
+
expectedStatus: {
|
|
120
|
+
errors: {
|
|
121
|
+
amount: new errors_1.AmountRequired(),
|
|
122
|
+
},
|
|
123
|
+
warnings: {},
|
|
124
|
+
},
|
|
125
|
+
},
|
|
126
|
+
],
|
|
127
|
+
},
|
|
128
|
+
],
|
|
129
|
+
};
|
|
130
|
+
exports.dataset = {
|
|
131
|
+
implementations: ["js"],
|
|
132
|
+
currencies: {
|
|
133
|
+
sui,
|
|
134
|
+
},
|
|
135
|
+
};
|
|
136
|
+
//# sourceMappingURL=bridge.integration.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bridge.integration.test.js","sourceRoot":"","sources":["../../src/bridge/bridge.integration.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { AccountBridge } from "@ledgerhq/types-live";
|
|
2
|
+
import { Transaction } from "../types";
|
|
3
|
+
/**
|
|
4
|
+
* Broadcast the signed transaction
|
|
5
|
+
* @param {Object} params - The parameters for broadcasting the transaction.
|
|
6
|
+
* @param {Object} params.signedOperation - The signed operation to be broadcasted.
|
|
7
|
+
* @param {Object} params.signedOperation.operation - The operation details.
|
|
8
|
+
* @param {Object} params.signedOperation.rawData - The raw data of the signed operation.
|
|
9
|
+
* @returns {Promise<Object>} The operation with the hash of the transaction.
|
|
10
|
+
*/
|
|
11
|
+
export declare const broadcast: AccountBridge<Transaction>["broadcast"];
|
|
12
|
+
//# sourceMappingURL=broadcast.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAG1D,OAAO,EAAsB,WAAW,EAAE,MAAM,UAAU,CAAC;AAE3D;;;;;;;GAOG;AACH,eAAO,MAAM,SAAS,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,WAAW,CAO7D,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.broadcast = void 0;
|
|
4
|
+
const operation_1 = require("@ledgerhq/coin-framework/operation");
|
|
5
|
+
const logic_1 = require("../logic");
|
|
6
|
+
/**
|
|
7
|
+
* Broadcast the signed transaction
|
|
8
|
+
* @param {Object} params - The parameters for broadcasting the transaction.
|
|
9
|
+
* @param {Object} params.signedOperation - The signed operation to be broadcasted.
|
|
10
|
+
* @param {Object} params.signedOperation.operation - The operation details.
|
|
11
|
+
* @param {Object} params.signedOperation.rawData - The raw data of the signed operation.
|
|
12
|
+
* @returns {Promise<Object>} The operation with the hash of the transaction.
|
|
13
|
+
*/
|
|
14
|
+
const broadcast = async ({ signedOperation }) => {
|
|
15
|
+
const { operation, rawData: { unsigned, serializedSignature }, } = signedOperation;
|
|
16
|
+
const hash = await (0, logic_1.broadcast)(unsigned, serializedSignature);
|
|
17
|
+
return (0, operation_1.patchOperationWithHash)(operation, hash);
|
|
18
|
+
};
|
|
19
|
+
exports.broadcast = broadcast;
|
|
20
|
+
//# sourceMappingURL=broadcast.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":";;;AACA,kEAA4E;AAC5E,oCAAuD;AAGvD;;;;;;;GAOG;AACI,MAAM,SAAS,GAA4C,KAAK,EAAE,EAAE,eAAe,EAAE,EAAE,EAAE;IAC9F,MAAM,EACJ,SAAS,EACT,OAAO,EAAE,EAAE,QAAQ,EAAE,mBAAmB,EAAE,GAC3C,GAAG,eAAgD,CAAC;IACrD,MAAM,IAAI,GAAG,MAAM,IAAA,iBAAc,EAAC,QAAQ,EAAE,mBAAmB,CAAC,CAAC;IACjE,OAAO,IAAA,kCAAsB,EAAC,SAAS,EAAE,IAAI,CAAC,CAAC;AACjD,CAAC,CAAC;AAPW,QAAA,SAAS,aAOpB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.test.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const bridge_fixture_1 = require("../types/bridge.fixture");
|
|
4
|
+
const broadcast_1 = require("./broadcast");
|
|
5
|
+
const executeTransactionBlock = jest.fn();
|
|
6
|
+
jest.mock("../network", () => {
|
|
7
|
+
return {
|
|
8
|
+
executeTransactionBlock: (arg) => executeTransactionBlock(arg),
|
|
9
|
+
};
|
|
10
|
+
});
|
|
11
|
+
describe("broadcast", () => {
|
|
12
|
+
it("calls explorer for broadcast operation", async () => {
|
|
13
|
+
// WHEN
|
|
14
|
+
await (0, broadcast_1.broadcast)({
|
|
15
|
+
account: {},
|
|
16
|
+
signedOperation: {
|
|
17
|
+
signature: "SIGNATURE",
|
|
18
|
+
operation: (0, bridge_fixture_1.createFixtureOperation)(),
|
|
19
|
+
rawData: {
|
|
20
|
+
serializedSignature: new Uint8Array(64).fill(0x42),
|
|
21
|
+
unsigned: Buffer.from(new Uint8Array(64).fill(0x42)).toString("base64"),
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
});
|
|
25
|
+
// THEN
|
|
26
|
+
expect(executeTransactionBlock).toHaveBeenCalledTimes(1);
|
|
27
|
+
expect(executeTransactionBlock.mock.lastCall[0]).toHaveProperty("signature");
|
|
28
|
+
});
|
|
29
|
+
it("updates the signed operation", async () => {
|
|
30
|
+
// GIVEN
|
|
31
|
+
const operation = (0, bridge_fixture_1.createFixtureOperation)();
|
|
32
|
+
// WHEN
|
|
33
|
+
const result = await (0, broadcast_1.broadcast)({
|
|
34
|
+
account: {},
|
|
35
|
+
signedOperation: {
|
|
36
|
+
signature: "SIGNATURE",
|
|
37
|
+
operation,
|
|
38
|
+
rawData: {
|
|
39
|
+
serializedSignature: new Uint8Array(64).fill(0x42),
|
|
40
|
+
unsigned: Buffer.from(new Uint8Array(64).fill(0x42)).toString("base64"),
|
|
41
|
+
},
|
|
42
|
+
},
|
|
43
|
+
});
|
|
44
|
+
// THEN
|
|
45
|
+
expect(result.hash).not.toEqual(operation.hash);
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
//# sourceMappingURL=broadcast.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.test.js","sourceRoot":"","sources":["../../src/bridge/broadcast.test.ts"],"names":[],"mappings":";;AAAA,4DAAiE;AACjE,2CAAwC;AAExC,MAAM,uBAAuB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AAE1C,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,GAAG,EAAE;IAC3B,OAAO;QACL,uBAAuB,EAAE,CAAC,GAAQ,EAAE,EAAE,CAAC,uBAAuB,CAAC,GAAG,CAAC;KACpE,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,OAAO;QACP,MAAM,IAAA,qBAAS,EAAC;YACd,OAAO,EAAE,EAAS;YAClB,eAAe,EAAE;gBACf,SAAS,EAAE,WAAW;gBACtB,SAAS,EAAE,IAAA,uCAAsB,GAAE;gBACnC,OAAO,EAAE;oBACP,mBAAmB,EAAE,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;oBAClD,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;iBACxE;aACF;SACF,CAAC,CAAC;QAEH,OAAO;QACP,MAAM,CAAC,uBAAuB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACzD,MAAM,CAAC,uBAAuB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;IAC/E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,KAAK,IAAI,EAAE;QAC5C,QAAQ;QACR,MAAM,SAAS,GAAG,IAAA,uCAAsB,GAAE,CAAC;QAE3C,OAAO;QACP,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAS,EAAC;YAC7B,OAAO,EAAE,EAAS;YAClB,eAAe,EAAE;gBACf,SAAS,EAAE,WAAW;gBACtB,SAAS;gBACT,OAAO,EAAE;oBACP,mBAAmB,EAAE,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;oBAClD,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;iBACxE;aACF;SACF,CAAC,CAAC;QAEH,OAAO;QACP,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAClD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
import { SuiAccount, SuiOperation, Transaction } from "../types";
|
|
3
|
+
export declare const buildOptimisticOperation: (account: SuiAccount, transaction: Transaction, fee: BigNumber) => SuiOperation;
|
|
4
|
+
//# sourceMappingURL=buildOptimisticOperation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildOptimisticOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AAGrC,OAAO,EAEL,UAAU,EACV,YAAY,EAGZ,WAAW,EACZ,MAAM,UAAU,CAAC;AAmBlB,eAAO,MAAM,wBAAwB,YAC1B,UAAU,eACN,WAAW,OACnB,SAAS,KACb,YAoBF,CAAC"}
|
|
@@ -0,0 +1,76 @@
|
|
|
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.buildOptimisticOperation = void 0;
|
|
7
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
8
|
+
const operation_1 = require("@ledgerhq/coin-framework/operation");
|
|
9
|
+
const utils_1 = require("./utils");
|
|
10
|
+
const MODE_TO_TYPE = {
|
|
11
|
+
send: "OUT",
|
|
12
|
+
default: "OUT",
|
|
13
|
+
};
|
|
14
|
+
const getExtra = (type, transaction) => {
|
|
15
|
+
const extra = {};
|
|
16
|
+
switch (type) {
|
|
17
|
+
case "OUT":
|
|
18
|
+
return { ...extra, transferAmount: new bignumber_js_1.default(transaction.amount) };
|
|
19
|
+
}
|
|
20
|
+
return extra;
|
|
21
|
+
};
|
|
22
|
+
const buildOptimisticOperation = (account, transaction, fee) => {
|
|
23
|
+
const commandDescriptor = {
|
|
24
|
+
command: {
|
|
25
|
+
kind: "transfer",
|
|
26
|
+
sender: account.freshAddress,
|
|
27
|
+
recipient: transaction.recipient,
|
|
28
|
+
amount: transaction.amount.toNumber(),
|
|
29
|
+
},
|
|
30
|
+
fee: fee.toNumber(),
|
|
31
|
+
warnings: {},
|
|
32
|
+
errors: {},
|
|
33
|
+
};
|
|
34
|
+
const optimisticOperation = buildOptimisticOperationForCommand(account, transaction, commandDescriptor);
|
|
35
|
+
return optimisticOperation;
|
|
36
|
+
};
|
|
37
|
+
exports.buildOptimisticOperation = buildOptimisticOperation;
|
|
38
|
+
function buildOptimisticOperationForCommand(account, transaction, commandDescriptor) {
|
|
39
|
+
const { command } = commandDescriptor;
|
|
40
|
+
switch (command.kind) {
|
|
41
|
+
case "transfer":
|
|
42
|
+
return optimisticOpForTransfer(account, transaction, commandDescriptor);
|
|
43
|
+
default:
|
|
44
|
+
// @ts-expect-error Seem like a bug in TS, remove once more commands are added
|
|
45
|
+
return (0, utils_1.assertUnreachable)(command);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
function optimisticOpForTransfer(account, transaction, commandDescriptor) {
|
|
49
|
+
const type = MODE_TO_TYPE.default;
|
|
50
|
+
const value = type === "OUT"
|
|
51
|
+
? new bignumber_js_1.default(transaction.amount).plus(commandDescriptor.fee)
|
|
52
|
+
: new bignumber_js_1.default(commandDescriptor.fee);
|
|
53
|
+
const extra = getExtra(type, transaction);
|
|
54
|
+
const commons = optimisticOpcommons(commandDescriptor);
|
|
55
|
+
return {
|
|
56
|
+
...commons,
|
|
57
|
+
id: (0, operation_1.encodeOperationId)(account.id, "", type),
|
|
58
|
+
type,
|
|
59
|
+
value,
|
|
60
|
+
senders: [account.freshAddress],
|
|
61
|
+
recipients: [transaction.recipient].filter(Boolean),
|
|
62
|
+
accountId: account.id,
|
|
63
|
+
date: new Date(),
|
|
64
|
+
extra,
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
function optimisticOpcommons(commandDescriptor) {
|
|
68
|
+
return {
|
|
69
|
+
hash: "",
|
|
70
|
+
fee: new bignumber_js_1.default(commandDescriptor.fee),
|
|
71
|
+
blockHash: null,
|
|
72
|
+
blockHeight: null,
|
|
73
|
+
extra: {},
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=buildOptimisticOperation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildOptimisticOperation.js","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildOptimisticOperation.test.d.ts","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,52 @@
|
|
|
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 bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
7
|
+
const bridge_fixture_1 = require("../types/bridge.fixture");
|
|
8
|
+
const buildOptimisticOperation_1 = require("./buildOptimisticOperation");
|
|
9
|
+
describe("buildOptimisticOperation", () => {
|
|
10
|
+
it("should build optimistic operation for transfer", () => {
|
|
11
|
+
// GIVEN
|
|
12
|
+
const account = (0, bridge_fixture_1.createFixtureAccount)();
|
|
13
|
+
const transaction = (0, bridge_fixture_1.createFixtureTransaction)();
|
|
14
|
+
const fee = new bignumber_js_1.default(10);
|
|
15
|
+
// WHEN
|
|
16
|
+
const result = (0, buildOptimisticOperation_1.buildOptimisticOperation)(account, transaction, fee);
|
|
17
|
+
// THEN
|
|
18
|
+
expect(result).toEqual({
|
|
19
|
+
id: "js:2:sui:0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0:sui--OUT",
|
|
20
|
+
hash: "",
|
|
21
|
+
type: "OUT",
|
|
22
|
+
value: transaction.amount.plus(fee), // amount + fee
|
|
23
|
+
fee: new bignumber_js_1.default(10),
|
|
24
|
+
senders: ["0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0"],
|
|
25
|
+
recipients: ["0x65449f57946938c84c512732f1d69405d1fce417d9c9894696ddf4522f479e24"],
|
|
26
|
+
accountId: "js:2:sui:0x6e143fe0a8ca010a86580dafac44298e5b1b7d73efc345356a59a15f0d7824f0:sui",
|
|
27
|
+
date: expect.any(Date),
|
|
28
|
+
blockHash: null,
|
|
29
|
+
blockHeight: null,
|
|
30
|
+
extra: {
|
|
31
|
+
transferAmount: new bignumber_js_1.default(3000000000),
|
|
32
|
+
},
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
it("should calculate correct value for OUT type", () => {
|
|
36
|
+
// GIVEN
|
|
37
|
+
const account = (0, bridge_fixture_1.createFixtureAccount)();
|
|
38
|
+
const transaction = (0, bridge_fixture_1.createFixtureTransaction)();
|
|
39
|
+
const amount = new bignumber_js_1.default(500);
|
|
40
|
+
const fee = new bignumber_js_1.default(50);
|
|
41
|
+
const tx = {
|
|
42
|
+
...transaction,
|
|
43
|
+
amount,
|
|
44
|
+
};
|
|
45
|
+
// WHEN
|
|
46
|
+
const result = (0, buildOptimisticOperation_1.buildOptimisticOperation)(account, tx, fee);
|
|
47
|
+
// THEN
|
|
48
|
+
expect(result.value).toEqual(amount.plus(fee));
|
|
49
|
+
expect(result.fee).toEqual(fee);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
//# sourceMappingURL=buildOptimisticOperation.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildOptimisticOperation.test.js","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.test.ts"],"names":[],"mappings":";;;;;AAAA,gEAAqC;AACrC,4DAAyF;AACzF,yEAAsE;AAGtE,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;IACxC,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;QACxD,QAAQ;QACR,MAAM,OAAO,GAAe,IAAA,qCAAoB,GAAE,CAAC;QACnD,MAAM,WAAW,GAAgB,IAAA,yCAAwB,GAAE,CAAC;QAC5D,MAAM,GAAG,GAAG,IAAI,sBAAS,CAAC,EAAE,CAAC,CAAC;QAE9B,OAAO;QACP,MAAM,MAAM,GAAG,IAAA,mDAAwB,EAAC,OAAO,EAAE,WAAW,EAAE,GAAG,CAAC,CAAC;QAEnE,OAAO;QACP,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACrB,EAAE,EAAE,sFAAsF;YAC1F,IAAI,EAAE,EAAE;YACR,IAAI,EAAE,KAAK;YACX,KAAK,EAAE,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,eAAe;YACpD,GAAG,EAAE,IAAI,sBAAS,CAAC,EAAE,CAAC;YACtB,OAAO,EAAE,CAAC,oEAAoE,CAAC;YAC/E,UAAU,EAAE,CAAC,oEAAoE,CAAC;YAClF,SAAS,EAAE,iFAAiF;YAC5F,IAAI,EAAE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC;YACtB,SAAS,EAAE,IAAI;YACf,WAAW,EAAE,IAAI;YACjB,KAAK,EAAE;gBACL,cAAc,EAAE,IAAI,sBAAS,CAAC,UAAU,CAAC;aAC1C;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,QAAQ;QACR,MAAM,OAAO,GAAe,IAAA,qCAAoB,GAAE,CAAC;QACnD,MAAM,WAAW,GAAgB,IAAA,yCAAwB,GAAE,CAAC;QAC5D,MAAM,MAAM,GAAG,IAAI,sBAAS,CAAC,GAAG,CAAC,CAAC;QAClC,MAAM,GAAG,GAAG,IAAI,sBAAS,CAAC,EAAE,CAAC,CAAC;QAC9B,MAAM,EAAE,GAAG;YACT,GAAG,WAAW;YACd,MAAM;SACP,CAAC;QAEF,OAAO;QACP,MAAM,MAAM,GAAG,IAAA,mDAAwB,EAAC,OAAO,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC;QAE1D,OAAO;QACP,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;QAC/C,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { SuiAccount, Transaction } from "../types";
|
|
2
|
+
import { type CreateExtrinsicArg } from "../logic";
|
|
3
|
+
export declare const extractExtrinsicArg: (transaction: Transaction) => CreateExtrinsicArg;
|
|
4
|
+
/**
|
|
5
|
+
* @param {Account} account
|
|
6
|
+
* @param {Transaction} transaction
|
|
7
|
+
*/
|
|
8
|
+
export declare const buildTransaction: (account: SuiAccount, transaction: Transaction) => Promise<import("../types").CoreTransaction>;
|
|
9
|
+
//# sourceMappingURL=buildTransaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/buildTransaction.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACxD,OAAO,EAAoB,KAAK,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAErE,eAAO,MAAM,mBAAmB,gBAAiB,WAAW,KAAG,kBACK,CAAC;AAErE;;;GAGG;AACH,eAAO,MAAM,gBAAgB,YAAmB,UAAU,eAAe,WAAW,gDAEnF,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
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.buildTransaction = exports.extractExtrinsicArg = void 0;
|
|
7
|
+
const pick_1 = __importDefault(require("lodash/pick"));
|
|
8
|
+
const logic_1 = require("../logic");
|
|
9
|
+
const extractExtrinsicArg = (transaction) => (0, pick_1.default)(transaction, ["mode", "amount", "recipient", "useAllAmount"]);
|
|
10
|
+
exports.extractExtrinsicArg = extractExtrinsicArg;
|
|
11
|
+
/**
|
|
12
|
+
* @param {Account} account
|
|
13
|
+
* @param {Transaction} transaction
|
|
14
|
+
*/
|
|
15
|
+
const buildTransaction = async (account, transaction) => {
|
|
16
|
+
return (0, logic_1.craftTransaction)(account.freshAddress, (0, exports.extractExtrinsicArg)(transaction));
|
|
17
|
+
};
|
|
18
|
+
exports.buildTransaction = buildTransaction;
|
|
19
|
+
//# sourceMappingURL=buildTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildTransaction.js","sourceRoot":"","sources":["../../src/bridge/buildTransaction.ts"],"names":[],"mappings":";;;;;;AAAA,uDAA+B;AAE/B,oCAAqE;AAE9D,MAAM,mBAAmB,GAAG,CAAC,WAAwB,EAAsB,EAAE,CAClF,IAAA,cAAI,EAAC,WAAW,EAAE,CAAC,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,cAAc,CAAC,CAAC,CAAC;AADxD,QAAA,mBAAmB,uBACqC;AAErE;;;GAGG;AACI,MAAM,gBAAgB,GAAG,KAAK,EAAE,OAAmB,EAAE,WAAwB,EAAE,EAAE;IACtF,OAAO,IAAA,wBAAgB,EAAC,OAAO,CAAC,YAAY,EAAE,IAAA,2BAAmB,EAAC,WAAW,CAAC,CAAC,CAAC;AAClF,CAAC,CAAC;AAFW,QAAA,gBAAgB,oBAE3B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildTransaction.test.d.ts","sourceRoot":"","sources":["../../src/bridge/buildTransaction.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const buildTransaction_1 = require("./buildTransaction");
|
|
4
|
+
const bridge_fixture_1 = require("../types/bridge.fixture");
|
|
5
|
+
describe("buildTransaction", () => {
|
|
6
|
+
it("returns unsigned tx bytes for given tx", async () => {
|
|
7
|
+
// GIVEN
|
|
8
|
+
const account = (0, bridge_fixture_1.createFixtureAccount)();
|
|
9
|
+
const transaction = (0, bridge_fixture_1.createFixtureTransaction)();
|
|
10
|
+
// WHEN
|
|
11
|
+
const result = await (0, buildTransaction_1.buildTransaction)(account, transaction);
|
|
12
|
+
// THEN
|
|
13
|
+
expect(result).not.toBeNull();
|
|
14
|
+
expect(result.unsigned).toBeInstanceOf(Uint8Array);
|
|
15
|
+
});
|
|
16
|
+
});
|
|
17
|
+
//# sourceMappingURL=buildTransaction.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildTransaction.test.js","sourceRoot":"","sources":["../../src/bridge/buildTransaction.test.ts"],"names":[],"mappings":";;AAAA,yDAAsD;AACtD,4DAAyF;AAEzF,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,QAAQ;QACR,MAAM,OAAO,GAAG,IAAA,qCAAoB,GAAE,CAAC;QACvC,MAAM,WAAW,GAAG,IAAA,yCAAwB,GAAE,CAAC;QAE/C,OAAO;QACP,MAAM,MAAM,GAAG,MAAM,IAAA,mCAAgB,EAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAE5D,OAAO;QACP,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QAC9B,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|