@ledgerhq/coin-mina 1.1.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 +20 -0
- package/.turbo/turbo-build.log +4 -0
- package/.unimportedrc.json +24 -0
- package/CHANGELOG.md +15 -0
- package/LICENSE.txt +21 -0
- package/jest.config.js +8 -0
- package/jest.integ.config.js +7 -0
- package/lib/api/index.d.ts +13 -0
- package/lib/api/index.d.ts.map +1 -0
- package/lib/api/index.integ.test.d.ts +2 -0
- package/lib/api/index.integ.test.d.ts.map +1 -0
- package/lib/api/index.integ.test.js +57 -0
- package/lib/api/index.integ.test.js.map +1 -0
- package/lib/api/index.js +91 -0
- package/lib/api/index.js.map +1 -0
- package/lib/api/rosetta/index.d.ts +9 -0
- package/lib/api/rosetta/index.d.ts.map +1 -0
- package/lib/api/rosetta/index.js +90 -0
- package/lib/api/rosetta/index.js.map +1 -0
- package/lib/api/rosetta/types.d.ts +143 -0
- package/lib/api/rosetta/types.d.ts.map +1 -0
- package/lib/api/rosetta/types.js +3 -0
- package/lib/api/rosetta/types.js.map +1 -0
- package/lib/api/rosetta/utils.d.ts +43 -0
- package/lib/api/rosetta/utils.d.ts.map +1 -0
- package/lib/api/rosetta/utils.js +60 -0
- package/lib/api/rosetta/utils.js.map +1 -0
- package/lib/api/rosetta/utils.test.d.ts +2 -0
- package/lib/api/rosetta/utils.test.d.ts.map +1 -0
- package/lib/api/rosetta/utils.test.js +82 -0
- package/lib/api/rosetta/utils.test.js.map +1 -0
- package/lib/bridge/broadcast.d.ts +6 -0
- package/lib/bridge/broadcast.d.ts.map +1 -0
- package/lib/bridge/broadcast.js +11 -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 +36 -0
- package/lib/bridge/broadcast.test.js.map +1 -0
- package/lib/bridge/buildTransaction.d.ts +4 -0
- package/lib/bridge/buildTransaction.d.ts.map +1 -0
- package/lib/bridge/buildTransaction.js +37 -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 +57 -0
- package/lib/bridge/buildTransaction.test.js.map +1 -0
- package/lib/bridge/cli-transaction.d.ts +18 -0
- package/lib/bridge/cli-transaction.d.ts.map +1 -0
- package/lib/bridge/cli-transaction.js +37 -0
- package/lib/bridge/cli-transaction.js.map +1 -0
- package/lib/bridge/createTransaction.d.ts +4 -0
- package/lib/bridge/createTransaction.d.ts.map +1 -0
- package/lib/bridge/createTransaction.js +21 -0
- package/lib/bridge/createTransaction.js.map +1 -0
- package/lib/bridge/createTransaction.test.d.ts +2 -0
- package/lib/bridge/createTransaction.test.d.ts.map +1 -0
- package/lib/bridge/createTransaction.test.js +24 -0
- package/lib/bridge/createTransaction.test.js.map +1 -0
- package/lib/bridge/deviceTransactionConfig.d.ts +11 -0
- package/lib/bridge/deviceTransactionConfig.d.ts.map +1 -0
- package/lib/bridge/deviceTransactionConfig.js +8 -0
- package/lib/bridge/deviceTransactionConfig.js.map +1 -0
- package/lib/bridge/errors.d.ts +10 -0
- package/lib/bridge/errors.d.ts.map +1 -0
- package/lib/bridge/errors.js +17 -0
- package/lib/bridge/errors.js.map +1 -0
- package/lib/bridge/estimateMaxSpendable.d.ts +5 -0
- package/lib/bridge/estimateMaxSpendable.d.ts.map +1 -0
- package/lib/bridge/estimateMaxSpendable.js +26 -0
- package/lib/bridge/estimateMaxSpendable.js.map +1 -0
- package/lib/bridge/getEstimatedFees.d.ts +8 -0
- package/lib/bridge/getEstimatedFees.d.ts.map +1 -0
- package/lib/bridge/getEstimatedFees.js +9 -0
- package/lib/bridge/getEstimatedFees.js.map +1 -0
- package/lib/bridge/getTransactionStatus.d.ts +5 -0
- package/lib/bridge/getTransactionStatus.d.ts.map +1 -0
- package/lib/bridge/getTransactionStatus.js +62 -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 +138 -0
- package/lib/bridge/getTransactionStatus.test.js.map +1 -0
- package/lib/bridge/index.d.ts +14 -0
- package/lib/bridge/index.d.ts.map +1 -0
- package/lib/bridge/index.js +59 -0
- package/lib/bridge/index.js.map +1 -0
- package/lib/bridge/index.test.d.ts +2 -0
- package/lib/bridge/index.test.d.ts.map +1 -0
- package/lib/bridge/index.test.js +32 -0
- package/lib/bridge/index.test.js.map +1 -0
- package/lib/bridge/prepareTransaction.d.ts +4 -0
- package/lib/bridge/prepareTransaction.d.ts.map +1 -0
- package/lib/bridge/prepareTransaction.js +23 -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 +43 -0
- package/lib/bridge/prepareTransaction.test.js.map +1 -0
- package/lib/bridge/signOperation.d.ts +12 -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 +129 -0
- package/lib/bridge/signOperation.test.js.map +1 -0
- package/lib/bridge/synchronisation.d.ts +7 -0
- package/lib/bridge/synchronisation.d.ts.map +1 -0
- package/lib/bridge/synchronisation.js +155 -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 +164 -0
- package/lib/bridge/synchronisation.test.js.map +1 -0
- package/lib/bridge/transaction.d.ts +14 -0
- package/lib/bridge/transaction.d.ts.map +1 -0
- package/lib/bridge/transaction.js +61 -0
- package/lib/bridge/transaction.js.map +1 -0
- package/lib/common-logic/index.d.ts +9 -0
- package/lib/common-logic/index.d.ts.map +1 -0
- package/lib/common-logic/index.js +96 -0
- package/lib/common-logic/index.js.map +1 -0
- package/lib/common-logic/index.test.d.ts +2 -0
- package/lib/common-logic/index.test.d.ts.map +1 -0
- package/lib/common-logic/index.test.js +181 -0
- package/lib/common-logic/index.test.js.map +1 -0
- package/lib/config.d.ts +9 -0
- package/lib/config.d.ts.map +1 -0
- package/lib/config.js +16 -0
- package/lib/config.js.map +1 -0
- package/lib/consts.d.ts +16 -0
- package/lib/consts.d.ts.map +1 -0
- package/lib/consts.js +19 -0
- package/lib/consts.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 +22 -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 +3 -0
- package/lib/signer/index.d.ts.map +1 -0
- package/lib/signer/index.js +8 -0
- package/lib/signer/index.js.map +1 -0
- package/lib/test/bot-deviceActions.d.ts +4 -0
- package/lib/test/bot-deviceActions.d.ts.map +1 -0
- package/lib/test/bot-deviceActions.js +67 -0
- package/lib/test/bot-deviceActions.js.map +1 -0
- package/lib/test/bot-specs.d.ts +7 -0
- package/lib/test/bot-specs.d.ts.map +1 -0
- package/lib/test/bot-specs.js +107 -0
- package/lib/test/bot-specs.js.map +1 -0
- package/lib/test/bridgeDatasetTest.d.ts +4 -0
- package/lib/test/bridgeDatasetTest.d.ts.map +1 -0
- package/lib/test/bridgeDatasetTest.js +174 -0
- package/lib/test/bridgeDatasetTest.js.map +1 -0
- package/lib/test/fixtures.d.ts +55 -0
- package/lib/test/fixtures.d.ts.map +1 -0
- package/lib/test/fixtures.js +194 -0
- package/lib/test/fixtures.js.map +1 -0
- package/lib/test/index.d.ts +4 -0
- package/lib/test/index.d.ts.map +1 -0
- package/lib/test/index.js +20 -0
- package/lib/test/index.js.map +1 -0
- package/lib/test/testUtils.d.ts +2 -0
- package/lib/test/testUtils.d.ts.map +1 -0
- package/lib/test/testUtils.js +8 -0
- package/lib/test/testUtils.js.map +1 -0
- package/lib/test/testUtils.test.d.ts +2 -0
- package/lib/test/testUtils.test.d.ts.map +1 -0
- package/lib/test/testUtils.test.js +11 -0
- package/lib/test/testUtils.test.js.map +1 -0
- package/lib/types/common.d.ts +55 -0
- package/lib/types/common.d.ts.map +1 -0
- package/lib/types/common.js +3 -0
- package/lib/types/common.js.map +1 -0
- package/lib/types/index.d.ts +3 -0
- package/lib/types/index.d.ts.map +1 -0
- package/lib/types/index.js +19 -0
- package/lib/types/index.js.map +1 -0
- package/lib/types/signer.d.ts +32 -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-es/api/index.d.ts +13 -0
- package/lib-es/api/index.d.ts.map +1 -0
- package/lib-es/api/index.integ.test.d.ts +2 -0
- package/lib-es/api/index.integ.test.d.ts.map +1 -0
- package/lib-es/api/index.integ.test.js +55 -0
- package/lib-es/api/index.integ.test.js.map +1 -0
- package/lib-es/api/index.js +79 -0
- package/lib-es/api/index.js.map +1 -0
- package/lib-es/api/rosetta/index.d.ts +8 -0
- package/lib-es/api/rosetta/index.d.ts.map +1 -0
- package/lib-es/api/rosetta/index.js +78 -0
- package/lib-es/api/rosetta/index.js.map +1 -0
- package/lib-es/api/rosetta/types.d.ts +143 -0
- package/lib-es/api/rosetta/types.d.ts.map +1 -0
- package/lib-es/api/rosetta/types.js +2 -0
- package/lib-es/api/rosetta/types.js.map +1 -0
- package/lib-es/api/rosetta/utils.d.ts +43 -0
- package/lib-es/api/rosetta/utils.d.ts.map +1 -0
- package/lib-es/api/rosetta/utils.js +54 -0
- package/lib-es/api/rosetta/utils.js.map +1 -0
- package/lib-es/api/rosetta/utils.test.d.ts +2 -0
- package/lib-es/api/rosetta/utils.test.d.ts.map +1 -0
- package/lib-es/api/rosetta/utils.test.js +80 -0
- package/lib-es/api/rosetta/utils.test.js.map +1 -0
- package/lib-es/bridge/broadcast.d.ts +6 -0
- package/lib-es/bridge/broadcast.d.ts.map +1 -0
- package/lib-es/bridge/broadcast.js +9 -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 +31 -0
- package/lib-es/bridge/broadcast.test.js.map +1 -0
- package/lib-es/bridge/buildTransaction.d.ts +4 -0
- package/lib-es/bridge/buildTransaction.d.ts.map +1 -0
- package/lib-es/bridge/buildTransaction.js +30 -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 +55 -0
- package/lib-es/bridge/buildTransaction.test.js.map +1 -0
- package/lib-es/bridge/cli-transaction.d.ts +18 -0
- package/lib-es/bridge/cli-transaction.d.ts.map +1 -0
- package/lib-es/bridge/cli-transaction.js +31 -0
- package/lib-es/bridge/cli-transaction.js.map +1 -0
- package/lib-es/bridge/createTransaction.d.ts +4 -0
- package/lib-es/bridge/createTransaction.d.ts.map +1 -0
- package/lib-es/bridge/createTransaction.js +14 -0
- package/lib-es/bridge/createTransaction.js.map +1 -0
- package/lib-es/bridge/createTransaction.test.d.ts +2 -0
- package/lib-es/bridge/createTransaction.test.d.ts.map +1 -0
- package/lib-es/bridge/createTransaction.test.js +19 -0
- package/lib-es/bridge/createTransaction.test.js.map +1 -0
- package/lib-es/bridge/deviceTransactionConfig.d.ts +11 -0
- package/lib-es/bridge/deviceTransactionConfig.d.ts.map +1 -0
- package/lib-es/bridge/deviceTransactionConfig.js +6 -0
- package/lib-es/bridge/deviceTransactionConfig.js.map +1 -0
- package/lib-es/bridge/errors.d.ts +10 -0
- package/lib-es/bridge/errors.d.ts.map +1 -0
- package/lib-es/bridge/errors.js +14 -0
- package/lib-es/bridge/errors.js.map +1 -0
- package/lib-es/bridge/estimateMaxSpendable.d.ts +5 -0
- package/lib-es/bridge/estimateMaxSpendable.d.ts.map +1 -0
- package/lib-es/bridge/estimateMaxSpendable.js +21 -0
- package/lib-es/bridge/estimateMaxSpendable.js.map +1 -0
- package/lib-es/bridge/getEstimatedFees.d.ts +8 -0
- package/lib-es/bridge/getEstimatedFees.d.ts.map +1 -0
- package/lib-es/bridge/getEstimatedFees.js +7 -0
- package/lib-es/bridge/getEstimatedFees.js.map +1 -0
- package/lib-es/bridge/getTransactionStatus.d.ts +5 -0
- package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -0
- package/lib-es/bridge/getTransactionStatus.js +60 -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 +133 -0
- package/lib-es/bridge/getTransactionStatus.test.js.map +1 -0
- package/lib-es/bridge/index.d.ts +14 -0
- package/lib-es/bridge/index.d.ts.map +1 -0
- package/lib-es/bridge/index.js +50 -0
- package/lib-es/bridge/index.js.map +1 -0
- package/lib-es/bridge/index.test.d.ts +2 -0
- package/lib-es/bridge/index.test.d.ts.map +1 -0
- package/lib-es/bridge/index.test.js +30 -0
- package/lib-es/bridge/index.test.js.map +1 -0
- package/lib-es/bridge/prepareTransaction.d.ts +4 -0
- package/lib-es/bridge/prepareTransaction.d.ts.map +1 -0
- package/lib-es/bridge/prepareTransaction.js +16 -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 +38 -0
- package/lib-es/bridge/prepareTransaction.test.js.map +1 -0
- package/lib-es/bridge/signOperation.d.ts +12 -0
- package/lib-es/bridge/signOperation.d.ts.map +1 -0
- package/lib-es/bridge/signOperation.js +64 -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 +127 -0
- package/lib-es/bridge/signOperation.test.js.map +1 -0
- package/lib-es/bridge/synchronisation.d.ts +7 -0
- package/lib-es/bridge/synchronisation.d.ts.map +1 -0
- package/lib-es/bridge/synchronisation.js +147 -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 +159 -0
- package/lib-es/bridge/synchronisation.test.js.map +1 -0
- package/lib-es/bridge/transaction.d.ts +14 -0
- package/lib-es/bridge/transaction.d.ts.map +1 -0
- package/lib-es/bridge/transaction.js +53 -0
- package/lib-es/bridge/transaction.js.map +1 -0
- package/lib-es/common-logic/index.d.ts +9 -0
- package/lib-es/common-logic/index.d.ts.map +1 -0
- package/lib-es/common-logic/index.js +84 -0
- package/lib-es/common-logic/index.js.map +1 -0
- package/lib-es/common-logic/index.test.d.ts +2 -0
- package/lib-es/common-logic/index.test.d.ts.map +1 -0
- package/lib-es/common-logic/index.test.js +179 -0
- package/lib-es/common-logic/index.test.js.map +1 -0
- package/lib-es/config.d.ts +9 -0
- package/lib-es/config.d.ts.map +1 -0
- package/lib-es/config.js +11 -0
- package/lib-es/config.js.map +1 -0
- package/lib-es/consts.d.ts +16 -0
- package/lib-es/consts.d.ts.map +1 -0
- package/lib-es/consts.js +16 -0
- package/lib-es/consts.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 +17 -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 +3 -0
- package/lib-es/signer/index.d.ts.map +1 -0
- package/lib-es/signer/index.js +3 -0
- package/lib-es/signer/index.js.map +1 -0
- package/lib-es/test/bot-deviceActions.d.ts +4 -0
- package/lib-es/test/bot-deviceActions.d.ts.map +1 -0
- package/lib-es/test/bot-deviceActions.js +64 -0
- package/lib-es/test/bot-deviceActions.js.map +1 -0
- package/lib-es/test/bot-specs.d.ts +7 -0
- package/lib-es/test/bot-specs.d.ts.map +1 -0
- package/lib-es/test/bot-specs.js +102 -0
- package/lib-es/test/bot-specs.js.map +1 -0
- package/lib-es/test/bridgeDatasetTest.d.ts +4 -0
- package/lib-es/test/bridgeDatasetTest.d.ts.map +1 -0
- package/lib-es/test/bridgeDatasetTest.js +171 -0
- package/lib-es/test/bridgeDatasetTest.js.map +1 -0
- package/lib-es/test/fixtures.d.ts +55 -0
- package/lib-es/test/fixtures.d.ts.map +1 -0
- package/lib-es/test/fixtures.js +182 -0
- package/lib-es/test/fixtures.js.map +1 -0
- package/lib-es/test/index.d.ts +4 -0
- package/lib-es/test/index.d.ts.map +1 -0
- package/lib-es/test/index.js +4 -0
- package/lib-es/test/index.js.map +1 -0
- package/lib-es/test/testUtils.d.ts +2 -0
- package/lib-es/test/testUtils.d.ts.map +1 -0
- package/lib-es/test/testUtils.js +4 -0
- package/lib-es/test/testUtils.js.map +1 -0
- package/lib-es/test/testUtils.test.d.ts +2 -0
- package/lib-es/test/testUtils.test.d.ts.map +1 -0
- package/lib-es/test/testUtils.test.js +9 -0
- package/lib-es/test/testUtils.test.js.map +1 -0
- package/lib-es/types/common.d.ts +55 -0
- package/lib-es/types/common.d.ts.map +1 -0
- package/lib-es/types/common.js +2 -0
- package/lib-es/types/common.js.map +1 -0
- package/lib-es/types/index.d.ts +3 -0
- package/lib-es/types/index.d.ts.map +1 -0
- package/lib-es/types/index.js +3 -0
- package/lib-es/types/index.js.map +1 -0
- package/lib-es/types/signer.d.ts +32 -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/package.json +143 -0
- package/src/api/index.integ.test.ts +62 -0
- package/src/api/index.ts +120 -0
- package/src/api/rosetta/index.ts +110 -0
- package/src/api/rosetta/types.ts +156 -0
- package/src/api/rosetta/utils.test.ts +100 -0
- package/src/api/rosetta/utils.ts +71 -0
- package/src/bridge/broadcast.test.ts +35 -0
- package/src/bridge/broadcast.ts +17 -0
- package/src/bridge/buildTransaction.test.ts +68 -0
- package/src/bridge/buildTransaction.ts +34 -0
- package/src/bridge/cli-transaction.ts +43 -0
- package/src/bridge/createTransaction.test.ts +21 -0
- package/src/bridge/createTransaction.ts +19 -0
- package/src/bridge/deviceTransactionConfig.ts +15 -0
- package/src/bridge/errors.ts +16 -0
- package/src/bridge/estimateMaxSpendable.ts +31 -0
- package/src/bridge/getEstimatedFees.ts +17 -0
- package/src/bridge/getTransactionStatus.test.ts +175 -0
- package/src/bridge/getTransactionStatus.ts +87 -0
- package/src/bridge/index.test.ts +39 -0
- package/src/bridge/index.ts +72 -0
- package/src/bridge/prepareTransaction.test.ts +43 -0
- package/src/bridge/prepareTransaction.ts +24 -0
- package/src/bridge/signOperation.test.ts +158 -0
- package/src/bridge/signOperation.ts +112 -0
- package/src/bridge/synchronisation.test.ts +184 -0
- package/src/bridge/synchronisation.ts +168 -0
- package/src/bridge/transaction.ts +69 -0
- package/src/common-logic/index.test.ts +225 -0
- package/src/common-logic/index.ts +97 -0
- package/src/config.ts +21 -0
- package/src/consts.ts +18 -0
- package/src/signer/getAddress.test.ts +131 -0
- package/src/signer/getAddress.ts +24 -0
- package/src/signer/index.ts +3 -0
- package/src/test/bot-deviceActions.ts +73 -0
- package/src/test/bot-specs.ts +130 -0
- package/src/test/bridgeDatasetTest.ts +180 -0
- package/src/test/fixtures.ts +226 -0
- package/src/test/index.ts +3 -0
- package/src/test/testUtils.test.ts +9 -0
- package/src/test/testUtils.ts +3 -0
- package/src/types/common.ts +70 -0
- package/src/types/index.ts +2 -0
- package/src/types/signer.ts +29 -0
- package/tsconfig.json +13 -0
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { BigNumber } from "bignumber.js";
|
|
2
|
+
import { Transaction } from "../types/common";
|
|
3
|
+
declare const getEstimatedFees: (transaction: Transaction, address: string) => Promise<{
|
|
4
|
+
fee: BigNumber;
|
|
5
|
+
accountCreationFee: BigNumber;
|
|
6
|
+
}>;
|
|
7
|
+
export default getEstimatedFees;
|
|
8
|
+
//# sourceMappingURL=getEstimatedFees.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getEstimatedFees.d.ts","sourceRoot":"","sources":["../../src/bridge/getEstimatedFees.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAE9C,QAAA,MAAM,gBAAgB,gBACP,WAAW,WACf,MAAM;SAEV,SAAS;wBACM,SAAS;EAK9B,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const api_1 = require("../api");
|
|
4
|
+
const getEstimatedFees = async (transaction, address) => {
|
|
5
|
+
const { fee, accountCreationFee } = await (0, api_1.getFees)(transaction, address);
|
|
6
|
+
return { fee, accountCreationFee };
|
|
7
|
+
};
|
|
8
|
+
exports.default = getEstimatedFees;
|
|
9
|
+
//# sourceMappingURL=getEstimatedFees.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getEstimatedFees.js","sourceRoot":"","sources":["../../src/bridge/getEstimatedFees.ts"],"names":[],"mappings":";;AACA,gCAAiC;AAGjC,MAAM,gBAAgB,GAAG,KAAK,EAC5B,WAAwB,EACxB,OAAe,EAId,EAAE;IACH,MAAM,EAAE,GAAG,EAAE,kBAAkB,EAAE,GAAG,MAAM,IAAA,aAAO,EAAC,WAAW,EAAE,OAAO,CAAC,CAAC;IAExE,OAAO,EAAE,GAAG,EAAE,kBAAkB,EAAE,CAAC;AACrC,CAAC,CAAC;AAEF,kBAAe,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { Transaction, MinaAccount, TransactionStatus } from "../types/common";
|
|
2
|
+
import { AccountBridge } from "@ledgerhq/types-live";
|
|
3
|
+
declare const getTransactionStatus: AccountBridge<Transaction, MinaAccount, TransactionStatus>["getTransactionStatus"];
|
|
4
|
+
export default getTransactionStatus;
|
|
5
|
+
//# sourceMappingURL=getTransactionStatus.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,iBAAiB,EAAkB,MAAM,iBAAiB,CAAC;AAEnG,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAIrD,QAAA,MAAM,oBAAoB,EAAE,aAAa,CACvC,WAAW,EACX,WAAW,EACX,iBAAiB,CAClB,CAAC,sBAAsB,CAiEvB,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const bignumber_js_1 = require("bignumber.js");
|
|
4
|
+
const errors_1 = require("@ledgerhq/errors");
|
|
5
|
+
const common_logic_1 = require("../common-logic");
|
|
6
|
+
const errors_2 = require("./errors");
|
|
7
|
+
const currencies_1 = require("@ledgerhq/coin-framework/currencies");
|
|
8
|
+
const getTransactionStatus = async (a, t) => {
|
|
9
|
+
const errors = {};
|
|
10
|
+
const warnings = {};
|
|
11
|
+
const useAllAmount = !!t.useAllAmount;
|
|
12
|
+
if (t.fees.fee.lte(0)) {
|
|
13
|
+
errors.fees = new errors_1.FeeNotLoaded();
|
|
14
|
+
}
|
|
15
|
+
if (!t.recipient) {
|
|
16
|
+
errors.recipient = new errors_1.RecipientRequired();
|
|
17
|
+
}
|
|
18
|
+
if (t.recipient && !(0, common_logic_1.isValidAddress)(t.recipient)) {
|
|
19
|
+
errors.recipient = new errors_1.InvalidAddress("", {
|
|
20
|
+
currencyName: a.currency.name,
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
if (t.memo && !(0, common_logic_1.isValidMemo)(t.memo)) {
|
|
24
|
+
errors.transaction = new errors_2.InvalidMemoMina();
|
|
25
|
+
}
|
|
26
|
+
if (t.recipient === a.freshAddress) {
|
|
27
|
+
errors.recipient = new errors_1.InvalidAddressBecauseDestinationIsAlsoSource();
|
|
28
|
+
}
|
|
29
|
+
if (t.fees?.accountCreationFee.gt(0)) {
|
|
30
|
+
const fee = (0, currencies_1.formatCurrencyUnit)(a.currency.units[0], t.fees.accountCreationFee, {
|
|
31
|
+
showCode: true,
|
|
32
|
+
disableRounding: true,
|
|
33
|
+
});
|
|
34
|
+
warnings.recipient = new errors_2.AccountCreationFeeWarning(undefined, {
|
|
35
|
+
fee,
|
|
36
|
+
});
|
|
37
|
+
if (t.amount.lt(t.fees.accountCreationFee) && t.amount.gt(0)) {
|
|
38
|
+
errors.amount = new errors_2.AmountTooSmall(undefined, {
|
|
39
|
+
amount: fee,
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
const estimatedFees = t.fees.fee || new bignumber_js_1.BigNumber(0);
|
|
44
|
+
const maxAmountWithFees = (0, common_logic_1.getMaxAmount)(a, t, estimatedFees);
|
|
45
|
+
const totalSpent = (0, common_logic_1.getTotalSpent)(a, t, estimatedFees);
|
|
46
|
+
const amount = useAllAmount ? maxAmountWithFees : new bignumber_js_1.BigNumber(t.amount);
|
|
47
|
+
if (amount.lte(0) && !t.useAllAmount) {
|
|
48
|
+
errors.amount = new errors_1.AmountRequired();
|
|
49
|
+
}
|
|
50
|
+
if (amount.gt(maxAmountWithFees)) {
|
|
51
|
+
errors.amount = new errors_1.NotEnoughBalance();
|
|
52
|
+
}
|
|
53
|
+
return Promise.resolve({
|
|
54
|
+
errors,
|
|
55
|
+
warnings,
|
|
56
|
+
estimatedFees,
|
|
57
|
+
amount,
|
|
58
|
+
totalSpent,
|
|
59
|
+
});
|
|
60
|
+
};
|
|
61
|
+
exports.default = getTransactionStatus;
|
|
62
|
+
//# sourceMappingURL=getTransactionStatus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.test.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,138 @@
|
|
|
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 = require("bignumber.js");
|
|
7
|
+
const errors_1 = require("@ledgerhq/errors");
|
|
8
|
+
const errors_2 = require("./errors");
|
|
9
|
+
const getTransactionStatus_1 = __importDefault(require("./getTransactionStatus"));
|
|
10
|
+
const fixtures_1 = require("../test/fixtures");
|
|
11
|
+
const currencies_1 = require("@ledgerhq/coin-framework/currencies");
|
|
12
|
+
const getEstimatedFees_1 = __importDefault(require("./getEstimatedFees"));
|
|
13
|
+
// Mock dependencies
|
|
14
|
+
jest.mock("@ledgerhq/coin-framework/currencies", () => ({
|
|
15
|
+
formatCurrencyUnit: jest.fn().mockReturnValue("0.1 MINA"),
|
|
16
|
+
}));
|
|
17
|
+
jest.mock("./getEstimatedFees");
|
|
18
|
+
describe("getTransactionStatus", () => {
|
|
19
|
+
// Standard test fixtures
|
|
20
|
+
const mockAccount = (0, fixtures_1.createMockAccount)();
|
|
21
|
+
const mockTransaction = (0, fixtures_1.createMockTransaction)({ amount: new bignumber_js_1.BigNumber(800) });
|
|
22
|
+
beforeEach(() => {
|
|
23
|
+
jest.clearAllMocks();
|
|
24
|
+
});
|
|
25
|
+
it("should return a valid transaction status with no errors for valid inputs", async () => {
|
|
26
|
+
const result = await (0, getTransactionStatus_1.default)(mockAccount, mockTransaction);
|
|
27
|
+
expect(result.errors).toEqual({});
|
|
28
|
+
expect(result.warnings).toEqual({});
|
|
29
|
+
expect(result.estimatedFees).toEqual(new bignumber_js_1.BigNumber(10));
|
|
30
|
+
expect(result.amount).toEqual(new bignumber_js_1.BigNumber(800));
|
|
31
|
+
expect(result.totalSpent).toEqual(new bignumber_js_1.BigNumber(810)); // amount + fee
|
|
32
|
+
});
|
|
33
|
+
it("should handle missing fees with FeeNotLoaded error", async () => {
|
|
34
|
+
getEstimatedFees_1.default.mockResolvedValue({
|
|
35
|
+
fee: new bignumber_js_1.BigNumber(10),
|
|
36
|
+
accountCreationFee: new bignumber_js_1.BigNumber(0),
|
|
37
|
+
});
|
|
38
|
+
// Using Type casting to handle the null fees for testing purposes
|
|
39
|
+
const txWithoutFees = {
|
|
40
|
+
...mockTransaction,
|
|
41
|
+
fees: {
|
|
42
|
+
fee: new bignumber_js_1.BigNumber(0),
|
|
43
|
+
accountCreationFee: new bignumber_js_1.BigNumber(0),
|
|
44
|
+
},
|
|
45
|
+
};
|
|
46
|
+
const result = await (0, getTransactionStatus_1.default)(mockAccount, txWithoutFees);
|
|
47
|
+
expect(result.errors.fees).toBeInstanceOf(errors_1.FeeNotLoaded);
|
|
48
|
+
});
|
|
49
|
+
it("should handle missing recipient with RecipientRequired error", async () => {
|
|
50
|
+
const txWithoutRecipient = {
|
|
51
|
+
...mockTransaction,
|
|
52
|
+
recipient: "",
|
|
53
|
+
};
|
|
54
|
+
const result = await (0, getTransactionStatus_1.default)(mockAccount, txWithoutRecipient);
|
|
55
|
+
expect(result.errors.recipient).toBeInstanceOf(errors_1.RecipientRequired);
|
|
56
|
+
});
|
|
57
|
+
it("should handle invalid recipient address with InvalidAddress error", async () => {
|
|
58
|
+
const txWithInvalidRecipient = {
|
|
59
|
+
...mockTransaction,
|
|
60
|
+
recipient: "invalid-address",
|
|
61
|
+
};
|
|
62
|
+
const result = await (0, getTransactionStatus_1.default)(mockAccount, txWithInvalidRecipient);
|
|
63
|
+
expect(result.errors.recipient).toBeInstanceOf(errors_1.InvalidAddress);
|
|
64
|
+
});
|
|
65
|
+
it("should handle self-transfer with InvalidAddressBecauseDestinationIsAlsoSource error", async () => {
|
|
66
|
+
const txWithSelfTransfer = {
|
|
67
|
+
...mockTransaction,
|
|
68
|
+
recipient: mockAccount.freshAddress,
|
|
69
|
+
};
|
|
70
|
+
const result = await (0, getTransactionStatus_1.default)(mockAccount, txWithSelfTransfer);
|
|
71
|
+
expect(result.errors.recipient).toBeInstanceOf(errors_1.InvalidAddressBecauseDestinationIsAlsoSource);
|
|
72
|
+
});
|
|
73
|
+
it("should handle invalid memo with InvalidMemoMina error", async () => {
|
|
74
|
+
const veryLongMemo = "a".repeat(33); // Create memo longer than MAX_MEMO_LENGTH (32)
|
|
75
|
+
const txWithInvalidMemo = {
|
|
76
|
+
...mockTransaction,
|
|
77
|
+
memo: veryLongMemo,
|
|
78
|
+
};
|
|
79
|
+
const result = await (0, getTransactionStatus_1.default)(mockAccount, txWithInvalidMemo);
|
|
80
|
+
expect(result.errors.transaction).toBeInstanceOf(errors_2.InvalidMemoMina);
|
|
81
|
+
});
|
|
82
|
+
it("should add AccountCreationFeeWarning when account creation fee is present", async () => {
|
|
83
|
+
const txWithAccountCreationFee = {
|
|
84
|
+
...mockTransaction,
|
|
85
|
+
fees: {
|
|
86
|
+
fee: new bignumber_js_1.BigNumber(10),
|
|
87
|
+
accountCreationFee: new bignumber_js_1.BigNumber(100),
|
|
88
|
+
},
|
|
89
|
+
};
|
|
90
|
+
const result = await (0, getTransactionStatus_1.default)(mockAccount, txWithAccountCreationFee);
|
|
91
|
+
expect(result.warnings.recipient).toBeInstanceOf(errors_2.AccountCreationFeeWarning);
|
|
92
|
+
expect(currencies_1.formatCurrencyUnit).toHaveBeenCalled();
|
|
93
|
+
});
|
|
94
|
+
it("should add AmountTooSmall error when amount is less than account creation fee", async () => {
|
|
95
|
+
const txWithSmallAmount = {
|
|
96
|
+
...mockTransaction,
|
|
97
|
+
amount: new bignumber_js_1.BigNumber(50),
|
|
98
|
+
fees: {
|
|
99
|
+
fee: new bignumber_js_1.BigNumber(10),
|
|
100
|
+
accountCreationFee: new bignumber_js_1.BigNumber(100),
|
|
101
|
+
},
|
|
102
|
+
};
|
|
103
|
+
const result = await (0, getTransactionStatus_1.default)(mockAccount, txWithSmallAmount);
|
|
104
|
+
expect(result.errors.amount).toBeInstanceOf(errors_2.AmountTooSmall);
|
|
105
|
+
});
|
|
106
|
+
it("should handle zero amount with AmountRequired error when useAllAmount is false", async () => {
|
|
107
|
+
const txWithZeroAmount = {
|
|
108
|
+
...mockTransaction,
|
|
109
|
+
amount: new bignumber_js_1.BigNumber(0),
|
|
110
|
+
useAllAmount: false,
|
|
111
|
+
};
|
|
112
|
+
const result = await (0, getTransactionStatus_1.default)(mockAccount, txWithZeroAmount);
|
|
113
|
+
expect(result.errors.amount).toBeInstanceOf(errors_1.AmountRequired);
|
|
114
|
+
});
|
|
115
|
+
it("should handle amount greater than max with NotEnoughBalance error", async () => {
|
|
116
|
+
// Account has spendable balance of 900
|
|
117
|
+
const txWithTooLargeAmount = {
|
|
118
|
+
...mockTransaction,
|
|
119
|
+
amount: new bignumber_js_1.BigNumber(1000),
|
|
120
|
+
useAllAmount: false,
|
|
121
|
+
};
|
|
122
|
+
const result = await (0, getTransactionStatus_1.default)(mockAccount, txWithTooLargeAmount);
|
|
123
|
+
expect(result.errors.amount).toBeInstanceOf(errors_1.NotEnoughBalance);
|
|
124
|
+
});
|
|
125
|
+
it("should calculate correct amount and totalSpent when useAllAmount is true", async () => {
|
|
126
|
+
const txWithUseAllAmount = {
|
|
127
|
+
...mockTransaction,
|
|
128
|
+
amount: new bignumber_js_1.BigNumber(0), // Amount should be ignored when useAllAmount is true
|
|
129
|
+
useAllAmount: true,
|
|
130
|
+
};
|
|
131
|
+
const result = await (0, getTransactionStatus_1.default)(mockAccount, txWithUseAllAmount);
|
|
132
|
+
// Should return spendableBalance - fee as the amount
|
|
133
|
+
expect(result.amount).toEqual(new bignumber_js_1.BigNumber(890)); // spendableBalance(900) - fee(10)
|
|
134
|
+
expect(result.totalSpent).toEqual(new bignumber_js_1.BigNumber(900)); // spendableBalance
|
|
135
|
+
expect(result.errors).toEqual({});
|
|
136
|
+
});
|
|
137
|
+
});
|
|
138
|
+
//# sourceMappingURL=getTransactionStatus.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.test.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { AccountBridge, CurrencyBridge } from "@ledgerhq/types-live";
|
|
2
|
+
import { SignerContext } from "@ledgerhq/coin-framework/signer";
|
|
3
|
+
import type { Transaction } from "../types/common";
|
|
4
|
+
import { MinaSigner } from "../types/signer";
|
|
5
|
+
import { MinaCoinConfig } from "../config";
|
|
6
|
+
import makeCliTools from "./cli-transaction";
|
|
7
|
+
export { makeCliTools };
|
|
8
|
+
export declare function buildCurrencyBridge(signerContext: SignerContext<MinaSigner>): CurrencyBridge;
|
|
9
|
+
export declare function buildAccountBridge(signerContext: SignerContext<MinaSigner>): AccountBridge<Transaction>;
|
|
10
|
+
export declare function createBridges(signerContext: SignerContext<MinaSigner>, coinConfig: MinaCoinConfig): {
|
|
11
|
+
currencyBridge: CurrencyBridge;
|
|
12
|
+
accountBridge: AccountBridge<Transaction>;
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAO1E,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAEhE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAGnD,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAiB,MAAM,WAAW,CAAC;AAO1D,OAAO,YAAY,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAE,YAAY,EAAE,CAAC;AAExB,wBAAgB,mBAAmB,CAAC,aAAa,EAAE,aAAa,CAAC,UAAU,CAAC,GAAG,cAAc,CAa5F;AAED,wBAAgB,kBAAkB,CAChC,aAAa,EAAE,aAAa,CAAC,UAAU,CAAC,GACvC,aAAa,CAAC,WAAW,CAAC,CAkB5B;AAED,wBAAgB,aAAa,CAC3B,aAAa,EAAE,aAAa,CAAC,UAAU,CAAC,EACxC,UAAU,EAAE,cAAc;;;EAQ3B"}
|
|
@@ -0,0 +1,59 @@
|
|
|
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.createBridges = exports.buildAccountBridge = exports.buildCurrencyBridge = exports.makeCliTools = void 0;
|
|
7
|
+
const jsHelpers_1 = require("@ledgerhq/coin-framework/bridge/jsHelpers");
|
|
8
|
+
const getAddressWrapper_1 = __importDefault(require("@ledgerhq/coin-framework/bridge/getAddressWrapper"));
|
|
9
|
+
const getAddress_1 = __importDefault(require("../signer/getAddress"));
|
|
10
|
+
const synchronisation_1 = require("./synchronisation");
|
|
11
|
+
const config_1 = require("../config");
|
|
12
|
+
const broadcast_1 = __importDefault(require("./broadcast"));
|
|
13
|
+
const createTransaction_1 = require("./createTransaction");
|
|
14
|
+
const estimateMaxSpendable_1 = __importDefault(require("./estimateMaxSpendable"));
|
|
15
|
+
const getTransactionStatus_1 = __importDefault(require("./getTransactionStatus"));
|
|
16
|
+
const prepareTransaction_1 = require("./prepareTransaction");
|
|
17
|
+
const signOperation_1 = __importDefault(require("./signOperation"));
|
|
18
|
+
const cli_transaction_1 = __importDefault(require("./cli-transaction"));
|
|
19
|
+
exports.makeCliTools = cli_transaction_1.default;
|
|
20
|
+
function buildCurrencyBridge(signerContext) {
|
|
21
|
+
const getAddress = (0, getAddress_1.default)(signerContext);
|
|
22
|
+
const scanAccounts = (0, jsHelpers_1.makeScanAccounts)({
|
|
23
|
+
getAccountShape: synchronisation_1.getAccountShape,
|
|
24
|
+
getAddressFn: getAddress,
|
|
25
|
+
});
|
|
26
|
+
return {
|
|
27
|
+
preload: async () => Promise.resolve({}),
|
|
28
|
+
hydrate: () => { },
|
|
29
|
+
scanAccounts,
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
exports.buildCurrencyBridge = buildCurrencyBridge;
|
|
33
|
+
function buildAccountBridge(signerContext) {
|
|
34
|
+
const getAddress = (0, getAddress_1.default)(signerContext);
|
|
35
|
+
const receive = (0, jsHelpers_1.makeAccountBridgeReceive)((0, getAddressWrapper_1.default)(getAddress));
|
|
36
|
+
const signOperation = (0, signOperation_1.default)(signerContext);
|
|
37
|
+
return {
|
|
38
|
+
estimateMaxSpendable: estimateMaxSpendable_1.default,
|
|
39
|
+
createTransaction: createTransaction_1.createTransaction,
|
|
40
|
+
updateTransaction: jsHelpers_1.updateTransaction,
|
|
41
|
+
getTransactionStatus: getTransactionStatus_1.default,
|
|
42
|
+
prepareTransaction: prepareTransaction_1.prepareTransaction,
|
|
43
|
+
sync: synchronisation_1.sync,
|
|
44
|
+
receive,
|
|
45
|
+
signOperation,
|
|
46
|
+
broadcast: broadcast_1.default,
|
|
47
|
+
getSerializedAddressParameters: jsHelpers_1.getSerializedAddressParameters,
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
exports.buildAccountBridge = buildAccountBridge;
|
|
51
|
+
function createBridges(signerContext, coinConfig) {
|
|
52
|
+
(0, config_1.setCoinConfig)(coinConfig);
|
|
53
|
+
return {
|
|
54
|
+
currencyBridge: buildCurrencyBridge(signerContext),
|
|
55
|
+
accountBridge: buildAccountBridge(signerContext),
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
exports.createBridges = createBridges;
|
|
59
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":";;;;;;AACA,yEAKmD;AAEnD,0GAAkF;AAElF,sEAA4C;AAC5C,uDAA0D;AAE1D,sCAA0D;AAC1D,4DAAoC;AACpC,2DAAwD;AACxD,kFAA0D;AAC1D,kFAA0D;AAC1D,6DAA0D;AAC1D,oEAAiD;AACjD,wEAA6C;AAEpC,uBAFF,yBAAY,CAEE;AAErB,SAAgB,mBAAmB,CAAC,aAAwC;IAC1E,MAAM,UAAU,GAAG,IAAA,oBAAQ,EAAC,aAAa,CAAC,CAAC;IAE3C,MAAM,YAAY,GAAG,IAAA,4BAAgB,EAAC;QACpC,eAAe,EAAf,iCAAe;QACf,YAAY,EAAE,UAAU;KACzB,CAAC,CAAC;IAEH,OAAO;QACL,OAAO,EAAE,KAAK,IAAI,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;QACxC,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;QACjB,YAAY;KACb,CAAC;AACJ,CAAC;AAbD,kDAaC;AAED,SAAgB,kBAAkB,CAChC,aAAwC;IAExC,MAAM,UAAU,GAAG,IAAA,oBAAQ,EAAC,aAAa,CAAC,CAAC;IAE3C,MAAM,OAAO,GAAG,IAAA,oCAAwB,EAAC,IAAA,2BAAiB,EAAC,UAAU,CAAC,CAAC,CAAC;IACxE,MAAM,aAAa,GAAG,IAAA,uBAAkB,EAAC,aAAa,CAAC,CAAC;IAExD,OAAO;QACL,oBAAoB,EAApB,8BAAoB;QACpB,iBAAiB,EAAjB,qCAAiB;QACjB,iBAAiB,EAAjB,6BAAiB;QACjB,oBAAoB,EAApB,8BAAoB;QACpB,kBAAkB,EAAlB,uCAAkB;QAClB,IAAI,EAAJ,sBAAI;QACJ,OAAO;QACP,aAAa;QACb,SAAS,EAAT,mBAAS;QACT,8BAA8B,EAA9B,0CAA8B;KAC/B,CAAC;AACJ,CAAC;AApBD,gDAoBC;AAED,SAAgB,aAAa,CAC3B,aAAwC,EACxC,UAA0B;IAE1B,IAAA,sBAAa,EAAC,UAAU,CAAC,CAAC;IAE1B,OAAO;QACL,cAAc,EAAE,mBAAmB,CAAC,aAAa,CAAC;QAClD,aAAa,EAAE,kBAAkB,CAAC,aAAa,CAAC;KACjD,CAAC;AACJ,CAAC;AAVD,sCAUC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.test.d.ts","sourceRoot":"","sources":["../../src/bridge/index.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const _1 = require(".");
|
|
4
|
+
describe("createBridges", () => {
|
|
5
|
+
let bridges;
|
|
6
|
+
beforeEach(() => {
|
|
7
|
+
bridges = (0, _1.createBridges)(undefined, {});
|
|
8
|
+
});
|
|
9
|
+
it("should return both bridges interface", () => {
|
|
10
|
+
expect(bridges.accountBridge).toBeDefined();
|
|
11
|
+
expect(bridges.currencyBridge).toBeDefined();
|
|
12
|
+
});
|
|
13
|
+
it("should have a currency bridge with required methods", () => {
|
|
14
|
+
expect(bridges.currencyBridge).toBeDefined();
|
|
15
|
+
expect(bridges.currencyBridge.preload).toBeDefined();
|
|
16
|
+
expect(bridges.currencyBridge.hydrate).toBeDefined();
|
|
17
|
+
expect(bridges.currencyBridge.scanAccounts).toBeDefined();
|
|
18
|
+
});
|
|
19
|
+
it("should have an account bridge with required methods", () => {
|
|
20
|
+
expect(bridges.accountBridge).toBeDefined();
|
|
21
|
+
expect(bridges.accountBridge.broadcast).toBeDefined();
|
|
22
|
+
expect(bridges.accountBridge.createTransaction).toBeDefined();
|
|
23
|
+
expect(bridges.accountBridge.estimateMaxSpendable).toBeDefined();
|
|
24
|
+
expect(bridges.accountBridge.getTransactionStatus).toBeDefined();
|
|
25
|
+
expect(bridges.accountBridge.prepareTransaction).toBeDefined();
|
|
26
|
+
expect(bridges.accountBridge.receive).toBeDefined();
|
|
27
|
+
expect(bridges.accountBridge.signOperation).toBeDefined();
|
|
28
|
+
expect(bridges.accountBridge.sync).toBeDefined();
|
|
29
|
+
expect(bridges.accountBridge.updateTransaction).toBeDefined();
|
|
30
|
+
});
|
|
31
|
+
});
|
|
32
|
+
//# sourceMappingURL=index.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../src/bridge/index.test.ts"],"names":[],"mappings":";;AACA,wBAAkC;AAIlC,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,IAAI,OAAyC,CAAC;IAC9C,UAAU,CAAC,GAAG,EAAE;QACd,OAAO,GAAG,IAAA,gBAAa,EACrB,SAAiD,EACjD,EAA+B,CAChC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sCAAsC,EAAE,GAAG,EAAE;QAC9C,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,WAAW,EAAE,CAAC;QAC5C,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,WAAW,EAAE,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC7D,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,WAAW,EAAE,CAAC;QAC7C,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;QACrD,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;QACrD,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC,WAAW,EAAE,CAAC;IAC5D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC7D,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,WAAW,EAAE,CAAC;QAC5C,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;QACtD,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC,WAAW,EAAE,CAAC;QAC9D,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC,WAAW,EAAE,CAAC;QACjE,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC,WAAW,EAAE,CAAC;QACjE,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,kBAAkB,CAAC,CAAC,WAAW,EAAE,CAAC;QAC/D,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;QACpD,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,WAAW,EAAE,CAAC;QAC1D,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;QACjD,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC,WAAW,EAAE,CAAC;IAChE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prepareTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAW,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAG9D,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAG3D,eAAO,MAAM,kBAAkB,EAAE,aAAa,CAC5C,WAAW,EACX,WAAW,CACZ,CAAC,oBAAoB,CAarB,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
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.prepareTransaction = void 0;
|
|
7
|
+
const jsHelpers_1 = require("@ledgerhq/coin-framework/bridge/jsHelpers");
|
|
8
|
+
const estimateMaxSpendable_1 = __importDefault(require("./estimateMaxSpendable"));
|
|
9
|
+
const getEstimatedFees_1 = __importDefault(require("./getEstimatedFees"));
|
|
10
|
+
const api_1 = require("../api");
|
|
11
|
+
const prepareTransaction = async (a, t) => {
|
|
12
|
+
const { fee, accountCreationFee } = await (0, getEstimatedFees_1.default)(t, a.freshAddress);
|
|
13
|
+
const amount = t.useAllAmount
|
|
14
|
+
? await (0, estimateMaxSpendable_1.default)({
|
|
15
|
+
account: a,
|
|
16
|
+
transaction: t,
|
|
17
|
+
})
|
|
18
|
+
: t.amount;
|
|
19
|
+
const nonce = await (0, api_1.getNonce)(t, a.freshAddress);
|
|
20
|
+
return (0, jsHelpers_1.updateTransaction)(t, { fees: { fee, accountCreationFee }, amount, nonce });
|
|
21
|
+
};
|
|
22
|
+
exports.prepareTransaction = prepareTransaction;
|
|
23
|
+
//# sourceMappingURL=prepareTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prepareTransaction.js","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":";;;;;;AAAA,yEAA8E;AAE9E,kFAA0D;AAC1D,0EAAkD;AAElD,gCAAkC;AAE3B,MAAM,kBAAkB,GAGL,KAAK,EAAE,CAAU,EAAE,CAAc,EAAE,EAAE;IAC7D,MAAM,EAAE,GAAG,EAAE,kBAAkB,EAAE,GAAG,MAAM,IAAA,0BAAgB,EAAC,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC;IAE9E,MAAM,MAAM,GAAG,CAAC,CAAC,YAAY;QAC3B,CAAC,CAAC,MAAM,IAAA,8BAAoB,EAAC;YACzB,OAAO,EAAE,CAAC;YACV,WAAW,EAAE,CAAC;SACf,CAAC;QACJ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;IAEb,MAAM,KAAK,GAAG,MAAM,IAAA,cAAQ,EAAC,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC;IAEhD,OAAO,IAAA,6BAAiB,EAAC,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,kBAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;AACpF,CAAC,CAAC;AAhBW,QAAA,kBAAkB,sBAgB7B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prepareTransaction.test.d.ts","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,43 @@
|
|
|
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 getEstimatedFees_1 = __importDefault(require("./getEstimatedFees"));
|
|
8
|
+
const api_1 = require("../api");
|
|
9
|
+
const prepareTransaction_1 = require("./prepareTransaction");
|
|
10
|
+
jest.mock("../api");
|
|
11
|
+
jest.mock("./getEstimatedFees");
|
|
12
|
+
describe("prepareTransaction", () => {
|
|
13
|
+
let estimateFeesSpy;
|
|
14
|
+
let getNonceSpy;
|
|
15
|
+
beforeEach(() => {
|
|
16
|
+
getNonceSpy = jest.spyOn({ getNonce: api_1.getNonce }, "getNonce");
|
|
17
|
+
estimateFeesSpy = jest.spyOn({ estimateFees: getEstimatedFees_1.default }, "estimateFees");
|
|
18
|
+
estimateFeesSpy.mockResolvedValue({
|
|
19
|
+
fee: new bignumber_js_1.default(1),
|
|
20
|
+
accountCreationFee: new bignumber_js_1.default(1),
|
|
21
|
+
});
|
|
22
|
+
getNonceSpy.mockResolvedValue(1);
|
|
23
|
+
});
|
|
24
|
+
it("should update fee fields if it's different", async () => {
|
|
25
|
+
const oldTx = {
|
|
26
|
+
fees: { fee: new bignumber_js_1.default(0), accountCreationFee: new bignumber_js_1.default(0) },
|
|
27
|
+
};
|
|
28
|
+
const newTx = await (0, prepareTransaction_1.prepareTransaction)({}, oldTx);
|
|
29
|
+
expect(newTx.fees.fee).toEqual(new bignumber_js_1.default(1));
|
|
30
|
+
expect(newTx.fees.accountCreationFee).toEqual(new bignumber_js_1.default(1));
|
|
31
|
+
expect(getNonceSpy).toHaveBeenCalledTimes(1);
|
|
32
|
+
expect(getNonceSpy).toHaveBeenCalledWith(oldTx, undefined);
|
|
33
|
+
});
|
|
34
|
+
it("should update nonce if it's different", async () => {
|
|
35
|
+
const oldTx = {
|
|
36
|
+
nonce: 0,
|
|
37
|
+
fees: { fee: new bignumber_js_1.default(0), accountCreationFee: new bignumber_js_1.default(0) },
|
|
38
|
+
};
|
|
39
|
+
const newTx = await (0, prepareTransaction_1.prepareTransaction)({}, oldTx);
|
|
40
|
+
expect(newTx.nonce).toEqual(1);
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
//# sourceMappingURL=prepareTransaction.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prepareTransaction.test.js","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.test.ts"],"names":[],"mappings":";;;;;AAAA,gEAAqC;AACrC,0EAA8C;AAC9C,gCAAkC;AAClC,6DAA0D;AAI1D,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;AACpB,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;AAEhC,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,IAAI,eAAiC,CAAC;IACtC,IAAI,WAA6B,CAAC;IAClC,UAAU,CAAC,GAAG,EAAE;QACd,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,QAAQ,EAAR,cAAQ,EAAE,EAAE,UAAU,CAAC,CAAC;QACnD,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,YAAY,EAAZ,0BAAY,EAAE,EAAE,cAAc,CAAC,CAAC;QAC/D,eAAe,CAAC,iBAAiB,CAAC;YAChC,GAAG,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;YACrB,kBAAkB,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;SACrC,CAAC,CAAC;QACH,WAAW,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,MAAM,KAAK,GAAG;YACZ,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC,EAAE;SACtE,CAAC;QACF,MAAM,KAAK,GAAG,MAAM,IAAA,uCAAkB,EAAC,EAAa,EAAE,KAAoB,CAAC,CAAC;QAC5E,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,IAAI,sBAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QACjD,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,OAAO,CAAC,IAAI,sBAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QAChE,MAAM,CAAC,WAAW,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,WAAW,CAAC,CAAC,oBAAoB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uCAAuC,EAAE,KAAK,IAAI,EAAE;QACrD,MAAM,KAAK,GAAG;YACZ,KAAK,EAAE,CAAC;YACR,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC,EAAE;SACtE,CAAC;QACF,MAAM,KAAK,GAAG,MAAM,IAAA,uCAAkB,EAAC,EAAa,EAAE,KAAoB,CAAC,CAAC;QAC5E,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { BigNumber } from "bignumber.js";
|
|
2
|
+
import type { MinaOperation, Transaction } from "../types/common";
|
|
3
|
+
import type { Account, AccountBridge } from "@ledgerhq/types-live";
|
|
4
|
+
import { MinaSigner } from "../types/signer";
|
|
5
|
+
import { SignerContext } from "@ledgerhq/coin-framework/signer";
|
|
6
|
+
export declare const buildOptimisticOperation: (account: Account, transaction: Transaction, fee: BigNumber) => MinaOperation;
|
|
7
|
+
/**
|
|
8
|
+
* Sign Transaction with Ledger hardware
|
|
9
|
+
*/
|
|
10
|
+
export declare const buildSignOperation: (signerContext: SignerContext<MinaSigner>) => AccountBridge<Transaction>["signOperation"];
|
|
11
|
+
export default buildSignOperation;
|
|
12
|
+
//# sourceMappingURL=signOperation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAGzC,OAAO,KAAK,EAAE,aAAa,EAAyB,WAAW,EAAE,MAAM,iBAAiB,CAAC;AACzF,OAAO,KAAK,EACV,OAAO,EAIP,aAAa,EACd,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAiB,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAKhE,eAAO,MAAM,wBAAwB,YAC1B,OAAO,eACH,WAAW,OACnB,SAAS,KACb,aA4BF,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,kBAAkB,kBACb,cAAc,UAAU,CAAC,KAAG,cAAc,WAAW,CAAC,CAAC,eAAe,CAqDlF,CAAC;AAEP,eAAe,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,72 @@
|
|
|
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.buildSignOperation = exports.buildOptimisticOperation = void 0;
|
|
7
|
+
const bignumber_js_1 = require("bignumber.js");
|
|
8
|
+
const rxjs_1 = require("rxjs");
|
|
9
|
+
const errors_1 = require("@ledgerhq/errors");
|
|
10
|
+
const operation_1 = require("@ledgerhq/coin-framework/operation");
|
|
11
|
+
const buildTransaction_1 = require("./buildTransaction");
|
|
12
|
+
const common_logic_1 = require("../common-logic");
|
|
13
|
+
const invariant_1 = __importDefault(require("invariant"));
|
|
14
|
+
const buildOptimisticOperation = (account, transaction, fee) => {
|
|
15
|
+
let value = new bignumber_js_1.BigNumber(transaction.amount).plus(fee);
|
|
16
|
+
if (transaction.fees?.accountCreationFee.gt(0)) {
|
|
17
|
+
value = value.minus(transaction.fees.accountCreationFee);
|
|
18
|
+
}
|
|
19
|
+
const type = "OUT";
|
|
20
|
+
const operation = {
|
|
21
|
+
id: (0, operation_1.encodeOperationId)(account.id, "", type),
|
|
22
|
+
hash: "",
|
|
23
|
+
type,
|
|
24
|
+
value,
|
|
25
|
+
fee,
|
|
26
|
+
blockHash: null,
|
|
27
|
+
blockHeight: null,
|
|
28
|
+
senders: [account.freshAddress],
|
|
29
|
+
recipients: [transaction.recipient].filter(Boolean),
|
|
30
|
+
accountId: account.id,
|
|
31
|
+
date: new Date(),
|
|
32
|
+
extra: {
|
|
33
|
+
memo: transaction.memo,
|
|
34
|
+
accountCreationFee: transaction.fees.accountCreationFee.toString(),
|
|
35
|
+
},
|
|
36
|
+
};
|
|
37
|
+
return operation;
|
|
38
|
+
};
|
|
39
|
+
exports.buildOptimisticOperation = buildOptimisticOperation;
|
|
40
|
+
/**
|
|
41
|
+
* Sign Transaction with Ledger hardware
|
|
42
|
+
*/
|
|
43
|
+
const buildSignOperation = (signerContext) => ({ account, transaction, deviceId, }) => new rxjs_1.Observable(o => {
|
|
44
|
+
async function main() {
|
|
45
|
+
o.next({ type: "device-signature-requested" });
|
|
46
|
+
if (!transaction.fees) {
|
|
47
|
+
throw new errors_1.FeeNotLoaded();
|
|
48
|
+
}
|
|
49
|
+
const unsigned = await (0, buildTransaction_1.buildTransaction)(account, transaction);
|
|
50
|
+
const { signature } = (await signerContext(deviceId, signer => signer.signTransaction(unsigned)));
|
|
51
|
+
(0, invariant_1.default)(signature, "signature should be defined if user accepted");
|
|
52
|
+
const encodedSignature = (0, common_logic_1.reEncodeRawSignature)(signature);
|
|
53
|
+
const signedTransaction = {
|
|
54
|
+
transaction: unsigned,
|
|
55
|
+
signature: encodedSignature,
|
|
56
|
+
};
|
|
57
|
+
o.next({ type: "device-signature-granted" });
|
|
58
|
+
const operation = (0, exports.buildOptimisticOperation)(account, transaction, transaction.fees.fee ?? new bignumber_js_1.BigNumber(0));
|
|
59
|
+
const signedSerializedTx = JSON.stringify(signedTransaction);
|
|
60
|
+
o.next({
|
|
61
|
+
type: "signed",
|
|
62
|
+
signedOperation: {
|
|
63
|
+
operation,
|
|
64
|
+
signature: signedSerializedTx,
|
|
65
|
+
},
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
main().then(() => o.complete(), e => o.error(e));
|
|
69
|
+
});
|
|
70
|
+
exports.buildSignOperation = buildSignOperation;
|
|
71
|
+
exports.default = exports.buildSignOperation;
|
|
72
|
+
//# sourceMappingURL=signOperation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signOperation.js","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signOperation.test.d.ts","sourceRoot":"","sources":["../../src/bridge/signOperation.test.ts"],"names":[],"mappings":""}
|