@ledgerhq/coin-mina 1.1.0-next.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 +8 -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,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.makeTransferPayload = exports.buildAccountIdentifier = exports.addNetworkIdentifier = void 0;
|
|
4
|
+
const consts_1 = require("../../consts");
|
|
5
|
+
const addNetworkIdentifier = (data) => {
|
|
6
|
+
return {
|
|
7
|
+
...consts_1.MAINNET_NETWORK_IDENTIFIER,
|
|
8
|
+
...data,
|
|
9
|
+
};
|
|
10
|
+
};
|
|
11
|
+
exports.addNetworkIdentifier = addNetworkIdentifier;
|
|
12
|
+
const buildAccountIdentifier = (address) => {
|
|
13
|
+
return {
|
|
14
|
+
account_identifier: {
|
|
15
|
+
address,
|
|
16
|
+
metadata: {
|
|
17
|
+
token_id: consts_1.MINA_TOKEN_ID,
|
|
18
|
+
},
|
|
19
|
+
},
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
exports.buildAccountIdentifier = buildAccountIdentifier;
|
|
23
|
+
function makeTransferPayload(from, to, feeNano, valueNano) {
|
|
24
|
+
function makeOperation(idx, relatedIdxs, opType, addr, value, isPositive) {
|
|
25
|
+
const relatedOps = relatedIdxs.length == 0
|
|
26
|
+
? {}
|
|
27
|
+
: {
|
|
28
|
+
related_operations: relatedIdxs.map(i => {
|
|
29
|
+
return { index: i };
|
|
30
|
+
}),
|
|
31
|
+
};
|
|
32
|
+
return {
|
|
33
|
+
operation_identifier: { index: idx },
|
|
34
|
+
relatedOps,
|
|
35
|
+
type: opType,
|
|
36
|
+
account: {
|
|
37
|
+
address: addr,
|
|
38
|
+
metadata: {
|
|
39
|
+
token_id: consts_1.MINA_TOKEN_ID,
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
amount: {
|
|
43
|
+
value: (isPositive ? "" : "-") + value.toString(),
|
|
44
|
+
currency: {
|
|
45
|
+
symbol: consts_1.MINA_SYMBOL,
|
|
46
|
+
decimals: consts_1.MINA_DECIMALS,
|
|
47
|
+
},
|
|
48
|
+
},
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
return {
|
|
52
|
+
operations: [
|
|
53
|
+
makeOperation(0, [], "fee_payment", from, feeNano, false),
|
|
54
|
+
makeOperation(1, [], "payment_source_dec", from, valueNano, false),
|
|
55
|
+
makeOperation(2, [1], "payment_receiver_inc", to, valueNano, true),
|
|
56
|
+
],
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
exports.makeTransferPayload = makeTransferPayload;
|
|
60
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/api/rosetta/utils.ts"],"names":[],"mappings":";;;AAAA,yCAKsB;AAEf,MAAM,oBAAoB,GAAG,CAAC,IAAY,EAAE,EAAE;IACnD,OAAO;QACL,GAAG,mCAA0B;QAC7B,GAAG,IAAI;KACR,CAAC;AACJ,CAAC,CAAC;AALW,QAAA,oBAAoB,wBAK/B;AAEK,MAAM,sBAAsB,GAAG,CAAC,OAAe,EAAE,EAAE;IACxD,OAAO;QACL,kBAAkB,EAAE;YAClB,OAAO;YACP,QAAQ,EAAE;gBACR,QAAQ,EAAE,sBAAa;aACxB;SACF;KACF,CAAC;AACJ,CAAC,CAAC;AATW,QAAA,sBAAsB,0BASjC;AAEF,SAAgB,mBAAmB,CAAC,IAAY,EAAE,EAAU,EAAE,OAAe,EAAE,SAAiB;IAC9F,SAAS,aAAa,CACpB,GAAW,EACX,WAAqB,EACrB,MAAc,EACd,IAAY,EACZ,KAAa,EACb,UAAmB;QAEnB,MAAM,UAAU,GACd,WAAW,CAAC,MAAM,IAAI,CAAC;YACrB,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC;gBACE,kBAAkB,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;oBACtC,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC;gBACtB,CAAC,CAAC;aACH,CAAC;QAER,OAAO;YACL,oBAAoB,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE;YACpC,UAAU;YACV,IAAI,EAAE,MAAM;YACZ,OAAO,EAAE;gBACP,OAAO,EAAE,IAAI;gBACb,QAAQ,EAAE;oBACR,QAAQ,EAAE,sBAAa;iBACxB;aACF;YACD,MAAM,EAAE;gBACN,KAAK,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAE;gBACjD,QAAQ,EAAE;oBACR,MAAM,EAAE,oBAAW;oBACnB,QAAQ,EAAE,sBAAa;iBACxB;aACF;SACF,CAAC;IACJ,CAAC;IAED,OAAO;QACL,UAAU,EAAE;YACV,aAAa,CAAC,CAAC,EAAE,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC;YACzD,aAAa,CAAC,CAAC,EAAE,EAAE,EAAE,oBAAoB,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,CAAC;YAClE,aAAa,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,sBAAsB,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,CAAC;SACnE;KACF,CAAC;AACJ,CAAC;AA7CD,kDA6CC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.test.d.ts","sourceRoot":"","sources":["../../../src/api/rosetta/utils.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const utils_1 = require("./utils");
|
|
4
|
+
const consts_1 = require("../../consts");
|
|
5
|
+
describe("addNetworkIdentifier", () => {
|
|
6
|
+
it("should add network identifier to an empty object", () => {
|
|
7
|
+
const result = (0, utils_1.addNetworkIdentifier)({});
|
|
8
|
+
expect(result).toEqual(consts_1.MAINNET_NETWORK_IDENTIFIER);
|
|
9
|
+
});
|
|
10
|
+
it("should add network identifier to an object with existing properties", () => {
|
|
11
|
+
const testObj = { test: "value" };
|
|
12
|
+
const result = (0, utils_1.addNetworkIdentifier)(testObj);
|
|
13
|
+
expect(result).toEqual({
|
|
14
|
+
...consts_1.MAINNET_NETWORK_IDENTIFIER,
|
|
15
|
+
test: "value",
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
it("should override network identifier properties if they exist in input object", () => {
|
|
19
|
+
// Assuming MAINNET_NETWORK_IDENTIFIER has a property like { blockchain: 'Mina' }
|
|
20
|
+
const testObj = { blockchain: "mina" };
|
|
21
|
+
const result = (0, utils_1.addNetworkIdentifier)(testObj);
|
|
22
|
+
expect(result.network_identifier.blockchain).toEqual("mina");
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
describe("buildAccountIdentifier", () => {
|
|
26
|
+
it("should build correct account identifier with given address", () => {
|
|
27
|
+
const testAddress = "B62qrPN5Y5yq8kGE3FbVKbGTdTAJNdtNtB5sNVpxyRwWGcDEhpMzc8g";
|
|
28
|
+
const result = (0, utils_1.buildAccountIdentifier)(testAddress);
|
|
29
|
+
expect(result).toEqual({
|
|
30
|
+
account_identifier: {
|
|
31
|
+
address: testAddress,
|
|
32
|
+
metadata: {
|
|
33
|
+
token_id: consts_1.MINA_TOKEN_ID,
|
|
34
|
+
},
|
|
35
|
+
},
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
describe("makeTransferPayload", () => {
|
|
40
|
+
const fromAddr = "sender-address";
|
|
41
|
+
const toAddr = "recipient-address";
|
|
42
|
+
const feeNano = 1000000;
|
|
43
|
+
const valueNano = 5000000;
|
|
44
|
+
it("should create a valid transfer payload with three operations", () => {
|
|
45
|
+
const result = (0, utils_1.makeTransferPayload)(fromAddr, toAddr, feeNano, valueNano);
|
|
46
|
+
expect(result.operations).toHaveLength(3);
|
|
47
|
+
});
|
|
48
|
+
it("should correctly create fee payment operation", () => {
|
|
49
|
+
const result = (0, utils_1.makeTransferPayload)(fromAddr, toAddr, feeNano, valueNano);
|
|
50
|
+
const feeOp = result.operations[0];
|
|
51
|
+
expect(feeOp.operation_identifier.index).toBe(0);
|
|
52
|
+
expect(feeOp.type).toBe("fee_payment");
|
|
53
|
+
expect(feeOp.account.address).toBe(fromAddr);
|
|
54
|
+
expect(feeOp.amount.value).toBe("-" + feeNano.toString());
|
|
55
|
+
expect(feeOp.amount.currency.symbol).toBe(consts_1.MINA_SYMBOL);
|
|
56
|
+
expect(feeOp.amount.currency.decimals).toBe(consts_1.MINA_DECIMALS);
|
|
57
|
+
});
|
|
58
|
+
it("should correctly create payment source operation", () => {
|
|
59
|
+
const result = (0, utils_1.makeTransferPayload)(fromAddr, toAddr, feeNano, valueNano);
|
|
60
|
+
const sourceOp = result.operations[1];
|
|
61
|
+
expect(sourceOp.operation_identifier.index).toBe(1);
|
|
62
|
+
expect(sourceOp.type).toBe("payment_source_dec");
|
|
63
|
+
expect(sourceOp.account.address).toBe(fromAddr);
|
|
64
|
+
expect(sourceOp.amount.value).toBe("-" + valueNano.toString());
|
|
65
|
+
});
|
|
66
|
+
it("should correctly create payment receiver operation with related operation", () => {
|
|
67
|
+
const result = (0, utils_1.makeTransferPayload)(fromAddr, toAddr, feeNano, valueNano);
|
|
68
|
+
const receiverOp = result.operations[2];
|
|
69
|
+
expect(receiverOp.operation_identifier.index).toBe(2);
|
|
70
|
+
expect(receiverOp.type).toBe("payment_receiver_inc");
|
|
71
|
+
expect(receiverOp.account.address).toBe(toAddr);
|
|
72
|
+
expect(receiverOp.amount.value).toBe(valueNano.toString());
|
|
73
|
+
expect(receiverOp.relatedOps.related_operations).toEqual([{ index: 1 }]);
|
|
74
|
+
});
|
|
75
|
+
it("should handle zero values correctly", () => {
|
|
76
|
+
const result = (0, utils_1.makeTransferPayload)(fromAddr, toAddr, 0, 0);
|
|
77
|
+
expect(result.operations[0].amount.value).toBe("-0");
|
|
78
|
+
expect(result.operations[1].amount.value).toBe("-0");
|
|
79
|
+
expect(result.operations[2].amount.value).toBe("0");
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
//# sourceMappingURL=utils.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.test.js","sourceRoot":"","sources":["../../../src/api/rosetta/utils.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { Operation, SignedOperation } from "@ledgerhq/types-live";
|
|
2
|
+
declare const broadcast: ({ signedOperation: { signature, operation }, }: {
|
|
3
|
+
signedOperation: SignedOperation;
|
|
4
|
+
}) => Promise<Operation>;
|
|
5
|
+
export default broadcast;
|
|
6
|
+
//# 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,SAAS,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAKvE,QAAA,MAAM,SAAS,mDAEZ;IACD,eAAe,EAAE,eAAe,CAAC;CAClC,KAAG,QAAQ,SAAS,CAKpB,CAAC;AAEF,eAAe,SAAS,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const operation_1 = require("@ledgerhq/coin-framework/operation");
|
|
4
|
+
const api_1 = require("../api");
|
|
5
|
+
const broadcast = async ({ signedOperation: { signature, operation }, }) => {
|
|
6
|
+
const signedPayload = JSON.parse(signature);
|
|
7
|
+
const hash = await (0, api_1.broadcastTransaction)(signedPayload);
|
|
8
|
+
return (0, operation_1.patchOperationWithHash)(operation, hash);
|
|
9
|
+
};
|
|
10
|
+
exports.default = broadcast;
|
|
11
|
+
//# sourceMappingURL=broadcast.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":";;AACA,kEAA4E;AAC5E,gCAA8C;AAG9C,MAAM,SAAS,GAAG,KAAK,EAAE,EACvB,eAAe,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,GAG1C,EAAsB,EAAE;IACvB,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAA0B,CAAC;IACrE,MAAM,IAAI,GAAG,MAAM,IAAA,0BAAoB,EAAC,aAAa,CAAC,CAAC;IAEvD,OAAO,IAAA,kCAAsB,EAAC,SAAS,EAAE,IAAI,CAAC,CAAC;AACjD,CAAC,CAAC;AAEF,kBAAe,SAAS,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.test.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,36 @@
|
|
|
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 broadcast_1 = __importDefault(require("./broadcast"));
|
|
7
|
+
jest.mock("@ledgerhq/coin-framework/operation");
|
|
8
|
+
jest.mock("../api");
|
|
9
|
+
const operation_1 = require("@ledgerhq/coin-framework/operation");
|
|
10
|
+
const api_1 = require("../api");
|
|
11
|
+
describe("broadcast", () => {
|
|
12
|
+
let patchOperationSpy;
|
|
13
|
+
let broadcastSpy;
|
|
14
|
+
beforeEach(() => {
|
|
15
|
+
patchOperationSpy = jest.spyOn({ patchOperationWithHash: operation_1.patchOperationWithHash }, "patchOperationWithHash");
|
|
16
|
+
broadcastSpy = jest.spyOn({ broadcastLogic: api_1.broadcastTransaction }, "broadcastLogic");
|
|
17
|
+
broadcastSpy.mockResolvedValue("hash");
|
|
18
|
+
});
|
|
19
|
+
const signedOperation = {
|
|
20
|
+
signature: JSON.stringify({}),
|
|
21
|
+
operation: undefined,
|
|
22
|
+
};
|
|
23
|
+
it("should broadcast", () => {
|
|
24
|
+
(0, broadcast_1.default)({
|
|
25
|
+
signedOperation,
|
|
26
|
+
});
|
|
27
|
+
expect(api_1.broadcastTransaction).toHaveBeenCalledTimes(1);
|
|
28
|
+
});
|
|
29
|
+
it("should patch operation with hash", () => {
|
|
30
|
+
(0, broadcast_1.default)({
|
|
31
|
+
signedOperation,
|
|
32
|
+
});
|
|
33
|
+
expect(patchOperationSpy).toHaveBeenCalledWith(undefined, "hash");
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
//# sourceMappingURL=broadcast.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.test.js","sourceRoot":"","sources":["../../src/bridge/broadcast.test.ts"],"names":[],"mappings":";;;;;AACA,4DAAoC;AACpC,IAAI,CAAC,IAAI,CAAC,oCAAoC,CAAC,CAAC;AAChD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;AACpB,kEAA4E;AAC5E,gCAAgE;AAEhE,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,IAAI,iBAAmC,CAAC;IACxC,IAAI,YAA8B,CAAC;IACnC,UAAU,CAAC,GAAG,EAAE;QACd,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,sBAAsB,EAAtB,kCAAsB,EAAE,EAAE,wBAAwB,CAAC,CAAC;QACrF,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,cAAc,EAAd,0BAAc,EAAE,EAAE,gBAAgB,CAAC,CAAC;QAChE,YAAY,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,MAAM,eAAe,GAAG;QACtB,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;QAC7B,SAAS,EAAE,SAAS;KACrB,CAAC;IAEF,EAAE,CAAC,kBAAkB,EAAE,GAAG,EAAE;QAC1B,IAAA,mBAAS,EAAC;YACR,eAAe;SACoB,CAAC,CAAC;QACvC,MAAM,CAAC,0BAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAClD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,IAAA,mBAAS,EAAC;YACR,eAAe;SACoB,CAAC,CAAC;QACvC,MAAM,CAAC,iBAAiB,CAAC,CAAC,oBAAoB,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { Account } from "@ledgerhq/types-live";
|
|
2
|
+
import type { MinaUnsignedTransaction, Transaction } from "../types/common";
|
|
3
|
+
export declare const buildTransaction: (a: Account, t: Transaction) => Promise<MinaUnsignedTransaction>;
|
|
4
|
+
//# 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,OAAO,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,KAAK,EAAE,uBAAuB,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAK5E,eAAO,MAAM,gBAAgB,MACxB,OAAO,KACP,WAAW,KACb,QAAQ,uBAAuB,CAuBjC,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
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 = void 0;
|
|
7
|
+
const logs_1 = require("@ledgerhq/logs");
|
|
8
|
+
const consts_1 = require("../consts");
|
|
9
|
+
const common_logic_1 = require("../common-logic");
|
|
10
|
+
const invariant_1 = __importDefault(require("invariant"));
|
|
11
|
+
const buildTransaction = async (a, t) => {
|
|
12
|
+
try {
|
|
13
|
+
const accountNum = (0, common_logic_1.getAccountNumFromPath)(a.freshAddressPath);
|
|
14
|
+
(0, invariant_1.default)(accountNum !== undefined, "mina: accountNum is required to build transaction");
|
|
15
|
+
return {
|
|
16
|
+
txType: consts_1.MINA_PAYMENT_TYPE_ID,
|
|
17
|
+
senderAccount: accountNum,
|
|
18
|
+
senderAddress: a.freshAddress,
|
|
19
|
+
receiverAddress: t.recipient,
|
|
20
|
+
amount: t.amount.toNumber(),
|
|
21
|
+
fee: t.fees.fee.toNumber(),
|
|
22
|
+
nonce: t.nonce,
|
|
23
|
+
memo: t.memo ?? "",
|
|
24
|
+
networkId: consts_1.MINA_MAINNET_NETWORK_ID,
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
catch (e) {
|
|
28
|
+
(0, logs_1.log)("error", "mina: error building transaction", {
|
|
29
|
+
error: e,
|
|
30
|
+
transaction: t,
|
|
31
|
+
account: a,
|
|
32
|
+
});
|
|
33
|
+
throw e;
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
exports.buildTransaction = buildTransaction;
|
|
37
|
+
//# sourceMappingURL=buildTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildTransaction.js","sourceRoot":"","sources":["../../src/bridge/buildTransaction.ts"],"names":[],"mappings":";;;;;;AAAA,yCAAqC;AAGrC,sCAA0E;AAC1E,kDAAwD;AACxD,0DAAkC;AAE3B,MAAM,gBAAgB,GAAG,KAAK,EACnC,CAAU,EACV,CAAc,EACoB,EAAE;IACpC,IAAI,CAAC;QACH,MAAM,UAAU,GAAG,IAAA,oCAAqB,EAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC;QAC7D,IAAA,mBAAS,EAAC,UAAU,KAAK,SAAS,EAAE,mDAAmD,CAAC,CAAC;QACzF,OAAO;YACL,MAAM,EAAE,6BAAoB;YAC5B,aAAa,EAAE,UAAU;YACzB,aAAa,EAAE,CAAC,CAAC,YAAY;YAC7B,eAAe,EAAE,CAAC,CAAC,SAAS;YAC5B,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,QAAQ,EAAE;YAC3B,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE;YAC1B,KAAK,EAAE,CAAC,CAAC,KAAK;YACd,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,EAAE;YAClB,SAAS,EAAE,gCAAuB;SACnC,CAAC;IACJ,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,IAAA,UAAG,EAAC,OAAO,EAAE,kCAAkC,EAAE;YAC/C,KAAK,EAAE,CAAC;YACR,WAAW,EAAE,CAAC;YACd,OAAO,EAAE,CAAC;SACX,CAAC,CAAC;QACH,MAAM,CAAC,CAAC;IACV,CAAC;AACH,CAAC,CAAC;AA1BW,QAAA,gBAAgB,oBA0B3B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildTransaction.test.d.ts","sourceRoot":"","sources":["../../src/bridge/buildTransaction.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const buildTransaction_1 = require("./buildTransaction");
|
|
4
|
+
const consts_1 = require("../consts");
|
|
5
|
+
const common_logic_1 = require("../common-logic");
|
|
6
|
+
const bignumber_js_1 = require("bignumber.js");
|
|
7
|
+
jest.mock("../common-logic");
|
|
8
|
+
describe("buildTransaction", () => {
|
|
9
|
+
let getAccountNumSpy;
|
|
10
|
+
beforeEach(() => {
|
|
11
|
+
getAccountNumSpy = jest.spyOn({ getAccountNumFromPath: common_logic_1.getAccountNumFromPath }, "getAccountNumFromPath");
|
|
12
|
+
getAccountNumSpy.mockReturnValue(42); // Mock account number
|
|
13
|
+
});
|
|
14
|
+
const mockAccount = {
|
|
15
|
+
freshAddress: "B62qrPN5Y5yq8kGE3FbVKbGTdTAJNdHm8qSqZhhtiu1Dq56Cmuo2aJ4",
|
|
16
|
+
freshAddressPath: "44'/12586'/0'/0/0",
|
|
17
|
+
};
|
|
18
|
+
const mockTransaction = {
|
|
19
|
+
recipient: "B62qoDWfBZUxKpaoQCoMPJEysXXWv7reVgo7CEAjqx1xAYs3CsT8Gtz",
|
|
20
|
+
amount: new bignumber_js_1.BigNumber(1000000000),
|
|
21
|
+
fees: {
|
|
22
|
+
fee: new bignumber_js_1.BigNumber(1000000),
|
|
23
|
+
accountCreationFee: new bignumber_js_1.BigNumber(0),
|
|
24
|
+
},
|
|
25
|
+
nonce: 5,
|
|
26
|
+
memo: "test transaction",
|
|
27
|
+
family: "mina",
|
|
28
|
+
};
|
|
29
|
+
it("should build a transaction correctly", async () => {
|
|
30
|
+
const result = await (0, buildTransaction_1.buildTransaction)(mockAccount, mockTransaction);
|
|
31
|
+
expect(result).toEqual({
|
|
32
|
+
txType: consts_1.MINA_PAYMENT_TYPE_ID,
|
|
33
|
+
senderAccount: 42,
|
|
34
|
+
senderAddress: mockAccount.freshAddress,
|
|
35
|
+
receiverAddress: mockTransaction.recipient,
|
|
36
|
+
amount: mockTransaction.amount.toNumber(),
|
|
37
|
+
fee: mockTransaction.fees.fee.toNumber(),
|
|
38
|
+
nonce: mockTransaction.nonce,
|
|
39
|
+
memo: mockTransaction.memo,
|
|
40
|
+
networkId: consts_1.MINA_MAINNET_NETWORK_ID,
|
|
41
|
+
});
|
|
42
|
+
expect(common_logic_1.getAccountNumFromPath).toHaveBeenCalledWith(mockAccount.freshAddressPath);
|
|
43
|
+
});
|
|
44
|
+
it("should handle empty memo", async () => {
|
|
45
|
+
const txWithoutMemo = {
|
|
46
|
+
...mockTransaction,
|
|
47
|
+
memo: undefined,
|
|
48
|
+
};
|
|
49
|
+
const result = await (0, buildTransaction_1.buildTransaction)(mockAccount, txWithoutMemo);
|
|
50
|
+
expect(result.memo).toBe("");
|
|
51
|
+
});
|
|
52
|
+
it("should throw error if accountNum is undefined", async () => {
|
|
53
|
+
getAccountNumSpy.mockReturnValue(undefined);
|
|
54
|
+
await expect((0, buildTransaction_1.buildTransaction)(mockAccount, mockTransaction)).rejects.toThrow();
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
//# sourceMappingURL=buildTransaction.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildTransaction.test.js","sourceRoot":"","sources":["../../src/bridge/buildTransaction.test.ts"],"names":[],"mappings":";;AACA,yDAAsD;AACtD,sCAA0E;AAC1E,kDAAwD;AACxD,+CAAyC;AAEzC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;AAE7B,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,IAAI,gBAAkC,CAAC;IAEvC,UAAU,CAAC,GAAG,EAAE;QACd,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,qBAAqB,EAArB,oCAAqB,EAAE,EAAE,uBAAuB,CAAC,CAAC;QAClF,gBAAgB,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC,CAAC,sBAAsB;IAC9D,CAAC,CAAC,CAAC;IAEH,MAAM,WAAW,GAAqB;QACpC,YAAY,EAAE,yDAAyD;QACvE,gBAAgB,EAAE,mBAAmB;KACtC,CAAC;IAEF,MAAM,eAAe,GAAgB;QACnC,SAAS,EAAE,yDAAyD;QACpE,MAAM,EAAE,IAAI,wBAAS,CAAC,UAAU,CAAC;QACjC,IAAI,EAAE;YACJ,GAAG,EAAE,IAAI,wBAAS,CAAC,OAAO,CAAC;YAC3B,kBAAkB,EAAE,IAAI,wBAAS,CAAC,CAAC,CAAC;SACrC;QACD,KAAK,EAAE,CAAC;QACR,IAAI,EAAE,kBAAkB;QACxB,MAAM,EAAE,MAAM;KACf,CAAC;IAEF,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;QACpD,MAAM,MAAM,GAAG,MAAM,IAAA,mCAAgB,EAAC,WAAsB,EAAE,eAAe,CAAC,CAAC;QAE/E,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACrB,MAAM,EAAE,6BAAoB;YAC5B,aAAa,EAAE,EAAE;YACjB,aAAa,EAAE,WAAW,CAAC,YAAY;YACvC,eAAe,EAAE,eAAe,CAAC,SAAS;YAC1C,MAAM,EAAE,eAAe,CAAC,MAAM,CAAC,QAAQ,EAAE;YACzC,GAAG,EAAE,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE;YACxC,KAAK,EAAE,eAAe,CAAC,KAAK;YAC5B,IAAI,EAAE,eAAe,CAAC,IAAI;YAC1B,SAAS,EAAE,gCAAuB;SACnC,CAAC,CAAC;QAEH,MAAM,CAAC,oCAAqB,CAAC,CAAC,oBAAoB,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;IACnF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE,KAAK,IAAI,EAAE;QACxC,MAAM,aAAa,GAAG;YACpB,GAAG,eAAe;YAClB,IAAI,EAAE,SAAS;SAChB,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,IAAA,mCAAgB,EAAC,WAAsB,EAAE,aAAa,CAAC,CAAC;QAE7E,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;QAC7D,gBAAgB,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;QAE5C,MAAM,MAAM,CAAC,IAAA,mCAAgB,EAAC,WAAsB,EAAE,eAAe,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;IAC5F,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { Account, AccountLike, AccountLikeArray } from "@ledgerhq/types-live";
|
|
2
|
+
import type { Transaction } from "../types/common";
|
|
3
|
+
declare function inferAccounts(account: Account): AccountLikeArray;
|
|
4
|
+
declare function inferTransactions(transactions: Array<{
|
|
5
|
+
account: AccountLike;
|
|
6
|
+
transaction: Transaction;
|
|
7
|
+
}>, opts: Record<string, string>): Transaction[];
|
|
8
|
+
export default function makeCliTools(): {
|
|
9
|
+
options: {
|
|
10
|
+
name: string;
|
|
11
|
+
type: StringConstructor;
|
|
12
|
+
desc: string;
|
|
13
|
+
}[];
|
|
14
|
+
inferAccounts: typeof inferAccounts;
|
|
15
|
+
inferTransactions: typeof inferTransactions;
|
|
16
|
+
};
|
|
17
|
+
export {};
|
|
18
|
+
//# sourceMappingURL=cli-transaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli-transaction.d.ts","sourceRoot":"","sources":["../../src/bridge/cli-transaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAGnF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAUnD,iBAAS,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,gBAAgB,CAGzD;AAED,iBAAS,iBAAiB,CACxB,YAAY,EAAE,KAAK,CAAC;IAClB,OAAO,EAAE,WAAW,CAAC;IACrB,WAAW,EAAE,WAAW,CAAC;CAC1B,CAAC,EACF,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAC3B,WAAW,EAAE,CAUf;AAED,MAAM,CAAC,OAAO,UAAU,YAAY;;;;;;;;EAMnC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
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 invariant_1 = __importDefault(require("invariant"));
|
|
7
|
+
const flatMap_1 = __importDefault(require("lodash/flatMap"));
|
|
8
|
+
const options = [
|
|
9
|
+
{
|
|
10
|
+
name: "memo",
|
|
11
|
+
type: String,
|
|
12
|
+
desc: "set a memo",
|
|
13
|
+
},
|
|
14
|
+
];
|
|
15
|
+
function inferAccounts(account) {
|
|
16
|
+
(0, invariant_1.default)(account.currency.family === "mina", "mina family");
|
|
17
|
+
return [account];
|
|
18
|
+
}
|
|
19
|
+
function inferTransactions(transactions, opts) {
|
|
20
|
+
return (0, flatMap_1.default)(transactions, ({ transaction }) => {
|
|
21
|
+
(0, invariant_1.default)(transaction.family === "mina", "mina family");
|
|
22
|
+
return {
|
|
23
|
+
...transaction,
|
|
24
|
+
family: "mina",
|
|
25
|
+
memo: opts.memo,
|
|
26
|
+
};
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
function makeCliTools() {
|
|
30
|
+
return {
|
|
31
|
+
options,
|
|
32
|
+
inferAccounts,
|
|
33
|
+
inferTransactions,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
exports.default = makeCliTools;
|
|
37
|
+
//# sourceMappingURL=cli-transaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli-transaction.js","sourceRoot":"","sources":["../../src/bridge/cli-transaction.ts"],"names":[],"mappings":";;;;;AACA,0DAAkC;AAClC,6DAAqC;AAGrC,MAAM,OAAO,GAAG;IACd;QACE,IAAI,EAAE,MAAM;QACZ,IAAI,EAAE,MAAM;QACZ,IAAI,EAAE,YAAY;KACnB;CACF,CAAC;AAEF,SAAS,aAAa,CAAC,OAAgB;IACrC,IAAA,mBAAS,EAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,KAAK,MAAM,EAAE,aAAa,CAAC,CAAC;IAC7D,OAAO,CAAC,OAAO,CAAC,CAAC;AACnB,CAAC;AAED,SAAS,iBAAiB,CACxB,YAGE,EACF,IAA4B;IAE5B,OAAO,IAAA,iBAAO,EAAC,YAAY,EAAE,CAAC,EAAE,WAAW,EAAE,EAAE,EAAE;QAC/C,IAAA,mBAAS,EAAC,WAAW,CAAC,MAAM,KAAK,MAAM,EAAE,aAAa,CAAC,CAAC;QAExD,OAAO;YACL,GAAG,WAAW;YACd,MAAM,EAAE,MAAM;YACd,IAAI,EAAE,IAAI,CAAC,IAAI;SAChB,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAwB,YAAY;IAClC,OAAO;QACL,OAAO;QACP,aAAa;QACb,iBAAiB;KAClB,CAAC;AACJ,CAAC;AAND,+BAMC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,eAAO,MAAM,iBAAiB,EAAE,aAAa,CAC3C,WAAW,EACX,WAAW,CACZ,CAAC,mBAAmB,CAWnB,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
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.createTransaction = void 0;
|
|
7
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
8
|
+
const createTransaction = () => ({
|
|
9
|
+
family: "mina",
|
|
10
|
+
amount: new bignumber_js_1.default(0),
|
|
11
|
+
recipient: "",
|
|
12
|
+
useAllAmount: false,
|
|
13
|
+
fees: {
|
|
14
|
+
fee: new bignumber_js_1.default(0),
|
|
15
|
+
accountCreationFee: new bignumber_js_1.default(0),
|
|
16
|
+
},
|
|
17
|
+
memo: undefined,
|
|
18
|
+
nonce: 0,
|
|
19
|
+
});
|
|
20
|
+
exports.createTransaction = createTransaction;
|
|
21
|
+
//# sourceMappingURL=createTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createTransaction.js","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":";;;;;;AAAA,gEAAqC;AAI9B,MAAM,iBAAiB,GAGL,GAAG,EAAE,CAAC,CAAC;IAC9B,MAAM,EAAE,MAAM;IACd,MAAM,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;IACxB,SAAS,EAAE,EAAE;IACb,YAAY,EAAE,KAAK;IACnB,IAAI,EAAE;QACJ,GAAG,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;QACrB,kBAAkB,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;KACrC;IACD,IAAI,EAAE,SAAS;IACf,KAAK,EAAE,CAAC;CACT,CAAC,CAAC;AAdU,QAAA,iBAAiB,qBAc3B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createTransaction.test.d.ts","sourceRoot":"","sources":["../../src/bridge/createTransaction.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,24 @@
|
|
|
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 createTransaction_1 = require("./createTransaction");
|
|
7
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
8
|
+
describe("createTransaction", () => {
|
|
9
|
+
it("should create a 0 amount transaction", () => {
|
|
10
|
+
expect((0, createTransaction_1.createTransaction)({}).amount.toNumber()).toEqual(0);
|
|
11
|
+
expect((0, createTransaction_1.createTransaction)({}).recipient).toEqual("");
|
|
12
|
+
expect((0, createTransaction_1.createTransaction)({}).useAllAmount).toEqual(false);
|
|
13
|
+
expect((0, createTransaction_1.createTransaction)({}).fees).toEqual({
|
|
14
|
+
fee: new bignumber_js_1.default(0),
|
|
15
|
+
accountCreationFee: new bignumber_js_1.default(0),
|
|
16
|
+
});
|
|
17
|
+
expect((0, createTransaction_1.createTransaction)({}).memo).toEqual(undefined);
|
|
18
|
+
expect((0, createTransaction_1.createTransaction)({}).nonce).toEqual(0);
|
|
19
|
+
});
|
|
20
|
+
it("should create a transaction with boilerplate family", () => {
|
|
21
|
+
expect((0, createTransaction_1.createTransaction)({}).family).toEqual("mina");
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
//# sourceMappingURL=createTransaction.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createTransaction.test.js","sourceRoot":"","sources":["../../src/bridge/createTransaction.test.ts"],"names":[],"mappings":";;;;;AACA,2DAAwD;AACxD,gEAAqC;AAErC,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,EAAE,CAAC,sCAAsC,EAAE,GAAG,EAAE;QAC9C,MAAM,CAAC,IAAA,qCAAiB,EAAC,EAA0B,CAAC,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QACnF,MAAM,CAAC,IAAA,qCAAiB,EAAC,EAA0B,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC5E,MAAM,CAAC,IAAA,qCAAiB,EAAC,EAA0B,CAAC,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAClF,MAAM,CAAC,IAAA,qCAAiB,EAAC,EAA0B,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC;YACjE,GAAG,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;YACrB,kBAAkB,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;SACrC,CAAC,CAAC;QACH,MAAM,CAAC,IAAA,qCAAiB,EAAC,EAA0B,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAC9E,MAAM,CAAC,IAAA,qCAAiB,EAAC,EAA0B,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACzE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC7D,MAAM,CAAC,IAAA,qCAAiB,EAAC,EAA0B,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAC/E,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Account, AccountLike } from "@ledgerhq/types-live";
|
|
2
|
+
import type { Transaction, TransactionStatus } from "../types/common";
|
|
3
|
+
import type { CommonDeviceTransactionField as DeviceTransactionField } from "@ledgerhq/coin-framework/transaction/common";
|
|
4
|
+
declare function getDeviceTransactionConfig(_input: {
|
|
5
|
+
account: AccountLike;
|
|
6
|
+
parentAccount: Account | null | undefined;
|
|
7
|
+
transaction: Transaction;
|
|
8
|
+
status: TransactionStatus;
|
|
9
|
+
}): Array<DeviceTransactionField>;
|
|
10
|
+
export default getDeviceTransactionConfig;
|
|
11
|
+
//# sourceMappingURL=deviceTransactionConfig.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deviceTransactionConfig.d.ts","sourceRoot":"","sources":["../../src/bridge/deviceTransactionConfig.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACjE,OAAO,KAAK,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACtE,OAAO,KAAK,EAAE,4BAA4B,IAAI,sBAAsB,EAAE,MAAM,6CAA6C,CAAC;AAE1H,iBAAS,0BAA0B,CAAC,MAAM,EAAE;IAC1C,OAAO,EAAE,WAAW,CAAC;IACrB,aAAa,EAAE,OAAO,GAAG,IAAI,GAAG,SAAS,CAAC;IAC1C,WAAW,EAAE,WAAW,CAAC;IACzB,MAAM,EAAE,iBAAiB,CAAC;CAC3B,GAAG,KAAK,CAAC,sBAAsB,CAAC,CAGhC;AAED,eAAe,0BAA0B,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
function getDeviceTransactionConfig(_input) {
|
|
4
|
+
const fields = [];
|
|
5
|
+
return fields;
|
|
6
|
+
}
|
|
7
|
+
exports.default = getDeviceTransactionConfig;
|
|
8
|
+
//# sourceMappingURL=deviceTransactionConfig.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deviceTransactionConfig.js","sourceRoot":"","sources":["../../src/bridge/deviceTransactionConfig.ts"],"names":[],"mappings":";;AAIA,SAAS,0BAA0B,CAAC,MAKnC;IACC,MAAM,MAAM,GAAkC,EAAE,CAAC;IACjD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,kBAAe,0BAA0B,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export declare const InvalidMemoMina: import("@ledgerhq/errors/lib/helpers").LedgerErrorConstructor<{
|
|
2
|
+
[key: string]: unknown;
|
|
3
|
+
}>;
|
|
4
|
+
export declare const AccountCreationFeeWarning: import("@ledgerhq/errors/lib/helpers").LedgerErrorConstructor<{
|
|
5
|
+
[key: string]: unknown;
|
|
6
|
+
}>;
|
|
7
|
+
export declare const AmountTooSmall: import("@ledgerhq/errors/lib/helpers").LedgerErrorConstructor<{
|
|
8
|
+
[key: string]: unknown;
|
|
9
|
+
}>;
|
|
10
|
+
//# sourceMappingURL=errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/bridge/errors.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,eAAe;;EAA4C,CAAC;AAKzE,eAAO,MAAM,yBAAyB;;EAAsD,CAAC;AAK7F,eAAO,MAAM,cAAc;;EAA2C,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AmountTooSmall = exports.AccountCreationFeeWarning = exports.InvalidMemoMina = void 0;
|
|
4
|
+
const errors_1 = require("@ledgerhq/errors");
|
|
5
|
+
/*
|
|
6
|
+
* When the memo is greater than 32 characters
|
|
7
|
+
*/
|
|
8
|
+
exports.InvalidMemoMina = (0, errors_1.createCustomErrorClass)("InvalidMemoMina");
|
|
9
|
+
/*
|
|
10
|
+
* When the user sends less than the account creation fee of 1 MINA
|
|
11
|
+
*/
|
|
12
|
+
exports.AccountCreationFeeWarning = (0, errors_1.createCustomErrorClass)("AccountCreationFeeWarning");
|
|
13
|
+
/*
|
|
14
|
+
* When the amount is less than the account creation fee of 1 MINA
|
|
15
|
+
*/
|
|
16
|
+
exports.AmountTooSmall = (0, errors_1.createCustomErrorClass)("AmountTooSmall");
|
|
17
|
+
//# sourceMappingURL=errors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/bridge/errors.ts"],"names":[],"mappings":";;;AAAA,6CAA0D;AAE1D;;GAEG;AACU,QAAA,eAAe,GAAG,IAAA,+BAAsB,EAAC,iBAAiB,CAAC,CAAC;AAEzE;;GAEG;AACU,QAAA,yBAAyB,GAAG,IAAA,+BAAsB,EAAC,2BAA2B,CAAC,CAAC;AAE7F;;GAEG;AACU,QAAA,cAAc,GAAG,IAAA,+BAAsB,EAAC,gBAAgB,CAAC,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { AccountBridge } from "@ledgerhq/types-live";
|
|
2
|
+
import type { Transaction, MinaAccount } from "../types/common";
|
|
3
|
+
declare const estimateMaxSpendable: AccountBridge<Transaction, MinaAccount>["estimateMaxSpendable"];
|
|
4
|
+
export default estimateMaxSpendable;
|
|
5
|
+
//# sourceMappingURL=estimateMaxSpendable.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estimateMaxSpendable.d.ts","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAMhE,QAAA,MAAM,oBAAoB,EAAE,aAAa,CACvC,WAAW,EACX,WAAW,CACZ,CAAC,sBAAsB,CAiBvB,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const bignumber_js_1 = require("bignumber.js");
|
|
7
|
+
const index_1 = require("@ledgerhq/coin-framework/account/index");
|
|
8
|
+
const common_logic_1 = require("../common-logic");
|
|
9
|
+
const createTransaction_1 = require("./createTransaction");
|
|
10
|
+
const getEstimatedFees_1 = __importDefault(require("./getEstimatedFees"));
|
|
11
|
+
const estimateMaxSpendable = async ({ account, parentAccount, transaction }) => {
|
|
12
|
+
const a = (0, index_1.getMainAccount)(account, parentAccount);
|
|
13
|
+
const t = {
|
|
14
|
+
...(0, createTransaction_1.createTransaction)(account),
|
|
15
|
+
...transaction,
|
|
16
|
+
amount: a.spendableBalance,
|
|
17
|
+
};
|
|
18
|
+
const { fee } = await (0, getEstimatedFees_1.default)(t, a.freshAddress);
|
|
19
|
+
const maxSpendable = (0, common_logic_1.getMaxAmount)(a, t, fee);
|
|
20
|
+
if (maxSpendable.lt(0)) {
|
|
21
|
+
return new bignumber_js_1.BigNumber(0);
|
|
22
|
+
}
|
|
23
|
+
return maxSpendable;
|
|
24
|
+
};
|
|
25
|
+
exports.default = estimateMaxSpendable;
|
|
26
|
+
//# sourceMappingURL=estimateMaxSpendable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estimateMaxSpendable.js","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":";;;;;AAAA,+CAAyC;AAGzC,kEAAwE;AACxE,kDAA+C;AAC/C,2DAAwD;AACxD,0EAAkD;AAElD,MAAM,oBAAoB,GAGE,KAAK,EAAE,EAAE,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,EAAsB,EAAE;IAChG,MAAM,CAAC,GAAG,IAAA,sBAAc,EAAC,OAAO,EAAE,aAAa,CAAgB,CAAC;IAChE,MAAM,CAAC,GAAG;QACR,GAAG,IAAA,qCAAiB,EAAC,OAAO,CAAC;QAC7B,GAAG,WAAW;QACd,MAAM,EAAE,CAAC,CAAC,gBAAgB;KAC3B,CAAC;IAEF,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,IAAA,0BAAgB,EAAC,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC;IAE1D,MAAM,YAAY,GAAG,IAAA,2BAAY,EAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC;IAE7C,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACvB,OAAO,IAAI,wBAAS,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;IAED,OAAO,YAAY,CAAC;AACtB,CAAC,CAAC;AAEF,kBAAe,oBAAoB,CAAC"}
|