@ledgerhq/coin-hedera 1.13.0-nightly.2 → 1.13.0-nightly.3
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 +1 -1
- package/CHANGELOG.md +14 -0
- package/jest.config.js +1 -1
- package/jest.integ.config.js +8 -0
- package/lib/api/index.d.ts +4 -0
- package/lib/api/index.d.ts.map +1 -0
- package/lib/api/index.js +119 -0
- package/lib/api/index.js.map +1 -0
- package/lib/bridge/broadcast.d.ts +1 -1
- package/lib/bridge/broadcast.d.ts.map +1 -1
- package/lib/bridge/broadcast.js +6 -9
- package/lib/bridge/broadcast.js.map +1 -1
- package/lib/bridge/buildOptimisticOperation.d.ts.map +1 -1
- package/lib/bridge/buildOptimisticOperation.js +14 -11
- package/lib/bridge/buildOptimisticOperation.js.map +1 -1
- package/lib/bridge/createTransaction.d.ts +1 -1
- package/lib/bridge/createTransaction.d.ts.map +1 -1
- package/lib/bridge/createTransaction.js +2 -0
- package/lib/bridge/createTransaction.js.map +1 -1
- package/lib/bridge/estimateMaxSpendable.d.ts.map +1 -1
- package/lib/bridge/estimateMaxSpendable.js +2 -2
- package/lib/bridge/estimateMaxSpendable.js.map +1 -1
- package/lib/bridge/getTransactionStatus.d.ts.map +1 -1
- package/lib/bridge/getTransactionStatus.js +11 -10
- package/lib/bridge/getTransactionStatus.js.map +1 -1
- package/lib/bridge/prepareTransaction.d.ts.map +1 -1
- package/lib/bridge/prepareTransaction.js +6 -5
- package/lib/bridge/prepareTransaction.js.map +1 -1
- package/lib/bridge/signOperation.d.ts +1 -1
- package/lib/bridge/signOperation.d.ts.map +1 -1
- package/lib/bridge/signOperation.js +53 -14
- package/lib/bridge/signOperation.js.map +1 -1
- package/lib/bridge/synchronisation.d.ts.map +1 -1
- package/lib/bridge/synchronisation.js +24 -11
- package/lib/bridge/synchronisation.js.map +1 -1
- package/lib/bridge/utils.d.ts +3 -13
- package/lib/bridge/utils.d.ts.map +1 -1
- package/lib/bridge/utils.js +10 -119
- package/lib/bridge/utils.js.map +1 -1
- package/lib/config.d.ts +8 -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 +11 -8
- package/lib/constants.d.ts.map +1 -1
- package/lib/constants.js +17 -13
- package/lib/constants.js.map +1 -1
- package/lib/deviceTransactionConfig.d.ts +1 -1
- package/lib/deviceTransactionConfig.d.ts.map +1 -1
- package/lib/deviceTransactionConfig.js +3 -3
- package/lib/deviceTransactionConfig.js.map +1 -1
- package/lib/logic/broadcast.d.ts +3 -0
- package/lib/logic/broadcast.d.ts.map +1 -0
- package/lib/logic/broadcast.js +11 -0
- package/lib/logic/broadcast.js.map +1 -0
- package/lib/logic/combine.d.ts +2 -0
- package/lib/logic/combine.d.ts.map +1 -0
- package/lib/logic/combine.js +19 -0
- package/lib/logic/combine.js.map +1 -0
- package/lib/logic/craftTransaction.d.ts +8 -0
- package/lib/logic/craftTransaction.d.ts.map +1 -0
- package/lib/logic/craftTransaction.js +107 -0
- package/lib/logic/craftTransaction.js.map +1 -0
- package/lib/logic/estimateFees.d.ts +5 -0
- package/lib/logic/estimateFees.d.ts.map +1 -0
- package/lib/logic/estimateFees.js +25 -0
- package/lib/logic/estimateFees.js.map +1 -0
- package/lib/logic/getAssetFromToken.d.ts +4 -0
- package/lib/logic/getAssetFromToken.d.ts.map +1 -0
- package/lib/logic/getAssetFromToken.js +14 -0
- package/lib/logic/getAssetFromToken.js.map +1 -0
- package/lib/logic/getBalance.d.ts +4 -0
- package/lib/logic/getBalance.d.ts.map +1 -0
- package/lib/logic/getBalance.js +36 -0
- package/lib/logic/getBalance.js.map +1 -0
- package/lib/logic/getTokenFromAsset.d.ts +4 -0
- package/lib/logic/getTokenFromAsset.d.ts.map +1 -0
- package/lib/logic/getTokenFromAsset.js +13 -0
- package/lib/logic/getTokenFromAsset.js.map +1 -0
- package/lib/logic/index.d.ts +10 -0
- package/lib/logic/index.d.ts.map +1 -0
- package/lib/logic/index.js +22 -0
- package/lib/logic/index.js.map +1 -0
- package/lib/logic/lastBlock.d.ts +12 -0
- package/lib/logic/lastBlock.d.ts.map +1 -0
- package/lib/logic/lastBlock.js +25 -0
- package/lib/logic/lastBlock.js.map +1 -0
- package/lib/logic/listOperations.d.ts +19 -0
- package/lib/logic/listOperations.d.ts.map +1 -0
- package/lib/logic/listOperations.js +179 -0
- package/lib/logic/listOperations.js.map +1 -0
- package/lib/logic/utils.d.ts +55 -0
- package/lib/logic/utils.d.ts.map +1 -0
- package/lib/logic/utils.js +197 -0
- package/lib/logic/utils.js.map +1 -0
- package/lib/network/api.d.ts +24 -0
- package/lib/network/api.d.ts.map +1 -0
- package/lib/network/api.js +119 -0
- package/lib/network/api.js.map +1 -0
- package/lib/network/rpc.d.ts +12 -0
- package/lib/network/rpc.d.ts.map +1 -0
- package/lib/network/rpc.js +22 -0
- package/lib/network/rpc.js.map +1 -0
- package/lib/{api → network}/utils.d.ts +1 -5
- package/lib/network/utils.d.ts.map +1 -0
- package/lib/network/utils.js +52 -0
- package/lib/network/utils.js.map +1 -0
- package/lib/test/bridgeDatasetTest.d.ts.map +1 -1
- package/lib/test/bridgeDatasetTest.js +5 -1
- package/lib/test/bridgeDatasetTest.js.map +1 -1
- package/lib/test/fixtures/account.fixture.d.ts +17 -0
- package/lib/test/fixtures/account.fixture.d.ts.map +1 -1
- package/lib/test/fixtures/account.fixture.js +18 -1
- package/lib/test/fixtures/account.fixture.js.map +1 -1
- package/lib/test/fixtures/currency.fixture.d.ts.map +1 -1
- package/lib/test/fixtures/currency.fixture.js +1 -1
- package/lib/test/fixtures/currency.fixture.js.map +1 -1
- package/lib/test/fixtures/mirror.fixture.d.ts +1 -1
- package/lib/test/fixtures/mirror.fixture.d.ts.map +1 -1
- package/lib/test/fixtures/network.fixture.d.ts +3 -0
- package/lib/test/fixtures/network.fixture.d.ts.map +1 -0
- package/lib/test/fixtures/network.fixture.js +9 -0
- package/lib/test/fixtures/network.fixture.js.map +1 -0
- package/lib/test/fixtures/transaction.fixture.d.ts.map +1 -1
- package/lib/test/fixtures/transaction.fixture.js +3 -0
- package/lib/test/fixtures/transaction.fixture.js.map +1 -1
- package/lib/transaction.d.ts +1 -1
- package/lib/transaction.d.ts.map +1 -1
- package/lib/transaction.js +35 -6
- package/lib/transaction.js.map +1 -1
- package/lib/types/alpaca.d.ts +3 -0
- package/lib/types/alpaca.d.ts.map +1 -0
- package/lib/{api/types.js → types/alpaca.js} +1 -1
- package/lib/types/alpaca.js.map +1 -0
- package/lib/types/bridge.d.ts +28 -9
- package/lib/types/bridge.d.ts.map +1 -1
- package/lib/types/index.d.ts +2 -0
- package/lib/types/index.d.ts.map +1 -1
- package/lib/types/index.js +2 -0
- package/lib/types/index.js.map +1 -1
- package/lib/{api/types.d.ts → types/mirror.d.ts} +21 -2
- package/lib/types/mirror.d.ts.map +1 -0
- package/lib/types/mirror.js +3 -0
- package/lib/types/mirror.js.map +1 -0
- package/lib-es/api/index.d.ts +4 -0
- package/lib-es/api/index.d.ts.map +1 -0
- package/lib-es/api/index.js +112 -0
- package/lib-es/api/index.js.map +1 -0
- package/lib-es/bridge/broadcast.d.ts +1 -1
- package/lib-es/bridge/broadcast.d.ts.map +1 -1
- package/lib-es/bridge/broadcast.js +4 -7
- package/lib-es/bridge/broadcast.js.map +1 -1
- package/lib-es/bridge/buildOptimisticOperation.d.ts.map +1 -1
- package/lib-es/bridge/buildOptimisticOperation.js +12 -9
- package/lib-es/bridge/buildOptimisticOperation.js.map +1 -1
- package/lib-es/bridge/createTransaction.d.ts +1 -1
- package/lib-es/bridge/createTransaction.d.ts.map +1 -1
- package/lib-es/bridge/createTransaction.js +2 -0
- package/lib-es/bridge/createTransaction.js.map +1 -1
- package/lib-es/bridge/estimateMaxSpendable.d.ts.map +1 -1
- package/lib-es/bridge/estimateMaxSpendable.js +2 -2
- package/lib-es/bridge/estimateMaxSpendable.js.map +1 -1
- package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -1
- package/lib-es/bridge/getTransactionStatus.js +7 -6
- package/lib-es/bridge/getTransactionStatus.js.map +1 -1
- package/lib-es/bridge/prepareTransaction.d.ts.map +1 -1
- package/lib-es/bridge/prepareTransaction.js +4 -3
- package/lib-es/bridge/prepareTransaction.js.map +1 -1
- package/lib-es/bridge/signOperation.d.ts +1 -1
- package/lib-es/bridge/signOperation.d.ts.map +1 -1
- package/lib-es/bridge/signOperation.js +53 -14
- package/lib-es/bridge/signOperation.js.map +1 -1
- package/lib-es/bridge/synchronisation.d.ts.map +1 -1
- package/lib-es/bridge/synchronisation.js +24 -11
- package/lib-es/bridge/synchronisation.js.map +1 -1
- package/lib-es/bridge/utils.d.ts +3 -13
- package/lib-es/bridge/utils.d.ts.map +1 -1
- package/lib-es/bridge/utils.js +7 -113
- package/lib-es/bridge/utils.js.map +1 -1
- package/lib-es/config.d.ts +8 -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 +11 -8
- package/lib-es/constants.d.ts.map +1 -1
- package/lib-es/constants.js +13 -9
- package/lib-es/constants.js.map +1 -1
- package/lib-es/deviceTransactionConfig.d.ts +1 -1
- package/lib-es/deviceTransactionConfig.d.ts.map +1 -1
- package/lib-es/deviceTransactionConfig.js +1 -1
- package/lib-es/deviceTransactionConfig.js.map +1 -1
- package/lib-es/logic/broadcast.d.ts +3 -0
- package/lib-es/logic/broadcast.d.ts.map +1 -0
- package/lib-es/logic/broadcast.js +7 -0
- package/lib-es/logic/broadcast.js.map +1 -0
- package/lib-es/logic/combine.d.ts +2 -0
- package/lib-es/logic/combine.d.ts.map +1 -0
- package/lib-es/logic/combine.js +12 -0
- package/lib-es/logic/combine.js.map +1 -0
- package/lib-es/logic/craftTransaction.d.ts +8 -0
- package/lib-es/logic/craftTransaction.d.ts.map +1 -0
- package/lib-es/logic/craftTransaction.js +100 -0
- package/lib-es/logic/craftTransaction.js.map +1 -0
- package/lib-es/logic/estimateFees.d.ts +5 -0
- package/lib-es/logic/estimateFees.d.ts.map +1 -0
- package/lib-es/logic/estimateFees.js +18 -0
- package/lib-es/logic/estimateFees.js.map +1 -0
- package/lib-es/logic/getAssetFromToken.d.ts +4 -0
- package/lib-es/logic/getAssetFromToken.d.ts.map +1 -0
- package/lib-es/logic/getAssetFromToken.js +10 -0
- package/lib-es/logic/getAssetFromToken.js.map +1 -0
- package/lib-es/logic/getBalance.d.ts +4 -0
- package/lib-es/logic/getBalance.d.ts.map +1 -0
- package/lib-es/logic/getBalance.js +32 -0
- package/lib-es/logic/getBalance.js.map +1 -0
- package/lib-es/logic/getTokenFromAsset.d.ts +4 -0
- package/lib-es/logic/getTokenFromAsset.d.ts.map +1 -0
- package/lib-es/logic/getTokenFromAsset.js +9 -0
- package/lib-es/logic/getTokenFromAsset.js.map +1 -0
- package/lib-es/logic/index.d.ts +10 -0
- package/lib-es/logic/index.d.ts.map +1 -0
- package/lib-es/logic/index.js +10 -0
- package/lib-es/logic/index.js.map +1 -0
- package/lib-es/logic/lastBlock.d.ts +12 -0
- package/lib-es/logic/lastBlock.d.ts.map +1 -0
- package/lib-es/logic/lastBlock.js +21 -0
- package/lib-es/logic/lastBlock.js.map +1 -0
- package/lib-es/logic/listOperations.d.ts +19 -0
- package/lib-es/logic/listOperations.d.ts.map +1 -0
- package/lib-es/logic/listOperations.js +172 -0
- package/lib-es/logic/listOperations.js.map +1 -0
- package/lib-es/logic/utils.d.ts +55 -0
- package/lib-es/logic/utils.d.ts.map +1 -0
- package/lib-es/logic/utils.js +174 -0
- package/lib-es/logic/utils.js.map +1 -0
- package/lib-es/network/api.d.ts +24 -0
- package/lib-es/network/api.d.ts.map +1 -0
- package/lib-es/network/api.js +113 -0
- package/lib-es/network/api.js.map +1 -0
- package/lib-es/network/rpc.d.ts +12 -0
- package/lib-es/network/rpc.d.ts.map +1 -0
- package/lib-es/network/rpc.js +19 -0
- package/lib-es/network/rpc.js.map +1 -0
- package/lib-es/{api → network}/utils.d.ts +1 -5
- package/lib-es/network/utils.d.ts.map +1 -0
- package/lib-es/network/utils.js +45 -0
- package/lib-es/network/utils.js.map +1 -0
- package/lib-es/test/bridgeDatasetTest.d.ts.map +1 -1
- package/lib-es/test/bridgeDatasetTest.js +5 -1
- package/lib-es/test/bridgeDatasetTest.js.map +1 -1
- package/lib-es/test/fixtures/account.fixture.d.ts +17 -0
- package/lib-es/test/fixtures/account.fixture.d.ts.map +1 -1
- package/lib-es/test/fixtures/account.fixture.js +17 -0
- package/lib-es/test/fixtures/account.fixture.js.map +1 -1
- package/lib-es/test/fixtures/currency.fixture.d.ts.map +1 -1
- package/lib-es/test/fixtures/currency.fixture.js +1 -1
- package/lib-es/test/fixtures/currency.fixture.js.map +1 -1
- package/lib-es/test/fixtures/mirror.fixture.d.ts +1 -1
- package/lib-es/test/fixtures/mirror.fixture.d.ts.map +1 -1
- package/lib-es/test/fixtures/network.fixture.d.ts +3 -0
- package/lib-es/test/fixtures/network.fixture.d.ts.map +1 -0
- package/lib-es/test/fixtures/network.fixture.js +5 -0
- package/lib-es/test/fixtures/network.fixture.js.map +1 -0
- package/lib-es/test/fixtures/transaction.fixture.d.ts.map +1 -1
- package/lib-es/test/fixtures/transaction.fixture.js +3 -0
- package/lib-es/test/fixtures/transaction.fixture.js.map +1 -1
- package/lib-es/transaction.d.ts +1 -1
- package/lib-es/transaction.d.ts.map +1 -1
- package/lib-es/transaction.js +35 -6
- package/lib-es/transaction.js.map +1 -1
- package/lib-es/types/alpaca.d.ts +3 -0
- package/lib-es/types/alpaca.d.ts.map +1 -0
- package/lib-es/types/alpaca.js +2 -0
- package/lib-es/types/alpaca.js.map +1 -0
- package/lib-es/types/bridge.d.ts +28 -9
- package/lib-es/types/bridge.d.ts.map +1 -1
- package/lib-es/types/index.d.ts +2 -0
- package/lib-es/types/index.d.ts.map +1 -1
- package/lib-es/types/index.js +2 -0
- package/lib-es/types/index.js.map +1 -1
- package/lib-es/{api/types.d.ts → types/mirror.d.ts} +21 -2
- package/lib-es/types/mirror.d.ts.map +1 -0
- package/lib-es/types/mirror.js +2 -0
- package/lib-es/types/mirror.js.map +1 -0
- package/package.json +4 -3
- package/src/api/index.integ.test.ts +401 -0
- package/src/api/index.test.ts +30 -0
- package/src/api/index.ts +149 -0
- package/src/bridge/broadcast.ts +5 -10
- package/src/bridge/buildOptimisticOperation.integration.test.ts +8 -8
- package/src/bridge/buildOptimisticOperation.ts +13 -10
- package/src/bridge/createTransaction.ts +3 -1
- package/src/bridge/estimateMaxSpendable.ts +6 -3
- package/src/bridge/getTransactionStatus.test.ts +11 -10
- package/src/bridge/getTransactionStatus.ts +12 -11
- package/src/bridge/js-estimateMaxSpendable.integration.test.ts +6 -3
- package/src/bridge/prepareTransaction.test.ts +9 -17
- package/src/bridge/prepareTransaction.ts +5 -4
- package/src/bridge/serialization.test.ts +6 -6
- package/src/bridge/signOperation.ts +69 -16
- package/src/bridge/synchronisation.ts +22 -14
- package/src/bridge/utils.integration.test.ts +19 -248
- package/src/bridge/utils.ts +14 -160
- package/src/config.ts +7 -0
- package/src/constants.ts +15 -9
- package/src/deviceTransactionConfig.ts +2 -2
- package/src/logic/broadcast.test.ts +58 -0
- package/src/logic/broadcast.ts +8 -0
- package/src/logic/combine.test.ts +119 -0
- package/src/logic/combine.ts +14 -0
- package/src/logic/craftTransaction.test.ts +215 -0
- package/src/logic/craftTransaction.ts +175 -0
- package/src/logic/estimateFees.test.ts +99 -0
- package/src/logic/estimateFees.ts +28 -0
- package/src/logic/getAssetFromToken.test.ts +27 -0
- package/src/logic/getAssetFromToken.ts +12 -0
- package/src/logic/getBalance.test.ts +200 -0
- package/src/logic/getBalance.ts +39 -0
- package/src/logic/getTokenFromAsset.test.ts +22 -0
- package/src/logic/getTokenFromAsset.ts +17 -0
- package/src/logic/index.ts +9 -0
- package/src/logic/lastBlock.test.ts +23 -0
- package/src/logic/lastBlock.ts +23 -0
- package/src/logic/listOperations.test.ts +388 -0
- package/src/logic/listOperations.ts +247 -0
- package/src/logic/utils.test.ts +432 -0
- package/src/logic/utils.ts +255 -0
- package/src/{api/mirror.test.ts → network/api.test.ts} +81 -35
- package/src/network/api.ts +159 -0
- package/src/network/rpc.test.ts +68 -0
- package/src/network/rpc.ts +25 -0
- package/src/network/utils.test.ts +175 -0
- package/src/network/utils.ts +58 -0
- package/src/test/bridgeDatasetTest.ts +6 -2
- package/src/test/fixtures/account.fixture.ts +18 -0
- package/src/test/fixtures/currency.fixture.ts +1 -1
- package/src/test/fixtures/mirror.fixture.ts +1 -1
- package/src/test/fixtures/network.fixture.ts +6 -0
- package/src/test/fixtures/transaction.fixture.ts +5 -2
- package/src/transaction.ts +40 -9
- package/src/types/alpaca.ts +3 -0
- package/src/types/bridge.ts +36 -10
- package/src/types/index.ts +2 -0
- package/src/{api/types.ts → types/mirror.ts} +23 -1
- package/lib/api/mirror.d.ts +0 -6
- package/lib/api/mirror.d.ts.map +0 -1
- package/lib/api/mirror.js +0 -84
- package/lib/api/mirror.js.map +0 -1
- package/lib/api/network.d.ts +0 -11
- package/lib/api/network.d.ts.map +0 -1
- package/lib/api/network.js +0 -80
- package/lib/api/network.js.map +0 -1
- package/lib/api/types.d.ts.map +0 -1
- package/lib/api/types.js.map +0 -1
- package/lib/api/utils.d.ts.map +0 -1
- package/lib/api/utils.js +0 -132
- package/lib/api/utils.js.map +0 -1
- package/lib/logic.d.ts +0 -11
- package/lib/logic.d.ts.map +0 -1
- package/lib/logic.js +0 -37
- package/lib/logic.js.map +0 -1
- package/lib-es/api/mirror.d.ts +0 -6
- package/lib-es/api/mirror.d.ts.map +0 -1
- package/lib-es/api/mirror.js +0 -74
- package/lib-es/api/mirror.js.map +0 -1
- package/lib-es/api/network.d.ts +0 -11
- package/lib-es/api/network.d.ts.map +0 -1
- package/lib-es/api/network.js +0 -71
- package/lib-es/api/network.js.map +0 -1
- package/lib-es/api/types.d.ts.map +0 -1
- package/lib-es/api/types.js +0 -2
- package/lib-es/api/types.js.map +0 -1
- package/lib-es/api/utils.d.ts.map +0 -1
- package/lib-es/api/utils.js +0 -124
- package/lib-es/api/utils.js.map +0 -1
- package/lib-es/logic.d.ts +0 -11
- package/lib-es/logic.d.ts.map +0 -1
- package/lib-es/logic.js +0 -29
- package/lib-es/logic.js.map +0 -1
- package/src/api/mirror.ts +0 -91
- package/src/api/network.test.ts +0 -49
- package/src/api/network.ts +0 -125
- package/src/api/utils.ts +0 -150
- package/src/logic.test.ts +0 -152
- package/src/logic.ts +0 -66
package/.turbo/turbo-build.log
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
|
|
2
|
-
> @ledgerhq/coin-hedera@1.
|
|
2
|
+
> @ledgerhq/coin-hedera@1.13.0-nightly.2 build /home/runner/work/ledger-live/ledger-live/libs/coin-modules/coin-hedera
|
|
3
3
|
> tsc --outDir lib --module commonjs --moduleResolution node10 && tsc -m ES6 --outDir lib-es
|
|
4
4
|
|
package/.unimportedrc.json
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"entry": [
|
|
3
3
|
"src/account.ts",
|
|
4
|
+
"src/api/index.ts",
|
|
4
5
|
"src/bridge/index.ts",
|
|
5
6
|
"src/test/cli.ts",
|
|
6
7
|
"src/deviceTransactionConfig.ts",
|
|
@@ -18,7 +19,6 @@
|
|
|
18
19
|
"ignoreUnresolved": [],
|
|
19
20
|
"ignoreUnimported": [
|
|
20
21
|
"src/index.ts",
|
|
21
|
-
"src/logic.ts",
|
|
22
22
|
"src/test/bot-specs.ts",
|
|
23
23
|
"src/test/bridgeDatasetTest.ts",
|
|
24
24
|
"src/test/cli.ts",
|
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,19 @@
|
|
|
1
1
|
# @ledgerhq/coin-hedera
|
|
2
2
|
|
|
3
|
+
## 1.13.0-nightly.3
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- [#12417](https://github.com/LedgerHQ/ledger-live/pull/12417) [`27ec886`](https://github.com/LedgerHQ/ledger-live/commit/27ec8862a1cf7e117ec8052fe258ad22e882a38c) Thanks [@francois-guerin-ledger](https://github.com/francois-guerin-ledger)! - fix(coin-hedera): add unimplemented getValidators
|
|
8
|
+
|
|
9
|
+
- [#12254](https://github.com/LedgerHQ/ledger-live/pull/12254) [`b10973c`](https://github.com/LedgerHQ/ledger-live/commit/b10973cdbcaf810f5dcde2ef7a9737437d79ee26) Thanks [@scavassa-yld](https://github.com/scavassa-yld)! - feat: alpaca refactor of coin-hedera
|
|
10
|
+
|
|
11
|
+
### Patch Changes
|
|
12
|
+
|
|
13
|
+
- Updated dependencies [[`eb176c2`](https://github.com/LedgerHQ/ledger-live/commit/eb176c201d711f1d28f74de831c4a6cd0c2d4a50)]:
|
|
14
|
+
- @ledgerhq/coin-framework@6.8.0-nightly.3
|
|
15
|
+
- @ledgerhq/live-countervalues@0.8.1-nightly.3
|
|
16
|
+
|
|
3
17
|
## 1.13.0-nightly.2
|
|
4
18
|
|
|
5
19
|
### Minor Changes
|
package/jest.config.js
CHANGED
|
@@ -10,7 +10,7 @@ module.exports = {
|
|
|
10
10
|
],
|
|
11
11
|
coverageReporters: ["json", ["lcov", { file: "lcov.info", projectRoot: "../../../" }], "text"],
|
|
12
12
|
testEnvironment: "node",
|
|
13
|
-
testPathIgnorePatterns: ["lib/", "lib-es/", ".integration.test.ts"],
|
|
13
|
+
testPathIgnorePatterns: ["lib/", "lib-es/", ".integration.test.ts", ".integ.test.ts"],
|
|
14
14
|
modulePathIgnorePatterns: ["__tests__/fixtures"],
|
|
15
15
|
reporters: [
|
|
16
16
|
"default",
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/** @type {import('ts-jest/dist/types').JestConfigWithTsJest} */
|
|
2
|
+
module.exports = {
|
|
3
|
+
preset: "ts-jest",
|
|
4
|
+
testEnvironment: "node",
|
|
5
|
+
testRegex: [".integ.test.ts$", ".integration.test.ts$"],
|
|
6
|
+
testPathIgnorePatterns: ["lib/", "lib-es/"],
|
|
7
|
+
testTimeout: 60000,
|
|
8
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/api/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,GAAG,EAWJ,MAAM,oCAAoC,CAAC;AAgB5C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAE3C,wBAAgB,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,GAAG,GAAG,CAAC,UAAU,CAAC,CAsHxE"}
|
package/lib/api/index.js
ADDED
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createApi = void 0;
|
|
7
|
+
const currencies_1 = require("@ledgerhq/cryptoassets/currencies");
|
|
8
|
+
const config_1 = __importDefault(require("../config"));
|
|
9
|
+
const index_1 = require("../logic/index");
|
|
10
|
+
const utils_1 = require("../logic/utils");
|
|
11
|
+
const api_1 = require("../network/api");
|
|
12
|
+
function createApi(config) {
|
|
13
|
+
config_1.default.setCoinConfig(() => ({ ...config, status: { type: "active" } }));
|
|
14
|
+
const currency = (0, currencies_1.getCryptoCurrencyById)("hedera");
|
|
15
|
+
return {
|
|
16
|
+
broadcast: async (tx) => {
|
|
17
|
+
const response = await (0, index_1.broadcast)(tx);
|
|
18
|
+
return Buffer.from(response.transactionHash).toString("base64");
|
|
19
|
+
},
|
|
20
|
+
combine: index_1.combine,
|
|
21
|
+
craftTransaction: async (txIntent, customFees) => {
|
|
22
|
+
const { serializedTx } = await (0, index_1.craftTransaction)(txIntent, customFees);
|
|
23
|
+
return {
|
|
24
|
+
transaction: serializedTx,
|
|
25
|
+
};
|
|
26
|
+
},
|
|
27
|
+
craftRawTransaction: (_transaction, _sender, _publicKey, _sequence) => {
|
|
28
|
+
throw new Error("craftRawTransaction is not supported");
|
|
29
|
+
},
|
|
30
|
+
estimateFees: async (transactionIntent) => {
|
|
31
|
+
const operationType = (0, utils_1.mapIntentToSDKOperation)(transactionIntent);
|
|
32
|
+
const estimatedFee = await (0, index_1.estimateFees)(currency, operationType);
|
|
33
|
+
return {
|
|
34
|
+
value: BigInt(estimatedFee.toString()),
|
|
35
|
+
};
|
|
36
|
+
},
|
|
37
|
+
getBalance: address => (0, index_1.getBalance)(currency, address),
|
|
38
|
+
lastBlock: index_1.lastBlock,
|
|
39
|
+
listOperations: async (address, pagination) => {
|
|
40
|
+
const mirrorTokens = await api_1.apiClient.getAccountTokens(address);
|
|
41
|
+
const latestAccountOperations = await (0, index_1.listOperations)({
|
|
42
|
+
currency,
|
|
43
|
+
address,
|
|
44
|
+
pagination,
|
|
45
|
+
mirrorTokens,
|
|
46
|
+
fetchAllPages: false,
|
|
47
|
+
skipFeesForTokenOperations: true,
|
|
48
|
+
useEncodedHash: false,
|
|
49
|
+
useSyntheticBlocks: true,
|
|
50
|
+
});
|
|
51
|
+
const liveOperations = [
|
|
52
|
+
...latestAccountOperations.coinOperations,
|
|
53
|
+
...latestAccountOperations.tokenOperations,
|
|
54
|
+
];
|
|
55
|
+
const sortedLiveOperations = [...liveOperations].sort((a, b) => {
|
|
56
|
+
const aTime = a.date.getTime();
|
|
57
|
+
const bTime = b.date.getTime();
|
|
58
|
+
return pagination.order === "desc" ? bTime - aTime : aTime - bTime;
|
|
59
|
+
});
|
|
60
|
+
const alpacaOperations = sortedLiveOperations.map(liveOp => {
|
|
61
|
+
const asset = liveOp.contract
|
|
62
|
+
? {
|
|
63
|
+
type: liveOp.standard ?? "token",
|
|
64
|
+
assetReference: liveOp.contract,
|
|
65
|
+
assetOwner: address,
|
|
66
|
+
}
|
|
67
|
+
: { type: "native" };
|
|
68
|
+
return {
|
|
69
|
+
id: liveOp.id,
|
|
70
|
+
type: liveOp.type,
|
|
71
|
+
senders: liveOp.senders,
|
|
72
|
+
recipients: liveOp.recipients,
|
|
73
|
+
value: (0, utils_1.getOperationValue)({ asset, operation: liveOp }),
|
|
74
|
+
asset,
|
|
75
|
+
details: {
|
|
76
|
+
...liveOp.extra,
|
|
77
|
+
ledgerOpType: liveOp.type,
|
|
78
|
+
status: liveOp.hasFailed ? "failed" : "success",
|
|
79
|
+
...(asset.type !== "native" && { assetAmount: liveOp.value.toFixed(0) }),
|
|
80
|
+
},
|
|
81
|
+
tx: {
|
|
82
|
+
hash: liveOp.hash,
|
|
83
|
+
fees: BigInt(liveOp.fee.toFixed(0)),
|
|
84
|
+
date: liveOp.date,
|
|
85
|
+
block: {
|
|
86
|
+
height: liveOp.blockHeight ?? 10,
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
};
|
|
90
|
+
});
|
|
91
|
+
return [alpacaOperations, latestAccountOperations.nextCursor ?? ""];
|
|
92
|
+
},
|
|
93
|
+
getTokenFromAsset: asset => (0, index_1.getTokenFromAsset)(currency, asset),
|
|
94
|
+
getAssetFromToken: index_1.getAssetFromToken,
|
|
95
|
+
validateIntent: async (_transactionIntent, _customFees) => {
|
|
96
|
+
throw new Error("validateIntent is not supported");
|
|
97
|
+
},
|
|
98
|
+
getSequence: async (_address) => {
|
|
99
|
+
throw new Error("getSequence is not supported");
|
|
100
|
+
},
|
|
101
|
+
getBlock: async (_height) => {
|
|
102
|
+
throw new Error("getBlock is not supported");
|
|
103
|
+
},
|
|
104
|
+
getBlockInfo: async (_height) => {
|
|
105
|
+
throw new Error("getBlockInfo is not supported");
|
|
106
|
+
},
|
|
107
|
+
getStakes: async (_address, _cursor) => {
|
|
108
|
+
throw new Error("getStakes is not supported");
|
|
109
|
+
},
|
|
110
|
+
getRewards: async (_address, _cursor) => {
|
|
111
|
+
throw new Error("getRewards is not supported");
|
|
112
|
+
},
|
|
113
|
+
getValidators(_cursor) {
|
|
114
|
+
throw new Error("getValidators is not supported");
|
|
115
|
+
},
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
exports.createApi = createApi;
|
|
119
|
+
//# 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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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAa,MAAM,sBAAsB,CAAC;AAIhE,OAAO,KAAK,EAAwB,WAAW,EAAE,MAAM,UAAU,CAAC;AAGlE,eAAO,MAAM,SAAS,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,WAAW,CAgB7D,CAAC"}
|
package/lib/bridge/broadcast.js
CHANGED
|
@@ -1,25 +1,22 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.broadcast = void 0;
|
|
4
|
-
const sdk_1 = require("@hashgraph/sdk");
|
|
5
4
|
const operation_1 = require("@ledgerhq/coin-framework/operation");
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
const
|
|
5
|
+
const broadcast_1 = require("../logic/broadcast");
|
|
6
|
+
const utils_1 = require("../logic/utils");
|
|
7
|
+
const utils_2 = require("./utils");
|
|
9
8
|
const broadcast = async ({ signedOperation }) => {
|
|
10
9
|
const { signature, operation } = signedOperation;
|
|
11
|
-
|
|
12
|
-
const hederaTransaction = sdk_1.Transaction.fromBytes(Buffer.from(signature, "base64"));
|
|
13
|
-
const response = await (0, network_1.broadcastTransaction)(hederaTransaction);
|
|
10
|
+
const response = await (0, broadcast_1.broadcast)(signature);
|
|
14
11
|
const base64Hash = Buffer.from(response.transactionHash).toString("base64");
|
|
15
12
|
const base64HashUrlSafe = (0, utils_1.base64ToUrlSafeBase64)(base64Hash);
|
|
16
13
|
const extra = {
|
|
17
|
-
...((0,
|
|
14
|
+
...((0, utils_1.isValidExtra)(operation.extra) ? operation.extra : {}),
|
|
18
15
|
transactionId: response.transactionId.toString(),
|
|
19
16
|
};
|
|
20
17
|
let patchedOperation = operation;
|
|
21
18
|
patchedOperation = (0, operation_1.patchOperationWithHash)(patchedOperation, base64HashUrlSafe);
|
|
22
|
-
patchedOperation = (0,
|
|
19
|
+
patchedOperation = (0, utils_2.patchOperationWithExtra)(patchedOperation, extra);
|
|
23
20
|
return patchedOperation;
|
|
24
21
|
};
|
|
25
22
|
exports.broadcast = broadcast;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":";;;AACA,kEAA4E;AAC5E,kDAAiE;AACjE,0CAAqE;AAErE,mCAAkD;AAE3C,MAAM,SAAS,GAA4C,KAAK,EAAE,EAAE,eAAe,EAAE,EAAE,EAAE;IAC9F,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,eAAe,CAAC;IACjD,MAAM,QAAQ,GAAG,MAAM,IAAA,qBAAc,EAAC,SAAS,CAAC,CAAC;IAEjD,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAC5E,MAAM,iBAAiB,GAAG,IAAA,6BAAqB,EAAC,UAAU,CAAC,CAAC;IAC5D,MAAM,KAAK,GAAyB;QAClC,GAAG,CAAC,IAAA,oBAAY,EAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;QACzD,aAAa,EAAE,QAAQ,CAAC,aAAa,CAAC,QAAQ,EAAE;KACjD,CAAC;IAEF,IAAI,gBAAgB,GAAc,SAAS,CAAC;IAC5C,gBAAgB,GAAG,IAAA,kCAAsB,EAAC,gBAAgB,EAAE,iBAAiB,CAAC,CAAC;IAC/E,gBAAgB,GAAG,IAAA,+BAAuB,EAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC;IAEpE,OAAO,gBAAgB,CAAC;AAC1B,CAAC,CAAC;AAhBW,QAAA,SAAS,aAgBpB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"buildOptimisticOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,SAAS,EAA+B,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"buildOptimisticOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,SAAS,EAA+B,MAAM,sBAAsB,CAAC;AAM5F,OAAO,KAAK,EAAwB,WAAW,EAAE,MAAM,UAAU,CAAC;AA0HlE,eAAO,MAAM,wBAAwB;aAI1B,OAAO;iBACH,WAAW;MACtB,QAAQ,SAAS,CAWpB,CAAC"}
|
|
@@ -7,19 +7,18 @@ exports.buildOptimisticOperation = void 0;
|
|
|
7
7
|
const invariant_1 = __importDefault(require("invariant"));
|
|
8
8
|
const operation_1 = require("@ledgerhq/coin-framework/operation");
|
|
9
9
|
const helpers_1 = require("@ledgerhq/coin-framework/account/helpers");
|
|
10
|
-
const utils_1 = require("./utils");
|
|
11
|
-
const logic_1 = require("../logic");
|
|
12
10
|
const constants_1 = require("../constants");
|
|
11
|
+
const estimateFees_1 = require("../logic/estimateFees");
|
|
12
|
+
const utils_1 = require("../logic/utils");
|
|
13
13
|
const buildOptimisticTokenAssociateOperation = async ({ account, transaction, }) => {
|
|
14
|
-
(0, invariant_1.default)((0,
|
|
15
|
-
const estimatedFee = await (0,
|
|
16
|
-
const value = transaction.amount;
|
|
14
|
+
(0, invariant_1.default)((0, utils_1.isTokenAssociateTransaction)(transaction), "invalid transaction properties");
|
|
15
|
+
const estimatedFee = await (0, estimateFees_1.estimateFees)(account.currency, constants_1.HEDERA_OPERATION_TYPES.TokenAssociate);
|
|
17
16
|
const type = "ASSOCIATE_TOKEN";
|
|
18
17
|
const operation = {
|
|
19
18
|
id: (0, operation_1.encodeOperationId)(account.id, "", type),
|
|
20
19
|
hash: "",
|
|
21
20
|
type,
|
|
22
|
-
value,
|
|
21
|
+
value: estimatedFee,
|
|
23
22
|
fee: estimatedFee,
|
|
24
23
|
blockHash: null,
|
|
25
24
|
blockHeight: null,
|
|
@@ -36,7 +35,7 @@ const buildOptimisticTokenAssociateOperation = async ({ account, transaction, })
|
|
|
36
35
|
const buildOptimisticCoinOperation = async ({ account, transaction, transactionType, }) => {
|
|
37
36
|
const estimatedFee = transactionType === "FEES"
|
|
38
37
|
? transaction.amount
|
|
39
|
-
: await (0,
|
|
38
|
+
: await (0, estimateFees_1.estimateFees)(account.currency, constants_1.HEDERA_OPERATION_TYPES.CryptoTransfer);
|
|
40
39
|
const value = transaction.amount;
|
|
41
40
|
const type = transactionType ?? "OUT";
|
|
42
41
|
const [_, recipientAddress] = (0, utils_1.safeParseAccountId)(transaction.recipient);
|
|
@@ -53,12 +52,14 @@ const buildOptimisticCoinOperation = async ({ account, transaction, transactionT
|
|
|
53
52
|
recipients: [recipientWithoutChecksum],
|
|
54
53
|
accountId: account.id,
|
|
55
54
|
date: new Date(),
|
|
56
|
-
extra: {
|
|
55
|
+
extra: {
|
|
56
|
+
...(!!transaction.memo && { memo: transaction.memo }),
|
|
57
|
+
},
|
|
57
58
|
};
|
|
58
59
|
return operation;
|
|
59
60
|
};
|
|
60
61
|
const buildOptimisticTokenOperation = async ({ account, tokenAccount, transaction, }) => {
|
|
61
|
-
const estimatedFee = await (0,
|
|
62
|
+
const estimatedFee = await (0, estimateFees_1.estimateFees)(account.currency, constants_1.HEDERA_OPERATION_TYPES.TokenTransfer);
|
|
62
63
|
const value = transaction.amount;
|
|
63
64
|
const type = "OUT";
|
|
64
65
|
const [_, recipientAddress] = (0, utils_1.safeParseAccountId)(transaction.recipient);
|
|
@@ -87,7 +88,9 @@ const buildOptimisticTokenOperation = async ({ account, tokenAccount, transactio
|
|
|
87
88
|
recipients: [recipientWithoutChecksum],
|
|
88
89
|
accountId: tokenAccount.id,
|
|
89
90
|
date: new Date(),
|
|
90
|
-
extra: {
|
|
91
|
+
extra: {
|
|
92
|
+
...(!!transaction.memo && { memo: transaction.memo }),
|
|
93
|
+
},
|
|
91
94
|
},
|
|
92
95
|
],
|
|
93
96
|
};
|
|
@@ -96,7 +99,7 @@ const buildOptimisticTokenOperation = async ({ account, tokenAccount, transactio
|
|
|
96
99
|
const buildOptimisticOperation = async ({ account, transaction, }) => {
|
|
97
100
|
const subAccount = (0, helpers_1.findSubAccountById)(account, transaction.subAccountId || "");
|
|
98
101
|
const isTokenTransaction = (0, helpers_1.isTokenAccount)(subAccount);
|
|
99
|
-
if ((0,
|
|
102
|
+
if ((0, utils_1.isTokenAssociateTransaction)(transaction)) {
|
|
100
103
|
return buildOptimisticTokenAssociateOperation({ account, transaction });
|
|
101
104
|
}
|
|
102
105
|
else if (isTokenTransaction) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"buildOptimisticOperation.js","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":";;;;;;AAAA,0DAAkC;AAElC,kEAAuE;AACvE,sEAA8F;
|
|
1
|
+
{"version":3,"file":"buildOptimisticOperation.js","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"createTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAE5C;;;;GAIG;AACH,eAAO,MAAM,iBAAiB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,mBAAmB,CAM5E,CAAC"}
|
|
@@ -5,12 +5,14 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.createTransaction = void 0;
|
|
7
7
|
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
8
|
+
const constants_1 = require("../constants");
|
|
8
9
|
/**
|
|
9
10
|
* Creates an empty transaction.
|
|
10
11
|
*
|
|
11
12
|
* @returns {Transaction}
|
|
12
13
|
*/
|
|
13
14
|
const createTransaction = () => ({
|
|
15
|
+
mode: constants_1.HEDERA_TRANSACTION_MODES.Send,
|
|
14
16
|
family: "hedera",
|
|
15
17
|
amount: new bignumber_js_1.default(0),
|
|
16
18
|
recipient: "",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createTransaction.js","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":";;;;;;AAAA,gEAAqC;
|
|
1
|
+
{"version":3,"file":"createTransaction.js","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":";;;;;;AAAA,gEAAqC;AAErC,4CAAwD;AAGxD;;;;GAIG;AACI,MAAM,iBAAiB,GAAoD,GAAG,EAAE,CAAC,CAAC;IACvF,IAAI,EAAE,oCAAwB,CAAC,IAAI;IACnC,MAAM,EAAE,QAAQ;IAChB,MAAM,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC;IACxB,SAAS,EAAE,EAAE;IACb,YAAY,EAAE,KAAK;CACpB,CAAC,CAAC;AANU,QAAA,iBAAiB,qBAM3B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"estimateMaxSpendable.d.ts","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"estimateMaxSpendable.d.ts","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAK1D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAE5C,eAAO,MAAM,oBAAoB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,sBAAsB,CAyBnF,CAAC"}
|
|
@@ -7,8 +7,8 @@ exports.estimateMaxSpendable = void 0;
|
|
|
7
7
|
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
8
8
|
const index_1 = require("@ledgerhq/coin-framework/account/index");
|
|
9
9
|
const helpers_1 = require("@ledgerhq/coin-framework/account/helpers");
|
|
10
|
-
const utils_1 = require("./utils");
|
|
11
10
|
const constants_1 = require("../constants");
|
|
11
|
+
const estimateFees_1 = require("../logic/estimateFees");
|
|
12
12
|
const estimateMaxSpendable = async ({ account, parentAccount, }) => {
|
|
13
13
|
const mainAccount = (0, index_1.getMainAccount)(account, parentAccount);
|
|
14
14
|
const isTokenTransaction = (0, helpers_1.isTokenAccount)(account);
|
|
@@ -16,7 +16,7 @@ const estimateMaxSpendable = async ({ account, parentAccount, }) => {
|
|
|
16
16
|
if (isTokenTransaction) {
|
|
17
17
|
return Promise.resolve(balance);
|
|
18
18
|
}
|
|
19
|
-
const estimatedFees = await (0,
|
|
19
|
+
const estimatedFees = await (0, estimateFees_1.estimateFees)(mainAccount.currency, constants_1.HEDERA_OPERATION_TYPES.CryptoTransfer);
|
|
20
20
|
let maxSpendable = balance.minus(estimatedFees);
|
|
21
21
|
// set max spendable to 0 if negative
|
|
22
22
|
// for cases where the user's account balance is smaller than the estimated fee
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"estimateMaxSpendable.js","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":";;;;;;AAAA,gEAAqC;AAErC,kEAAwE;AACxE,sEAA0E;
|
|
1
|
+
{"version":3,"file":"estimateMaxSpendable.js","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":";;;;;;AAAA,gEAAqC;AAErC,kEAAwE;AACxE,sEAA0E;AAC1E,4CAAsD;AACtD,wDAAqD;AAG9C,MAAM,oBAAoB,GAAuD,KAAK,EAAE,EAC7F,OAAO,EACP,aAAa,GACd,EAAE,EAAE;IACH,MAAM,WAAW,GAAG,IAAA,sBAAc,EAAC,OAAO,EAAE,aAAa,CAAC,CAAC;IAC3D,MAAM,kBAAkB,GAAG,IAAA,wBAAc,EAAC,OAAO,CAAC,CAAC;IACnD,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAEhC,IAAI,kBAAkB,EAAE,CAAC;QACvB,OAAO,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;IAED,MAAM,aAAa,GAAG,MAAM,IAAA,2BAAY,EACtC,WAAW,CAAC,QAAQ,EACpB,kCAAsB,CAAC,cAAc,CACtC,CAAC;IACF,IAAI,YAAY,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;IAEhD,qCAAqC;IACrC,+EAA+E;IAC/E,IAAI,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/B,YAAY,GAAG,IAAI,sBAAS,CAAC,CAAC,CAAC,CAAC;IAClC,CAAC;IAED,OAAO,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;AACvC,CAAC,CAAC;AAzBW,QAAA,oBAAoB,wBAyB/B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getTransactionStatus.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,OAAO,EAAE,aAAa,EAAgB,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,OAAO,EAAE,aAAa,EAAgB,MAAM,sBAAsB,CAAC;AAiBjF,OAAO,KAAK,EAAE,WAAW,EAAE,iBAAiB,EAA6B,MAAM,UAAU,CAAC;AAuJ1F,eAAO,MAAM,oBAAoB,EAAE,aAAa,CAC9C,WAAW,EACX,OAAO,EACP,iBAAiB,CAClB,CAAC,sBAAsB,CAWvB,CAAC"}
|
|
@@ -8,10 +8,11 @@ const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
|
8
8
|
const errors_1 = require("@ledgerhq/errors");
|
|
9
9
|
const account_1 = require("@ledgerhq/coin-framework/account");
|
|
10
10
|
const live_env_1 = require("@ledgerhq/live-env");
|
|
11
|
-
const errors_2 = require("../errors");
|
|
12
|
-
const logic_1 = require("../logic");
|
|
13
|
-
const utils_1 = require("./utils");
|
|
14
11
|
const constants_1 = require("../constants");
|
|
12
|
+
const errors_2 = require("../errors");
|
|
13
|
+
const estimateFees_1 = require("../logic/estimateFees");
|
|
14
|
+
const utils_1 = require("../logic/utils");
|
|
15
|
+
const utils_2 = require("./utils");
|
|
15
16
|
function validateRecipient(account, recipient) {
|
|
16
17
|
if (!recipient || recipient.length === 0) {
|
|
17
18
|
return new errors_1.RecipientRequired();
|
|
@@ -31,11 +32,11 @@ async function handleTokenAssociateTransaction(account, transaction) {
|
|
|
31
32
|
const warnings = {};
|
|
32
33
|
const [usdRate, estimatedFees] = await Promise.all([
|
|
33
34
|
(0, utils_1.getCurrencyToUSDRate)(account.currency),
|
|
34
|
-
(0,
|
|
35
|
+
(0, estimateFees_1.estimateFees)(account.currency, constants_1.HEDERA_OPERATION_TYPES.TokenAssociate),
|
|
35
36
|
]);
|
|
36
37
|
const amount = (0, bignumber_js_1.default)(0);
|
|
37
38
|
const totalSpent = amount.plus(estimatedFees);
|
|
38
|
-
const isAssociationFlow = (0,
|
|
39
|
+
const isAssociationFlow = (0, utils_1.isTokenAssociationRequired)(account, transaction.properties.token);
|
|
39
40
|
if (isAssociationFlow) {
|
|
40
41
|
const hbarBalance = account.balance.dividedBy(10 ** account.currency.units[0].magnitude);
|
|
41
42
|
const currentWorthInUSD = usdRate ? hbarBalance.multipliedBy(usdRate) : new bignumber_js_1.default(0);
|
|
@@ -58,8 +59,8 @@ async function handleTokenTransaction(account, subAccount, transaction) {
|
|
|
58
59
|
const errors = {};
|
|
59
60
|
const warnings = {};
|
|
60
61
|
const [calculatedAmount, estimatedFees] = await Promise.all([
|
|
61
|
-
(0,
|
|
62
|
-
(0,
|
|
62
|
+
(0, utils_2.calculateAmount)({ transaction, account }),
|
|
63
|
+
(0, estimateFees_1.estimateFees)(account.currency, constants_1.HEDERA_OPERATION_TYPES.TokenTransfer),
|
|
63
64
|
]);
|
|
64
65
|
const recipientError = validateRecipient(account, transaction.recipient);
|
|
65
66
|
if (recipientError) {
|
|
@@ -97,8 +98,8 @@ async function handleCoinTransaction(account, transaction) {
|
|
|
97
98
|
const errors = {};
|
|
98
99
|
const warnings = {};
|
|
99
100
|
const [calculatedAmount, estimatedFees] = await Promise.all([
|
|
100
|
-
(0,
|
|
101
|
-
(0,
|
|
101
|
+
(0, utils_2.calculateAmount)({ transaction, account }),
|
|
102
|
+
(0, estimateFees_1.estimateFees)(account.currency, constants_1.HEDERA_OPERATION_TYPES.CryptoTransfer),
|
|
102
103
|
]);
|
|
103
104
|
const recipientError = validateRecipient(account, transaction.recipient);
|
|
104
105
|
if (recipientError) {
|
|
@@ -121,7 +122,7 @@ async function handleCoinTransaction(account, transaction) {
|
|
|
121
122
|
const getTransactionStatus = async (account, transaction) => {
|
|
122
123
|
const subAccount = (0, account_1.findSubAccountById)(account, transaction?.subAccountId || "");
|
|
123
124
|
const isTokenTransaction = (0, account_1.isTokenAccount)(subAccount);
|
|
124
|
-
if ((0,
|
|
125
|
+
if ((0, utils_1.isTokenAssociateTransaction)(transaction)) {
|
|
125
126
|
return handleTokenAssociateTransaction(account, transaction);
|
|
126
127
|
}
|
|
127
128
|
else if (isTokenTransaction) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getTransactionStatus.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":";;;;;;AAAA,gEAAqC;AACrC,6CAK0B;AAE1B,8DAAsF;AACtF,iDAA4C;AAC5C,sCAImB;AACnB,
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prepareTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"prepareTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAI1D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAG5C;;;;;;;GAOG;AACH,eAAO,MAAM,kBAAkB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,oBAAoB,CA+B/E,CAAC"}
|
|
@@ -2,9 +2,10 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.prepareTransaction = void 0;
|
|
4
4
|
const helpers_1 = require("@ledgerhq/coin-framework/account/helpers");
|
|
5
|
-
const utils_1 = require("./utils");
|
|
6
5
|
const constants_1 = require("../constants");
|
|
7
|
-
const
|
|
6
|
+
const estimateFees_1 = require("../logic/estimateFees");
|
|
7
|
+
const utils_1 = require("../logic/utils");
|
|
8
|
+
const utils_2 = require("./utils");
|
|
8
9
|
/**
|
|
9
10
|
* Gather any more neccessary information for a transaction,
|
|
10
11
|
* potentially from a network.
|
|
@@ -17,7 +18,7 @@ const prepareTransaction = async (account, transaction) => {
|
|
|
17
18
|
const subAccount = (0, helpers_1.findSubAccountById)(account, transaction?.subAccountId || "");
|
|
18
19
|
const isTokenTransaction = (0, helpers_1.isTokenAccount)(subAccount);
|
|
19
20
|
let operationType;
|
|
20
|
-
if ((0,
|
|
21
|
+
if ((0, utils_1.isTokenAssociateTransaction)(transaction)) {
|
|
21
22
|
operationType = constants_1.HEDERA_OPERATION_TYPES.TokenAssociate;
|
|
22
23
|
}
|
|
23
24
|
else if (isTokenTransaction) {
|
|
@@ -29,8 +30,8 @@ const prepareTransaction = async (account, transaction) => {
|
|
|
29
30
|
// explicitly calculate transaction amount to account for `useAllAmount` flag (send max flow)
|
|
30
31
|
// i.e. if `useAllAmount` has been toggled to true, this is where it will update the transaction to reflect that action
|
|
31
32
|
const [{ amount }, estimatedFees] = await Promise.all([
|
|
32
|
-
(0,
|
|
33
|
-
(0,
|
|
33
|
+
(0, utils_2.calculateAmount)({ account, transaction }),
|
|
34
|
+
(0, estimateFees_1.estimateFees)(account.currency, operationType),
|
|
34
35
|
]);
|
|
35
36
|
// `maxFee` must be explicitly set to avoid the @hashgraph/sdk default fallback
|
|
36
37
|
// this ensures device app validation passes (e.g. during swap flow)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prepareTransaction.js","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":";;;AAAA,sEAA8F;
|
|
1
|
+
{"version":3,"file":"prepareTransaction.js","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":";;;AAAA,sEAA8F;AAE9F,4CAAsD;AACtD,wDAAqD;AACrD,0CAA6D;AAE7D,mCAA0C;AAE1C;;;;;;;GAOG;AACI,MAAM,kBAAkB,GAAqD,KAAK,EACvF,OAAO,EACP,WAAW,EACW,EAAE;IACxB,MAAM,UAAU,GAAG,IAAA,4BAAkB,EAAC,OAAO,EAAE,WAAW,EAAE,YAAY,IAAI,EAAE,CAAC,CAAC;IAChF,MAAM,kBAAkB,GAAG,IAAA,wBAAc,EAAC,UAAU,CAAC,CAAC;IACtD,IAAI,aAAqC,CAAC;IAE1C,IAAI,IAAA,mCAA2B,EAAC,WAAW,CAAC,EAAE,CAAC;QAC7C,aAAa,GAAG,kCAAsB,CAAC,cAAc,CAAC;IACxD,CAAC;SAAM,IAAI,kBAAkB,EAAE,CAAC;QAC9B,aAAa,GAAG,kCAAsB,CAAC,aAAa,CAAC;IACvD,CAAC;SAAM,CAAC;QACN,aAAa,GAAG,kCAAsB,CAAC,cAAc,CAAC;IACxD,CAAC;IAED,6FAA6F;IAC7F,uHAAuH;IACvH,MAAM,CAAC,EAAE,MAAM,EAAE,EAAE,aAAa,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QACpD,IAAA,uBAAe,EAAC,EAAE,OAAO,EAAE,WAAW,EAAE,CAAC;QACzC,IAAA,2BAAY,EAAC,OAAO,CAAC,QAAQ,EAAE,aAAa,CAAC;KAC9C,CAAC,CAAC;IAEH,+EAA+E;IAC/E,oEAAoE;IACpE,2EAA2E;IAC3E,WAAW,CAAC,MAAM,GAAG,aAAa,CAAC;IAEnC,WAAW,CAAC,MAAM,GAAG,MAAM,CAAC;IAE5B,OAAO,WAAW,CAAC;AACrB,CAAC,CAAC;AA/BW,QAAA,kBAAkB,sBA+B7B"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Account, AccountBridge } from "@ledgerhq/types-live";
|
|
2
2
|
import { SignerContext } from "@ledgerhq/coin-framework/signer";
|
|
3
|
-
import { Transaction, HederaSigner } from "../types";
|
|
3
|
+
import type { Transaction, HederaSigner } from "../types";
|
|
4
4
|
export declare const buildSignOperation: (signerContext: SignerContext<HederaSigner>) => AccountBridge<Transaction, Account>["signOperation"];
|
|
5
5
|
//# sourceMappingURL=signOperation.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"signOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"signOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAE9D,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAYhE,OAAO,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAE1D,eAAO,MAAM,kBAAkB,kBAEZ,cAAc,YAAY,CAAC,KACzC,cAAc,WAAW,EAAE,OAAO,CAAC,CAAC,eAAe,CA0FlD,CAAC"}
|