@ledgerhq/coin-aptos 2.0.0-nightly.5 → 2.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/.turbo/turbo-build.log +1 -1
- package/.unimportedrc.json +18 -6
- package/CHANGELOG.md +178 -34
- package/jest.config.js +2 -1
- package/jest.integ.config.js +8 -0
- package/lib/__tests__/api/craftTransaction.unit.test.d.ts +2 -0
- package/lib/__tests__/api/craftTransaction.unit.test.d.ts.map +1 -0
- package/lib/__tests__/api/craftTransaction.unit.test.js +187 -0
- package/lib/__tests__/api/craftTransaction.unit.test.js.map +1 -0
- package/lib/__tests__/api/getBalance.unit.test.d.ts +2 -0
- package/lib/__tests__/api/getBalance.unit.test.d.ts.map +1 -0
- package/lib/__tests__/api/getBalance.unit.test.js +41 -0
- package/lib/__tests__/api/getBalance.unit.test.js.map +1 -0
- package/lib/__tests__/api/index.integ.test.d.ts +2 -0
- package/lib/__tests__/api/index.integ.test.d.ts.map +1 -0
- package/lib/__tests__/api/index.integ.test.js +319 -0
- package/lib/__tests__/api/index.integ.test.js.map +1 -0
- package/lib/__tests__/api/index.test.js +48 -404
- package/lib/__tests__/api/index.test.js.map +1 -1
- package/lib/__tests__/bridge/broadcast.test.js +5 -5
- package/lib/__tests__/bridge/broadcast.test.js.map +1 -1
- package/lib/__tests__/bridge/getFeesForTransaction.test.js +115 -14
- package/lib/__tests__/bridge/getFeesForTransaction.test.js.map +1 -1
- package/lib/__tests__/bridge/getTransactionStatus.test.js +175 -37
- package/lib/__tests__/bridge/getTransactionStatus.test.js.map +1 -1
- package/lib/__tests__/bridge/logic.test.js +703 -479
- package/lib/__tests__/bridge/logic.test.js.map +1 -1
- package/lib/__tests__/bridge/prepareTransaction.test.js +3 -3
- package/lib/__tests__/bridge/prepareTransaction.test.js.map +1 -1
- package/lib/__tests__/bridge/signOperation.test.js +137 -14
- package/lib/__tests__/bridge/signOperation.test.js.map +1 -1
- package/lib/__tests__/bridge/synchronisation.test.js +1215 -68
- package/lib/__tests__/bridge/synchronisation.test.js.map +1 -1
- package/lib/__tests__/index.test.js +1 -1
- package/lib/__tests__/index.test.js.map +1 -1
- package/lib/__tests__/logic/buildTransaction.test.d.ts.map +1 -0
- package/lib/__tests__/logic/buildTransaction.test.js +114 -0
- package/lib/__tests__/logic/buildTransaction.test.js.map +1 -0
- package/lib/__tests__/logic/calculateAmount.unit.test.d.ts +2 -0
- package/lib/__tests__/logic/calculateAmount.unit.test.d.ts.map +1 -0
- package/lib/__tests__/logic/calculateAmount.unit.test.js +45 -0
- package/lib/__tests__/logic/calculateAmount.unit.test.js.map +1 -0
- package/lib/__tests__/logic/combine.unit.test.d.ts +2 -0
- package/lib/__tests__/logic/combine.unit.test.d.ts.map +1 -0
- package/lib/__tests__/logic/combine.unit.test.js +47 -0
- package/lib/__tests__/logic/combine.unit.test.js.map +1 -0
- package/lib/__tests__/logic/compareAddress.unit.test.d.ts +2 -0
- package/lib/__tests__/logic/compareAddress.unit.test.d.ts.map +1 -0
- package/lib/__tests__/logic/compareAddress.unit.test.js +26 -0
- package/lib/__tests__/logic/compareAddress.unit.test.js.map +1 -0
- package/lib/__tests__/logic/createTransaction.test.d.ts.map +1 -0
- package/lib/__tests__/{bridge → logic}/createTransaction.test.js +2 -2
- package/lib/__tests__/logic/createTransaction.test.js.map +1 -0
- package/lib/__tests__/logic/getCoinAndAmounts.unit.test.d.ts +2 -0
- package/lib/__tests__/logic/getCoinAndAmounts.unit.test.d.ts.map +1 -0
- package/lib/__tests__/logic/getCoinAndAmounts.unit.test.js +186 -0
- package/lib/__tests__/logic/getCoinAndAmounts.unit.test.js.map +1 -0
- package/lib/__tests__/logic/getFunctionAddress.unit.test.d.ts +2 -0
- package/lib/__tests__/logic/getFunctionAddress.unit.test.d.ts.map +1 -0
- package/lib/__tests__/logic/getFunctionAddress.unit.test.js +29 -0
- package/lib/__tests__/logic/getFunctionAddress.unit.test.js.map +1 -0
- package/lib/__tests__/logic/getResourceAddress.unit.test.d.ts +2 -0
- package/lib/__tests__/logic/getResourceAddress.unit.test.d.ts.map +1 -0
- package/lib/__tests__/logic/getResourceAddress.unit.test.js +218 -0
- package/lib/__tests__/logic/getResourceAddress.unit.test.js.map +1 -0
- package/lib/__tests__/logic/isTestnet.unit.test.d.ts +2 -0
- package/lib/__tests__/logic/isTestnet.unit.test.d.ts.map +1 -0
- package/lib/__tests__/logic/isTestnet.unit.test.js +12 -0
- package/lib/__tests__/logic/isTestnet.unit.test.js.map +1 -0
- package/lib/__tests__/logic/normalizeAddress.unit.test.d.ts +2 -0
- package/lib/__tests__/logic/normalizeAddress.unit.test.d.ts.map +1 -0
- package/lib/__tests__/logic/normalizeAddress.unit.test.js +12 -0
- package/lib/__tests__/logic/normalizeAddress.unit.test.js.map +1 -0
- package/lib/__tests__/logic/processRecipients.unit.test.d.ts +2 -0
- package/lib/__tests__/logic/processRecipients.unit.test.d.ts.map +1 -0
- package/lib/__tests__/logic/processRecipients.unit.test.js +79 -0
- package/lib/__tests__/logic/processRecipients.unit.test.js.map +1 -0
- package/lib/__tests__/network/client.test.d.ts +2 -0
- package/lib/__tests__/network/client.test.d.ts.map +1 -0
- package/lib/__tests__/network/client.test.js +1124 -0
- package/lib/__tests__/network/client.test.js.map +1 -0
- package/lib/api/index.d.ts +4 -30
- package/lib/api/index.d.ts.map +1 -1
- package/lib/api/index.js +19 -170
- package/lib/api/index.js.map +1 -1
- package/lib/bridge/bridge.fixture.d.ts +2 -0
- package/lib/bridge/bridge.fixture.d.ts.map +1 -1
- package/lib/bridge/bridge.fixture.js +85 -13
- package/lib/bridge/bridge.fixture.js.map +1 -1
- package/lib/bridge/broadcast.d.ts +3 -2
- package/lib/bridge/broadcast.d.ts.map +1 -1
- package/lib/bridge/broadcast.js +4 -3
- package/lib/bridge/broadcast.js.map +1 -1
- package/lib/bridge/estimateMaxSpendable.d.ts.map +1 -1
- package/lib/bridge/estimateMaxSpendable.js +6 -5
- package/lib/bridge/estimateMaxSpendable.js.map +1 -1
- package/lib/bridge/getFeesForTransaction.d.ts +1 -1
- package/lib/bridge/getFeesForTransaction.d.ts.map +1 -1
- package/lib/bridge/getFeesForTransaction.js +20 -14
- package/lib/bridge/getFeesForTransaction.js.map +1 -1
- package/lib/bridge/getTransactionStatus.d.ts.map +1 -1
- package/lib/bridge/getTransactionStatus.js +28 -14
- package/lib/bridge/getTransactionStatus.js.map +1 -1
- package/lib/bridge/index.d.ts +1 -1
- package/lib/bridge/index.d.ts.map +1 -1
- package/lib/bridge/index.js +1 -1
- package/lib/bridge/index.js.map +1 -1
- package/lib/bridge/logic.d.ts +5 -19
- package/lib/bridge/logic.d.ts.map +1 -1
- package/lib/bridge/logic.js +50 -147
- package/lib/bridge/logic.js.map +1 -1
- package/lib/bridge/prepareTransaction.d.ts.map +1 -1
- package/lib/bridge/prepareTransaction.js +5 -4
- package/lib/bridge/prepareTransaction.js.map +1 -1
- package/lib/bridge/signOperation.d.ts.map +1 -1
- package/lib/bridge/signOperation.js +21 -7
- package/lib/bridge/signOperation.js.map +1 -1
- package/lib/bridge/synchronisation.d.ts +15 -0
- package/lib/bridge/synchronisation.d.ts.map +1 -1
- package/lib/bridge/synchronisation.js +129 -6
- package/lib/bridge/synchronisation.js.map +1 -1
- package/lib/config.d.ts +13 -0
- package/lib/config.d.ts.map +1 -0
- package/lib/config.js +9 -0
- package/lib/config.js.map +1 -0
- package/lib/constants.d.ts +13 -2
- package/lib/constants.d.ts.map +1 -1
- package/lib/constants.js +17 -2
- package/lib/constants.js.map +1 -1
- package/lib/logic/buildTransaction.d.ts +9 -0
- package/lib/logic/buildTransaction.d.ts.map +1 -0
- package/lib/logic/buildTransaction.js +47 -0
- package/lib/logic/buildTransaction.js.map +1 -0
- package/lib/logic/calculateAmount.d.ts +3 -0
- package/lib/logic/calculateAmount.d.ts.map +1 -0
- package/lib/logic/calculateAmount.js +13 -0
- package/lib/logic/calculateAmount.js.map +1 -0
- package/lib/logic/combine.d.ts +4 -0
- package/lib/logic/combine.d.ts.map +1 -0
- package/lib/logic/combine.js +34 -0
- package/lib/logic/combine.js.map +1 -0
- package/lib/logic/craftTransaction.d.ts +5 -0
- package/lib/logic/craftTransaction.d.ts.map +1 -0
- package/lib/logic/craftTransaction.js +68 -0
- package/lib/logic/craftTransaction.js.map +1 -0
- package/lib/logic/createTransaction.d.ts.map +1 -0
- package/lib/{bridge → logic}/createTransaction.js +3 -3
- package/lib/logic/createTransaction.js.map +1 -0
- package/lib/logic/getBalance.d.ts +5 -0
- package/lib/logic/getBalance.d.ts.map +1 -0
- package/lib/logic/getBalance.js +12 -0
- package/lib/logic/getBalance.js.map +1 -0
- package/lib/logic/getCoinAndAmounts.d.ts +13 -0
- package/lib/logic/getCoinAndAmounts.d.ts.map +1 -0
- package/lib/logic/getCoinAndAmounts.js +112 -0
- package/lib/logic/getCoinAndAmounts.js.map +1 -0
- package/lib/logic/getFunctionAddress.d.ts +3 -0
- package/lib/logic/getFunctionAddress.d.ts.map +1 -0
- package/lib/logic/getFunctionAddress.js +12 -0
- package/lib/logic/getFunctionAddress.js.map +1 -0
- package/lib/logic/getResourceAddress.d.ts +4 -0
- package/lib/logic/getResourceAddress.d.ts.map +1 -0
- package/lib/logic/getResourceAddress.js +17 -0
- package/lib/logic/getResourceAddress.js.map +1 -0
- package/lib/logic/isTestnet.d.ts +2 -0
- package/lib/logic/isTestnet.d.ts.map +1 -0
- package/lib/logic/isTestnet.js +9 -0
- package/lib/logic/isTestnet.js.map +1 -0
- package/lib/logic/isWriteSetChangeWriteResource.d.ts +3 -0
- package/lib/logic/isWriteSetChangeWriteResource.d.ts.map +1 -0
- package/lib/logic/isWriteSetChangeWriteResource.js +8 -0
- package/lib/logic/isWriteSetChangeWriteResource.js.map +1 -0
- package/lib/logic/normalizeAddress.d.ts +2 -0
- package/lib/logic/normalizeAddress.d.ts.map +1 -0
- package/lib/logic/normalizeAddress.js +12 -0
- package/lib/logic/normalizeAddress.js.map +1 -0
- package/lib/logic/normalizeTransactionOptions.d.ts +3 -0
- package/lib/logic/normalizeTransactionOptions.d.ts.map +1 -0
- package/lib/logic/normalizeTransactionOptions.js +21 -0
- package/lib/logic/normalizeTransactionOptions.js.map +1 -0
- package/lib/logic/processRecipients.d.ts +6 -0
- package/lib/logic/processRecipients.d.ts.map +1 -0
- package/lib/logic/processRecipients.js +58 -0
- package/lib/logic/processRecipients.js.map +1 -0
- package/lib/logic/transactionsToOperations.d.ts +7 -0
- package/lib/logic/transactionsToOperations.d.ts.map +1 -0
- package/lib/logic/transactionsToOperations.js +89 -0
- package/lib/logic/transactionsToOperations.js.map +1 -0
- package/lib/network/client.d.ts +38 -0
- package/lib/network/client.d.ts.map +1 -0
- package/lib/network/client.js +283 -0
- package/lib/network/client.js.map +1 -0
- package/lib/network/graphql/queries.d.ts.map +1 -0
- package/lib/{api → network}/graphql/queries.js +6 -6
- package/lib/network/graphql/queries.js.map +1 -0
- package/lib/{api → network}/graphql/types.d.ts +9 -9
- package/lib/network/graphql/types.d.ts.map +1 -0
- package/lib/{api → network}/graphql/types.js.map +1 -1
- package/lib/network/index.d.ts +2 -1
- package/lib/network/index.d.ts.map +1 -1
- package/lib/network/index.js +19 -7
- package/lib/network/index.js.map +1 -1
- package/lib/test/bot-specs.d.ts.map +1 -1
- package/lib/test/bot-specs.js +40 -1
- package/lib/test/bot-specs.js.map +1 -1
- package/lib/test/bridgeDatasetTest.d.ts.map +1 -1
- package/lib/test/bridgeDatasetTest.js +44 -62
- package/lib/test/bridgeDatasetTest.js.map +1 -1
- package/lib/test/speculos-deviceActions.d.ts +1 -0
- package/lib/test/speculos-deviceActions.d.ts.map +1 -1
- package/lib/test/speculos-deviceActions.js +37 -5
- package/lib/test/speculos-deviceActions.js.map +1 -1
- package/lib/types/assets.d.ts +16 -0
- package/lib/types/assets.d.ts.map +1 -0
- package/lib/types/assets.js +3 -0
- package/lib/types/assets.js.map +1 -0
- package/lib/types/index.d.ts +22 -7
- package/lib/types/index.d.ts.map +1 -1
- package/lib-es/__tests__/api/craftTransaction.unit.test.d.ts +2 -0
- package/lib-es/__tests__/api/craftTransaction.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/api/craftTransaction.unit.test.js +185 -0
- package/lib-es/__tests__/api/craftTransaction.unit.test.js.map +1 -0
- package/lib-es/__tests__/api/getBalance.unit.test.d.ts +2 -0
- package/lib-es/__tests__/api/getBalance.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/api/getBalance.unit.test.js +36 -0
- package/lib-es/__tests__/api/getBalance.unit.test.js.map +1 -0
- package/lib-es/__tests__/api/index.integ.test.d.ts +2 -0
- package/lib-es/__tests__/api/index.integ.test.d.ts.map +1 -0
- package/lib-es/__tests__/api/index.integ.test.js +317 -0
- package/lib-es/__tests__/api/index.integ.test.js.map +1 -0
- package/lib-es/__tests__/api/index.test.js +52 -408
- package/lib-es/__tests__/api/index.test.js.map +1 -1
- package/lib-es/__tests__/bridge/broadcast.test.js +2 -2
- package/lib-es/__tests__/bridge/broadcast.test.js.map +1 -1
- package/lib-es/__tests__/bridge/getFeesForTransaction.test.js +112 -11
- package/lib-es/__tests__/bridge/getFeesForTransaction.test.js.map +1 -1
- package/lib-es/__tests__/bridge/getTransactionStatus.test.js +177 -39
- package/lib-es/__tests__/bridge/getTransactionStatus.test.js.map +1 -1
- package/lib-es/__tests__/bridge/logic.test.js +703 -479
- package/lib-es/__tests__/bridge/logic.test.js.map +1 -1
- package/lib-es/__tests__/bridge/prepareTransaction.test.js +2 -2
- package/lib-es/__tests__/bridge/prepareTransaction.test.js.map +1 -1
- package/lib-es/__tests__/bridge/signOperation.test.js +137 -14
- package/lib-es/__tests__/bridge/signOperation.test.js.map +1 -1
- package/lib-es/__tests__/bridge/synchronisation.test.js +1213 -69
- package/lib-es/__tests__/bridge/synchronisation.test.js.map +1 -1
- package/lib-es/__tests__/index.test.js +1 -1
- package/lib-es/__tests__/index.test.js.map +1 -1
- package/lib-es/__tests__/logic/buildTransaction.test.d.ts.map +1 -0
- package/lib-es/__tests__/logic/buildTransaction.test.js +109 -0
- package/lib-es/__tests__/logic/buildTransaction.test.js.map +1 -0
- package/lib-es/__tests__/logic/calculateAmount.unit.test.d.ts +2 -0
- package/lib-es/__tests__/logic/calculateAmount.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/logic/calculateAmount.unit.test.js +40 -0
- package/lib-es/__tests__/logic/calculateAmount.unit.test.js.map +1 -0
- package/lib-es/__tests__/logic/combine.unit.test.d.ts +2 -0
- package/lib-es/__tests__/logic/combine.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/logic/combine.unit.test.js +45 -0
- package/lib-es/__tests__/logic/combine.unit.test.js.map +1 -0
- package/lib-es/__tests__/logic/compareAddress.unit.test.d.ts +2 -0
- package/lib-es/__tests__/logic/compareAddress.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/logic/compareAddress.unit.test.js +24 -0
- package/lib-es/__tests__/logic/compareAddress.unit.test.js.map +1 -0
- package/lib-es/__tests__/logic/createTransaction.test.d.ts.map +1 -0
- package/lib-es/__tests__/{bridge → logic}/createTransaction.test.js +2 -2
- package/lib-es/__tests__/logic/createTransaction.test.js.map +1 -0
- package/lib-es/__tests__/logic/getCoinAndAmounts.unit.test.d.ts +2 -0
- package/lib-es/__tests__/logic/getCoinAndAmounts.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/logic/getCoinAndAmounts.unit.test.js +181 -0
- package/lib-es/__tests__/logic/getCoinAndAmounts.unit.test.js.map +1 -0
- package/lib-es/__tests__/logic/getFunctionAddress.unit.test.d.ts +2 -0
- package/lib-es/__tests__/logic/getFunctionAddress.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/logic/getFunctionAddress.unit.test.js +27 -0
- package/lib-es/__tests__/logic/getFunctionAddress.unit.test.js.map +1 -0
- package/lib-es/__tests__/logic/getResourceAddress.unit.test.d.ts +2 -0
- package/lib-es/__tests__/logic/getResourceAddress.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/logic/getResourceAddress.unit.test.js +216 -0
- package/lib-es/__tests__/logic/getResourceAddress.unit.test.js.map +1 -0
- package/lib-es/__tests__/logic/isTestnet.unit.test.d.ts +2 -0
- package/lib-es/__tests__/logic/isTestnet.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/logic/isTestnet.unit.test.js +10 -0
- package/lib-es/__tests__/logic/isTestnet.unit.test.js.map +1 -0
- package/lib-es/__tests__/logic/normalizeAddress.unit.test.d.ts +2 -0
- package/lib-es/__tests__/logic/normalizeAddress.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/logic/normalizeAddress.unit.test.js +10 -0
- package/lib-es/__tests__/logic/normalizeAddress.unit.test.js.map +1 -0
- package/lib-es/__tests__/logic/processRecipients.unit.test.d.ts +2 -0
- package/lib-es/__tests__/logic/processRecipients.unit.test.d.ts.map +1 -0
- package/lib-es/__tests__/logic/processRecipients.unit.test.js +74 -0
- package/lib-es/__tests__/logic/processRecipients.unit.test.js.map +1 -0
- package/lib-es/__tests__/network/client.test.d.ts +2 -0
- package/lib-es/__tests__/network/client.test.d.ts.map +1 -0
- package/lib-es/__tests__/network/client.test.js +1119 -0
- package/lib-es/__tests__/network/client.test.js.map +1 -0
- package/lib-es/api/index.d.ts +4 -30
- package/lib-es/api/index.d.ts.map +1 -1
- package/lib-es/api/index.js +17 -168
- package/lib-es/api/index.js.map +1 -1
- package/lib-es/bridge/bridge.fixture.d.ts +2 -0
- package/lib-es/bridge/bridge.fixture.d.ts.map +1 -1
- package/lib-es/bridge/bridge.fixture.js +82 -12
- package/lib-es/bridge/bridge.fixture.js.map +1 -1
- package/lib-es/bridge/broadcast.d.ts +3 -2
- package/lib-es/bridge/broadcast.d.ts.map +1 -1
- package/lib-es/bridge/broadcast.js +4 -3
- package/lib-es/bridge/broadcast.js.map +1 -1
- package/lib-es/bridge/estimateMaxSpendable.d.ts.map +1 -1
- package/lib-es/bridge/estimateMaxSpendable.js +4 -3
- package/lib-es/bridge/estimateMaxSpendable.js.map +1 -1
- package/lib-es/bridge/getFeesForTransaction.d.ts +1 -1
- package/lib-es/bridge/getFeesForTransaction.d.ts.map +1 -1
- package/lib-es/bridge/getFeesForTransaction.js +15 -9
- package/lib-es/bridge/getFeesForTransaction.js.map +1 -1
- package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -1
- package/lib-es/bridge/getTransactionStatus.js +28 -14
- package/lib-es/bridge/getTransactionStatus.js.map +1 -1
- package/lib-es/bridge/index.d.ts +1 -1
- package/lib-es/bridge/index.d.ts.map +1 -1
- package/lib-es/bridge/index.js +1 -1
- package/lib-es/bridge/index.js.map +1 -1
- package/lib-es/bridge/logic.d.ts +5 -19
- package/lib-es/bridge/logic.d.ts.map +1 -1
- package/lib-es/bridge/logic.js +44 -134
- package/lib-es/bridge/logic.js.map +1 -1
- package/lib-es/bridge/prepareTransaction.d.ts.map +1 -1
- package/lib-es/bridge/prepareTransaction.js +5 -4
- package/lib-es/bridge/prepareTransaction.js.map +1 -1
- package/lib-es/bridge/signOperation.d.ts.map +1 -1
- package/lib-es/bridge/signOperation.js +19 -5
- package/lib-es/bridge/signOperation.js.map +1 -1
- package/lib-es/bridge/synchronisation.d.ts +15 -0
- package/lib-es/bridge/synchronisation.d.ts.map +1 -1
- package/lib-es/bridge/synchronisation.js +124 -4
- package/lib-es/bridge/synchronisation.js.map +1 -1
- package/lib-es/config.d.ts +13 -0
- package/lib-es/config.d.ts.map +1 -0
- package/lib-es/config.js +4 -0
- package/lib-es/config.js.map +1 -0
- package/lib-es/constants.d.ts +13 -2
- package/lib-es/constants.d.ts.map +1 -1
- package/lib-es/constants.js +13 -1
- package/lib-es/constants.js.map +1 -1
- package/lib-es/logic/buildTransaction.d.ts +9 -0
- package/lib-es/logic/buildTransaction.d.ts.map +1 -0
- package/lib-es/logic/buildTransaction.js +43 -0
- package/lib-es/logic/buildTransaction.js.map +1 -0
- package/lib-es/logic/calculateAmount.d.ts +3 -0
- package/lib-es/logic/calculateAmount.d.ts.map +1 -0
- package/lib-es/logic/calculateAmount.js +9 -0
- package/lib-es/logic/calculateAmount.js.map +1 -0
- package/lib-es/logic/combine.d.ts +4 -0
- package/lib-es/logic/combine.d.ts.map +1 -0
- package/lib-es/logic/combine.js +29 -0
- package/lib-es/logic/combine.js.map +1 -0
- package/lib-es/logic/craftTransaction.d.ts +5 -0
- package/lib-es/logic/craftTransaction.d.ts.map +1 -0
- package/lib-es/logic/craftTransaction.js +38 -0
- package/lib-es/logic/craftTransaction.js.map +1 -0
- package/lib-es/logic/createTransaction.d.ts.map +1 -0
- package/lib-es/{bridge → logic}/createTransaction.js +1 -1
- package/lib-es/logic/createTransaction.js.map +1 -0
- package/lib-es/logic/getBalance.d.ts +5 -0
- package/lib-es/logic/getBalance.d.ts.map +1 -0
- package/lib-es/logic/getBalance.js +8 -0
- package/lib-es/logic/getBalance.js.map +1 -0
- package/lib-es/logic/getCoinAndAmounts.d.ts +13 -0
- package/lib-es/logic/getCoinAndAmounts.d.ts.map +1 -0
- package/lib-es/logic/getCoinAndAmounts.js +101 -0
- package/lib-es/logic/getCoinAndAmounts.js.map +1 -0
- package/lib-es/logic/getFunctionAddress.d.ts +3 -0
- package/lib-es/logic/getFunctionAddress.d.ts.map +1 -0
- package/lib-es/logic/getFunctionAddress.js +8 -0
- package/lib-es/logic/getFunctionAddress.js.map +1 -0
- package/lib-es/logic/getResourceAddress.d.ts +4 -0
- package/lib-es/logic/getResourceAddress.d.ts.map +1 -0
- package/lib-es/logic/getResourceAddress.js +13 -0
- package/lib-es/logic/getResourceAddress.js.map +1 -0
- package/lib-es/logic/isTestnet.d.ts +2 -0
- package/lib-es/logic/isTestnet.d.ts.map +1 -0
- package/lib-es/logic/isTestnet.js +5 -0
- package/lib-es/logic/isTestnet.js.map +1 -0
- package/lib-es/logic/isWriteSetChangeWriteResource.d.ts +3 -0
- package/lib-es/logic/isWriteSetChangeWriteResource.d.ts.map +1 -0
- package/lib-es/logic/isWriteSetChangeWriteResource.js +4 -0
- package/lib-es/logic/isWriteSetChangeWriteResource.js.map +1 -0
- package/lib-es/logic/normalizeAddress.d.ts +2 -0
- package/lib-es/logic/normalizeAddress.d.ts.map +1 -0
- package/lib-es/logic/normalizeAddress.js +8 -0
- package/lib-es/logic/normalizeAddress.js.map +1 -0
- package/lib-es/logic/normalizeTransactionOptions.d.ts +3 -0
- package/lib-es/logic/normalizeTransactionOptions.d.ts.map +1 -0
- package/lib-es/logic/normalizeTransactionOptions.js +17 -0
- package/lib-es/logic/normalizeTransactionOptions.js.map +1 -0
- package/lib-es/logic/processRecipients.d.ts +6 -0
- package/lib-es/logic/processRecipients.d.ts.map +1 -0
- package/lib-es/logic/processRecipients.js +54 -0
- package/lib-es/logic/processRecipients.js.map +1 -0
- package/lib-es/logic/transactionsToOperations.d.ts +7 -0
- package/lib-es/logic/transactionsToOperations.d.ts.map +1 -0
- package/lib-es/logic/transactionsToOperations.js +81 -0
- package/lib-es/logic/transactionsToOperations.js.map +1 -0
- package/lib-es/network/client.d.ts +38 -0
- package/lib-es/network/client.d.ts.map +1 -0
- package/lib-es/network/client.js +276 -0
- package/lib-es/network/client.js.map +1 -0
- package/lib-es/network/graphql/queries.d.ts.map +1 -0
- package/lib-es/{api → network}/graphql/queries.js +6 -6
- package/lib-es/network/graphql/queries.js.map +1 -0
- package/lib-es/{api → network}/graphql/types.d.ts +9 -9
- package/lib-es/network/graphql/types.d.ts.map +1 -0
- package/lib-es/{api → network}/graphql/types.js.map +1 -1
- package/lib-es/network/index.d.ts +2 -1
- package/lib-es/network/index.d.ts.map +1 -1
- package/lib-es/network/index.js +6 -8
- package/lib-es/network/index.js.map +1 -1
- package/lib-es/test/bot-specs.d.ts.map +1 -1
- package/lib-es/test/bot-specs.js +41 -2
- package/lib-es/test/bot-specs.js.map +1 -1
- package/lib-es/test/bridgeDatasetTest.d.ts.map +1 -1
- package/lib-es/test/bridgeDatasetTest.js +44 -59
- package/lib-es/test/bridgeDatasetTest.js.map +1 -1
- package/lib-es/test/speculos-deviceActions.d.ts +1 -0
- package/lib-es/test/speculos-deviceActions.d.ts.map +1 -1
- package/lib-es/test/speculos-deviceActions.js +36 -4
- package/lib-es/test/speculos-deviceActions.js.map +1 -1
- package/lib-es/types/assets.d.ts +16 -0
- package/lib-es/types/assets.d.ts.map +1 -0
- package/lib-es/types/assets.js +2 -0
- package/lib-es/types/assets.js.map +1 -0
- package/lib-es/types/index.d.ts +22 -7
- package/lib-es/types/index.d.ts.map +1 -1
- package/package.json +16 -13
- package/src/__tests__/api/craftTransaction.unit.test.ts +243 -0
- package/src/__tests__/api/getBalance.unit.test.ts +44 -0
- package/src/__tests__/api/index.integ.test.ts +401 -0
- package/src/__tests__/api/index.test.ts +60 -477
- package/src/__tests__/bridge/broadcast.test.ts +2 -2
- package/src/__tests__/bridge/getFeesForTransaction.test.ts +146 -11
- package/src/__tests__/bridge/getTransactionStatus.test.ts +217 -38
- package/src/__tests__/bridge/logic.test.ts +728 -569
- package/src/__tests__/bridge/prepareTransaction.test.ts +2 -2
- package/src/__tests__/bridge/signOperation.test.ts +153 -15
- package/src/__tests__/bridge/synchronisation.test.ts +1265 -71
- package/src/__tests__/index.test.ts +1 -1
- package/src/__tests__/logic/buildTransaction.test.ts +150 -0
- package/src/__tests__/logic/calculateAmount.unit.test.ts +51 -0
- package/src/__tests__/logic/combine.unit.test.ts +65 -0
- package/src/__tests__/logic/compareAddress.unit.test.ts +27 -0
- package/src/__tests__/{bridge → logic}/createTransaction.test.ts +2 -2
- package/src/__tests__/logic/getCoinAndAmounts.unit.test.ts +195 -0
- package/src/__tests__/logic/getFunctionAddress.unit.test.ts +33 -0
- package/src/__tests__/logic/getResourceAddress.unit.test.ts +241 -0
- package/src/__tests__/logic/isTestnet.unit.test.ts +11 -0
- package/src/__tests__/logic/normalizeAddress.unit.test.ts +15 -0
- package/src/__tests__/logic/processRecipients.unit.test.ts +95 -0
- package/src/__tests__/network/client.test.ts +1257 -0
- package/src/api/index.ts +29 -224
- package/src/bridge/bridge.fixture.ts +91 -12
- package/src/bridge/broadcast.ts +7 -7
- package/src/bridge/estimateMaxSpendable.ts +4 -3
- package/src/bridge/getFeesForTransaction.ts +17 -11
- package/src/bridge/getTransactionStatus.ts +35 -13
- package/src/bridge/index.ts +2 -2
- package/src/bridge/logic.ts +58 -194
- package/src/bridge/prepareTransaction.ts +7 -4
- package/src/bridge/signOperation.ts +21 -5
- package/src/bridge/synchronisation.ts +171 -4
- package/src/config.ts +19 -0
- package/src/constants.ts +22 -2
- package/src/logic/buildTransaction.ts +70 -0
- package/src/logic/calculateAmount.ts +15 -0
- package/src/logic/combine.ts +51 -0
- package/src/logic/craftTransaction.ts +65 -0
- package/src/{bridge → logic}/createTransaction.ts +1 -1
- package/src/logic/getBalance.ts +15 -0
- package/src/logic/getCoinAndAmounts.ts +141 -0
- package/src/logic/getFunctionAddress.ts +9 -0
- package/src/logic/getResourceAddress.ts +24 -0
- package/src/logic/isTestnet.ts +5 -0
- package/src/logic/isWriteSetChangeWriteResource.ts +7 -0
- package/src/logic/normalizeAddress.ts +8 -0
- package/src/logic/normalizeTransactionOptions.ts +18 -0
- package/src/logic/processRecipients.ts +88 -0
- package/src/logic/transactionsToOperations.ts +106 -0
- package/src/network/client.ts +374 -0
- package/src/{api → network}/graphql/queries.ts +6 -6
- package/src/{api → network}/graphql/types.ts +9 -9
- package/src/network/index.ts +6 -14
- package/src/test/bot-specs.ts +63 -3
- package/src/test/bridgeDatasetTest.ts +46 -59
- package/src/test/speculos-deviceActions.ts +40 -4
- package/src/types/assets.ts +20 -0
- package/src/types/index.ts +20 -1
- package/lib/__tests__/bridge/buildTransaction.test.d.ts.map +0 -1
- package/lib/__tests__/bridge/buildTransaction.test.js +0 -53
- package/lib/__tests__/bridge/buildTransaction.test.js.map +0 -1
- package/lib/__tests__/bridge/createTransaction.test.d.ts.map +0 -1
- package/lib/__tests__/bridge/createTransaction.test.js.map +0 -1
- package/lib/api/graphql/queries.d.ts.map +0 -1
- package/lib/api/graphql/queries.js.map +0 -1
- package/lib/api/graphql/types.d.ts.map +0 -1
- package/lib/bridge/buildTransaction.d.ts +0 -7
- package/lib/bridge/buildTransaction.d.ts.map +0 -1
- package/lib/bridge/buildTransaction.js +0 -19
- package/lib/bridge/buildTransaction.js.map +0 -1
- package/lib/bridge/createTransaction.d.ts.map +0 -1
- package/lib/bridge/createTransaction.js.map +0 -1
- package/lib-es/__tests__/bridge/buildTransaction.test.d.ts.map +0 -1
- package/lib-es/__tests__/bridge/buildTransaction.test.js +0 -48
- package/lib-es/__tests__/bridge/buildTransaction.test.js.map +0 -1
- package/lib-es/__tests__/bridge/createTransaction.test.d.ts.map +0 -1
- package/lib-es/__tests__/bridge/createTransaction.test.js.map +0 -1
- package/lib-es/api/graphql/queries.d.ts.map +0 -1
- package/lib-es/api/graphql/queries.js.map +0 -1
- package/lib-es/api/graphql/types.d.ts.map +0 -1
- package/lib-es/bridge/buildTransaction.d.ts +0 -7
- package/lib-es/bridge/buildTransaction.d.ts.map +0 -1
- package/lib-es/bridge/buildTransaction.js +0 -17
- package/lib-es/bridge/buildTransaction.js.map +0 -1
- package/lib-es/bridge/createTransaction.d.ts.map +0 -1
- package/lib-es/bridge/createTransaction.js.map +0 -1
- package/src/__tests__/bridge/buildTransaction.test.ts +0 -61
- package/src/bridge/buildTransaction.ts +0 -29
- /package/lib/__tests__/{bridge → logic}/buildTransaction.test.d.ts +0 -0
- /package/lib/__tests__/{bridge → logic}/createTransaction.test.d.ts +0 -0
- /package/lib/{bridge → logic}/createTransaction.d.ts +0 -0
- /package/lib/{api → network}/graphql/queries.d.ts +0 -0
- /package/lib/{api → network}/graphql/types.js +0 -0
- /package/lib-es/__tests__/{bridge → logic}/buildTransaction.test.d.ts +0 -0
- /package/lib-es/__tests__/{bridge → logic}/createTransaction.test.d.ts +0 -0
- /package/lib-es/{bridge → logic}/createTransaction.d.ts +0 -0
- /package/lib-es/{api → network}/graphql/queries.d.ts +0 -0
- /package/lib-es/{api → network}/graphql/types.js +0 -0
|
@@ -6,10 +6,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
exports.getAddress = void 0;
|
|
7
7
|
const rxjs_1 = require("rxjs");
|
|
8
8
|
const operation_1 = require("@ledgerhq/coin-framework/operation");
|
|
9
|
-
const buildTransaction_1 = __importDefault(require("./buildTransaction"));
|
|
10
9
|
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
11
|
-
const api_1 = require("../api");
|
|
12
10
|
const network_1 = require("../network");
|
|
11
|
+
const network_2 = require("../network");
|
|
12
|
+
const helpers_1 = require("@ledgerhq/coin-framework/account/helpers");
|
|
13
|
+
const buildTransaction_1 = __importDefault(require("../logic/buildTransaction"));
|
|
13
14
|
const getAddress = (a) => ({
|
|
14
15
|
address: a.freshAddress,
|
|
15
16
|
derivationPath: a.freshAddressPath,
|
|
@@ -18,9 +19,9 @@ exports.getAddress = getAddress;
|
|
|
18
19
|
const buildSignOperation = (signerContext) => ({ account, transaction, deviceId }) => new rxjs_1.Observable(o => {
|
|
19
20
|
async function main() {
|
|
20
21
|
o.next({ type: "device-signature-requested" });
|
|
21
|
-
const aptosClient = new
|
|
22
|
+
const aptosClient = new network_1.AptosAPI(account.currency.id);
|
|
22
23
|
const rawTx = await (0, buildTransaction_1.default)(account, transaction, aptosClient);
|
|
23
|
-
const txBytes = await (0,
|
|
24
|
+
const txBytes = await (0, network_2.signTransaction)(signerContext, account, deviceId, rawTx);
|
|
24
25
|
const signature = Buffer.from(txBytes).toString("hex");
|
|
25
26
|
o.next({ type: "device-signature-granted" });
|
|
26
27
|
const accountId = account.id;
|
|
@@ -34,14 +35,13 @@ const buildSignOperation = (signerContext) => ({ account, transaction, deviceId
|
|
|
34
35
|
senders.push(account.freshAddress);
|
|
35
36
|
recipients.push(transaction.recipient);
|
|
36
37
|
}
|
|
38
|
+
const subAccount = !!transaction.subAccountId && (0, helpers_1.findSubAccountById)(account, transaction.subAccountId);
|
|
37
39
|
// build optimistic operation
|
|
38
40
|
const operation = {
|
|
39
41
|
id: (0, operation_1.encodeOperationId)(accountId, hash, type),
|
|
40
42
|
hash,
|
|
41
43
|
type,
|
|
42
|
-
value: transaction.
|
|
43
|
-
? account.balance.minus(fee)
|
|
44
|
-
: transaction.amount.plus(fee),
|
|
44
|
+
value: subAccount ? fee : transaction.amount.plus(fee),
|
|
45
45
|
fee,
|
|
46
46
|
extra,
|
|
47
47
|
blockHash: null,
|
|
@@ -51,6 +51,20 @@ const buildSignOperation = (signerContext) => ({ account, transaction, deviceId
|
|
|
51
51
|
accountId,
|
|
52
52
|
date: new Date(),
|
|
53
53
|
transactionSequenceNumber: Number(rawTx.sequence_number),
|
|
54
|
+
subOperations: subAccount
|
|
55
|
+
? [
|
|
56
|
+
{
|
|
57
|
+
id: (0, operation_1.encodeOperationId)(subAccount.id, "", "OUT"),
|
|
58
|
+
type: "OUT",
|
|
59
|
+
accountId: transaction.subAccountId,
|
|
60
|
+
senders: [account.freshAddress],
|
|
61
|
+
recipients: [transaction.recipient],
|
|
62
|
+
value: transaction.amount,
|
|
63
|
+
fee,
|
|
64
|
+
date: new Date(),
|
|
65
|
+
},
|
|
66
|
+
]
|
|
67
|
+
: [],
|
|
54
68
|
};
|
|
55
69
|
o.next({
|
|
56
70
|
type: "signed",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"signOperation.js","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":";;;;;;AACA,+BAAkC;AAClC,kEAAuE;AACvE,
|
|
1
|
+
{"version":3,"file":"signOperation.js","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,3 +1,18 @@
|
|
|
1
1
|
import type { GetAccountShape } from "@ledgerhq/coin-framework/bridge/jsHelpers";
|
|
2
|
+
import { Account, Operation, TokenAccount } from "@ledgerhq/types-live";
|
|
3
|
+
import { CryptoCurrency, TokenCurrency } from "@ledgerhq/types-cryptoassets";
|
|
4
|
+
import { AccountShapeInfo } from "@ledgerhq/coin-framework/bridge/jsHelpers";
|
|
5
|
+
/**
|
|
6
|
+
* In charge of smartly merging sub accounts while maintaining references as much as possible
|
|
7
|
+
*/
|
|
8
|
+
export declare const mergeSubAccounts: (initialAccount: Account | undefined, newSubAccounts: TokenAccount[]) => Array<TokenAccount>;
|
|
9
|
+
/**
|
|
10
|
+
* Fetch the balance for a token and creates a TokenAccount based on this and the provided operations
|
|
11
|
+
*/
|
|
12
|
+
export declare const getSubAccountShape: (currency: CryptoCurrency, address: string, parentId: string, token: TokenCurrency, operations: Operation[]) => Promise<TokenAccount>;
|
|
13
|
+
/**
|
|
14
|
+
* Getting all token related operations in order to provide TokenAccounts
|
|
15
|
+
*/
|
|
16
|
+
export declare const getSubAccounts: (infos: AccountShapeInfo<Account>, address: string, accountId: string, lastTokenOperations: Operation[]) => Promise<TokenAccount[]>;
|
|
2
17
|
export declare const getAccountShape: GetAccountShape;
|
|
3
18
|
//# sourceMappingURL=synchronisation.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"synchronisation.d.ts","sourceRoot":"","sources":["../../src/bridge/synchronisation.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"synchronisation.d.ts","sourceRoot":"","sources":["../../src/bridge/synchronisation.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAC;AAKjF,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACxE,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAM7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,2CAA2C,CAAC;AAY7E;;GAEG;AACH,eAAO,MAAM,gBAAgB,mBACX,OAAO,GAAG,SAAS,kBACnB,YAAY,EAAE,KAC7B,MAAM,YAAY,CAwDpB,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,kBAAkB,aACnB,cAAc,WACf,MAAM,YACL,MAAM,SACT,aAAa,cACR,SAAS,EAAE,KACtB,QAAQ,YAAY,CAsBtB,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,cAAc,UAClB,iBAAiB,OAAO,CAAC,WACvB,MAAM,aACJ,MAAM,uBACI,SAAS,EAAE,KAC/B,QAAQ,YAAY,EAAE,CAyBxB,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,eA0D7B,CAAC"}
|
|
@@ -1,10 +1,123 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getAccountShape = void 0;
|
|
3
|
+
exports.getAccountShape = exports.getSubAccounts = exports.getSubAccountShape = exports.mergeSubAccounts = void 0;
|
|
4
|
+
const index_1 = require("@ledgerhq/coin-framework/serialization/index");
|
|
4
5
|
const account_1 = require("@ledgerhq/coin-framework/account");
|
|
5
6
|
const jsHelpers_1 = require("@ledgerhq/coin-framework/bridge/jsHelpers");
|
|
6
|
-
const
|
|
7
|
+
const network_1 = require("../network");
|
|
7
8
|
const logic_1 = require("./logic");
|
|
9
|
+
const index_2 = require("@ledgerhq/coin-framework/account/index");
|
|
10
|
+
/**
|
|
11
|
+
* List of properties of a sub account that can be updated when 2 "identical" accounts are found
|
|
12
|
+
*/
|
|
13
|
+
const updatableSubAccountProperties = [
|
|
14
|
+
{ name: "balance", isOps: false },
|
|
15
|
+
{ name: "spendableBalance", isOps: false },
|
|
16
|
+
{ name: "balanceHistoryCache", isOps: false },
|
|
17
|
+
{ name: "operations", isOps: true },
|
|
18
|
+
{ name: "pendingOperations", isOps: true },
|
|
19
|
+
];
|
|
20
|
+
/**
|
|
21
|
+
* In charge of smartly merging sub accounts while maintaining references as much as possible
|
|
22
|
+
*/
|
|
23
|
+
const mergeSubAccounts = (initialAccount, newSubAccounts) => {
|
|
24
|
+
const oldSubAccounts = initialAccount?.subAccounts;
|
|
25
|
+
if (!oldSubAccounts) {
|
|
26
|
+
return newSubAccounts;
|
|
27
|
+
}
|
|
28
|
+
// Creating a map of already existing sub accounts by id
|
|
29
|
+
const oldSubAccountsById = {};
|
|
30
|
+
for (const oldSubAccount of oldSubAccounts) {
|
|
31
|
+
oldSubAccountsById[oldSubAccount.id] = oldSubAccount;
|
|
32
|
+
}
|
|
33
|
+
// Looping on new sub accounts to compare them with already existing ones
|
|
34
|
+
// Already existing will be updated if necessary (see `updatableSubAccountProperties`)
|
|
35
|
+
// Fresh new sub accounts will be added/pushed after already existing
|
|
36
|
+
const newSubAccountsToAdd = [];
|
|
37
|
+
for (const newSubAccount of newSubAccounts) {
|
|
38
|
+
const duplicatedAccount = oldSubAccountsById[newSubAccount.id];
|
|
39
|
+
// If this sub account was not already in the initialAccount
|
|
40
|
+
if (!duplicatedAccount) {
|
|
41
|
+
// We'll add it later
|
|
42
|
+
newSubAccountsToAdd.push(newSubAccount);
|
|
43
|
+
continue;
|
|
44
|
+
}
|
|
45
|
+
const updates = {};
|
|
46
|
+
for (const { name, isOps } of updatableSubAccountProperties) {
|
|
47
|
+
if (!isOps) {
|
|
48
|
+
if (newSubAccount[name] !==
|
|
49
|
+
duplicatedAccount[name]) {
|
|
50
|
+
updates[name] = newSubAccount[name];
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
updates[name] =
|
|
55
|
+
(0, jsHelpers_1.mergeOps)(duplicatedAccount[name], newSubAccount[name]) || [];
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
// Updating the operationsCount in case the mergeOps changed it
|
|
59
|
+
updates.operationsCount =
|
|
60
|
+
updates.operations?.length || duplicatedAccount?.operations?.length || 0;
|
|
61
|
+
// Modifying the Map with the updated sub account with a new ref
|
|
62
|
+
oldSubAccountsById[newSubAccount.id] = {
|
|
63
|
+
...duplicatedAccount,
|
|
64
|
+
...updates,
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
const updatedSubAccounts = Object.values(oldSubAccountsById);
|
|
68
|
+
return [...updatedSubAccounts, ...newSubAccountsToAdd];
|
|
69
|
+
};
|
|
70
|
+
exports.mergeSubAccounts = mergeSubAccounts;
|
|
71
|
+
/**
|
|
72
|
+
* Fetch the balance for a token and creates a TokenAccount based on this and the provided operations
|
|
73
|
+
*/
|
|
74
|
+
const getSubAccountShape = async (currency, address, parentId, token, operations) => {
|
|
75
|
+
const aptosClient = new network_1.AptosAPI(currency.id);
|
|
76
|
+
const tokenAccountId = (0, index_2.encodeTokenAccountId)(parentId, token);
|
|
77
|
+
const balance = await aptosClient.getBalance(address, token);
|
|
78
|
+
const firstOperation = operations
|
|
79
|
+
.sort((a, b) => b.date.getTime() - a.date.getTime())
|
|
80
|
+
.at(operations.length - 1);
|
|
81
|
+
return {
|
|
82
|
+
type: "TokenAccount",
|
|
83
|
+
id: tokenAccountId,
|
|
84
|
+
parentId,
|
|
85
|
+
token,
|
|
86
|
+
balance,
|
|
87
|
+
spendableBalance: balance,
|
|
88
|
+
creationDate: firstOperation?.date || new Date(0),
|
|
89
|
+
operations,
|
|
90
|
+
operationsCount: operations.length,
|
|
91
|
+
pendingOperations: [],
|
|
92
|
+
balanceHistoryCache: index_2.emptyHistoryCache,
|
|
93
|
+
swapHistory: [],
|
|
94
|
+
};
|
|
95
|
+
};
|
|
96
|
+
exports.getSubAccountShape = getSubAccountShape;
|
|
97
|
+
/**
|
|
98
|
+
* Getting all token related operations in order to provide TokenAccounts
|
|
99
|
+
*/
|
|
100
|
+
const getSubAccounts = async (infos, address, accountId, lastTokenOperations) => {
|
|
101
|
+
const { currency } = infos;
|
|
102
|
+
// Creating a Map of Operations by TokenCurrencies in order to know which TokenAccounts should be synced as well
|
|
103
|
+
const operationsByToken = lastTokenOperations.reduce((acc, operation) => {
|
|
104
|
+
const { token } = (0, index_2.decodeTokenAccountId)(operation.accountId);
|
|
105
|
+
if (!token)
|
|
106
|
+
return acc; // TODO: do we need to check blacklistedTokenIds
|
|
107
|
+
if (!acc.has(token)) {
|
|
108
|
+
acc.set(token, []);
|
|
109
|
+
}
|
|
110
|
+
acc.get(token)?.push(operation);
|
|
111
|
+
return acc;
|
|
112
|
+
}, new Map());
|
|
113
|
+
// Fetching all TokenAccounts possible and providing already filtered operations
|
|
114
|
+
const subAccountsPromises = [];
|
|
115
|
+
for (const [token, ops] of operationsByToken.entries()) {
|
|
116
|
+
subAccountsPromises.push((0, exports.getSubAccountShape)(currency, address, accountId, token, ops));
|
|
117
|
+
}
|
|
118
|
+
return Promise.all(subAccountsPromises);
|
|
119
|
+
};
|
|
120
|
+
exports.getSubAccounts = getSubAccounts;
|
|
8
121
|
const getAccountShape = async (info) => {
|
|
9
122
|
const { address, initialAccount, currency, derivationMode, rest } = info;
|
|
10
123
|
const publicKey = rest?.publicKey || (initialAccount && (0, account_1.decodeAccountId)(initialAccount.id).xpubOrAddress);
|
|
@@ -21,11 +134,20 @@ const getAccountShape = async (info) => {
|
|
|
21
134
|
// "xpub" field is used because this field exists in ledger operation type
|
|
22
135
|
const xpub = initialAccount?.xpub || publicKey || "";
|
|
23
136
|
const oldOperations = initialAccount?.operations || [];
|
|
24
|
-
const
|
|
25
|
-
const
|
|
26
|
-
const
|
|
27
|
-
const newOperations = (0, logic_1.txsToOps)(info, accountId, transactions);
|
|
137
|
+
const aptosClient = new network_1.AptosAPI(currency.id);
|
|
138
|
+
const { balance, transactions, blockHeight } = await aptosClient.getAccountInfo(address);
|
|
139
|
+
const [newOperations, tokenOperations] = (0, logic_1.txsToOps)(info, accountId, transactions);
|
|
28
140
|
const operations = (0, jsHelpers_1.mergeOps)(oldOperations, newOperations);
|
|
141
|
+
const newSubAccounts = await (0, exports.getSubAccounts)(info, address, accountId, tokenOperations);
|
|
142
|
+
const shouldSyncFromScratch = initialAccount === undefined;
|
|
143
|
+
const subAccounts = shouldSyncFromScratch
|
|
144
|
+
? newSubAccounts
|
|
145
|
+
: (0, exports.mergeSubAccounts)(initialAccount, newSubAccounts);
|
|
146
|
+
operations.forEach(op => {
|
|
147
|
+
const subOperations = (0, index_1.inferSubOperations)(op.hash, subAccounts);
|
|
148
|
+
op.subOperations =
|
|
149
|
+
subOperations.length === 1 ? subOperations : subOperations.filter(op => !!op.blockHash);
|
|
150
|
+
});
|
|
29
151
|
const shape = {
|
|
30
152
|
type: "Account",
|
|
31
153
|
id: accountId,
|
|
@@ -36,6 +158,7 @@ const getAccountShape = async (info) => {
|
|
|
36
158
|
operationsCount: operations.length,
|
|
37
159
|
blockHeight,
|
|
38
160
|
lastSyncDate: new Date(),
|
|
161
|
+
subAccounts,
|
|
39
162
|
};
|
|
40
163
|
return shape;
|
|
41
164
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"synchronisation.js","sourceRoot":"","sources":["../../src/bridge/synchronisation.ts"],"names":[],"mappings":";;;AAAA,8DAAoF;AAEpF,yEAAqE;AACrE,
|
|
1
|
+
{"version":3,"file":"synchronisation.js","sourceRoot":"","sources":["../../src/bridge/synchronisation.ts"],"names":[],"mappings":"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"}
|
package/lib/config.d.ts
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { AptosSettings } from "@aptos-labs/ts-sdk";
|
|
2
|
+
import { type CoinConfig, type CurrencyConfig } from "@ledgerhq/coin-framework/config";
|
|
3
|
+
import type { CryptoCurrency } from "@ledgerhq/types-cryptoassets";
|
|
4
|
+
export type AptosConfig = {
|
|
5
|
+
aptosSettings: AptosSettings;
|
|
6
|
+
};
|
|
7
|
+
export type AptosCoinConfig = CurrencyConfig & AptosConfig;
|
|
8
|
+
declare const coinConfig: {
|
|
9
|
+
setCoinConfig: (config: CoinConfig<AptosCoinConfig>) => void;
|
|
10
|
+
getCoinConfig: (currency?: CryptoCurrency) => AptosCoinConfig;
|
|
11
|
+
};
|
|
12
|
+
export default coinConfig;
|
|
13
|
+
//# sourceMappingURL=config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAwB,EACtB,KAAK,UAAU,EACf,KAAK,cAAc,EACpB,MAAM,iCAAiC,CAAC;AACzC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAEnE,MAAM,MAAM,WAAW,GAAG;IACxB,aAAa,EAAE,aAAa,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG,cAAc,GAAG,WAAW,CAAC;AAE3D,QAAA,MAAM,UAAU,EAAE;IAChB,aAAa,EAAE,CAAC,MAAM,EAAE,UAAU,CAAC,eAAe,CAAC,KAAK,IAAI,CAAC;IAC7D,aAAa,EAAE,CAAC,QAAQ,CAAC,EAAE,cAAc,KAAK,eAAe,CAAC;CAC1B,CAAC;AAEvC,eAAe,UAAU,CAAC"}
|
package/lib/config.js
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
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 config_1 = __importDefault(require("@ledgerhq/coin-framework/config"));
|
|
7
|
+
const coinConfig = (0, config_1.default)();
|
|
8
|
+
exports.default = coinConfig;
|
|
9
|
+
//# sourceMappingURL=config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":";;;;;AACA,6EAGyC;AASzC,MAAM,UAAU,GAGZ,IAAA,gBAAe,GAAmB,CAAC;AAEvC,kBAAe,UAAU,CAAC"}
|
package/lib/constants.d.ts
CHANGED
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
import { MoveStructId } from "@aptos-labs/ts-sdk";
|
|
1
|
+
import type { MoveStructId } from "@aptos-labs/ts-sdk";
|
|
2
|
+
import BigNumber from "bignumber.js";
|
|
3
|
+
export declare const ESTIMATE_GAS_MUL: BigNumber;
|
|
2
4
|
export declare const LOAD_LIMIT = 10;
|
|
3
5
|
export declare enum TX_STATUS {
|
|
4
6
|
PENDING = "pending",
|
|
@@ -6,14 +8,23 @@ export declare enum TX_STATUS {
|
|
|
6
8
|
SUCCESS = "success"
|
|
7
9
|
}
|
|
8
10
|
export declare const WRITE_RESOURCE = "write_resource";
|
|
9
|
-
export declare const
|
|
11
|
+
export declare const COIN_TRANSFER_TYPES: MoveStructId[];
|
|
12
|
+
export declare const FA_TRANSFER_TYPES: MoveStructId[];
|
|
10
13
|
export declare const BATCH_TRANSFER_TYPES: MoveStructId[];
|
|
11
14
|
export declare const DELEGATION_POOL_TYPES: MoveStructId[];
|
|
12
15
|
export declare const APTOS_ASSET_ID: MoveStructId;
|
|
13
16
|
export declare const APTOS_COIN_CHANGE: MoveStructId;
|
|
17
|
+
export declare const APTOS_FUNGIBLE_STORE: MoveStructId;
|
|
18
|
+
export declare const APTOS_OBJECT_CORE: MoveStructId;
|
|
14
19
|
export declare enum DIRECTION {
|
|
15
20
|
IN = "IN",
|
|
16
21
|
OUT = "OUT",
|
|
17
22
|
UNKNOWN = "UNKNOWN"
|
|
18
23
|
}
|
|
24
|
+
export declare enum TOKEN_TYPE {
|
|
25
|
+
COIN = "coin",
|
|
26
|
+
FUNGIBLE_ASSET = "fungible_asset"
|
|
27
|
+
}
|
|
28
|
+
export declare const DEFAULT_GAS: BigNumber;
|
|
29
|
+
export declare const DEFAULT_GAS_PRICE: BigNumber;
|
|
19
30
|
//# sourceMappingURL=constants.d.ts.map
|
package/lib/constants.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,SAAS,MAAM,cAAc,CAAC;AAErC,eAAO,MAAM,gBAAgB,WAAqB,CAAC;AAEnD,eAAO,MAAM,UAAU,KAAK,CAAC;AAE7B,oBAAY,SAAS;IACnB,OAAO,YAAY;IACnB,IAAI,SAAS;IACb,OAAO,YAAY;CACpB;AAED,eAAO,MAAM,cAAc,mBAAmB,CAAC;AAE/C,eAAO,MAAM,mBAAmB,EAAE,YAAY,EAI7C,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,YAAY,EAA8C,CAAC;AAE3F,eAAO,MAAM,oBAAoB,EAAE,YAAY,EAG9C,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,YAAY,EAG/C,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,YAA2C,CAAC;AAEzE,eAAO,MAAM,iBAAiB,EAAE,YAAwD,CAAC;AAEzF,eAAO,MAAM,oBAAoB,EAAE,YAAmD,CAAC;AAEvF,eAAO,MAAM,iBAAiB,EAAE,YAAwC,CAAC;AAEzE,oBAAY,SAAS;IACnB,EAAE,OAAO;IACT,GAAG,QAAQ;IACX,OAAO,YAAY;CACpB;AAED,oBAAY,UAAU;IACpB,IAAI,SAAS;IACb,cAAc,mBAAmB;CAClC;AAED,eAAO,MAAM,WAAW,WAAqB,CAAC;AAC9C,eAAO,MAAM,iBAAiB,WAAqB,CAAC"}
|
package/lib/constants.js
CHANGED
|
@@ -1,6 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
2
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.DIRECTION = exports.APTOS_COIN_CHANGE = exports.APTOS_ASSET_ID = exports.DELEGATION_POOL_TYPES = exports.BATCH_TRANSFER_TYPES = exports.
|
|
6
|
+
exports.DEFAULT_GAS_PRICE = exports.DEFAULT_GAS = exports.TOKEN_TYPE = exports.DIRECTION = exports.APTOS_OBJECT_CORE = exports.APTOS_FUNGIBLE_STORE = exports.APTOS_COIN_CHANGE = exports.APTOS_ASSET_ID = exports.DELEGATION_POOL_TYPES = exports.BATCH_TRANSFER_TYPES = exports.FA_TRANSFER_TYPES = exports.COIN_TRANSFER_TYPES = exports.WRITE_RESOURCE = exports.TX_STATUS = exports.LOAD_LIMIT = exports.ESTIMATE_GAS_MUL = void 0;
|
|
7
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
8
|
+
exports.ESTIMATE_GAS_MUL = new bignumber_js_1.default(1.0); // define buffer for gas estimation change here, if needed
|
|
4
9
|
exports.LOAD_LIMIT = 10;
|
|
5
10
|
var TX_STATUS;
|
|
6
11
|
(function (TX_STATUS) {
|
|
@@ -9,11 +14,12 @@ var TX_STATUS;
|
|
|
9
14
|
TX_STATUS["SUCCESS"] = "success";
|
|
10
15
|
})(TX_STATUS || (exports.TX_STATUS = TX_STATUS = {}));
|
|
11
16
|
exports.WRITE_RESOURCE = "write_resource";
|
|
12
|
-
exports.
|
|
17
|
+
exports.COIN_TRANSFER_TYPES = [
|
|
13
18
|
"0x1::aptos_account::transfer",
|
|
14
19
|
"0x1::aptos_account::transfer_coins",
|
|
15
20
|
"0x1::coin::transfer",
|
|
16
21
|
];
|
|
22
|
+
exports.FA_TRANSFER_TYPES = ["0x1::primary_fungible_store::transfer"];
|
|
17
23
|
exports.BATCH_TRANSFER_TYPES = [
|
|
18
24
|
"0x1::aptos_account::batch_transfer",
|
|
19
25
|
"0x1::aptos_account::batch_transfer_coins",
|
|
@@ -24,10 +30,19 @@ exports.DELEGATION_POOL_TYPES = [
|
|
|
24
30
|
];
|
|
25
31
|
exports.APTOS_ASSET_ID = "0x1::aptos_coin::AptosCoin";
|
|
26
32
|
exports.APTOS_COIN_CHANGE = `0x1::coin::CoinStore<${exports.APTOS_ASSET_ID}>`;
|
|
33
|
+
exports.APTOS_FUNGIBLE_STORE = "0x1::fungible_asset::FungibleStore";
|
|
34
|
+
exports.APTOS_OBJECT_CORE = "0x1::object::ObjectCore";
|
|
27
35
|
var DIRECTION;
|
|
28
36
|
(function (DIRECTION) {
|
|
29
37
|
DIRECTION["IN"] = "IN";
|
|
30
38
|
DIRECTION["OUT"] = "OUT";
|
|
31
39
|
DIRECTION["UNKNOWN"] = "UNKNOWN";
|
|
32
40
|
})(DIRECTION || (exports.DIRECTION = DIRECTION = {}));
|
|
41
|
+
var TOKEN_TYPE;
|
|
42
|
+
(function (TOKEN_TYPE) {
|
|
43
|
+
TOKEN_TYPE["COIN"] = "coin";
|
|
44
|
+
TOKEN_TYPE["FUNGIBLE_ASSET"] = "fungible_asset";
|
|
45
|
+
})(TOKEN_TYPE || (exports.TOKEN_TYPE = TOKEN_TYPE = {}));
|
|
46
|
+
exports.DEFAULT_GAS = new bignumber_js_1.default(200);
|
|
47
|
+
exports.DEFAULT_GAS_PRICE = new bignumber_js_1.default(100);
|
|
33
48
|
//# sourceMappingURL=constants.js.map
|
package/lib/constants.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":";;;;;;AACA,gEAAqC;AAExB,QAAA,gBAAgB,GAAG,IAAI,sBAAS,CAAC,GAAG,CAAC,CAAC,CAAC,0DAA0D;AAEjG,QAAA,UAAU,GAAG,EAAE,CAAC;AAE7B,IAAY,SAIX;AAJD,WAAY,SAAS;IACnB,gCAAmB,CAAA;IACnB,0BAAa,CAAA;IACb,gCAAmB,CAAA;AACrB,CAAC,EAJW,SAAS,yBAAT,SAAS,QAIpB;AAEY,QAAA,cAAc,GAAG,gBAAgB,CAAC;AAElC,QAAA,mBAAmB,GAAmB;IACjD,8BAA8B;IAC9B,oCAAoC;IACpC,qBAAqB;CACtB,CAAC;AAEW,QAAA,iBAAiB,GAAmB,CAAC,uCAAuC,CAAC,CAAC;AAE9E,QAAA,oBAAoB,GAAmB;IAClD,oCAAoC;IACpC,0CAA0C;CAC3C,CAAC;AAEW,QAAA,qBAAqB,GAAmB;IACnD,iCAAiC;IACjC,gCAAgC;CACjC,CAAC;AAEW,QAAA,cAAc,GAAiB,4BAA4B,CAAC;AAE5D,QAAA,iBAAiB,GAAiB,wBAAwB,sBAAc,GAAG,CAAC;AAE5E,QAAA,oBAAoB,GAAiB,oCAAoC,CAAC;AAE1E,QAAA,iBAAiB,GAAiB,yBAAyB,CAAC;AAEzE,IAAY,SAIX;AAJD,WAAY,SAAS;IACnB,sBAAS,CAAA;IACT,wBAAW,CAAA;IACX,gCAAmB,CAAA;AACrB,CAAC,EAJW,SAAS,yBAAT,SAAS,QAIpB;AAED,IAAY,UAGX;AAHD,WAAY,UAAU;IACpB,2BAAa,CAAA;IACb,+CAAiC,CAAA;AACnC,CAAC,EAHW,UAAU,0BAAV,UAAU,QAGrB;AAEY,QAAA,WAAW,GAAG,IAAI,sBAAS,CAAC,GAAG,CAAC,CAAC;AACjC,QAAA,iBAAiB,GAAG,IAAI,sBAAS,CAAC,GAAG,CAAC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { RawTransaction } from "@aptos-labs/ts-sdk";
|
|
2
|
+
import type { Account } from "@ledgerhq/types-live";
|
|
3
|
+
import { TOKEN_TYPE } from "../constants";
|
|
4
|
+
import type { AptosAPI } from "../network";
|
|
5
|
+
import type { Transaction } from "../types";
|
|
6
|
+
declare const buildTransaction: (account: Account, transaction: Transaction, aptosClient: AptosAPI, contractAddress?: string, tokenType?: TOKEN_TYPE) => Promise<RawTransaction>;
|
|
7
|
+
export declare const isTokenType: (value: string) => boolean;
|
|
8
|
+
export default buildTransaction;
|
|
9
|
+
//# sourceMappingURL=buildTransaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildTransaction.d.ts","sourceRoot":"","sources":["../../src/logic/buildTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAA0B,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACjF,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAEpD,OAAO,EAAkB,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAE3C,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAG5C,QAAA,MAAM,gBAAgB,YACX,OAAO,eACH,WAAW,eACX,QAAQ,oBACH,MAAM,cACZ,UAAU,KACrB,QAAQ,cAAc,CAkBxB,CAAC;AAgCF,eAAO,MAAM,WAAW,UAAW,MAAM,KAAG,OAE3C,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isTokenType = void 0;
|
|
4
|
+
const index_1 = require("@ledgerhq/coin-framework/account/index");
|
|
5
|
+
const constants_1 = require("../constants");
|
|
6
|
+
const normalizeTransactionOptions_1 = require("./normalizeTransactionOptions");
|
|
7
|
+
const buildTransaction = async (account, transaction, aptosClient, contractAddress, tokenType) => {
|
|
8
|
+
const subAccount = (0, index_1.findSubAccountById)(account, transaction.subAccountId ?? "");
|
|
9
|
+
const payloadContracAddress = subAccount ? subAccount.token.contractAddress : contractAddress;
|
|
10
|
+
const payloadTokenType = subAccount?.token?.tokenType ?? tokenType;
|
|
11
|
+
const txPayload = getPayload({
|
|
12
|
+
amount: transaction.amount,
|
|
13
|
+
recipient: transaction.recipient,
|
|
14
|
+
contractAddress: payloadContracAddress,
|
|
15
|
+
tokenType: payloadTokenType,
|
|
16
|
+
});
|
|
17
|
+
const txOptions = (0, normalizeTransactionOptions_1.normalizeTransactionOptions)(transaction.options);
|
|
18
|
+
const tx = await aptosClient.generateTransaction(account.freshAddress, txPayload, txOptions);
|
|
19
|
+
return tx;
|
|
20
|
+
};
|
|
21
|
+
const getPayload = (args) => {
|
|
22
|
+
if (args.tokenType !== undefined && !(0, exports.isTokenType)(args.tokenType)) {
|
|
23
|
+
throw new Error(`Token type ${args.tokenType} not supported`);
|
|
24
|
+
}
|
|
25
|
+
if (args.tokenType === constants_1.TOKEN_TYPE.FUNGIBLE_ASSET) {
|
|
26
|
+
return {
|
|
27
|
+
function: "0x1::primary_fungible_store::transfer",
|
|
28
|
+
typeArguments: ["0x1::fungible_asset::Metadata"],
|
|
29
|
+
functionArguments: [args.contractAddress, args.recipient, args.amount.toString()],
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
let address = args.contractAddress ?? "";
|
|
33
|
+
if (address === "") {
|
|
34
|
+
address = constants_1.APTOS_ASSET_ID;
|
|
35
|
+
}
|
|
36
|
+
return {
|
|
37
|
+
function: "0x1::aptos_account::transfer_coins",
|
|
38
|
+
typeArguments: [address],
|
|
39
|
+
functionArguments: [args.recipient, args.amount.toString()],
|
|
40
|
+
};
|
|
41
|
+
};
|
|
42
|
+
const isTokenType = (value) => {
|
|
43
|
+
return Object.values(constants_1.TOKEN_TYPE).includes(value);
|
|
44
|
+
};
|
|
45
|
+
exports.isTokenType = isTokenType;
|
|
46
|
+
exports.default = buildTransaction;
|
|
47
|
+
//# sourceMappingURL=buildTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildTransaction.js","sourceRoot":"","sources":["../../src/logic/buildTransaction.ts"],"names":[],"mappings":";;;AAEA,kEAA4E;AAC5E,4CAA0D;AAE1D,+EAA4E;AAI5E,MAAM,gBAAgB,GAAG,KAAK,EAC5B,OAAgB,EAChB,WAAwB,EACxB,WAAqB,EACrB,eAAwB,EACxB,SAAsB,EACG,EAAE;IAC3B,MAAM,UAAU,GAAG,IAAA,0BAAkB,EAAC,OAAO,EAAE,WAAW,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC;IAE/E,MAAM,qBAAqB,GAAG,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC;IAC9F,MAAM,gBAAgB,GAAI,UAAU,EAAE,KAAK,EAAE,SAAwB,IAAI,SAAS,CAAC;IAEnF,MAAM,SAAS,GAAG,UAAU,CAAC;QAC3B,MAAM,EAAE,WAAW,CAAC,MAAM;QAC1B,SAAS,EAAE,WAAW,CAAC,SAAS;QAChC,eAAe,EAAE,qBAAqB;QACtC,SAAS,EAAE,gBAAgB;KAC5B,CAAC,CAAC;IAEH,MAAM,SAAS,GAAG,IAAA,yDAA2B,EAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IAEnE,MAAM,EAAE,GAAG,MAAM,WAAW,CAAC,mBAAmB,CAAC,OAAO,CAAC,YAAY,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;IAE7F,OAAO,EAAE,CAAC;AACZ,CAAC,CAAC;AAEF,MAAM,UAAU,GAAG,CAAC,IAKnB,EAA0B,EAAE;IAC3B,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,IAAI,CAAC,IAAA,mBAAW,EAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;QACjE,MAAM,IAAI,KAAK,CAAC,cAAc,IAAI,CAAC,SAAS,gBAAgB,CAAC,CAAC;IAChE,CAAC;IAED,IAAI,IAAI,CAAC,SAAS,KAAK,sBAAU,CAAC,cAAc,EAAE,CAAC;QACjD,OAAO;YACL,QAAQ,EAAE,uCAAuC;YACjD,aAAa,EAAE,CAAC,+BAA+B,CAAC;YAChD,iBAAiB,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;SAClF,CAAC;IACJ,CAAC;IAED,IAAI,OAAO,GAAG,IAAI,CAAC,eAAe,IAAI,EAAE,CAAC;IACzC,IAAI,OAAO,KAAK,EAAE,EAAE,CAAC;QACnB,OAAO,GAAG,0BAAc,CAAC;IAC3B,CAAC;IAED,OAAO;QACL,QAAQ,EAAE,oCAAoC;QAC9C,aAAa,EAAE,CAAC,OAAO,CAAC;QACxB,iBAAiB,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;KAC5D,CAAC;AACJ,CAAC,CAAC;AAEK,MAAM,WAAW,GAAG,CAAC,KAAa,EAAW,EAAE;IACpD,OAAO,MAAM,CAAC,MAAM,CAAC,sBAAU,CAAC,CAAC,QAAQ,CAAC,KAAmB,CAAC,CAAC;AACjE,CAAC,CAAC;AAFW,QAAA,WAAW,eAEtB;AAEF,kBAAe,gBAAgB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calculateAmount.d.ts","sourceRoot":"","sources":["../../src/logic/calculateAmount.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AAGrC,wBAAgB,eAAe,CAC7B,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,SAAS,EACpB,UAAU,EAAE,SAAS,GACpB,SAAS,CAMX"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculateAmount = void 0;
|
|
4
|
+
const getCoinAndAmounts_1 = require("./getCoinAndAmounts");
|
|
5
|
+
function calculateAmount(sender, address, amount_in, amount_out) {
|
|
6
|
+
const is_sender = (0, getCoinAndAmounts_1.compareAddress)(sender, address);
|
|
7
|
+
// LL negates the amount for SEND transactions
|
|
8
|
+
// to show positive amount on the send transaction (ex: in "cancel" tx, when amount will be returned to our account)
|
|
9
|
+
// we need to make it negative
|
|
10
|
+
return is_sender ? amount_out.minus(amount_in) : amount_in.minus(amount_out);
|
|
11
|
+
}
|
|
12
|
+
exports.calculateAmount = calculateAmount;
|
|
13
|
+
//# sourceMappingURL=calculateAmount.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calculateAmount.js","sourceRoot":"","sources":["../../src/logic/calculateAmount.ts"],"names":[],"mappings":";;;AACA,2DAAqD;AAErD,SAAgB,eAAe,CAC7B,MAAc,EACd,OAAe,EACf,SAAoB,EACpB,UAAqB;IAErB,MAAM,SAAS,GAAY,IAAA,kCAAc,EAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3D,8CAA8C;IAC9C,oHAAoH;IACpH,8BAA8B;IAC9B,OAAO,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;AAC/E,CAAC;AAXD,0CAWC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { Ed25519PublicKey, Ed25519Signature, RawTransaction } from "@aptos-labs/ts-sdk";
|
|
2
|
+
export declare function combineSignedTransaction(txRaw: RawTransaction, signature: Ed25519Signature, pubkey: Ed25519PublicKey): Uint8Array;
|
|
3
|
+
export declare function combine(tx: string, signature: string, pubkey?: string): string;
|
|
4
|
+
//# sourceMappingURL=combine.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"combine.d.ts","sourceRoot":"","sources":["../../src/logic/combine.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,gBAAgB,EAChB,gBAAgB,EAEhB,cAAc,EAGf,MAAM,oBAAoB,CAAC;AAE5B,wBAAgB,wBAAwB,CACtC,KAAK,EAAE,cAAc,EACrB,SAAS,EAAE,gBAAgB,EAC3B,MAAM,EAAE,gBAAgB,GACvB,UAAU,CAOZ;AAED,wBAAgB,OAAO,CAAC,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,UA0BrE"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.combine = exports.combineSignedTransaction = void 0;
|
|
4
|
+
const ts_sdk_1 = require("@aptos-labs/ts-sdk");
|
|
5
|
+
function combineSignedTransaction(txRaw, signature, pubkey) {
|
|
6
|
+
const authenticator = new ts_sdk_1.AccountAuthenticatorEd25519(pubkey, signature);
|
|
7
|
+
return (0, ts_sdk_1.generateSignedTransaction)({
|
|
8
|
+
transaction: { rawTransaction: txRaw },
|
|
9
|
+
senderAuthenticator: authenticator,
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
exports.combineSignedTransaction = combineSignedTransaction;
|
|
13
|
+
function combine(tx, signature, pubkey) {
|
|
14
|
+
if (!ts_sdk_1.Hex.isValid(tx).valid) {
|
|
15
|
+
throw new Error("tx must be a valid hex value");
|
|
16
|
+
}
|
|
17
|
+
if (!ts_sdk_1.Hex.isValid(signature).valid) {
|
|
18
|
+
throw new Error("signature must be a valid hex value");
|
|
19
|
+
}
|
|
20
|
+
if (pubkey === undefined) {
|
|
21
|
+
throw new Error("account must have a public key");
|
|
22
|
+
}
|
|
23
|
+
if (!ts_sdk_1.Hex.isValid(pubkey).valid) {
|
|
24
|
+
throw new Error("pubkey must be a valid hex value");
|
|
25
|
+
}
|
|
26
|
+
const ed25519Signature = new ts_sdk_1.Ed25519Signature(signature);
|
|
27
|
+
const ed25519PubKey = new ts_sdk_1.Ed25519PublicKey(pubkey);
|
|
28
|
+
const txBytes = ts_sdk_1.Hex.fromHexString(tx).toUint8Array();
|
|
29
|
+
const txRaw = ts_sdk_1.RawTransaction.deserialize(new ts_sdk_1.Deserializer(txBytes));
|
|
30
|
+
const signedTxBytes = combineSignedTransaction(txRaw, ed25519Signature, ed25519PubKey);
|
|
31
|
+
return ts_sdk_1.Hex.fromHexInput(signedTxBytes).toString();
|
|
32
|
+
}
|
|
33
|
+
exports.combine = combine;
|
|
34
|
+
//# sourceMappingURL=combine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"combine.js","sourceRoot":"","sources":["../../src/logic/combine.ts"],"names":[],"mappings":";;;AAAA,+CAS4B;AAE5B,SAAgB,wBAAwB,CACtC,KAAqB,EACrB,SAA2B,EAC3B,MAAwB;IAExB,MAAM,aAAa,GAAG,IAAI,oCAA2B,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IAEzE,OAAO,IAAA,kCAAyB,EAAC;QAC/B,WAAW,EAAE,EAAE,cAAc,EAAE,KAAK,EAAuB;QAC3D,mBAAmB,EAAE,aAAa;KACnC,CAAC,CAAC;AACL,CAAC;AAXD,4DAWC;AAED,SAAgB,OAAO,CAAC,EAAU,EAAE,SAAiB,EAAE,MAAe;IACpE,IAAI,CAAC,YAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC;QAC3B,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;IAClD,CAAC;IAED,IAAI,CAAC,YAAG,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,CAAC;QAClC,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;IACzD,CAAC;IAED,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;QACzB,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;IACpD,CAAC;IAED,IAAI,CAAC,YAAG,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,CAAC;QAC/B,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;IACtD,CAAC;IAED,MAAM,gBAAgB,GAAG,IAAI,yBAAgB,CAAC,SAAS,CAAC,CAAC;IACzD,MAAM,aAAa,GAAG,IAAI,yBAAgB,CAAC,MAAM,CAAC,CAAC;IAEnD,MAAM,OAAO,GAAG,YAAG,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC,YAAY,EAAE,CAAC;IACrD,MAAM,KAAK,GAAG,uBAAc,CAAC,WAAW,CAAC,IAAI,qBAAY,CAAC,OAAO,CAAC,CAAC,CAAC;IAEpE,MAAM,aAAa,GAAG,wBAAwB,CAAC,KAAK,EAAE,gBAAgB,EAAE,aAAa,CAAC,CAAC;IAEvF,OAAO,YAAG,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,QAAQ,EAAE,CAAC;AACpD,CAAC;AA1BD,0BA0BC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { TransactionIntent } from "@ledgerhq/coin-framework/lib/api/types";
|
|
2
|
+
import type { AptosAsset, AptosExtra, AptosSender } from "../types/assets";
|
|
3
|
+
import type { AptosAPI } from "../network";
|
|
4
|
+
export declare function craftTransaction(aptosClient: AptosAPI, transactionIntent: TransactionIntent<AptosAsset, AptosExtra, AptosSender>): Promise<string>;
|
|
5
|
+
//# sourceMappingURL=craftTransaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"craftTransaction.d.ts","sourceRoot":"","sources":["../../src/logic/craftTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAChF,OAAO,KAAK,EAAE,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAE3E,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAO3C,wBAAsB,gBAAgB,CACpC,WAAW,EAAE,QAAQ,EACrB,iBAAiB,EAAE,iBAAiB,CAAC,UAAU,EAAE,UAAU,EAAE,WAAW,CAAC,GACxE,OAAO,CAAC,MAAM,CAAC,CAyCjB"}
|