@ledgerhq/coin-mina 1.1.0-nightly.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.js +20 -0
- package/.turbo/turbo-build.log +4 -0
- package/.unimportedrc.json +24 -0
- package/CHANGELOG.md +15 -0
- package/LICENSE.txt +21 -0
- package/jest.config.js +8 -0
- package/jest.integ.config.js +7 -0
- package/lib/api/index.d.ts +13 -0
- package/lib/api/index.d.ts.map +1 -0
- package/lib/api/index.integ.test.d.ts +2 -0
- package/lib/api/index.integ.test.d.ts.map +1 -0
- package/lib/api/index.integ.test.js +57 -0
- package/lib/api/index.integ.test.js.map +1 -0
- package/lib/api/index.js +91 -0
- package/lib/api/index.js.map +1 -0
- package/lib/api/rosetta/index.d.ts +9 -0
- package/lib/api/rosetta/index.d.ts.map +1 -0
- package/lib/api/rosetta/index.js +90 -0
- package/lib/api/rosetta/index.js.map +1 -0
- package/lib/api/rosetta/types.d.ts +143 -0
- package/lib/api/rosetta/types.d.ts.map +1 -0
- package/lib/api/rosetta/types.js +3 -0
- package/lib/api/rosetta/types.js.map +1 -0
- package/lib/api/rosetta/utils.d.ts +43 -0
- package/lib/api/rosetta/utils.d.ts.map +1 -0
- package/lib/api/rosetta/utils.js +60 -0
- package/lib/api/rosetta/utils.js.map +1 -0
- package/lib/api/rosetta/utils.test.d.ts +2 -0
- package/lib/api/rosetta/utils.test.d.ts.map +1 -0
- package/lib/api/rosetta/utils.test.js +82 -0
- package/lib/api/rosetta/utils.test.js.map +1 -0
- package/lib/bridge/broadcast.d.ts +6 -0
- package/lib/bridge/broadcast.d.ts.map +1 -0
- package/lib/bridge/broadcast.js +11 -0
- package/lib/bridge/broadcast.js.map +1 -0
- package/lib/bridge/broadcast.test.d.ts +2 -0
- package/lib/bridge/broadcast.test.d.ts.map +1 -0
- package/lib/bridge/broadcast.test.js +36 -0
- package/lib/bridge/broadcast.test.js.map +1 -0
- package/lib/bridge/buildTransaction.d.ts +4 -0
- package/lib/bridge/buildTransaction.d.ts.map +1 -0
- package/lib/bridge/buildTransaction.js +37 -0
- package/lib/bridge/buildTransaction.js.map +1 -0
- package/lib/bridge/buildTransaction.test.d.ts +2 -0
- package/lib/bridge/buildTransaction.test.d.ts.map +1 -0
- package/lib/bridge/buildTransaction.test.js +57 -0
- package/lib/bridge/buildTransaction.test.js.map +1 -0
- package/lib/bridge/cli-transaction.d.ts +18 -0
- package/lib/bridge/cli-transaction.d.ts.map +1 -0
- package/lib/bridge/cli-transaction.js +37 -0
- package/lib/bridge/cli-transaction.js.map +1 -0
- package/lib/bridge/createTransaction.d.ts +4 -0
- package/lib/bridge/createTransaction.d.ts.map +1 -0
- package/lib/bridge/createTransaction.js +21 -0
- package/lib/bridge/createTransaction.js.map +1 -0
- package/lib/bridge/createTransaction.test.d.ts +2 -0
- package/lib/bridge/createTransaction.test.d.ts.map +1 -0
- package/lib/bridge/createTransaction.test.js +24 -0
- package/lib/bridge/createTransaction.test.js.map +1 -0
- package/lib/bridge/deviceTransactionConfig.d.ts +11 -0
- package/lib/bridge/deviceTransactionConfig.d.ts.map +1 -0
- package/lib/bridge/deviceTransactionConfig.js +8 -0
- package/lib/bridge/deviceTransactionConfig.js.map +1 -0
- package/lib/bridge/errors.d.ts +10 -0
- package/lib/bridge/errors.d.ts.map +1 -0
- package/lib/bridge/errors.js +17 -0
- package/lib/bridge/errors.js.map +1 -0
- package/lib/bridge/estimateMaxSpendable.d.ts +5 -0
- package/lib/bridge/estimateMaxSpendable.d.ts.map +1 -0
- package/lib/bridge/estimateMaxSpendable.js +26 -0
- package/lib/bridge/estimateMaxSpendable.js.map +1 -0
- package/lib/bridge/getEstimatedFees.d.ts +8 -0
- package/lib/bridge/getEstimatedFees.d.ts.map +1 -0
- package/lib/bridge/getEstimatedFees.js +9 -0
- package/lib/bridge/getEstimatedFees.js.map +1 -0
- package/lib/bridge/getTransactionStatus.d.ts +5 -0
- package/lib/bridge/getTransactionStatus.d.ts.map +1 -0
- package/lib/bridge/getTransactionStatus.js +62 -0
- package/lib/bridge/getTransactionStatus.js.map +1 -0
- package/lib/bridge/getTransactionStatus.test.d.ts +2 -0
- package/lib/bridge/getTransactionStatus.test.d.ts.map +1 -0
- package/lib/bridge/getTransactionStatus.test.js +138 -0
- package/lib/bridge/getTransactionStatus.test.js.map +1 -0
- package/lib/bridge/index.d.ts +14 -0
- package/lib/bridge/index.d.ts.map +1 -0
- package/lib/bridge/index.js +59 -0
- package/lib/bridge/index.js.map +1 -0
- package/lib/bridge/index.test.d.ts +2 -0
- package/lib/bridge/index.test.d.ts.map +1 -0
- package/lib/bridge/index.test.js +32 -0
- package/lib/bridge/index.test.js.map +1 -0
- package/lib/bridge/prepareTransaction.d.ts +4 -0
- package/lib/bridge/prepareTransaction.d.ts.map +1 -0
- package/lib/bridge/prepareTransaction.js +23 -0
- package/lib/bridge/prepareTransaction.js.map +1 -0
- package/lib/bridge/prepareTransaction.test.d.ts +2 -0
- package/lib/bridge/prepareTransaction.test.d.ts.map +1 -0
- package/lib/bridge/prepareTransaction.test.js +43 -0
- package/lib/bridge/prepareTransaction.test.js.map +1 -0
- package/lib/bridge/signOperation.d.ts +12 -0
- package/lib/bridge/signOperation.d.ts.map +1 -0
- package/lib/bridge/signOperation.js +72 -0
- package/lib/bridge/signOperation.js.map +1 -0
- package/lib/bridge/signOperation.test.d.ts +2 -0
- package/lib/bridge/signOperation.test.d.ts.map +1 -0
- package/lib/bridge/signOperation.test.js +129 -0
- package/lib/bridge/signOperation.test.js.map +1 -0
- package/lib/bridge/synchronisation.d.ts +7 -0
- package/lib/bridge/synchronisation.d.ts.map +1 -0
- package/lib/bridge/synchronisation.js +155 -0
- package/lib/bridge/synchronisation.js.map +1 -0
- package/lib/bridge/synchronisation.test.d.ts +2 -0
- package/lib/bridge/synchronisation.test.d.ts.map +1 -0
- package/lib/bridge/synchronisation.test.js +164 -0
- package/lib/bridge/synchronisation.test.js.map +1 -0
- package/lib/bridge/transaction.d.ts +14 -0
- package/lib/bridge/transaction.d.ts.map +1 -0
- package/lib/bridge/transaction.js +61 -0
- package/lib/bridge/transaction.js.map +1 -0
- package/lib/common-logic/index.d.ts +9 -0
- package/lib/common-logic/index.d.ts.map +1 -0
- package/lib/common-logic/index.js +96 -0
- package/lib/common-logic/index.js.map +1 -0
- package/lib/common-logic/index.test.d.ts +2 -0
- package/lib/common-logic/index.test.d.ts.map +1 -0
- package/lib/common-logic/index.test.js +181 -0
- package/lib/common-logic/index.test.js.map +1 -0
- package/lib/config.d.ts +9 -0
- package/lib/config.d.ts.map +1 -0
- package/lib/config.js +16 -0
- package/lib/config.js.map +1 -0
- package/lib/consts.d.ts +16 -0
- package/lib/consts.d.ts.map +1 -0
- package/lib/consts.js +19 -0
- package/lib/consts.js.map +1 -0
- package/lib/signer/getAddress.d.ts +6 -0
- package/lib/signer/getAddress.d.ts.map +1 -0
- package/lib/signer/getAddress.js +22 -0
- package/lib/signer/getAddress.js.map +1 -0
- package/lib/signer/getAddress.test.d.ts +2 -0
- package/lib/signer/getAddress.test.d.ts.map +1 -0
- package/lib/signer/getAddress.test.js +106 -0
- package/lib/signer/getAddress.test.js.map +1 -0
- package/lib/signer/index.d.ts +3 -0
- package/lib/signer/index.d.ts.map +1 -0
- package/lib/signer/index.js +8 -0
- package/lib/signer/index.js.map +1 -0
- package/lib/test/bot-deviceActions.d.ts +4 -0
- package/lib/test/bot-deviceActions.d.ts.map +1 -0
- package/lib/test/bot-deviceActions.js +67 -0
- package/lib/test/bot-deviceActions.js.map +1 -0
- package/lib/test/bot-specs.d.ts +7 -0
- package/lib/test/bot-specs.d.ts.map +1 -0
- package/lib/test/bot-specs.js +107 -0
- package/lib/test/bot-specs.js.map +1 -0
- package/lib/test/bridgeDatasetTest.d.ts +4 -0
- package/lib/test/bridgeDatasetTest.d.ts.map +1 -0
- package/lib/test/bridgeDatasetTest.js +174 -0
- package/lib/test/bridgeDatasetTest.js.map +1 -0
- package/lib/test/fixtures.d.ts +55 -0
- package/lib/test/fixtures.d.ts.map +1 -0
- package/lib/test/fixtures.js +194 -0
- package/lib/test/fixtures.js.map +1 -0
- package/lib/test/index.d.ts +4 -0
- package/lib/test/index.d.ts.map +1 -0
- package/lib/test/index.js +20 -0
- package/lib/test/index.js.map +1 -0
- package/lib/test/testUtils.d.ts +2 -0
- package/lib/test/testUtils.d.ts.map +1 -0
- package/lib/test/testUtils.js +8 -0
- package/lib/test/testUtils.js.map +1 -0
- package/lib/test/testUtils.test.d.ts +2 -0
- package/lib/test/testUtils.test.d.ts.map +1 -0
- package/lib/test/testUtils.test.js +11 -0
- package/lib/test/testUtils.test.js.map +1 -0
- package/lib/types/common.d.ts +55 -0
- package/lib/types/common.d.ts.map +1 -0
- package/lib/types/common.js +3 -0
- package/lib/types/common.js.map +1 -0
- package/lib/types/index.d.ts +3 -0
- package/lib/types/index.d.ts.map +1 -0
- package/lib/types/index.js +19 -0
- package/lib/types/index.js.map +1 -0
- package/lib/types/signer.d.ts +32 -0
- package/lib/types/signer.d.ts.map +1 -0
- package/lib/types/signer.js +3 -0
- package/lib/types/signer.js.map +1 -0
- package/lib-es/api/index.d.ts +13 -0
- package/lib-es/api/index.d.ts.map +1 -0
- package/lib-es/api/index.integ.test.d.ts +2 -0
- package/lib-es/api/index.integ.test.d.ts.map +1 -0
- package/lib-es/api/index.integ.test.js +55 -0
- package/lib-es/api/index.integ.test.js.map +1 -0
- package/lib-es/api/index.js +79 -0
- package/lib-es/api/index.js.map +1 -0
- package/lib-es/api/rosetta/index.d.ts +8 -0
- package/lib-es/api/rosetta/index.d.ts.map +1 -0
- package/lib-es/api/rosetta/index.js +78 -0
- package/lib-es/api/rosetta/index.js.map +1 -0
- package/lib-es/api/rosetta/types.d.ts +143 -0
- package/lib-es/api/rosetta/types.d.ts.map +1 -0
- package/lib-es/api/rosetta/types.js +2 -0
- package/lib-es/api/rosetta/types.js.map +1 -0
- package/lib-es/api/rosetta/utils.d.ts +43 -0
- package/lib-es/api/rosetta/utils.d.ts.map +1 -0
- package/lib-es/api/rosetta/utils.js +54 -0
- package/lib-es/api/rosetta/utils.js.map +1 -0
- package/lib-es/api/rosetta/utils.test.d.ts +2 -0
- package/lib-es/api/rosetta/utils.test.d.ts.map +1 -0
- package/lib-es/api/rosetta/utils.test.js +80 -0
- package/lib-es/api/rosetta/utils.test.js.map +1 -0
- package/lib-es/bridge/broadcast.d.ts +6 -0
- package/lib-es/bridge/broadcast.d.ts.map +1 -0
- package/lib-es/bridge/broadcast.js +9 -0
- package/lib-es/bridge/broadcast.js.map +1 -0
- package/lib-es/bridge/broadcast.test.d.ts +2 -0
- package/lib-es/bridge/broadcast.test.d.ts.map +1 -0
- package/lib-es/bridge/broadcast.test.js +31 -0
- package/lib-es/bridge/broadcast.test.js.map +1 -0
- package/lib-es/bridge/buildTransaction.d.ts +4 -0
- package/lib-es/bridge/buildTransaction.d.ts.map +1 -0
- package/lib-es/bridge/buildTransaction.js +30 -0
- package/lib-es/bridge/buildTransaction.js.map +1 -0
- package/lib-es/bridge/buildTransaction.test.d.ts +2 -0
- package/lib-es/bridge/buildTransaction.test.d.ts.map +1 -0
- package/lib-es/bridge/buildTransaction.test.js +55 -0
- package/lib-es/bridge/buildTransaction.test.js.map +1 -0
- package/lib-es/bridge/cli-transaction.d.ts +18 -0
- package/lib-es/bridge/cli-transaction.d.ts.map +1 -0
- package/lib-es/bridge/cli-transaction.js +31 -0
- package/lib-es/bridge/cli-transaction.js.map +1 -0
- package/lib-es/bridge/createTransaction.d.ts +4 -0
- package/lib-es/bridge/createTransaction.d.ts.map +1 -0
- package/lib-es/bridge/createTransaction.js +14 -0
- package/lib-es/bridge/createTransaction.js.map +1 -0
- package/lib-es/bridge/createTransaction.test.d.ts +2 -0
- package/lib-es/bridge/createTransaction.test.d.ts.map +1 -0
- package/lib-es/bridge/createTransaction.test.js +19 -0
- package/lib-es/bridge/createTransaction.test.js.map +1 -0
- package/lib-es/bridge/deviceTransactionConfig.d.ts +11 -0
- package/lib-es/bridge/deviceTransactionConfig.d.ts.map +1 -0
- package/lib-es/bridge/deviceTransactionConfig.js +6 -0
- package/lib-es/bridge/deviceTransactionConfig.js.map +1 -0
- package/lib-es/bridge/errors.d.ts +10 -0
- package/lib-es/bridge/errors.d.ts.map +1 -0
- package/lib-es/bridge/errors.js +14 -0
- package/lib-es/bridge/errors.js.map +1 -0
- package/lib-es/bridge/estimateMaxSpendable.d.ts +5 -0
- package/lib-es/bridge/estimateMaxSpendable.d.ts.map +1 -0
- package/lib-es/bridge/estimateMaxSpendable.js +21 -0
- package/lib-es/bridge/estimateMaxSpendable.js.map +1 -0
- package/lib-es/bridge/getEstimatedFees.d.ts +8 -0
- package/lib-es/bridge/getEstimatedFees.d.ts.map +1 -0
- package/lib-es/bridge/getEstimatedFees.js +7 -0
- package/lib-es/bridge/getEstimatedFees.js.map +1 -0
- package/lib-es/bridge/getTransactionStatus.d.ts +5 -0
- package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -0
- package/lib-es/bridge/getTransactionStatus.js +60 -0
- package/lib-es/bridge/getTransactionStatus.js.map +1 -0
- package/lib-es/bridge/getTransactionStatus.test.d.ts +2 -0
- package/lib-es/bridge/getTransactionStatus.test.d.ts.map +1 -0
- package/lib-es/bridge/getTransactionStatus.test.js +133 -0
- package/lib-es/bridge/getTransactionStatus.test.js.map +1 -0
- package/lib-es/bridge/index.d.ts +14 -0
- package/lib-es/bridge/index.d.ts.map +1 -0
- package/lib-es/bridge/index.js +50 -0
- package/lib-es/bridge/index.js.map +1 -0
- package/lib-es/bridge/index.test.d.ts +2 -0
- package/lib-es/bridge/index.test.d.ts.map +1 -0
- package/lib-es/bridge/index.test.js +30 -0
- package/lib-es/bridge/index.test.js.map +1 -0
- package/lib-es/bridge/prepareTransaction.d.ts +4 -0
- package/lib-es/bridge/prepareTransaction.d.ts.map +1 -0
- package/lib-es/bridge/prepareTransaction.js +16 -0
- package/lib-es/bridge/prepareTransaction.js.map +1 -0
- package/lib-es/bridge/prepareTransaction.test.d.ts +2 -0
- package/lib-es/bridge/prepareTransaction.test.d.ts.map +1 -0
- package/lib-es/bridge/prepareTransaction.test.js +38 -0
- package/lib-es/bridge/prepareTransaction.test.js.map +1 -0
- package/lib-es/bridge/signOperation.d.ts +12 -0
- package/lib-es/bridge/signOperation.d.ts.map +1 -0
- package/lib-es/bridge/signOperation.js +64 -0
- package/lib-es/bridge/signOperation.js.map +1 -0
- package/lib-es/bridge/signOperation.test.d.ts +2 -0
- package/lib-es/bridge/signOperation.test.d.ts.map +1 -0
- package/lib-es/bridge/signOperation.test.js +127 -0
- package/lib-es/bridge/signOperation.test.js.map +1 -0
- package/lib-es/bridge/synchronisation.d.ts +7 -0
- package/lib-es/bridge/synchronisation.d.ts.map +1 -0
- package/lib-es/bridge/synchronisation.js +147 -0
- package/lib-es/bridge/synchronisation.js.map +1 -0
- package/lib-es/bridge/synchronisation.test.d.ts +2 -0
- package/lib-es/bridge/synchronisation.test.d.ts.map +1 -0
- package/lib-es/bridge/synchronisation.test.js +159 -0
- package/lib-es/bridge/synchronisation.test.js.map +1 -0
- package/lib-es/bridge/transaction.d.ts +14 -0
- package/lib-es/bridge/transaction.d.ts.map +1 -0
- package/lib-es/bridge/transaction.js +53 -0
- package/lib-es/bridge/transaction.js.map +1 -0
- package/lib-es/common-logic/index.d.ts +9 -0
- package/lib-es/common-logic/index.d.ts.map +1 -0
- package/lib-es/common-logic/index.js +84 -0
- package/lib-es/common-logic/index.js.map +1 -0
- package/lib-es/common-logic/index.test.d.ts +2 -0
- package/lib-es/common-logic/index.test.d.ts.map +1 -0
- package/lib-es/common-logic/index.test.js +179 -0
- package/lib-es/common-logic/index.test.js.map +1 -0
- package/lib-es/config.d.ts +9 -0
- package/lib-es/config.d.ts.map +1 -0
- package/lib-es/config.js +11 -0
- package/lib-es/config.js.map +1 -0
- package/lib-es/consts.d.ts +16 -0
- package/lib-es/consts.d.ts.map +1 -0
- package/lib-es/consts.js +16 -0
- package/lib-es/consts.js.map +1 -0
- package/lib-es/signer/getAddress.d.ts +6 -0
- package/lib-es/signer/getAddress.d.ts.map +1 -0
- package/lib-es/signer/getAddress.js +17 -0
- package/lib-es/signer/getAddress.js.map +1 -0
- package/lib-es/signer/getAddress.test.d.ts +2 -0
- package/lib-es/signer/getAddress.test.d.ts.map +1 -0
- package/lib-es/signer/getAddress.test.js +101 -0
- package/lib-es/signer/getAddress.test.js.map +1 -0
- package/lib-es/signer/index.d.ts +3 -0
- package/lib-es/signer/index.d.ts.map +1 -0
- package/lib-es/signer/index.js +3 -0
- package/lib-es/signer/index.js.map +1 -0
- package/lib-es/test/bot-deviceActions.d.ts +4 -0
- package/lib-es/test/bot-deviceActions.d.ts.map +1 -0
- package/lib-es/test/bot-deviceActions.js +64 -0
- package/lib-es/test/bot-deviceActions.js.map +1 -0
- package/lib-es/test/bot-specs.d.ts +7 -0
- package/lib-es/test/bot-specs.d.ts.map +1 -0
- package/lib-es/test/bot-specs.js +102 -0
- package/lib-es/test/bot-specs.js.map +1 -0
- package/lib-es/test/bridgeDatasetTest.d.ts +4 -0
- package/lib-es/test/bridgeDatasetTest.d.ts.map +1 -0
- package/lib-es/test/bridgeDatasetTest.js +171 -0
- package/lib-es/test/bridgeDatasetTest.js.map +1 -0
- package/lib-es/test/fixtures.d.ts +55 -0
- package/lib-es/test/fixtures.d.ts.map +1 -0
- package/lib-es/test/fixtures.js +182 -0
- package/lib-es/test/fixtures.js.map +1 -0
- package/lib-es/test/index.d.ts +4 -0
- package/lib-es/test/index.d.ts.map +1 -0
- package/lib-es/test/index.js +4 -0
- package/lib-es/test/index.js.map +1 -0
- package/lib-es/test/testUtils.d.ts +2 -0
- package/lib-es/test/testUtils.d.ts.map +1 -0
- package/lib-es/test/testUtils.js +4 -0
- package/lib-es/test/testUtils.js.map +1 -0
- package/lib-es/test/testUtils.test.d.ts +2 -0
- package/lib-es/test/testUtils.test.d.ts.map +1 -0
- package/lib-es/test/testUtils.test.js +9 -0
- package/lib-es/test/testUtils.test.js.map +1 -0
- package/lib-es/types/common.d.ts +55 -0
- package/lib-es/types/common.d.ts.map +1 -0
- package/lib-es/types/common.js +2 -0
- package/lib-es/types/common.js.map +1 -0
- package/lib-es/types/index.d.ts +3 -0
- package/lib-es/types/index.d.ts.map +1 -0
- package/lib-es/types/index.js +3 -0
- package/lib-es/types/index.js.map +1 -0
- package/lib-es/types/signer.d.ts +32 -0
- package/lib-es/types/signer.d.ts.map +1 -0
- package/lib-es/types/signer.js +2 -0
- package/lib-es/types/signer.js.map +1 -0
- package/package.json +143 -0
- package/src/api/index.integ.test.ts +62 -0
- package/src/api/index.ts +120 -0
- package/src/api/rosetta/index.ts +110 -0
- package/src/api/rosetta/types.ts +156 -0
- package/src/api/rosetta/utils.test.ts +100 -0
- package/src/api/rosetta/utils.ts +71 -0
- package/src/bridge/broadcast.test.ts +35 -0
- package/src/bridge/broadcast.ts +17 -0
- package/src/bridge/buildTransaction.test.ts +68 -0
- package/src/bridge/buildTransaction.ts +34 -0
- package/src/bridge/cli-transaction.ts +43 -0
- package/src/bridge/createTransaction.test.ts +21 -0
- package/src/bridge/createTransaction.ts +19 -0
- package/src/bridge/deviceTransactionConfig.ts +15 -0
- package/src/bridge/errors.ts +16 -0
- package/src/bridge/estimateMaxSpendable.ts +31 -0
- package/src/bridge/getEstimatedFees.ts +17 -0
- package/src/bridge/getTransactionStatus.test.ts +175 -0
- package/src/bridge/getTransactionStatus.ts +87 -0
- package/src/bridge/index.test.ts +39 -0
- package/src/bridge/index.ts +72 -0
- package/src/bridge/prepareTransaction.test.ts +43 -0
- package/src/bridge/prepareTransaction.ts +24 -0
- package/src/bridge/signOperation.test.ts +158 -0
- package/src/bridge/signOperation.ts +112 -0
- package/src/bridge/synchronisation.test.ts +184 -0
- package/src/bridge/synchronisation.ts +168 -0
- package/src/bridge/transaction.ts +69 -0
- package/src/common-logic/index.test.ts +225 -0
- package/src/common-logic/index.ts +97 -0
- package/src/config.ts +21 -0
- package/src/consts.ts +18 -0
- package/src/signer/getAddress.test.ts +131 -0
- package/src/signer/getAddress.ts +24 -0
- package/src/signer/index.ts +3 -0
- package/src/test/bot-deviceActions.ts +73 -0
- package/src/test/bot-specs.ts +130 -0
- package/src/test/bridgeDatasetTest.ts +180 -0
- package/src/test/fixtures.ts +226 -0
- package/src/test/index.ts +3 -0
- package/src/test/testUtils.test.ts +9 -0
- package/src/test/testUtils.ts +3 -0
- package/src/types/common.ts +70 -0
- package/src/types/index.ts +2 -0
- package/src/types/signer.ts +29 -0
- package/tsconfig.json +13 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/test/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC;AACpC,cAAc,aAAa,CAAC;AAC5B,cAAc,qBAAqB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./bridgeDatasetTest"), exports);
|
|
18
|
+
__exportStar(require("./bot-specs"), exports);
|
|
19
|
+
__exportStar(require("./bot-deviceActions"), exports);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/test/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,sDAAoC;AACpC,8CAA4B;AAC5B,sDAAoC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"testUtils.d.ts","sourceRoot":"","sources":["../../src/test/testUtils.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,mBAAmB,cAE/B,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getRandomTransferID = void 0;
|
|
4
|
+
const getRandomTransferID = () => {
|
|
5
|
+
return Math.random().toString(36).substring(2, 15) + Math.random().toString(36).substring(2, 15);
|
|
6
|
+
};
|
|
7
|
+
exports.getRandomTransferID = getRandomTransferID;
|
|
8
|
+
//# sourceMappingURL=testUtils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"testUtils.js","sourceRoot":"","sources":["../../src/test/testUtils.ts"],"names":[],"mappings":";;;AAAO,MAAM,mBAAmB,GAAG,GAAG,EAAE;IACtC,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;AACnG,CAAC,CAAC;AAFW,QAAA,mBAAmB,uBAE9B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"testUtils.test.d.ts","sourceRoot":"","sources":["../../src/test/testUtils.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const testUtils_1 = require("./testUtils");
|
|
4
|
+
describe("testUtils", () => {
|
|
5
|
+
it("getRandomTransferID", () => {
|
|
6
|
+
const id = (0, testUtils_1.getRandomTransferID)();
|
|
7
|
+
expect(id).toBeDefined();
|
|
8
|
+
expect(id.length).toBeGreaterThan(0);
|
|
9
|
+
});
|
|
10
|
+
});
|
|
11
|
+
//# sourceMappingURL=testUtils.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"testUtils.test.js","sourceRoot":"","sources":["../../src/test/testUtils.test.ts"],"names":[],"mappings":";;AAAA,2CAAkD;AAElD,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,EAAE,CAAC,qBAAqB,EAAE,GAAG,EAAE;QAC7B,MAAM,EAAE,GAAG,IAAA,+BAAmB,GAAE,CAAC;QACjC,MAAM,CAAC,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;QACzB,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -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,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./common"), exports);
|
|
18
|
+
__exportStar(require("./signer"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAyB;AACzB,2CAAyB"}
|
|
@@ -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":""}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
import { MinaAPIAccount, MinaSignedTransaction, Transaction } from "../types/common";
|
|
3
|
+
import { RosettaBlockInfoResponse, RosettaTransaction } from "./rosetta/types";
|
|
4
|
+
export declare const getAccount: (address: string) => Promise<MinaAPIAccount>;
|
|
5
|
+
export declare const getBlockInfo: (blockHeight: number) => Promise<RosettaBlockInfoResponse>;
|
|
6
|
+
export declare const getTransactions: (address: string, offset?: number) => Promise<RosettaTransaction[]>;
|
|
7
|
+
export declare const broadcastTransaction: (txn: MinaSignedTransaction) => Promise<string>;
|
|
8
|
+
export declare const getFees: (txn: Transaction, address: string) => Promise<{
|
|
9
|
+
fee: BigNumber;
|
|
10
|
+
accountCreationFee: BigNumber;
|
|
11
|
+
}>;
|
|
12
|
+
export declare const getNonce: (txn: Transaction, address: string) => Promise<number>;
|
|
13
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/api/index.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,cAAc,EAAE,qBAAqB,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAWrF,OAAO,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAG/E,eAAO,MAAM,UAAU,YAAmB,MAAM,KAAG,QAAQ,cAAc,CAsBxE,CAAC;AAEF,eAAO,MAAM,YAAY,gBAAuB,MAAM,KAAG,QAAQ,wBAAwB,CAGxF,CAAC;AAEF,eAAO,MAAM,eAAe,YACjB,MAAM,WACP,MAAM,KACb,QAAQ,kBAAkB,EAAE,CAG9B,CAAC;AAEF,eAAO,MAAM,oBAAoB,QAAe,qBAAqB,KAAG,QAAQ,MAAM,CAoBrF,CAAC;AAEF,eAAO,MAAM,OAAO,QACb,WAAW,WACP,MAAM;SAEV,SAAS;wBACM,SAAS;EAqB9B,CAAC;AAEF,eAAO,MAAM,QAAQ,QAAe,WAAW,WAAW,MAAM,KAAG,QAAQ,MAAM,CAiBhF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.integ.test.d.ts","sourceRoot":"","sources":["../../src/api/index.integ.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { getAccount, getBlockInfo, getTransactions } from ".";
|
|
2
|
+
import { getCoinConfig } from "../config";
|
|
3
|
+
jest.mock("../config");
|
|
4
|
+
describe("backend api tests", () => {
|
|
5
|
+
jest.mocked(getCoinConfig).mockReturnValue({
|
|
6
|
+
...{},
|
|
7
|
+
infra: {
|
|
8
|
+
API_MINA_ROSETTA_NODE: "https://mina.coin.ledger.com/node",
|
|
9
|
+
},
|
|
10
|
+
});
|
|
11
|
+
const validAddress = ["B62qjWLs1W3J2fFGixeX49w1o7VvSGuMBNotnFhzs3PZ7PbtdFbhdeD"];
|
|
12
|
+
const invalidAddress = [
|
|
13
|
+
"B62qkdFWJSW8zaTBZjTVtmeU3rVxyUkNxPhKKW8T2JBtpj5XfdywLJM",
|
|
14
|
+
"novalidaddress",
|
|
15
|
+
];
|
|
16
|
+
it("getAccount for valid address", async () => {
|
|
17
|
+
const account = await getAccount(validAddress[0]);
|
|
18
|
+
expect(account).toBeDefined();
|
|
19
|
+
expect(account.balance.toNumber()).toBeGreaterThan(0);
|
|
20
|
+
});
|
|
21
|
+
it("get block info", async () => {
|
|
22
|
+
const blockInfo = await getBlockInfo(1);
|
|
23
|
+
expect(blockInfo).toBeDefined();
|
|
24
|
+
expect(blockInfo.block.block_identifier.index).toBe(1);
|
|
25
|
+
});
|
|
26
|
+
it("get balance should fail for invalid address", async () => {
|
|
27
|
+
for (const address of invalidAddress) {
|
|
28
|
+
const account = await getAccount(address);
|
|
29
|
+
expect(account).toBeDefined();
|
|
30
|
+
expect(account.balance.toNumber()).toBe(0);
|
|
31
|
+
}
|
|
32
|
+
}, 10000);
|
|
33
|
+
it("get balance should succeed for valid address", async () => {
|
|
34
|
+
for (const address of validAddress) {
|
|
35
|
+
const account = await getAccount(address);
|
|
36
|
+
expect(account).toBeDefined();
|
|
37
|
+
expect(account.balance.toNumber()).toBeGreaterThan(0);
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
it("get transactions should not fail for invalid address", async () => {
|
|
41
|
+
for (const address of invalidAddress) {
|
|
42
|
+
const transactions = await getTransactions(address);
|
|
43
|
+
expect(transactions).toBeDefined();
|
|
44
|
+
expect(transactions.length).toBe(0);
|
|
45
|
+
}
|
|
46
|
+
}, 30000);
|
|
47
|
+
it("get transactions should succeed for valid address", async () => {
|
|
48
|
+
for (const address of validAddress) {
|
|
49
|
+
const transactions = await getTransactions(address);
|
|
50
|
+
expect(transactions).toBeDefined();
|
|
51
|
+
expect(transactions.length).toBeGreaterThan(0);
|
|
52
|
+
}
|
|
53
|
+
}, 30000);
|
|
54
|
+
});
|
|
55
|
+
//# sourceMappingURL=index.integ.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.integ.test.js","sourceRoot":"","sources":["../../src/api/index.integ.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
import { fetchAccountBalance, fetchAccountTransactions, fetchNetworkStatus, fetchTransactionMetadata, rosettaGetBlockInfo, rosettaSubmitTransaction, } from "./rosetta";
|
|
3
|
+
import { MINA_TOKEN_ID } from "../consts";
|
|
4
|
+
import { isValidAddress } from "../common-logic";
|
|
5
|
+
import { log } from "@ledgerhq/logs";
|
|
6
|
+
export const getAccount = async (address) => {
|
|
7
|
+
const networkStatus = await fetchNetworkStatus();
|
|
8
|
+
let balance = new BigNumber(0);
|
|
9
|
+
let spendableBalance = new BigNumber(0);
|
|
10
|
+
try {
|
|
11
|
+
const resp = await fetchAccountBalance(address);
|
|
12
|
+
balance = new BigNumber(resp.balances[0].metadata.total_balance);
|
|
13
|
+
spendableBalance = new BigNumber(resp.balances[0].metadata.liquid_balance);
|
|
14
|
+
}
|
|
15
|
+
catch (e) {
|
|
16
|
+
log("info", "[mina] getAccount error:", {
|
|
17
|
+
address,
|
|
18
|
+
error: e,
|
|
19
|
+
});
|
|
20
|
+
// fail is expected for when account has no balance and no transactions
|
|
21
|
+
/* empty */
|
|
22
|
+
}
|
|
23
|
+
return {
|
|
24
|
+
blockHeight: networkStatus.current_block_identifier.index,
|
|
25
|
+
balance,
|
|
26
|
+
spendableBalance,
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
export const getBlockInfo = async (blockHeight) => {
|
|
30
|
+
const data = await rosettaGetBlockInfo(blockHeight);
|
|
31
|
+
return data;
|
|
32
|
+
};
|
|
33
|
+
export const getTransactions = async (address, offset = 0) => {
|
|
34
|
+
const txns = await fetchAccountTransactions(address, offset);
|
|
35
|
+
return txns.sort((a, b) => b.timestamp - a.timestamp);
|
|
36
|
+
};
|
|
37
|
+
export const broadcastTransaction = async (txn) => {
|
|
38
|
+
const { nonce, receiverAddress, amount, fee, memo, senderAddress } = txn.transaction;
|
|
39
|
+
const blob = {
|
|
40
|
+
signature: txn.signature,
|
|
41
|
+
payment: {
|
|
42
|
+
to: receiverAddress,
|
|
43
|
+
from: senderAddress,
|
|
44
|
+
fee: fee.toFixed(),
|
|
45
|
+
token: MINA_TOKEN_ID,
|
|
46
|
+
nonce: nonce.toFixed(),
|
|
47
|
+
memo: memo ?? null,
|
|
48
|
+
amount: amount.toFixed(),
|
|
49
|
+
valid_until: null,
|
|
50
|
+
},
|
|
51
|
+
stake_delegation: null,
|
|
52
|
+
};
|
|
53
|
+
const { data } = await rosettaSubmitTransaction(JSON.stringify(blob));
|
|
54
|
+
return data.transaction_identifier.hash;
|
|
55
|
+
};
|
|
56
|
+
export const getFees = async (txn, address) => {
|
|
57
|
+
if (!txn.amount || !txn.recipient || !isValidAddress(txn.recipient)) {
|
|
58
|
+
return { fee: txn.fees.fee, accountCreationFee: new BigNumber(0) };
|
|
59
|
+
}
|
|
60
|
+
const { data } = await fetchTransactionMetadata(address, txn.recipient, txn.fees.fee.toNumber(), txn.amount.toNumber());
|
|
61
|
+
const accountCreationFee = data.metadata.account_creation_fee
|
|
62
|
+
? new BigNumber(data.metadata.account_creation_fee)
|
|
63
|
+
: new BigNumber(0);
|
|
64
|
+
return {
|
|
65
|
+
fee: new BigNumber(data.suggested_fee[0].value),
|
|
66
|
+
accountCreationFee,
|
|
67
|
+
};
|
|
68
|
+
};
|
|
69
|
+
export const getNonce = async (txn, address) => {
|
|
70
|
+
if (!txn.recipient || !isValidAddress(txn.recipient)) {
|
|
71
|
+
return txn.nonce;
|
|
72
|
+
}
|
|
73
|
+
if (!txn.amount || !txn.fees) {
|
|
74
|
+
return txn.nonce;
|
|
75
|
+
}
|
|
76
|
+
const { data } = await fetchTransactionMetadata(address, txn.recipient, txn.fees.fee.toNumber(), txn.amount.toNumber());
|
|
77
|
+
return parseInt(data.metadata.nonce);
|
|
78
|
+
};
|
|
79
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/api/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { FetchAccountBalanceResponse, FetchNetworkStatusResponse, RosettaBlockInfoResponse, RosettaMetadataResponse, RosettaSubmitResponse, RosettaTransaction } from "./types";
|
|
2
|
+
export declare const fetchNetworkStatus: () => Promise<FetchNetworkStatusResponse>;
|
|
3
|
+
export declare const fetchAccountBalance: (address: string) => Promise<FetchAccountBalanceResponse>;
|
|
4
|
+
export declare const fetchAccountTransactions: (address: string, offset?: number) => Promise<RosettaTransaction[]>;
|
|
5
|
+
export declare const rosettaGetBlockInfo: (blockHeight: number) => Promise<RosettaBlockInfoResponse>;
|
|
6
|
+
export declare const fetchTransactionMetadata: (srcAddress: string, destAddress: string, feeNano: number, valueNano: number) => Promise<import("@ledgerhq/live-network/lib-es/network").LiveNetworkResponse<RosettaMetadataResponse>>;
|
|
7
|
+
export declare const rosettaSubmitTransaction: (blob: string) => Promise<import("@ledgerhq/live-network/lib-es/network").LiveNetworkResponse<RosettaSubmitResponse>>;
|
|
8
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/api/rosetta/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,2BAA2B,EAE3B,0BAA0B,EAC1B,wBAAwB,EACxB,uBAAuB,EAEvB,qBAAqB,EACrB,kBAAkB,EACnB,MAAM,SAAS,CAAC;AAWjB,eAAO,MAAM,kBAAkB,2CAQ9B,CAAC;AAEF,eAAO,MAAM,mBAAmB,YAAmB,MAAM,yCAQxD,CAAC;AAEF,eAAO,MAAM,wBAAwB,YAC1B,MAAM,WACP,MAAM,KACb,QAAQ,kBAAkB,EAAE,CAsB9B,CAAC;AAEF,eAAO,MAAM,mBAAmB,gBAAuB,MAAM,sCAO5D,CAAC;AAaF,eAAO,MAAM,wBAAwB,eACvB,MAAM,eACL,MAAM,WACV,MAAM,aACJ,MAAM,0GASlB,CAAC;AAEF,eAAO,MAAM,wBAAwB,SAAgB,MAAM,wGAM1D,CAAC"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import network from "@ledgerhq/live-network";
|
|
2
|
+
import { getCoinConfig } from "../../config";
|
|
3
|
+
import { addNetworkIdentifier, buildAccountIdentifier, makeTransferPayload } from "./utils";
|
|
4
|
+
import { MAX_TRANSACTIONS_PER_PAGE } from "../../consts";
|
|
5
|
+
const getRosettaUrl = (route) => {
|
|
6
|
+
const currencyConfig = getCoinConfig();
|
|
7
|
+
return `${currencyConfig.infra.API_MINA_ROSETTA_NODE}${route || ""}`;
|
|
8
|
+
};
|
|
9
|
+
export const fetchNetworkStatus = async () => {
|
|
10
|
+
const { data } = await network({
|
|
11
|
+
method: "POST",
|
|
12
|
+
url: getRosettaUrl("/network/status"),
|
|
13
|
+
data: addNetworkIdentifier({}),
|
|
14
|
+
});
|
|
15
|
+
return data;
|
|
16
|
+
};
|
|
17
|
+
export const fetchAccountBalance = async (address) => {
|
|
18
|
+
const { data } = await network({
|
|
19
|
+
method: "POST",
|
|
20
|
+
url: getRosettaUrl("/account/balance"),
|
|
21
|
+
data: addNetworkIdentifier(buildAccountIdentifier(address)),
|
|
22
|
+
});
|
|
23
|
+
return data;
|
|
24
|
+
};
|
|
25
|
+
export const fetchAccountTransactions = async (address, offset = 0) => {
|
|
26
|
+
const transactions = [];
|
|
27
|
+
let currentOffset = offset;
|
|
28
|
+
while (currentOffset !== undefined) {
|
|
29
|
+
const response = await network({
|
|
30
|
+
method: "POST",
|
|
31
|
+
url: getRosettaUrl("/search/transactions"),
|
|
32
|
+
data: {
|
|
33
|
+
...addNetworkIdentifier(buildAccountIdentifier(address)),
|
|
34
|
+
offset: currentOffset,
|
|
35
|
+
limit: MAX_TRANSACTIONS_PER_PAGE,
|
|
36
|
+
include_timestamp: true,
|
|
37
|
+
},
|
|
38
|
+
});
|
|
39
|
+
const { data } = response;
|
|
40
|
+
transactions.push(...data.transactions);
|
|
41
|
+
currentOffset = data.next_offset;
|
|
42
|
+
}
|
|
43
|
+
return transactions;
|
|
44
|
+
};
|
|
45
|
+
export const rosettaGetBlockInfo = async (blockHeight) => {
|
|
46
|
+
const { data } = await network({
|
|
47
|
+
method: "POST",
|
|
48
|
+
url: getRosettaUrl("/block"),
|
|
49
|
+
data: addNetworkIdentifier({ block_identifier: { index: blockHeight } }),
|
|
50
|
+
});
|
|
51
|
+
return data;
|
|
52
|
+
};
|
|
53
|
+
const rosettaPreprocess = async (from, to, feeNano, valueNano) => {
|
|
54
|
+
const payload = makeTransferPayload(from, to, feeNano, valueNano);
|
|
55
|
+
const { data } = await network({
|
|
56
|
+
method: "POST",
|
|
57
|
+
url: getRosettaUrl("/construction/preprocess"),
|
|
58
|
+
data: addNetworkIdentifier(payload),
|
|
59
|
+
});
|
|
60
|
+
return data;
|
|
61
|
+
};
|
|
62
|
+
export const fetchTransactionMetadata = async (srcAddress, destAddress, feeNano, valueNano) => {
|
|
63
|
+
const options = await rosettaPreprocess(srcAddress, destAddress, feeNano, valueNano);
|
|
64
|
+
const payload = makeTransferPayload(srcAddress, destAddress, feeNano, valueNano);
|
|
65
|
+
return await network({
|
|
66
|
+
method: "POST",
|
|
67
|
+
url: getRosettaUrl("/construction/metadata"),
|
|
68
|
+
data: addNetworkIdentifier({ ...payload, ...options }),
|
|
69
|
+
});
|
|
70
|
+
};
|
|
71
|
+
export const rosettaSubmitTransaction = async (blob) => {
|
|
72
|
+
return await network({
|
|
73
|
+
method: "POST",
|
|
74
|
+
url: getRosettaUrl("/construction/submit"),
|
|
75
|
+
data: addNetworkIdentifier({ signed_transaction: blob }),
|
|
76
|
+
});
|
|
77
|
+
};
|
|
78
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/api/rosetta/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
export type FetchNetworkStatusResponse = {
|
|
2
|
+
current_block_identifier: {
|
|
3
|
+
index: number;
|
|
4
|
+
hash: string;
|
|
5
|
+
};
|
|
6
|
+
current_block_timestamp: number;
|
|
7
|
+
genesis_block_identifier: {
|
|
8
|
+
index: number;
|
|
9
|
+
hash: string;
|
|
10
|
+
};
|
|
11
|
+
oldest_block_identifier: {
|
|
12
|
+
index: number;
|
|
13
|
+
hash: string;
|
|
14
|
+
};
|
|
15
|
+
sync_status: {
|
|
16
|
+
current_index: number;
|
|
17
|
+
stage: string;
|
|
18
|
+
synced: boolean;
|
|
19
|
+
};
|
|
20
|
+
peers: Array<{
|
|
21
|
+
peer_id: string;
|
|
22
|
+
}>;
|
|
23
|
+
};
|
|
24
|
+
export type FetchAccountBalanceResponse = {
|
|
25
|
+
block_identifier: {
|
|
26
|
+
index: number;
|
|
27
|
+
hash: string;
|
|
28
|
+
};
|
|
29
|
+
balances: Array<{
|
|
30
|
+
value: string;
|
|
31
|
+
currency: {
|
|
32
|
+
symbol: string;
|
|
33
|
+
decimals: number;
|
|
34
|
+
};
|
|
35
|
+
metadata: {
|
|
36
|
+
locked_balance: number;
|
|
37
|
+
liquid_balance: number;
|
|
38
|
+
total_balance: number;
|
|
39
|
+
};
|
|
40
|
+
}>;
|
|
41
|
+
metadata: {
|
|
42
|
+
created_via_historical_lookup: boolean;
|
|
43
|
+
nonce: string;
|
|
44
|
+
};
|
|
45
|
+
};
|
|
46
|
+
export type RosettaTransaction = {
|
|
47
|
+
block_identifier: {
|
|
48
|
+
index: number;
|
|
49
|
+
hash: string;
|
|
50
|
+
};
|
|
51
|
+
transaction: {
|
|
52
|
+
transaction_identifier: {
|
|
53
|
+
hash: string;
|
|
54
|
+
};
|
|
55
|
+
operations: Array<{
|
|
56
|
+
operation_identifier: {
|
|
57
|
+
index: number;
|
|
58
|
+
};
|
|
59
|
+
type: "fee_payment" | "payment_source_dec" | "payment_receiver_inc" | "account_creation_fee_via_payment" | "zkapp_fee_payer_dec" | "delegate_change" | "zkapp_balance_update";
|
|
60
|
+
status: "Success" | "Failed";
|
|
61
|
+
account: {
|
|
62
|
+
address: string;
|
|
63
|
+
metadata: {
|
|
64
|
+
token_id: string;
|
|
65
|
+
};
|
|
66
|
+
};
|
|
67
|
+
amount?: {
|
|
68
|
+
value: string;
|
|
69
|
+
currency: {
|
|
70
|
+
symbol: string;
|
|
71
|
+
decimals: number;
|
|
72
|
+
};
|
|
73
|
+
};
|
|
74
|
+
related_operations?: Array<{
|
|
75
|
+
index: number;
|
|
76
|
+
}>;
|
|
77
|
+
metadata?: {
|
|
78
|
+
delegate_change_target?: string;
|
|
79
|
+
};
|
|
80
|
+
}>;
|
|
81
|
+
metadata?: {
|
|
82
|
+
memo?: string;
|
|
83
|
+
nonce?: number;
|
|
84
|
+
};
|
|
85
|
+
};
|
|
86
|
+
timestamp: number;
|
|
87
|
+
};
|
|
88
|
+
export type FetchAccountTransactionsResponse = {
|
|
89
|
+
transactions: RosettaTransaction[];
|
|
90
|
+
total_count: number;
|
|
91
|
+
next_offset?: number;
|
|
92
|
+
};
|
|
93
|
+
export type RosettaPreprocessResponse = {
|
|
94
|
+
options: {
|
|
95
|
+
sender: string;
|
|
96
|
+
token_id: string;
|
|
97
|
+
receiver: string;
|
|
98
|
+
};
|
|
99
|
+
};
|
|
100
|
+
export type RosettaMetadataResponse = {
|
|
101
|
+
metadata: {
|
|
102
|
+
sender: string;
|
|
103
|
+
nonce: string;
|
|
104
|
+
token_id: string;
|
|
105
|
+
receiver: string;
|
|
106
|
+
account_creation_fee?: string;
|
|
107
|
+
};
|
|
108
|
+
suggested_fee: Array<{
|
|
109
|
+
value: string;
|
|
110
|
+
currency: {
|
|
111
|
+
symbol: string;
|
|
112
|
+
decimals: number;
|
|
113
|
+
};
|
|
114
|
+
metadata: {
|
|
115
|
+
minimum_fee: {
|
|
116
|
+
value: string;
|
|
117
|
+
currency: {
|
|
118
|
+
symbol: string;
|
|
119
|
+
decimals: number;
|
|
120
|
+
};
|
|
121
|
+
};
|
|
122
|
+
};
|
|
123
|
+
}>;
|
|
124
|
+
};
|
|
125
|
+
export type RosettaSubmitResponse = {
|
|
126
|
+
transaction_identifier: {
|
|
127
|
+
hash: string;
|
|
128
|
+
};
|
|
129
|
+
};
|
|
130
|
+
export type RosettaBlockInfoResponse = {
|
|
131
|
+
block: {
|
|
132
|
+
block_identifier: {
|
|
133
|
+
index: number;
|
|
134
|
+
hash: string;
|
|
135
|
+
};
|
|
136
|
+
parent_block_identifier: {
|
|
137
|
+
index: number;
|
|
138
|
+
hash: string;
|
|
139
|
+
};
|
|
140
|
+
timestamp: number;
|
|
141
|
+
};
|
|
142
|
+
};
|
|
143
|
+
//# sourceMappingURL=types.d.ts.map
|