@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,55 @@
|
|
|
1
|
+
import type { BigNumber } from "bignumber.js";
|
|
2
|
+
import { Account, AccountRaw, Operation, TransactionCommon, TransactionCommonRaw, TransactionStatusCommon, TransactionStatusCommonRaw } from "@ledgerhq/types-live";
|
|
3
|
+
export type Transaction = TransactionCommon & {
|
|
4
|
+
family: "mina";
|
|
5
|
+
fees: {
|
|
6
|
+
fee: BigNumber;
|
|
7
|
+
accountCreationFee: BigNumber;
|
|
8
|
+
};
|
|
9
|
+
memo: string | undefined;
|
|
10
|
+
nonce: number;
|
|
11
|
+
};
|
|
12
|
+
export type TransactionRaw = TransactionCommonRaw & {
|
|
13
|
+
family: "mina";
|
|
14
|
+
fees: {
|
|
15
|
+
fee: string;
|
|
16
|
+
accountCreationFee: string;
|
|
17
|
+
};
|
|
18
|
+
memo: string | undefined;
|
|
19
|
+
nonce: number;
|
|
20
|
+
};
|
|
21
|
+
export type MinaAccount = Account;
|
|
22
|
+
export type MinaAPIAccount = {
|
|
23
|
+
blockHeight: number;
|
|
24
|
+
balance: BigNumber;
|
|
25
|
+
spendableBalance: BigNumber;
|
|
26
|
+
};
|
|
27
|
+
export type MinaAccountRaw = AccountRaw;
|
|
28
|
+
export type TransactionStatus = TransactionStatusCommon;
|
|
29
|
+
export type TransactionStatusRaw = TransactionStatusCommonRaw;
|
|
30
|
+
export type StatusErrorMap = {
|
|
31
|
+
recipient?: Error;
|
|
32
|
+
amount?: Error;
|
|
33
|
+
fees?: Error;
|
|
34
|
+
transaction?: Error;
|
|
35
|
+
};
|
|
36
|
+
export type MinaUnsignedTransaction = {
|
|
37
|
+
txType: number;
|
|
38
|
+
senderAccount: number;
|
|
39
|
+
senderAddress: string;
|
|
40
|
+
receiverAddress: string;
|
|
41
|
+
amount: number;
|
|
42
|
+
fee: number;
|
|
43
|
+
nonce: number;
|
|
44
|
+
memo: string;
|
|
45
|
+
networkId: number;
|
|
46
|
+
};
|
|
47
|
+
export interface MinaSignedTransaction {
|
|
48
|
+
signature: string;
|
|
49
|
+
transaction: MinaUnsignedTransaction;
|
|
50
|
+
}
|
|
51
|
+
export type MinaOperation = Operation<{
|
|
52
|
+
memo: string | undefined;
|
|
53
|
+
accountCreationFee: string;
|
|
54
|
+
}>;
|
|
55
|
+
//# sourceMappingURL=common.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../src/types/common.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EACL,OAAO,EACP,UAAU,EACV,SAAS,EACT,iBAAiB,EACjB,oBAAoB,EACpB,uBAAuB,EACvB,0BAA0B,EAC3B,MAAM,sBAAsB,CAAC;AAE9B,MAAM,MAAM,WAAW,GAAG,iBAAiB,GAAG;IAC5C,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE;QACJ,GAAG,EAAE,SAAS,CAAC;QACf,kBAAkB,EAAE,SAAS,CAAC;KAC/B,CAAC;IACF,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;IACzB,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,oBAAoB,GAAG;IAClD,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE;QACJ,GAAG,EAAE,MAAM,CAAC;QACZ,kBAAkB,EAAE,MAAM,CAAC;KAC5B,CAAC;IACF,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;IACzB,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG,OAAO,CAAC;AAElC,MAAM,MAAM,cAAc,GAAG;IAC3B,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,SAAS,CAAC;IACnB,gBAAgB,EAAE,SAAS,CAAC;CAC7B,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,UAAU,CAAC;AAExC,MAAM,MAAM,iBAAiB,GAAG,uBAAuB,CAAC;AAExD,MAAM,MAAM,oBAAoB,GAAG,0BAA0B,CAAC;AAE9D,MAAM,MAAM,cAAc,GAAG;IAC3B,SAAS,CAAC,EAAE,KAAK,CAAC;IAClB,MAAM,CAAC,EAAE,KAAK,CAAC;IACf,IAAI,CAAC,EAAE,KAAK,CAAC;IACb,WAAW,CAAC,EAAE,KAAK,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG;IACpC,MAAM,EAAE,MAAM,CAAC;IACf,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,MAAM,CAAC;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,MAAM,WAAW,qBAAqB;IACpC,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,uBAAuB,CAAC;CACtC;AAED,MAAM,MAAM,aAAa,GAAG,SAAS,CAAC;IAAE,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;IAAC,kBAAkB,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"common.js","sourceRoot":"","sources":["../../src/types/common.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
interface SignTransactionArgs {
|
|
2
|
+
txType: number;
|
|
3
|
+
senderAccount: number;
|
|
4
|
+
senderAddress: string;
|
|
5
|
+
receiverAddress: string;
|
|
6
|
+
amount: number;
|
|
7
|
+
fee: number;
|
|
8
|
+
nonce: number;
|
|
9
|
+
validUntil?: number;
|
|
10
|
+
memo?: string;
|
|
11
|
+
networkId: number;
|
|
12
|
+
}
|
|
13
|
+
interface BaseLedgerResponse {
|
|
14
|
+
returnCode: string;
|
|
15
|
+
statusText?: string;
|
|
16
|
+
message?: string;
|
|
17
|
+
}
|
|
18
|
+
interface SignTransactionResponse extends BaseLedgerResponse {
|
|
19
|
+
signature?: string | null;
|
|
20
|
+
}
|
|
21
|
+
export interface GetAddressResponse extends BaseLedgerResponse {
|
|
22
|
+
publicKey?: string | null;
|
|
23
|
+
}
|
|
24
|
+
export type MinaSignature = {
|
|
25
|
+
signature?: string;
|
|
26
|
+
};
|
|
27
|
+
export interface MinaSigner {
|
|
28
|
+
getAddress(account?: number, verify?: boolean): Promise<GetAddressResponse>;
|
|
29
|
+
signTransaction(transaction: SignTransactionArgs): Promise<SignTransactionResponse>;
|
|
30
|
+
}
|
|
31
|
+
export {};
|
|
32
|
+
//# sourceMappingURL=signer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../../src/types/signer.ts"],"names":[],"mappings":"AAAA,UAAU,mBAAmB;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,MAAM,CAAC;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CACnB;AACD,UAAU,kBAAkB;IAC1B,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AACD,UAAU,uBAAwB,SAAQ,kBAAkB;IAC1D,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC3B;AAED,MAAM,WAAW,kBAAmB,SAAQ,kBAAkB;IAC5D,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC3B;AACD,MAAM,MAAM,aAAa,GAAG;IAAE,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC;AACnD,MAAM,WAAW,UAAU;IACzB,UAAU,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAC5E,eAAe,CAAC,WAAW,EAAE,mBAAmB,GAAG,OAAO,CAAC,uBAAuB,CAAC,CAAC;CACrF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signer.js","sourceRoot":"","sources":["../../src/types/signer.ts"],"names":[],"mappings":""}
|
package/package.json
ADDED
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@ledgerhq/coin-mina",
|
|
3
|
+
"version": "1.1.0-next.0",
|
|
4
|
+
"description": "Mina Coin integration",
|
|
5
|
+
"keywords": [
|
|
6
|
+
"Ledger",
|
|
7
|
+
"LedgerWallet",
|
|
8
|
+
"mina",
|
|
9
|
+
"Hardware Wallet"
|
|
10
|
+
],
|
|
11
|
+
"repository": {
|
|
12
|
+
"type": "git",
|
|
13
|
+
"url": "https://github.com/LedgerHQ/ledger-live.git"
|
|
14
|
+
},
|
|
15
|
+
"bugs": {
|
|
16
|
+
"url": "https://github.com/LedgerHQ/ledger-live/issues"
|
|
17
|
+
},
|
|
18
|
+
"homepage": "https://github.com/LedgerHQ/ledger-live/tree/develop/libs/coin-modules/coin-mina",
|
|
19
|
+
"publishConfig": {
|
|
20
|
+
"access": "public"
|
|
21
|
+
},
|
|
22
|
+
"typesVersions": {
|
|
23
|
+
"*": {
|
|
24
|
+
"lib/*": [
|
|
25
|
+
"lib/*"
|
|
26
|
+
],
|
|
27
|
+
"lib-es/*": [
|
|
28
|
+
"lib-es/*"
|
|
29
|
+
],
|
|
30
|
+
"api": [
|
|
31
|
+
"lib/api/index"
|
|
32
|
+
],
|
|
33
|
+
"deviceTransactionConfig": [
|
|
34
|
+
"lib/bridge/deviceTransactionConfig"
|
|
35
|
+
],
|
|
36
|
+
"logic": [
|
|
37
|
+
"lib/logic/index"
|
|
38
|
+
],
|
|
39
|
+
"specs": [
|
|
40
|
+
"lib/test/bot-specs"
|
|
41
|
+
],
|
|
42
|
+
"transaction": [
|
|
43
|
+
"lib/bridge/transaction"
|
|
44
|
+
],
|
|
45
|
+
"types": [
|
|
46
|
+
"lib/types/index"
|
|
47
|
+
],
|
|
48
|
+
"*": [
|
|
49
|
+
"lib/*",
|
|
50
|
+
"lib/bridge/*",
|
|
51
|
+
"lib/logic/*",
|
|
52
|
+
"lib/signer/*",
|
|
53
|
+
"lib/test/*",
|
|
54
|
+
"lib/types/*"
|
|
55
|
+
]
|
|
56
|
+
}
|
|
57
|
+
},
|
|
58
|
+
"exports": {
|
|
59
|
+
"./lib/*": "./lib/*.js",
|
|
60
|
+
"./lib-es/*": "./lib-es/*.js",
|
|
61
|
+
"./api": {
|
|
62
|
+
"require": "./lib/api/index.js",
|
|
63
|
+
"default": "./lib-es/api/index.js"
|
|
64
|
+
},
|
|
65
|
+
"./deviceTransactionConfig": {
|
|
66
|
+
"require": "./lib/bridge/deviceTransactionConfig.js",
|
|
67
|
+
"default": "./lib-es/bridge/deviceTransactionConfig.js"
|
|
68
|
+
},
|
|
69
|
+
"./logic": {
|
|
70
|
+
"require": "./lib/common-logic/index.js",
|
|
71
|
+
"default": "./lib-es/common-logic/index.js"
|
|
72
|
+
},
|
|
73
|
+
"./signer": {
|
|
74
|
+
"require": "./lib/signer/index.js",
|
|
75
|
+
"default": "./lib-es/signer/index.js"
|
|
76
|
+
},
|
|
77
|
+
"./specs": {
|
|
78
|
+
"require": "./lib/test/bot-specs.js",
|
|
79
|
+
"default": "./lib-es/test/bot-specs.js"
|
|
80
|
+
},
|
|
81
|
+
"./bridge": {
|
|
82
|
+
"require": "./lib/bridge/index.js",
|
|
83
|
+
"default": "./lib-es/bridge/index.js"
|
|
84
|
+
},
|
|
85
|
+
"./transaction": {
|
|
86
|
+
"require": "./lib/bridge/transaction.js",
|
|
87
|
+
"default": "./lib-es/bridge/transaction.js"
|
|
88
|
+
},
|
|
89
|
+
"./types": {
|
|
90
|
+
"require": "./lib/types/index.js",
|
|
91
|
+
"default": "./lib-es/types/index.js"
|
|
92
|
+
},
|
|
93
|
+
"./*": {
|
|
94
|
+
"require": "./lib/*.js",
|
|
95
|
+
"default": "./lib-es/*.js"
|
|
96
|
+
},
|
|
97
|
+
".": {
|
|
98
|
+
"require": "./lib/index.js",
|
|
99
|
+
"default": "./lib-es/index.js"
|
|
100
|
+
},
|
|
101
|
+
"./package.json": "./package.json"
|
|
102
|
+
},
|
|
103
|
+
"license": "Apache-2.0",
|
|
104
|
+
"dependencies": {
|
|
105
|
+
"bignumber.js": "^9.1.2",
|
|
106
|
+
"bs58check": "^2.1.2",
|
|
107
|
+
"expect": "^27.4.6",
|
|
108
|
+
"invariant": "^2.2.2",
|
|
109
|
+
"lodash": "^4.17.21",
|
|
110
|
+
"rxjs": "^7.8.1",
|
|
111
|
+
"@ledgerhq/coin-framework": "^3.0.0-next.0",
|
|
112
|
+
"@ledgerhq/cryptoassets": "^13.15.0-next.0",
|
|
113
|
+
"@ledgerhq/devices": "^8.4.4",
|
|
114
|
+
"@ledgerhq/errors": "^6.19.1",
|
|
115
|
+
"@ledgerhq/live-network": "^2.0.7",
|
|
116
|
+
"@ledgerhq/logs": "^6.12.0",
|
|
117
|
+
"@ledgerhq/types-cryptoassets": "^7.22.0-next.0",
|
|
118
|
+
"@ledgerhq/types-live": "^6.67.0-next.0"
|
|
119
|
+
},
|
|
120
|
+
"devDependencies": {
|
|
121
|
+
"@types/invariant": "^2.2.2",
|
|
122
|
+
"@types/bs58check": "^2.1.2",
|
|
123
|
+
"expect": "^27.4.6",
|
|
124
|
+
"@types/jest": "^29.5.10",
|
|
125
|
+
"@types/lodash": "^4.14.191",
|
|
126
|
+
"jest": "^29.7.0",
|
|
127
|
+
"ts-jest": "^29.1.1"
|
|
128
|
+
},
|
|
129
|
+
"scripts": {
|
|
130
|
+
"clean": "rimraf lib lib-es",
|
|
131
|
+
"build": "tsc && tsc -m esnext --moduleResolution bundler --outDir lib-es",
|
|
132
|
+
"coverage": "jest --coverage --testPathIgnorePatterns='/bridge.integration.test.ts|node_modules|lib-es|lib/' --passWithNoTests && mv coverage/coverage-final.json coverage/coverage-boilerplate.json",
|
|
133
|
+
"prewatch": "pnpm build",
|
|
134
|
+
"watch": "tsc --watch",
|
|
135
|
+
"doc": "documentation readme src/** --section=API --pe ts --re ts --re d.ts",
|
|
136
|
+
"lint": "eslint ./src --no-error-on-unmatched-pattern --ext .ts,.tsx --cache",
|
|
137
|
+
"lint:fix": "pnpm lint --fix",
|
|
138
|
+
"test": "jest",
|
|
139
|
+
"test-integ": "DOTENV_CONFIG_PATH=.env.integ.test jest --config=jest.integ.config.js",
|
|
140
|
+
"typecheck": "tsc --noEmit",
|
|
141
|
+
"unimported": "unimported"
|
|
142
|
+
}
|
|
143
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { getAccount, getBlockInfo, getTransactions } from ".";
|
|
2
|
+
import { getCoinConfig } from "../config";
|
|
3
|
+
import { CurrencyConfig } from "@ledgerhq/coin-framework/config";
|
|
4
|
+
|
|
5
|
+
jest.mock("../config");
|
|
6
|
+
describe("backend api tests", () => {
|
|
7
|
+
jest.mocked(getCoinConfig).mockReturnValue({
|
|
8
|
+
...({} as unknown as CurrencyConfig),
|
|
9
|
+
infra: {
|
|
10
|
+
API_MINA_ROSETTA_NODE: "https://mina.coin.ledger.com/node",
|
|
11
|
+
},
|
|
12
|
+
});
|
|
13
|
+
const validAddress = ["B62qjWLs1W3J2fFGixeX49w1o7VvSGuMBNotnFhzs3PZ7PbtdFbhdeD"];
|
|
14
|
+
const invalidAddress = [
|
|
15
|
+
"B62qkdFWJSW8zaTBZjTVtmeU3rVxyUkNxPhKKW8T2JBtpj5XfdywLJM",
|
|
16
|
+
"novalidaddress",
|
|
17
|
+
];
|
|
18
|
+
|
|
19
|
+
it("getAccount for valid address", async () => {
|
|
20
|
+
const account = await getAccount(validAddress[0]);
|
|
21
|
+
expect(account).toBeDefined();
|
|
22
|
+
expect(account.balance.toNumber()).toBeGreaterThan(0);
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
it("get block info", async () => {
|
|
26
|
+
const blockInfo = await getBlockInfo(1);
|
|
27
|
+
expect(blockInfo).toBeDefined();
|
|
28
|
+
expect(blockInfo.block.block_identifier.index).toBe(1);
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
it("get balance should fail for invalid address", async () => {
|
|
32
|
+
for (const address of invalidAddress) {
|
|
33
|
+
const account = await getAccount(address);
|
|
34
|
+
expect(account).toBeDefined();
|
|
35
|
+
expect(account.balance.toNumber()).toBe(0);
|
|
36
|
+
}
|
|
37
|
+
}, 10000);
|
|
38
|
+
|
|
39
|
+
it("get balance should succeed for valid address", async () => {
|
|
40
|
+
for (const address of validAddress) {
|
|
41
|
+
const account = await getAccount(address);
|
|
42
|
+
expect(account).toBeDefined();
|
|
43
|
+
expect(account.balance.toNumber()).toBeGreaterThan(0);
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
it("get transactions should not fail for invalid address", async () => {
|
|
48
|
+
for (const address of invalidAddress) {
|
|
49
|
+
const transactions = await getTransactions(address);
|
|
50
|
+
expect(transactions).toBeDefined();
|
|
51
|
+
expect(transactions.length).toBe(0);
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
it("get transactions should succeed for valid address", async () => {
|
|
56
|
+
for (const address of validAddress) {
|
|
57
|
+
const transactions = await getTransactions(address);
|
|
58
|
+
expect(transactions).toBeDefined();
|
|
59
|
+
expect(transactions.length).toBeGreaterThan(0);
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
});
|
package/src/api/index.ts
ADDED
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
import { MinaAPIAccount, MinaSignedTransaction, Transaction } from "../types/common";
|
|
3
|
+
import {
|
|
4
|
+
fetchAccountBalance,
|
|
5
|
+
fetchAccountTransactions,
|
|
6
|
+
fetchNetworkStatus,
|
|
7
|
+
fetchTransactionMetadata,
|
|
8
|
+
rosettaGetBlockInfo,
|
|
9
|
+
rosettaSubmitTransaction,
|
|
10
|
+
} from "./rosetta";
|
|
11
|
+
import { MINA_TOKEN_ID } from "../consts";
|
|
12
|
+
import { isValidAddress } from "../common-logic";
|
|
13
|
+
import { RosettaBlockInfoResponse, RosettaTransaction } from "./rosetta/types";
|
|
14
|
+
import { log } from "@ledgerhq/logs";
|
|
15
|
+
|
|
16
|
+
export const getAccount = async (address: string): Promise<MinaAPIAccount> => {
|
|
17
|
+
const networkStatus = await fetchNetworkStatus();
|
|
18
|
+
let balance = new BigNumber(0);
|
|
19
|
+
let spendableBalance = new BigNumber(0);
|
|
20
|
+
try {
|
|
21
|
+
const resp = await fetchAccountBalance(address);
|
|
22
|
+
balance = new BigNumber(resp.balances[0].metadata.total_balance);
|
|
23
|
+
spendableBalance = new BigNumber(resp.balances[0].metadata.liquid_balance);
|
|
24
|
+
} catch (e) {
|
|
25
|
+
log("info", "[mina] getAccount error:", {
|
|
26
|
+
address,
|
|
27
|
+
error: e,
|
|
28
|
+
});
|
|
29
|
+
// fail is expected for when account has no balance and no transactions
|
|
30
|
+
/* empty */
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
return {
|
|
34
|
+
blockHeight: networkStatus.current_block_identifier.index,
|
|
35
|
+
balance,
|
|
36
|
+
spendableBalance,
|
|
37
|
+
};
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
export const getBlockInfo = async (blockHeight: number): Promise<RosettaBlockInfoResponse> => {
|
|
41
|
+
const data = await rosettaGetBlockInfo(blockHeight);
|
|
42
|
+
return data;
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
export const getTransactions = async (
|
|
46
|
+
address: string,
|
|
47
|
+
offset: number = 0,
|
|
48
|
+
): Promise<RosettaTransaction[]> => {
|
|
49
|
+
const txns = await fetchAccountTransactions(address, offset);
|
|
50
|
+
return txns.sort((a, b) => b.timestamp - a.timestamp);
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
export const broadcastTransaction = async (txn: MinaSignedTransaction): Promise<string> => {
|
|
54
|
+
const { nonce, receiverAddress, amount, fee, memo, senderAddress } = txn.transaction;
|
|
55
|
+
const blob = {
|
|
56
|
+
signature: txn.signature,
|
|
57
|
+
payment: {
|
|
58
|
+
to: receiverAddress,
|
|
59
|
+
from: senderAddress,
|
|
60
|
+
fee: fee.toFixed(),
|
|
61
|
+
token: MINA_TOKEN_ID,
|
|
62
|
+
nonce: nonce.toFixed(),
|
|
63
|
+
memo: memo ?? null,
|
|
64
|
+
amount: amount.toFixed(),
|
|
65
|
+
valid_until: null,
|
|
66
|
+
},
|
|
67
|
+
stake_delegation: null,
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
const { data } = await rosettaSubmitTransaction(JSON.stringify(blob));
|
|
71
|
+
|
|
72
|
+
return data.transaction_identifier.hash;
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
export const getFees = async (
|
|
76
|
+
txn: Transaction,
|
|
77
|
+
address: string,
|
|
78
|
+
): Promise<{
|
|
79
|
+
fee: BigNumber;
|
|
80
|
+
accountCreationFee: BigNumber;
|
|
81
|
+
}> => {
|
|
82
|
+
if (!txn.amount || !txn.recipient || !isValidAddress(txn.recipient)) {
|
|
83
|
+
return { fee: txn.fees.fee, accountCreationFee: new BigNumber(0) };
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
const { data } = await fetchTransactionMetadata(
|
|
87
|
+
address,
|
|
88
|
+
txn.recipient,
|
|
89
|
+
txn.fees.fee.toNumber(),
|
|
90
|
+
txn.amount.toNumber(),
|
|
91
|
+
);
|
|
92
|
+
|
|
93
|
+
const accountCreationFee = data.metadata.account_creation_fee
|
|
94
|
+
? new BigNumber(data.metadata.account_creation_fee)
|
|
95
|
+
: new BigNumber(0);
|
|
96
|
+
|
|
97
|
+
return {
|
|
98
|
+
fee: new BigNumber(data.suggested_fee[0].value),
|
|
99
|
+
accountCreationFee,
|
|
100
|
+
};
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
export const getNonce = async (txn: Transaction, address: string): Promise<number> => {
|
|
104
|
+
if (!txn.recipient || !isValidAddress(txn.recipient)) {
|
|
105
|
+
return txn.nonce;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
if (!txn.amount || !txn.fees) {
|
|
109
|
+
return txn.nonce;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
const { data } = await fetchTransactionMetadata(
|
|
113
|
+
address,
|
|
114
|
+
txn.recipient,
|
|
115
|
+
txn.fees.fee.toNumber(),
|
|
116
|
+
txn.amount.toNumber(),
|
|
117
|
+
);
|
|
118
|
+
|
|
119
|
+
return parseInt(data.metadata.nonce);
|
|
120
|
+
};
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import network from "@ledgerhq/live-network";
|
|
2
|
+
import {
|
|
3
|
+
FetchAccountBalanceResponse,
|
|
4
|
+
FetchAccountTransactionsResponse,
|
|
5
|
+
FetchNetworkStatusResponse,
|
|
6
|
+
RosettaBlockInfoResponse,
|
|
7
|
+
RosettaMetadataResponse,
|
|
8
|
+
RosettaPreprocessResponse,
|
|
9
|
+
RosettaSubmitResponse,
|
|
10
|
+
RosettaTransaction,
|
|
11
|
+
} from "./types";
|
|
12
|
+
import { getCoinConfig } from "../../config";
|
|
13
|
+
import { addNetworkIdentifier, buildAccountIdentifier, makeTransferPayload } from "./utils";
|
|
14
|
+
import { MAX_TRANSACTIONS_PER_PAGE } from "../../consts";
|
|
15
|
+
import { LiveNetworkResponse } from "@ledgerhq/live-network/lib/network";
|
|
16
|
+
|
|
17
|
+
const getRosettaUrl = (route: string): string => {
|
|
18
|
+
const currencyConfig = getCoinConfig();
|
|
19
|
+
return `${currencyConfig.infra.API_MINA_ROSETTA_NODE}${route || ""}`;
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
export const fetchNetworkStatus = async () => {
|
|
23
|
+
const { data } = await network<FetchNetworkStatusResponse>({
|
|
24
|
+
method: "POST",
|
|
25
|
+
url: getRosettaUrl("/network/status"),
|
|
26
|
+
data: addNetworkIdentifier({}),
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
return data;
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
export const fetchAccountBalance = async (address: string) => {
|
|
33
|
+
const { data } = await network<FetchAccountBalanceResponse>({
|
|
34
|
+
method: "POST",
|
|
35
|
+
url: getRosettaUrl("/account/balance"),
|
|
36
|
+
data: addNetworkIdentifier(buildAccountIdentifier(address)),
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
return data;
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
export const fetchAccountTransactions = async (
|
|
43
|
+
address: string,
|
|
44
|
+
offset: number = 0,
|
|
45
|
+
): Promise<RosettaTransaction[]> => {
|
|
46
|
+
const transactions: RosettaTransaction[] = [];
|
|
47
|
+
let currentOffset: number | undefined = offset;
|
|
48
|
+
while (currentOffset !== undefined) {
|
|
49
|
+
const response: LiveNetworkResponse<FetchAccountTransactionsResponse> =
|
|
50
|
+
await network<FetchAccountTransactionsResponse>({
|
|
51
|
+
method: "POST",
|
|
52
|
+
url: getRosettaUrl("/search/transactions"),
|
|
53
|
+
data: {
|
|
54
|
+
...addNetworkIdentifier(buildAccountIdentifier(address)),
|
|
55
|
+
offset: currentOffset,
|
|
56
|
+
limit: MAX_TRANSACTIONS_PER_PAGE,
|
|
57
|
+
include_timestamp: true,
|
|
58
|
+
},
|
|
59
|
+
});
|
|
60
|
+
const { data } = response;
|
|
61
|
+
transactions.push(...data.transactions);
|
|
62
|
+
|
|
63
|
+
currentOffset = data.next_offset;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
return transactions;
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
export const rosettaGetBlockInfo = async (blockHeight: number) => {
|
|
70
|
+
const { data } = await network<RosettaBlockInfoResponse>({
|
|
71
|
+
method: "POST",
|
|
72
|
+
url: getRosettaUrl("/block"),
|
|
73
|
+
data: addNetworkIdentifier({ block_identifier: { index: blockHeight } }),
|
|
74
|
+
});
|
|
75
|
+
return data;
|
|
76
|
+
};
|
|
77
|
+
|
|
78
|
+
const rosettaPreprocess = async (from: string, to: string, feeNano: number, valueNano: number) => {
|
|
79
|
+
const payload = makeTransferPayload(from, to, feeNano, valueNano);
|
|
80
|
+
const { data } = await network<RosettaPreprocessResponse>({
|
|
81
|
+
method: "POST",
|
|
82
|
+
url: getRosettaUrl("/construction/preprocess"),
|
|
83
|
+
data: addNetworkIdentifier(payload),
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
return data;
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
export const fetchTransactionMetadata = async (
|
|
90
|
+
srcAddress: string,
|
|
91
|
+
destAddress: string,
|
|
92
|
+
feeNano: number,
|
|
93
|
+
valueNano: number,
|
|
94
|
+
) => {
|
|
95
|
+
const options = await rosettaPreprocess(srcAddress, destAddress, feeNano, valueNano);
|
|
96
|
+
const payload = makeTransferPayload(srcAddress, destAddress, feeNano, valueNano);
|
|
97
|
+
return await network<RosettaMetadataResponse>({
|
|
98
|
+
method: "POST",
|
|
99
|
+
url: getRosettaUrl("/construction/metadata"),
|
|
100
|
+
data: addNetworkIdentifier({ ...payload, ...options }),
|
|
101
|
+
});
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
export const rosettaSubmitTransaction = async (blob: string) => {
|
|
105
|
+
return await network<RosettaSubmitResponse>({
|
|
106
|
+
method: "POST",
|
|
107
|
+
url: getRosettaUrl("/construction/submit"),
|
|
108
|
+
data: addNetworkIdentifier({ signed_transaction: blob }),
|
|
109
|
+
});
|
|
110
|
+
};
|