@ledgerhq/coin-tezos 6.6.0-nightly.1 → 6.6.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 +30 -4
- package/CHANGELOG.md +17 -8
- package/jest.integ.config.js +0 -1
- package/lib/api/index.d.ts.map +1 -1
- package/lib/api/index.js +40 -188
- package/lib/api/index.js.map +1 -1
- package/lib/api/index.test.js +10 -79
- package/lib/api/index.test.js.map +1 -1
- package/lib/api/types.d.ts +5 -7
- package/lib/api/types.d.ts.map +1 -1
- package/lib/bridge/broadcast.d.ts +4 -0
- package/lib/bridge/broadcast.d.ts.map +1 -0
- package/lib/bridge/broadcast.js +11 -0
- package/lib/bridge/broadcast.js.map +1 -0
- package/lib/bridge/broadcast.test.d.ts +2 -0
- package/lib/bridge/broadcast.test.d.ts.map +1 -0
- package/lib/bridge/broadcast.test.js +36 -0
- package/lib/bridge/broadcast.test.js.map +1 -0
- package/lib/bridge/buildOptimisticOperation.d.ts +4 -0
- package/lib/bridge/buildOptimisticOperation.d.ts.map +1 -0
- package/lib/bridge/buildOptimisticOperation.js +28 -0
- package/lib/bridge/buildOptimisticOperation.js.map +1 -0
- package/lib/bridge/createTransaction.d.ts +4 -0
- package/lib/bridge/createTransaction.d.ts.map +1 -0
- package/lib/bridge/createTransaction.js +24 -0
- package/lib/bridge/createTransaction.js.map +1 -0
- package/lib/bridge/estimateMaxSpendable.d.ts +5 -0
- package/lib/bridge/estimateMaxSpendable.d.ts.map +1 -0
- package/lib/bridge/estimateMaxSpendable.js +30 -0
- package/lib/bridge/estimateMaxSpendable.js.map +1 -0
- package/lib/bridge/getFeesForTransaction.d.ts +21 -0
- package/lib/bridge/getFeesForTransaction.d.ts.map +1 -0
- package/lib/bridge/getFeesForTransaction.js +39 -0
- package/lib/bridge/getFeesForTransaction.js.map +1 -0
- package/lib/bridge/getTransactionStatus.d.ts +4 -0
- package/lib/bridge/getTransactionStatus.d.ts.map +1 -0
- package/lib/bridge/getTransactionStatus.js +108 -0
- package/lib/bridge/getTransactionStatus.js.map +1 -0
- package/lib/bridge/getTransactionStatus.test.d.ts +2 -0
- package/lib/bridge/getTransactionStatus.test.d.ts.map +1 -0
- package/lib/bridge/getTransactionStatus.test.js +107 -0
- package/lib/bridge/getTransactionStatus.test.js.map +1 -0
- package/lib/bridge/index.d.ts +10 -0
- package/lib/bridge/index.d.ts.map +1 -0
- package/lib/bridge/index.js +59 -0
- package/lib/bridge/index.js.map +1 -0
- package/lib/bridge/logic.d.ts +10 -0
- package/lib/bridge/logic.d.ts.map +1 -0
- package/lib/bridge/logic.js +155 -0
- package/lib/bridge/logic.js.map +1 -0
- package/lib/bridge/preload.d.ts +9 -0
- package/lib/bridge/preload.d.ts.map +1 -0
- package/lib/bridge/preload.js +23 -0
- package/lib/bridge/preload.js.map +1 -0
- package/lib/bridge/prepareTransaction.d.ts +5 -0
- package/lib/bridge/prepareTransaction.d.ts.map +1 -0
- package/lib/bridge/prepareTransaction.integ.test.d.ts +2 -0
- package/lib/bridge/prepareTransaction.integ.test.d.ts.map +1 -0
- package/lib/bridge/prepareTransaction.integ.test.js +34 -0
- package/lib/bridge/prepareTransaction.integ.test.js.map +1 -0
- package/lib/bridge/prepareTransaction.js +57 -0
- package/lib/bridge/prepareTransaction.js.map +1 -0
- package/lib/bridge/prepareTransaction.test.d.ts +2 -0
- package/lib/bridge/prepareTransaction.test.d.ts.map +1 -0
- package/lib/bridge/prepareTransaction.test.js +178 -0
- package/lib/bridge/prepareTransaction.test.js.map +1 -0
- package/lib/bridge/serialization.d.ts +7 -0
- package/lib/bridge/serialization.d.ts.map +1 -0
- package/lib/bridge/serialization.js +26 -0
- package/lib/bridge/serialization.js.map +1 -0
- package/lib/bridge/signOperation.d.ts +16 -0
- package/lib/bridge/signOperation.d.ts.map +1 -0
- package/lib/bridge/signOperation.js +88 -0
- package/lib/bridge/signOperation.js.map +1 -0
- package/lib/bridge/signOperation.test.d.ts +2 -0
- package/lib/bridge/signOperation.test.d.ts.map +1 -0
- package/lib/bridge/signOperation.test.js +283 -0
- package/lib/bridge/signOperation.test.js.map +1 -0
- package/lib/bridge/synchronization.d.ts +5 -0
- package/lib/bridge/synchronization.d.ts.map +1 -0
- package/lib/bridge/synchronization.integ.test.d.ts +2 -0
- package/lib/bridge/synchronization.integ.test.d.ts.map +1 -0
- package/lib/bridge/synchronization.integ.test.js +32 -0
- package/lib/bridge/synchronization.integ.test.js.map +1 -0
- package/lib/bridge/synchronization.js +100 -0
- package/lib/bridge/synchronization.js.map +1 -0
- package/lib/{transaction.d.ts → bridge/transaction.d.ts} +1 -1
- package/lib/bridge/transaction.d.ts.map +1 -0
- package/lib/{transaction.js → bridge/transaction.js} +3 -3
- package/lib/bridge/transaction.js.map +1 -0
- package/lib/config.d.ts +3 -4
- package/lib/config.d.ts.map +1 -1
- package/lib/config.js.map +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +3 -1
- package/lib/index.js.map +1 -1
- package/lib/logic/craftTransaction.d.ts.map +1 -1
- package/lib/logic/craftTransaction.js +0 -7
- package/lib/logic/craftTransaction.js.map +1 -1
- package/lib/logic/craftTransaction.test.js +0 -1
- package/lib/logic/craftTransaction.test.js.map +1 -1
- package/lib/logic/estimateFees.d.ts.map +1 -1
- package/lib/logic/estimateFees.integ.test.js +2 -8
- package/lib/logic/estimateFees.integ.test.js.map +1 -1
- package/lib/logic/estimateFees.js +45 -119
- package/lib/logic/estimateFees.js.map +1 -1
- package/lib/logic/getBalance.js +1 -1
- package/lib/logic/getBalance.js.map +1 -1
- package/lib/logic/index.d.ts +0 -2
- package/lib/logic/index.d.ts.map +1 -1
- package/lib/logic/index.js +1 -5
- package/lib/logic/index.js.map +1 -1
- package/lib/logic/listOperations.d.ts.map +1 -1
- package/lib/logic/listOperations.js +10 -56
- package/lib/logic/listOperations.js.map +1 -1
- package/lib/logic/listOperations.test.js +10 -14
- package/lib/logic/listOperations.test.js.map +1 -1
- package/lib/types/bridge.d.ts +0 -3
- package/lib/types/bridge.d.ts.map +1 -1
- package/lib/types/bridge.fixture.d.ts.map +1 -1
- package/lib/types/bridge.fixture.js +0 -1
- package/lib/types/bridge.fixture.js.map +1 -1
- package/lib/types/bridge.js.map +1 -1
- package/lib-es/api/index.d.ts.map +1 -1
- package/lib-es/api/index.js +41 -189
- package/lib-es/api/index.js.map +1 -1
- package/lib-es/api/index.test.js +10 -79
- package/lib-es/api/index.test.js.map +1 -1
- package/lib-es/api/types.d.ts +5 -7
- package/lib-es/api/types.d.ts.map +1 -1
- package/lib-es/bridge/broadcast.d.ts +4 -0
- package/lib-es/bridge/broadcast.d.ts.map +1 -0
- package/lib-es/bridge/broadcast.js +7 -0
- package/lib-es/bridge/broadcast.js.map +1 -0
- package/lib-es/bridge/broadcast.test.d.ts +2 -0
- package/lib-es/bridge/broadcast.test.d.ts.map +1 -0
- package/lib-es/bridge/broadcast.test.js +31 -0
- package/lib-es/bridge/broadcast.test.js.map +1 -0
- package/lib-es/bridge/buildOptimisticOperation.d.ts +4 -0
- package/lib-es/bridge/buildOptimisticOperation.d.ts.map +1 -0
- package/lib-es/bridge/buildOptimisticOperation.js +21 -0
- package/lib-es/bridge/buildOptimisticOperation.js.map +1 -0
- package/lib-es/bridge/createTransaction.d.ts +4 -0
- package/lib-es/bridge/createTransaction.d.ts.map +1 -0
- package/lib-es/bridge/createTransaction.js +17 -0
- package/lib-es/bridge/createTransaction.js.map +1 -0
- package/lib-es/bridge/estimateMaxSpendable.d.ts +5 -0
- package/lib-es/bridge/estimateMaxSpendable.d.ts.map +1 -0
- package/lib-es/bridge/estimateMaxSpendable.js +23 -0
- package/lib-es/bridge/estimateMaxSpendable.js.map +1 -0
- package/lib-es/bridge/getFeesForTransaction.d.ts +21 -0
- package/lib-es/bridge/getFeesForTransaction.d.ts.map +1 -0
- package/lib-es/bridge/getFeesForTransaction.js +33 -0
- package/lib-es/bridge/getFeesForTransaction.js.map +1 -0
- package/lib-es/bridge/getTransactionStatus.d.ts +4 -0
- package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -0
- package/lib-es/bridge/getTransactionStatus.js +101 -0
- package/lib-es/bridge/getTransactionStatus.js.map +1 -0
- package/lib-es/bridge/getTransactionStatus.test.d.ts +2 -0
- package/lib-es/bridge/getTransactionStatus.test.d.ts.map +1 -0
- package/lib-es/bridge/getTransactionStatus.test.js +102 -0
- package/lib-es/bridge/getTransactionStatus.test.js.map +1 -0
- package/lib-es/bridge/index.d.ts +10 -0
- package/lib-es/bridge/index.d.ts.map +1 -0
- package/lib-es/bridge/index.js +53 -0
- package/lib-es/bridge/index.js.map +1 -0
- package/lib-es/bridge/logic.d.ts +10 -0
- package/lib-es/bridge/logic.d.ts.map +1 -0
- package/lib-es/bridge/logic.js +145 -0
- package/lib-es/bridge/logic.js.map +1 -0
- package/lib-es/bridge/preload.d.ts +9 -0
- package/lib-es/bridge/preload.d.ts.map +1 -0
- package/lib-es/bridge/preload.js +17 -0
- package/lib-es/bridge/preload.js.map +1 -0
- package/lib-es/bridge/prepareTransaction.d.ts +5 -0
- package/lib-es/bridge/prepareTransaction.d.ts.map +1 -0
- package/lib-es/bridge/prepareTransaction.integ.test.d.ts +2 -0
- package/lib-es/bridge/prepareTransaction.integ.test.d.ts.map +1 -0
- package/lib-es/bridge/prepareTransaction.integ.test.js +29 -0
- package/lib-es/bridge/prepareTransaction.integ.test.js.map +1 -0
- package/lib-es/bridge/prepareTransaction.js +50 -0
- package/lib-es/bridge/prepareTransaction.js.map +1 -0
- package/lib-es/bridge/prepareTransaction.test.d.ts +2 -0
- package/lib-es/bridge/prepareTransaction.test.d.ts.map +1 -0
- package/lib-es/bridge/prepareTransaction.test.js +173 -0
- package/lib-es/bridge/prepareTransaction.test.js.map +1 -0
- package/lib-es/bridge/serialization.d.ts +7 -0
- package/lib-es/bridge/serialization.d.ts.map +1 -0
- package/lib-es/bridge/serialization.js +20 -0
- package/lib-es/bridge/serialization.js.map +1 -0
- package/lib-es/bridge/signOperation.d.ts +16 -0
- package/lib-es/bridge/signOperation.d.ts.map +1 -0
- package/lib-es/bridge/signOperation.js +83 -0
- package/lib-es/bridge/signOperation.js.map +1 -0
- package/lib-es/bridge/signOperation.test.d.ts +2 -0
- package/lib-es/bridge/signOperation.test.d.ts.map +1 -0
- package/lib-es/bridge/signOperation.test.js +255 -0
- package/lib-es/bridge/signOperation.test.js.map +1 -0
- package/lib-es/bridge/synchronization.d.ts +5 -0
- package/lib-es/bridge/synchronization.d.ts.map +1 -0
- package/lib-es/bridge/synchronization.integ.test.d.ts +2 -0
- package/lib-es/bridge/synchronization.integ.test.d.ts.map +1 -0
- package/lib-es/bridge/synchronization.integ.test.js +27 -0
- package/lib-es/bridge/synchronization.integ.test.js.map +1 -0
- package/lib-es/bridge/synchronization.js +70 -0
- package/lib-es/bridge/synchronization.js.map +1 -0
- package/lib-es/{transaction.d.ts → bridge/transaction.d.ts} +1 -1
- package/lib-es/bridge/transaction.d.ts.map +1 -0
- package/lib-es/{transaction.js → bridge/transaction.js} +3 -3
- package/lib-es/bridge/transaction.js.map +1 -0
- package/lib-es/config.d.ts +3 -4
- package/lib-es/config.d.ts.map +1 -1
- package/lib-es/config.js.map +1 -1
- package/lib-es/index.d.ts +1 -1
- package/lib-es/index.d.ts.map +1 -1
- package/lib-es/index.js +1 -1
- package/lib-es/index.js.map +1 -1
- package/lib-es/logic/craftTransaction.d.ts.map +1 -1
- package/lib-es/logic/craftTransaction.js +0 -7
- package/lib-es/logic/craftTransaction.js.map +1 -1
- package/lib-es/logic/craftTransaction.test.js +0 -1
- package/lib-es/logic/craftTransaction.test.js.map +1 -1
- package/lib-es/logic/estimateFees.d.ts.map +1 -1
- package/lib-es/logic/estimateFees.integ.test.js +2 -8
- package/lib-es/logic/estimateFees.integ.test.js.map +1 -1
- package/lib-es/logic/estimateFees.js +45 -119
- package/lib-es/logic/estimateFees.js.map +1 -1
- package/lib-es/logic/getBalance.js +1 -1
- package/lib-es/logic/getBalance.js.map +1 -1
- package/lib-es/logic/index.d.ts +0 -2
- package/lib-es/logic/index.d.ts.map +1 -1
- package/lib-es/logic/index.js +0 -2
- package/lib-es/logic/index.js.map +1 -1
- package/lib-es/logic/listOperations.d.ts.map +1 -1
- package/lib-es/logic/listOperations.js +10 -56
- package/lib-es/logic/listOperations.js.map +1 -1
- package/lib-es/logic/listOperations.test.js +10 -14
- package/lib-es/logic/listOperations.test.js.map +1 -1
- package/lib-es/types/bridge.d.ts +0 -3
- package/lib-es/types/bridge.d.ts.map +1 -1
- package/lib-es/types/bridge.fixture.d.ts.map +1 -1
- package/lib-es/types/bridge.fixture.js +0 -1
- package/lib-es/types/bridge.fixture.js.map +1 -1
- package/lib-es/types/bridge.js.map +1 -1
- package/package.json +14 -11
- package/src/api/index.test.ts +15 -87
- package/src/api/index.ts +55 -204
- package/src/api/types.ts +6 -11
- package/src/bridge/broadcast.test.ts +36 -0
- package/src/bridge/broadcast.ts +13 -0
- package/src/bridge/buildOptimisticOperation.ts +28 -0
- package/src/bridge/createTransaction.ts +19 -0
- package/src/bridge/estimateMaxSpendable.ts +37 -0
- package/src/bridge/getFeesForTransaction.ts +49 -0
- package/src/bridge/getTransactionStatus.test.ts +124 -0
- package/src/bridge/getTransactionStatus.ts +123 -0
- package/src/bridge/index.ts +74 -0
- package/src/bridge/logic.ts +171 -0
- package/src/bridge/preload.ts +18 -0
- package/src/bridge/prepareTransaction.integ.test.ts +35 -0
- package/src/bridge/prepareTransaction.test.ts +205 -0
- package/src/bridge/prepareTransaction.ts +69 -0
- package/src/bridge/serialization.ts +27 -0
- package/src/bridge/signOperation.test.ts +284 -0
- package/src/bridge/signOperation.ts +130 -0
- package/src/bridge/synchronization.integ.test.ts +33 -0
- package/src/bridge/synchronization.ts +100 -0
- package/src/{transaction.ts → bridge/transaction.ts} +4 -4
- package/src/config.ts +2 -9
- package/src/index.ts +2 -1
- package/src/logic/craftTransaction.test.ts +0 -1
- package/src/logic/craftTransaction.ts +0 -8
- package/src/logic/estimateFees.integ.test.ts +2 -8
- package/src/logic/estimateFees.ts +49 -140
- package/src/logic/getBalance.ts +1 -1
- package/src/logic/index.ts +0 -2
- package/src/logic/listOperations.test.ts +54 -64
- package/src/logic/listOperations.ts +9 -57
- package/src/types/bridge.fixture.ts +0 -1
- package/src/types/bridge.ts +1 -6
- package/lib/logic/getStakes.d.ts +0 -3
- package/lib/logic/getStakes.d.ts.map +0 -1
- package/lib/logic/getStakes.js +0 -26
- package/lib/logic/getStakes.js.map +0 -1
- package/lib/logic/getStakes.test.d.ts +0 -2
- package/lib/logic/getStakes.test.d.ts.map +0 -1
- package/lib/logic/getStakes.test.js +0 -133
- package/lib/logic/getStakes.test.js.map +0 -1
- package/lib/logic/validateIntent.d.ts +0 -3
- package/lib/logic/validateIntent.d.ts.map +0 -1
- package/lib/logic/validateIntent.js +0 -179
- package/lib/logic/validateIntent.js.map +0 -1
- package/lib/logic/validateIntent.test.d.ts +0 -2
- package/lib/logic/validateIntent.test.d.ts.map +0 -1
- package/lib/logic/validateIntent.test.js +0 -249
- package/lib/logic/validateIntent.test.js.map +0 -1
- package/lib/transaction.d.ts.map +0 -1
- package/lib/transaction.js.map +0 -1
- package/lib/utils.d.ts +0 -48
- package/lib/utils.d.ts.map +0 -1
- package/lib/utils.js +0 -112
- package/lib/utils.js.map +0 -1
- package/lib-es/logic/getStakes.d.ts +0 -3
- package/lib-es/logic/getStakes.d.ts.map +0 -1
- package/lib-es/logic/getStakes.js +0 -20
- package/lib-es/logic/getStakes.js.map +0 -1
- package/lib-es/logic/getStakes.test.d.ts +0 -2
- package/lib-es/logic/getStakes.test.d.ts.map +0 -1
- package/lib-es/logic/getStakes.test.js +0 -128
- package/lib-es/logic/getStakes.test.js.map +0 -1
- package/lib-es/logic/validateIntent.d.ts +0 -3
- package/lib-es/logic/validateIntent.d.ts.map +0 -1
- package/lib-es/logic/validateIntent.js +0 -173
- package/lib-es/logic/validateIntent.js.map +0 -1
- package/lib-es/logic/validateIntent.test.d.ts +0 -2
- package/lib-es/logic/validateIntent.test.d.ts.map +0 -1
- package/lib-es/logic/validateIntent.test.js +0 -221
- package/lib-es/logic/validateIntent.test.js.map +0 -1
- package/lib-es/transaction.d.ts.map +0 -1
- package/lib-es/transaction.js.map +0 -1
- package/lib-es/utils.d.ts +0 -48
- package/lib-es/utils.d.ts.map +0 -1
- package/lib-es/utils.js +0 -105
- package/lib-es/utils.js.map +0 -1
- package/src/logic/getStakes.test.ts +0 -145
- package/src/logic/getStakes.ts +0 -20
- package/src/logic/validateIntent.test.ts +0 -262
- package/src/logic/validateIntent.ts +0 -207
- package/src/utils.ts +0 -115
package/lib-es/api/types.d.ts
CHANGED
|
@@ -1,17 +1,15 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { AlpacaApi, FeeEstimation, TransactionIntent } from "@ledgerhq/coin-framework/api/types";
|
|
2
2
|
export type TezosFeeParameters = {
|
|
3
3
|
gasLimit: bigint;
|
|
4
4
|
storageLimit: bigint;
|
|
5
|
-
amount?: bigint;
|
|
6
|
-
txFee?: bigint;
|
|
7
|
-
};
|
|
8
|
-
export type TezosFeeEstimation = FeeEstimation & {
|
|
9
|
-
parameters?: TezosFeeParameters & Record<string, unknown>;
|
|
10
5
|
};
|
|
6
|
+
export type TezosFeeEstimation = FeeEstimation;
|
|
11
7
|
export type TezosSender = {
|
|
12
8
|
address: string;
|
|
13
9
|
xpub?: string;
|
|
14
10
|
};
|
|
15
11
|
export type TezosTransactionIntent = TransactionIntent;
|
|
16
|
-
export type TezosApi =
|
|
12
|
+
export type TezosApi = AlpacaApi & {
|
|
13
|
+
estimateFees: (transactionIntent: TezosTransactionIntent) => Promise<TezosFeeEstimation>;
|
|
14
|
+
};
|
|
17
15
|
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/api/types.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/api/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AAEjG,MAAM,MAAM,kBAAkB,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAC;IAAC,YAAY,EAAE,MAAM,CAAA;CAAE,CAAC;AAC5E,MAAM,MAAM,kBAAkB,GAAG,aAAa,CAAC;AAE/C,MAAM,MAAM,WAAW,GAAG;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC;AAC7D,MAAM,MAAM,sBAAsB,GAAG,iBAAiB,CAAC;AAEvD,MAAM,MAAM,QAAQ,GAAG,SAAS,GAAG;IACjC,YAAY,EAAE,CAAC,iBAAiB,EAAE,sBAAsB,KAAK,OAAO,CAAC,kBAAkB,CAAC,CAAC;CAC1F,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAmB,MAAM,sBAAsB,CAAC;AACtE,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAGvC,eAAO,MAAM,SAAS,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,WAAW,CAO7D,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { patchOperationWithHash } from "@ledgerhq/coin-framework/operation";
|
|
2
|
+
import { broadcast as logicBroadcast } from "../logic";
|
|
3
|
+
export const broadcast = async ({ signedOperation: { operation, signature }, }) => {
|
|
4
|
+
const hash = await logicBroadcast(signature);
|
|
5
|
+
return patchOperationWithHash(operation, hash);
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=broadcast.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAG5E,OAAO,EAAE,SAAS,IAAI,cAAc,EAAE,MAAM,UAAU,CAAC;AAEvD,MAAM,CAAC,MAAM,SAAS,GAA4C,KAAK,EAAE,EACvE,eAAe,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,GAG1C,EAAE,EAAE;IACH,MAAM,IAAI,GAAG,MAAM,cAAc,CAAC,SAAS,CAAC,CAAC;IAC7C,OAAO,sBAAsB,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;AACjD,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.test.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { createFixtureOperation } from "../types/bridge.fixture";
|
|
2
|
+
import config from "../config";
|
|
3
|
+
import { broadcast } from "./broadcast";
|
|
4
|
+
import { mockConfig } from "../test/config";
|
|
5
|
+
const mockInjectOperation = jest.fn();
|
|
6
|
+
jest.mock("@taquito/taquito", () => ({
|
|
7
|
+
TezosToolkit: jest.fn().mockReturnValue({
|
|
8
|
+
rpc: {
|
|
9
|
+
injectOperation: () => mockInjectOperation(),
|
|
10
|
+
},
|
|
11
|
+
}),
|
|
12
|
+
}));
|
|
13
|
+
describe("broadcast", () => {
|
|
14
|
+
beforeAll(() => {
|
|
15
|
+
config.setCoinConfig(() => mockConfig);
|
|
16
|
+
});
|
|
17
|
+
it("calls 'injectOperation' from TezosToolkit and returns its hash computation", async () => {
|
|
18
|
+
// GIVEN
|
|
19
|
+
const signedOperation = {
|
|
20
|
+
operation: createFixtureOperation(),
|
|
21
|
+
signature: "SIGNATURE",
|
|
22
|
+
};
|
|
23
|
+
mockInjectOperation.mockResolvedValue("SIGN_HASH");
|
|
24
|
+
// WHEN
|
|
25
|
+
const op = await broadcast({ signedOperation, account: {} });
|
|
26
|
+
// THEN
|
|
27
|
+
expect(mockInjectOperation).toHaveBeenCalledTimes(1);
|
|
28
|
+
expect(op.hash).toEqual("SIGN_HASH");
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
//# sourceMappingURL=broadcast.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"broadcast.test.js","sourceRoot":"","sources":["../../src/bridge/broadcast.test.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,MAAgC,MAAM,WAAW,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAE5C,MAAM,mBAAmB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AACtC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,GAAG,EAAE,CAAC,CAAC;IACnC,YAAY,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC;QACtC,GAAG,EAAE;YACH,eAAe,EAAE,GAAG,EAAE,CAAC,mBAAmB,EAAE;SAC7C;KACF,CAAC;CACH,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,CAAC,aAAa,CAAC,GAAoB,EAAE,CAAC,UAA6B,CAAC,CAAC;IAC7E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;QAC1F,QAAQ;QACR,MAAM,eAAe,GAAoB;YACvC,SAAS,EAAE,sBAAsB,EAAE;YACnC,SAAS,EAAE,WAAW;SACvB,CAAC;QACF,mBAAmB,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QAEnD,OAAO;QACP,MAAM,EAAE,GAAG,MAAM,SAAS,CAAC,EAAE,eAAe,EAAE,OAAO,EAAE,EAAS,EAAE,CAAC,CAAC;QAEpE,OAAO;QACP,MAAM,CAAC,mBAAmB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACrD,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { OperationType } from "@ledgerhq/types-live";
|
|
2
|
+
import { TezosAccount, TezosOperation, Transaction } from "../types";
|
|
3
|
+
export declare const buildOptimisticOperation: (account: TezosAccount, transaction: Transaction, operationType: OperationType) => TezosOperation;
|
|
4
|
+
//# sourceMappingURL=buildOptimisticOperation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildOptimisticOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAGrE,eAAO,MAAM,wBAAwB,YAC1B,YAAY,eACR,WAAW,iBACT,aAAa,KAC3B,cAkBF,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { encodeOperationId } from "@ledgerhq/coin-framework/operation";
|
|
2
|
+
import BigNumber from "bignumber.js";
|
|
3
|
+
export const buildOptimisticOperation = (account, transaction, operationType) => {
|
|
4
|
+
const txHash = ""; // resolved at broadcast time
|
|
5
|
+
const { id: accountId } = account;
|
|
6
|
+
return {
|
|
7
|
+
id: encodeOperationId(accountId, txHash, operationType),
|
|
8
|
+
hash: txHash,
|
|
9
|
+
type: operationType,
|
|
10
|
+
value: transaction.amount,
|
|
11
|
+
fee: transaction.fees || new BigNumber(0),
|
|
12
|
+
extra: {},
|
|
13
|
+
blockHash: null,
|
|
14
|
+
blockHeight: null,
|
|
15
|
+
senders: [account.freshAddress],
|
|
16
|
+
recipients: [transaction.recipient],
|
|
17
|
+
accountId,
|
|
18
|
+
date: new Date(),
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
//# sourceMappingURL=buildOptimisticOperation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildOptimisticOperation.js","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AAEvE,OAAO,SAAS,MAAM,cAAc,CAAC;AAErC,MAAM,CAAC,MAAM,wBAAwB,GAAG,CACtC,OAAqB,EACrB,WAAwB,EACxB,aAA4B,EACZ,EAAE;IAClB,MAAM,MAAM,GAAG,EAAE,CAAC,CAAC,6BAA6B;IAChD,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC;IAElC,OAAO;QACL,EAAE,EAAE,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,aAAa,CAAC;QACvD,IAAI,EAAE,MAAM;QACZ,IAAI,EAAE,aAAa;QACnB,KAAK,EAAE,WAAW,CAAC,MAAM;QACzB,GAAG,EAAE,WAAW,CAAC,IAAI,IAAI,IAAI,SAAS,CAAC,CAAC,CAAC;QACzC,KAAK,EAAE,EAAE;QACT,SAAS,EAAE,IAAI;QACf,WAAW,EAAE,IAAI;QACjB,OAAO,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC;QAC/B,UAAU,EAAE,CAAC,WAAW,CAAC,SAAS,CAAC;QACnC,SAAS;QACT,IAAI,EAAE,IAAI,IAAI,EAAE;KACjB,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,eAAO,MAAM,iBAAiB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,mBAAmB,CAc7E,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
export const createTransaction = () => {
|
|
3
|
+
return {
|
|
4
|
+
family: "tezos",
|
|
5
|
+
mode: "send",
|
|
6
|
+
amount: new BigNumber(0),
|
|
7
|
+
fees: null,
|
|
8
|
+
gasLimit: null,
|
|
9
|
+
storageLimit: null,
|
|
10
|
+
recipient: "",
|
|
11
|
+
networkInfo: null,
|
|
12
|
+
useAllAmount: false,
|
|
13
|
+
taquitoError: null,
|
|
14
|
+
estimatedFees: null,
|
|
15
|
+
};
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=createTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createTransaction.js","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AAIrC,MAAM,CAAC,MAAM,iBAAiB,GAAoD,GAAG,EAAE;IACrF,OAAO;QACL,MAAM,EAAE,OAAO;QACf,IAAI,EAAE,MAAM;QACZ,MAAM,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC;QACxB,IAAI,EAAE,IAAI;QACV,QAAQ,EAAE,IAAI;QACd,YAAY,EAAE,IAAI;QAClB,SAAS,EAAE,EAAE;QACb,WAAW,EAAE,IAAI;QACjB,YAAY,EAAE,KAAK;QACnB,YAAY,EAAE,IAAI;QAClB,aAAa,EAAE,IAAI;KACpB,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { AccountBridge } from "@ledgerhq/types-live";
|
|
2
|
+
import { Transaction } from "../types";
|
|
3
|
+
export declare const estimateMaxSpendable: AccountBridge<Transaction>["estimateMaxSpendable"];
|
|
4
|
+
export default estimateMaxSpendable;
|
|
5
|
+
//# sourceMappingURL=estimateMaxSpendable.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estimateMaxSpendable.d.ts","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":"AACA,OAAO,EAAW,aAAa,EAAe,MAAM,sBAAsB,CAAC;AAE3E,OAAO,EAAgB,WAAW,EAAE,MAAM,UAAU,CAAC;AAOrD,eAAO,MAAM,oBAAoB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,sBAAsB,CAwBnF,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { getMainAccount } from "@ledgerhq/coin-framework/account/index";
|
|
2
|
+
import { prepareTransaction } from "./prepareTransaction";
|
|
3
|
+
import { createTransaction } from "./createTransaction";
|
|
4
|
+
import getEstimatedFees from "./getFeesForTransaction";
|
|
5
|
+
const TEZOS_BURN_ADDRESS = "tz1burnburnburnburnburnburnburjAYjjX";
|
|
6
|
+
export const estimateMaxSpendable = async ({ account, parentAccount, transaction, }) => {
|
|
7
|
+
const mainAccount = getMainAccount(account, parentAccount);
|
|
8
|
+
const tx = await prepareTransaction(mainAccount, {
|
|
9
|
+
...createTransaction(account),
|
|
10
|
+
...transaction,
|
|
11
|
+
// estimate using a burn address that exists so we don't enter into NotEnoughBalanceBecauseDestinationNotCreated
|
|
12
|
+
recipient: transaction?.recipient || TEZOS_BURN_ADDRESS,
|
|
13
|
+
useAllAmount: true,
|
|
14
|
+
});
|
|
15
|
+
const estimation = await getEstimatedFees({
|
|
16
|
+
account: mainAccount,
|
|
17
|
+
transaction: tx,
|
|
18
|
+
});
|
|
19
|
+
// As we use `useAllAmount`, we know we will receive an amount value.
|
|
20
|
+
return estimation.amount;
|
|
21
|
+
};
|
|
22
|
+
export default estimateMaxSpendable;
|
|
23
|
+
//# sourceMappingURL=estimateMaxSpendable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estimateMaxSpendable.js","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,wCAAwC,CAAC;AAExE,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,gBAAgB,MAAM,yBAAyB,CAAC;AAEvD,MAAM,kBAAkB,GAAG,sCAAsC,CAAC;AAElE,MAAM,CAAC,MAAM,oBAAoB,GAAuD,KAAK,EAAE,EAC7F,OAAO,EACP,aAAa,EACb,WAAW,GAKZ,EAAsB,EAAE;IACvB,MAAM,WAAW,GAAG,cAAc,CAAC,OAAO,EAAE,aAAa,CAAiB,CAAC;IAC3E,MAAM,EAAE,GAAG,MAAM,kBAAkB,CAAC,WAAW,EAAE;QAC/C,GAAG,iBAAiB,CAAC,OAAO,CAAC;QAC7B,GAAG,WAAW;QACd,gHAAgH;QAChH,SAAS,EAAE,WAAW,EAAE,SAAS,IAAI,kBAAkB;QACvD,YAAY,EAAE,IAAI;KACnB,CAAC,CAAC;IACH,MAAM,UAAU,GAAG,MAAM,gBAAgB,CAAC;QACxC,OAAO,EAAE,WAAW;QACpB,WAAW,EAAE,EAAE;KAChB,CAAC,CAAC;IAEH,qEAAqE;IACrE,OAAO,UAAU,CAAC,MAAO,CAAC;AAC5B,CAAC,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
import { TezosAccount, Transaction } from "../types";
|
|
3
|
+
export type EstimatedFees = {
|
|
4
|
+
fees: BigNumber;
|
|
5
|
+
gasLimit: BigNumber;
|
|
6
|
+
storageLimit: BigNumber;
|
|
7
|
+
estimatedFees: BigNumber;
|
|
8
|
+
amount?: BigNumber;
|
|
9
|
+
taquitoError?: string;
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* Fetch the transaction fees for a transaction
|
|
13
|
+
*
|
|
14
|
+
* @param {Account} a
|
|
15
|
+
* @param {Transaction} t
|
|
16
|
+
*/
|
|
17
|
+
export default function getEstimatedFees({ account, transaction, }: {
|
|
18
|
+
account: TezosAccount;
|
|
19
|
+
transaction: Transaction;
|
|
20
|
+
}): Promise<EstimatedFees>;
|
|
21
|
+
//# sourceMappingURL=getFeesForTransaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getFeesForTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/getFeesForTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAGrD,MAAM,MAAM,aAAa,GAAG;IAC1B,IAAI,EAAE,SAAS,CAAC;IAChB,QAAQ,EAAE,SAAS,CAAC;IACpB,YAAY,EAAE,SAAS,CAAC;IACxB,aAAa,EAAE,SAAS,CAAC;IACzB,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AACF;;;;;GAKG;AACH,wBAA8B,gBAAgB,CAAC,EAC7C,OAAO,EACP,WAAW,GACZ,EAAE;IACD,OAAO,EAAE,YAAY,CAAC;IACtB,WAAW,EAAE,WAAW,CAAC;CAC1B,GAAG,OAAO,CAAC,aAAa,CAAC,CAwBzB"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
import { estimateFees } from "../logic";
|
|
3
|
+
/**
|
|
4
|
+
* Fetch the transaction fees for a transaction
|
|
5
|
+
*
|
|
6
|
+
* @param {Account} a
|
|
7
|
+
* @param {Transaction} t
|
|
8
|
+
*/
|
|
9
|
+
export default async function getEstimatedFees({ account, transaction, }) {
|
|
10
|
+
const estimate = await estimateFees({
|
|
11
|
+
account: {
|
|
12
|
+
xpub: account.xpub,
|
|
13
|
+
address: account.freshAddress,
|
|
14
|
+
balance: BigInt(account.balance.toString()),
|
|
15
|
+
revealed: account.tezosResources.revealed,
|
|
16
|
+
},
|
|
17
|
+
transaction: {
|
|
18
|
+
mode: transaction.mode,
|
|
19
|
+
recipient: transaction.recipient,
|
|
20
|
+
amount: BigInt(transaction.amount.toString()),
|
|
21
|
+
useAllAmount: transaction.useAllAmount,
|
|
22
|
+
},
|
|
23
|
+
});
|
|
24
|
+
return {
|
|
25
|
+
fees: BigNumber(estimate.fees.toString()),
|
|
26
|
+
gasLimit: BigNumber(estimate.gasLimit.toString()),
|
|
27
|
+
storageLimit: BigNumber(estimate.storageLimit.toString()),
|
|
28
|
+
estimatedFees: BigNumber(estimate.estimatedFees.toString()),
|
|
29
|
+
amount: estimate.amount !== undefined ? BigNumber(estimate.amount.toString()) : BigNumber(0),
|
|
30
|
+
taquitoError: estimate.taquitoError,
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=getFeesForTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getFeesForTransaction.js","sourceRoot":"","sources":["../../src/bridge/getFeesForTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AAErC,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAUxC;;;;;GAKG;AACH,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,gBAAgB,CAAC,EAC7C,OAAO,EACP,WAAW,GAIZ;IACC,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC;QAClC,OAAO,EAAE;YACP,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,OAAO,EAAE,OAAO,CAAC,YAAY;YAC7B,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;YAC3C,QAAQ,EAAE,OAAO,CAAC,cAAc,CAAC,QAAQ;SAC1C;QACD,WAAW,EAAE;YACX,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,SAAS,EAAE,WAAW,CAAC,SAAS;YAChC,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;YAC7C,YAAY,EAAE,WAAW,CAAC,YAAY;SACvC;KACF,CAAC,CAAC;IAEH,OAAO;QACL,IAAI,EAAE,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACzC,QAAQ,EAAE,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACjD,YAAY,EAAE,SAAS,CAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;QACzD,aAAa,EAAE,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;QAC3D,MAAM,EAAE,QAAQ,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;QAC5F,YAAY,EAAE,QAAQ,CAAC,YAAY;KACpC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AAWA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAKrD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAIvC,eAAO,MAAM,oBAAoB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,sBAAsB,CAsGnF,CAAC"}
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import { AmountRequired, FeeTooHigh, InvalidAddressBecauseDestinationIsAlsoSource, NotEnoughBalance, NotEnoughBalanceBecauseDestinationNotCreated, NotEnoughBalanceToDelegate, RecommendUndelegation, } from "@ledgerhq/errors";
|
|
2
|
+
import { log } from "@ledgerhq/logs";
|
|
3
|
+
import BigNumber from "bignumber.js";
|
|
4
|
+
import { InvalidAddressBecauseAlreadyDelegated } from "../types/errors";
|
|
5
|
+
import { validateRecipient } from "../logic";
|
|
6
|
+
import { isAccountDelegating } from "../network/bakers";
|
|
7
|
+
import api from "../network/tzkt";
|
|
8
|
+
const EXISTENTIAL_DEPOSIT = new BigNumber(275000);
|
|
9
|
+
export const getTransactionStatus = async (account, transaction) => {
|
|
10
|
+
const errors = {};
|
|
11
|
+
const warnings = {};
|
|
12
|
+
let resetTotalSpent = false;
|
|
13
|
+
// Recipient validation logic
|
|
14
|
+
if (transaction.mode !== "undelegate") {
|
|
15
|
+
if (account.freshAddress === transaction.recipient) {
|
|
16
|
+
errors.recipient = new InvalidAddressBecauseDestinationIsAlsoSource();
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
const { recipientError, recipientWarning } = await validateRecipient(transaction.recipient);
|
|
20
|
+
if (recipientError) {
|
|
21
|
+
errors.recipient = recipientError;
|
|
22
|
+
}
|
|
23
|
+
if (recipientWarning) {
|
|
24
|
+
warnings.recipient = recipientWarning;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
// Pre validation of amount field
|
|
29
|
+
const estimatedFees = transaction.estimatedFees || new BigNumber(0);
|
|
30
|
+
if (transaction.mode === "send") {
|
|
31
|
+
if (!errors.amount && transaction.amount.eq(0) && !transaction.useAllAmount) {
|
|
32
|
+
resetTotalSpent = true;
|
|
33
|
+
errors.amount = new AmountRequired();
|
|
34
|
+
}
|
|
35
|
+
else if (transaction.amount.gt(0) && estimatedFees.times(10).gt(transaction.amount)) {
|
|
36
|
+
warnings.feeTooHigh = new FeeTooHigh();
|
|
37
|
+
}
|
|
38
|
+
const thresholdWarning = 0.5 * 10 ** account.currency.units[0].magnitude;
|
|
39
|
+
if (!errors.amount &&
|
|
40
|
+
account.balance.minus(transaction.amount).minus(estimatedFees).lt(thresholdWarning)) {
|
|
41
|
+
if (isAccountDelegating(account)) {
|
|
42
|
+
if (transaction.useAllAmount) {
|
|
43
|
+
errors.amount = new RecommendUndelegation();
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
warnings.amount = new RecommendUndelegation();
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
// effective amount
|
|
52
|
+
// if we also have taquitoError, we interprete them and they override the previously inferred errors
|
|
53
|
+
if (transaction.taquitoError) {
|
|
54
|
+
log("taquitoerror", String(transaction.taquitoError));
|
|
55
|
+
// remap taquito errors
|
|
56
|
+
if (transaction.taquitoError.endsWith("balance_too_low") ||
|
|
57
|
+
transaction.taquitoError.endsWith("subtraction_underflow")) {
|
|
58
|
+
if (transaction.mode === "send") {
|
|
59
|
+
resetTotalSpent = true;
|
|
60
|
+
errors.amount = new NotEnoughBalance();
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
errors.amount = new NotEnoughBalanceToDelegate();
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
else if (transaction.taquitoError.endsWith("delegate.unchanged")) {
|
|
67
|
+
errors.recipient = new InvalidAddressBecauseAlreadyDelegated();
|
|
68
|
+
}
|
|
69
|
+
else if (!errors.amount) {
|
|
70
|
+
// unidentified error case
|
|
71
|
+
errors.amount = new Error(transaction.taquitoError);
|
|
72
|
+
resetTotalSpent = true;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
if (!errors.amount && account.balance.lte(0)) {
|
|
76
|
+
resetTotalSpent = true;
|
|
77
|
+
errors.amount = new NotEnoughBalance();
|
|
78
|
+
}
|
|
79
|
+
if (!errors.amount && transaction.mode === "delegate" && account.balance.lte(estimatedFees)) {
|
|
80
|
+
resetTotalSpent = true;
|
|
81
|
+
errors.amount = new NotEnoughBalance();
|
|
82
|
+
}
|
|
83
|
+
// Catch a specific case that requires a minimum amount
|
|
84
|
+
if (!errors.amount &&
|
|
85
|
+
transaction.mode === "send" &&
|
|
86
|
+
transaction.amount.lt(EXISTENTIAL_DEPOSIT) &&
|
|
87
|
+
(await api.getAccountByAddress(transaction.recipient)).type === "empty") {
|
|
88
|
+
resetTotalSpent = true;
|
|
89
|
+
errors.amount = new NotEnoughBalanceBecauseDestinationNotCreated("", {
|
|
90
|
+
minimalAmount: "0.275 XTZ",
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
return {
|
|
94
|
+
errors,
|
|
95
|
+
warnings,
|
|
96
|
+
estimatedFees,
|
|
97
|
+
amount: transaction.amount,
|
|
98
|
+
totalSpent: resetTotalSpent ? new BigNumber(0) : transaction.amount.plus(estimatedFees),
|
|
99
|
+
};
|
|
100
|
+
};
|
|
101
|
+
//# sourceMappingURL=getTransactionStatus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EACd,UAAU,EACV,4CAA4C,EAC5C,gBAAgB,EAChB,4CAA4C,EAC5C,0BAA0B,EAC1B,qBAAqB,GACtB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,SAAS,MAAM,cAAc,CAAC;AAErC,OAAO,EAAE,qCAAqC,EAAE,MAAM,iBAAiB,CAAC;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,GAAG,MAAM,iBAAiB,CAAC;AAGlC,MAAM,mBAAmB,GAAG,IAAI,SAAS,CAAC,MAAM,CAAC,CAAC;AAElD,MAAM,CAAC,MAAM,oBAAoB,GAAuD,KAAK,EAC3F,OAAO,EACP,WAAW,EACX,EAAE;IACF,MAAM,MAAM,GAA0B,EAAE,CAAC;IACzC,MAAM,QAAQ,GAA0B,EAAE,CAAC;IAC3C,IAAI,eAAe,GAAG,KAAK,CAAC;IAE5B,6BAA6B;IAC7B,IAAI,WAAW,CAAC,IAAI,KAAK,YAAY,EAAE,CAAC;QACtC,IAAI,OAAO,CAAC,YAAY,KAAK,WAAW,CAAC,SAAS,EAAE,CAAC;YACnD,MAAM,CAAC,SAAS,GAAG,IAAI,4CAA4C,EAAE,CAAC;QACxE,CAAC;aAAM,CAAC;YACN,MAAM,EAAE,cAAc,EAAE,gBAAgB,EAAE,GAAG,MAAM,iBAAiB,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;YAC5F,IAAI,cAAc,EAAE,CAAC;gBACnB,MAAM,CAAC,SAAS,GAAG,cAAc,CAAC;YACpC,CAAC;YACD,IAAI,gBAAgB,EAAE,CAAC;gBACrB,QAAQ,CAAC,SAAS,GAAG,gBAAgB,CAAC;YACxC,CAAC;QACH,CAAC;IACH,CAAC;IAED,iCAAiC;IACjC,MAAM,aAAa,GAAG,WAAW,CAAC,aAAa,IAAI,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC;IACpE,IAAI,WAAW,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;QAChC,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,CAAC;YAC5E,eAAe,GAAG,IAAI,CAAC;YACvB,MAAM,CAAC,MAAM,GAAG,IAAI,cAAc,EAAE,CAAC;QACvC,CAAC;aAAM,IAAI,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,aAAa,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC;YACtF,QAAQ,CAAC,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;QACzC,CAAC;QACD,MAAM,gBAAgB,GAAG,GAAG,GAAG,EAAE,IAAI,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QACzE,IACE,CAAC,MAAM,CAAC,MAAM;YACd,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,EAAE,CAAC,gBAAgB,CAAC,EACnF,CAAC;YACD,IAAI,mBAAmB,CAAC,OAAO,CAAC,EAAE,CAAC;gBACjC,IAAI,WAAW,CAAC,YAAY,EAAE,CAAC;oBAC7B,MAAM,CAAC,MAAM,GAAG,IAAI,qBAAqB,EAAE,CAAC;gBAC9C,CAAC;qBAAM,CAAC;oBACN,QAAQ,CAAC,MAAM,GAAG,IAAI,qBAAqB,EAAE,CAAC;gBAChD,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,mBAAmB;IACnB,oGAAoG;IACpG,IAAI,WAAW,CAAC,YAAY,EAAE,CAAC;QAC7B,GAAG,CAAC,cAAc,EAAE,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC;QAEtD,uBAAuB;QACvB,IACE,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,iBAAiB,CAAC;YACpD,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,uBAAuB,CAAC,EAC1D,CAAC;YACD,IAAI,WAAW,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;gBAChC,eAAe,GAAG,IAAI,CAAC;gBACvB,MAAM,CAAC,MAAM,GAAG,IAAI,gBAAgB,EAAE,CAAC;YACzC,CAAC;iBAAM,CAAC;gBACN,MAAM,CAAC,MAAM,GAAG,IAAI,0BAA0B,EAAE,CAAC;YACnD,CAAC;QACH,CAAC;aAAM,IAAI,WAAW,CAAC,YAAY,CAAC,QAAQ,CAAC,oBAAoB,CAAC,EAAE,CAAC;YACnE,MAAM,CAAC,SAAS,GAAG,IAAI,qCAAqC,EAAE,CAAC;QACjE,CAAC;aAAM,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;YAC1B,0BAA0B;YAC1B,MAAM,CAAC,MAAM,GAAG,IAAI,KAAK,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;YACpD,eAAe,GAAG,IAAI,CAAC;QACzB,CAAC;IACH,CAAC;IAED,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QAC7C,eAAe,GAAG,IAAI,CAAC;QACvB,MAAM,CAAC,MAAM,GAAG,IAAI,gBAAgB,EAAE,CAAC;IACzC,CAAC;IAED,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,WAAW,CAAC,IAAI,KAAK,UAAU,IAAI,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC;QAC5F,eAAe,GAAG,IAAI,CAAC;QACvB,MAAM,CAAC,MAAM,GAAG,IAAI,gBAAgB,EAAE,CAAC;IACzC,CAAC;IAED,uDAAuD;IACvD,IACE,CAAC,MAAM,CAAC,MAAM;QACd,WAAW,CAAC,IAAI,KAAK,MAAM;QAC3B,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,mBAAmB,CAAC;QAC1C,CAAC,MAAM,GAAG,CAAC,mBAAmB,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,EACvE,CAAC;QACD,eAAe,GAAG,IAAI,CAAC;QACvB,MAAM,CAAC,MAAM,GAAG,IAAI,4CAA4C,CAAC,EAAE,EAAE;YACnE,aAAa,EAAE,WAAW;SAC3B,CAAC,CAAC;IACL,CAAC;IAED,OAAO;QACL,MAAM;QACN,QAAQ;QACR,aAAa;QACb,MAAM,EAAE,WAAW,CAAC,MAAM;QAC1B,UAAU,EAAE,eAAe,CAAC,CAAC,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC;KACxF,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.test.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import BigNumber from "bignumber.js";
|
|
2
|
+
import { getTransactionStatus } from "./getTransactionStatus";
|
|
3
|
+
import { validateRecipient } from "../logic";
|
|
4
|
+
import { isAccountDelegating } from "../network/bakers";
|
|
5
|
+
import api from "../network/tzkt";
|
|
6
|
+
import { AmountRequired, FeeTooHigh, InvalidAddressBecauseDestinationIsAlsoSource, NotEnoughBalance, NotEnoughBalanceBecauseDestinationNotCreated, RecommendUndelegation, } from "@ledgerhq/errors";
|
|
7
|
+
jest.mock("../logic", () => ({
|
|
8
|
+
validateRecipient: jest.fn(),
|
|
9
|
+
}));
|
|
10
|
+
jest.mock("../network/bakers", () => ({
|
|
11
|
+
isAccountDelegating: jest.fn(),
|
|
12
|
+
}));
|
|
13
|
+
jest.mock("../network/tzkt", () => ({
|
|
14
|
+
getAccountByAddress: jest.fn(),
|
|
15
|
+
}));
|
|
16
|
+
describe("getTransactionStatus", () => {
|
|
17
|
+
const mockAccount = {
|
|
18
|
+
type: "Account",
|
|
19
|
+
freshAddress: "tz1SourceAddress",
|
|
20
|
+
balance: new BigNumber(1000000),
|
|
21
|
+
currency: {
|
|
22
|
+
type: "CryptoCurrency",
|
|
23
|
+
units: [
|
|
24
|
+
{
|
|
25
|
+
name: "tezos",
|
|
26
|
+
code: "XTZ",
|
|
27
|
+
magnitude: 6,
|
|
28
|
+
},
|
|
29
|
+
],
|
|
30
|
+
},
|
|
31
|
+
tezosResources: {
|
|
32
|
+
revealed: true,
|
|
33
|
+
counter: 0,
|
|
34
|
+
},
|
|
35
|
+
};
|
|
36
|
+
const mockTransaction = {
|
|
37
|
+
family: "tezos",
|
|
38
|
+
mode: "send",
|
|
39
|
+
amount: new BigNumber(500000),
|
|
40
|
+
recipient: "tz1RecipientAddress",
|
|
41
|
+
estimatedFees: new BigNumber(1000),
|
|
42
|
+
useAllAmount: false,
|
|
43
|
+
};
|
|
44
|
+
beforeEach(() => {
|
|
45
|
+
jest.clearAllMocks();
|
|
46
|
+
validateRecipient.mockResolvedValue({
|
|
47
|
+
recipientError: null,
|
|
48
|
+
recipientWarning: null,
|
|
49
|
+
});
|
|
50
|
+
api.getAccountByAddress.mockResolvedValue({ type: "empty" });
|
|
51
|
+
});
|
|
52
|
+
it("should return an error if the recipient is the same as the source address", async () => {
|
|
53
|
+
const transaction = { ...mockTransaction, recipient: mockAccount.freshAddress };
|
|
54
|
+
const result = await getTransactionStatus(mockAccount, transaction);
|
|
55
|
+
expect(result.errors.recipient).toBeInstanceOf(InvalidAddressBecauseDestinationIsAlsoSource);
|
|
56
|
+
});
|
|
57
|
+
it("should return an error if the amount is zero and useAllAmount is false", async () => {
|
|
58
|
+
const transaction = { ...mockTransaction, amount: new BigNumber(0) };
|
|
59
|
+
const result = await getTransactionStatus(mockAccount, transaction);
|
|
60
|
+
expect(result.errors.amount).toBeInstanceOf(AmountRequired);
|
|
61
|
+
});
|
|
62
|
+
it("should return a warning if the fees are too high compared to the amount", async () => {
|
|
63
|
+
const transaction = { ...mockTransaction, amount: new BigNumber(1000) };
|
|
64
|
+
const result = await getTransactionStatus(mockAccount, transaction);
|
|
65
|
+
expect(result.warnings.feeTooHigh).toBeInstanceOf(FeeTooHigh);
|
|
66
|
+
});
|
|
67
|
+
it("should return a warning if the balance after transaction is below the threshold", async () => {
|
|
68
|
+
isAccountDelegating.mockReturnValue(true);
|
|
69
|
+
const transaction = { ...mockTransaction, amount: new BigNumber(999000) };
|
|
70
|
+
const result = await getTransactionStatus(mockAccount, transaction);
|
|
71
|
+
expect(result.warnings.amount).toBeInstanceOf(RecommendUndelegation);
|
|
72
|
+
});
|
|
73
|
+
it("should map taquito errors to appropriate errors", async () => {
|
|
74
|
+
const transaction = { ...mockTransaction, taquitoError: "balance_too_low" };
|
|
75
|
+
const result = await getTransactionStatus(mockAccount, transaction);
|
|
76
|
+
expect(result.errors.amount).toBeInstanceOf(NotEnoughBalance);
|
|
77
|
+
});
|
|
78
|
+
it("should return an error if the account balance is zero or less", async () => {
|
|
79
|
+
const account = { ...mockAccount, balance: new BigNumber(0) };
|
|
80
|
+
const result = await getTransactionStatus(account, mockTransaction);
|
|
81
|
+
expect(result.errors.amount).toBeInstanceOf(NotEnoughBalance);
|
|
82
|
+
});
|
|
83
|
+
it("should return an error if the account balance is less than the estimated fees for delegation", async () => {
|
|
84
|
+
const transaction = { ...mockTransaction, mode: "delegate" };
|
|
85
|
+
const account = { ...mockAccount, balance: new BigNumber(500) };
|
|
86
|
+
const result = await getTransactionStatus(account, transaction);
|
|
87
|
+
expect(result.errors.amount).toBeInstanceOf(NotEnoughBalance);
|
|
88
|
+
});
|
|
89
|
+
it("should return an error if the recipient account is empty and the amount is below the existential deposit", async () => {
|
|
90
|
+
const transaction = { ...mockTransaction, amount: new BigNumber(100000) };
|
|
91
|
+
const result = await getTransactionStatus(mockAccount, transaction);
|
|
92
|
+
expect(result.errors.amount).toBeInstanceOf(NotEnoughBalanceBecauseDestinationNotCreated);
|
|
93
|
+
});
|
|
94
|
+
it("should return no errors or warnings for a valid transaction", async () => {
|
|
95
|
+
const account = { ...mockAccount, balance: new BigNumber(2000000) };
|
|
96
|
+
const transaction = { ...mockTransaction, amount: new BigNumber(500000) };
|
|
97
|
+
const result = await getTransactionStatus(account, transaction);
|
|
98
|
+
expect(result.errors).toEqual({});
|
|
99
|
+
expect(result.warnings).toEqual({});
|
|
100
|
+
});
|
|
101
|
+
});
|
|
102
|
+
//# sourceMappingURL=getTransactionStatus.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.test.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.test.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,GAAG,MAAM,iBAAiB,CAAC;AAClC,OAAO,EACL,cAAc,EACd,UAAU,EACV,4CAA4C,EAC5C,gBAAgB,EAChB,4CAA4C,EAC5C,qBAAqB,GACtB,MAAM,kBAAkB,CAAC;AAG1B,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,CAAC;IAC3B,iBAAiB,EAAE,IAAI,CAAC,EAAE,EAAE;CAC7B,CAAC,CAAC,CAAC;AAEJ,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,GAAG,EAAE,CAAC,CAAC;IACpC,mBAAmB,EAAE,IAAI,CAAC,EAAE,EAAE;CAC/B,CAAC,CAAC,CAAC;AAEJ,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,GAAG,EAAE,CAAC,CAAC;IAClC,mBAAmB,EAAE,IAAI,CAAC,EAAE,EAAE;CAC/B,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,MAAM,WAAW,GAAG;QAClB,IAAI,EAAE,SAAS;QACf,YAAY,EAAE,kBAAkB;QAChC,OAAO,EAAE,IAAI,SAAS,CAAC,OAAO,CAAC;QAC/B,QAAQ,EAAE;YACR,IAAI,EAAE,gBAAgB;YACtB,KAAK,EAAE;gBACL;oBACE,IAAI,EAAE,OAAO;oBACb,IAAI,EAAE,KAAK;oBACX,SAAS,EAAE,CAAC;iBACb;aACF;SACF;QACD,cAAc,EAAE;YACd,QAAQ,EAAE,IAAI;YACd,OAAO,EAAE,CAAC;SACX;KACyB,CAAC;IAE7B,MAAM,eAAe,GAAG;QACtB,MAAM,EAAE,OAAO;QACf,IAAI,EAAE,MAAM;QACZ,MAAM,EAAE,IAAI,SAAS,CAAC,MAAM,CAAC;QAC7B,SAAS,EAAE,qBAAqB;QAChC,aAAa,EAAE,IAAI,SAAS,CAAC,IAAI,CAAC;QAClC,YAAY,EAAE,KAAK;KACL,CAAC;IAEjB,UAAU,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;QACpB,iBAA+B,CAAC,iBAAiB,CAAC;YACjD,cAAc,EAAE,IAAI;YACpB,gBAAgB,EAAE,IAAI;SACvB,CAAC,CAAC;QACF,GAAG,CAAC,mBAAiC,CAAC,iBAAiB,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;IAC9E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2EAA2E,EAAE,KAAK,IAAI,EAAE;QACzF,MAAM,WAAW,GAAG,EAAE,GAAG,eAAe,EAAE,SAAS,EAAE,WAAW,CAAC,YAAY,EAAE,CAAC;QAChF,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,cAAc,CAAC,4CAA4C,CAAC,CAAC;IAC/F,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wEAAwE,EAAE,KAAK,IAAI,EAAE;QACtF,MAAM,WAAW,GAAG,EAAE,GAAG,eAAe,EAAE,MAAM,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;QACrE,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;IAC9D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yEAAyE,EAAE,KAAK,IAAI,EAAE;QACvF,MAAM,WAAW,GAAG,EAAE,GAAG,eAAe,EAAE,MAAM,EAAE,IAAI,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC;QACxE,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;IAChE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iFAAiF,EAAE,KAAK,IAAI,EAAE;QAC9F,mBAAiC,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QACzD,MAAM,WAAW,GAAG,EAAE,GAAG,eAAe,EAAE,MAAM,EAAE,IAAI,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC;QAC1E,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,qBAAqB,CAAC,CAAC;IACvE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,WAAW,GAAG,EAAE,GAAG,eAAe,EAAE,YAAY,EAAE,iBAAiB,EAAE,CAAC;QAC5E,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,gBAAgB,CAAC,CAAC;IAChE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+DAA+D,EAAE,KAAK,IAAI,EAAE;QAC7E,MAAM,OAAO,GAAG,EAAE,GAAG,WAAW,EAAE,OAAO,EAAE,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9D,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,gBAAgB,CAAC,CAAC;IAChE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8FAA8F,EAAE,KAAK,IAAI,EAAE;QAC5G,MAAM,WAAW,GAAG,EAAE,GAAG,eAAe,EAAE,IAAI,EAAE,UAAU,EAAiB,CAAC;QAC5E,MAAM,OAAO,GAAG,EAAE,GAAG,WAAW,EAAE,OAAO,EAAE,IAAI,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC;QAChE,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAChE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,gBAAgB,CAAC,CAAC;IAChE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0GAA0G,EAAE,KAAK,IAAI,EAAE;QACxH,MAAM,WAAW,GAAG,EAAE,GAAG,eAAe,EAAE,MAAM,EAAE,IAAI,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC;QAC1E,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,4CAA4C,CAAC,CAAC;IAC5F,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6DAA6D,EAAE,KAAK,IAAI,EAAE;QAC3E,MAAM,OAAO,GAAG,EAAE,GAAG,WAAW,EAAE,OAAO,EAAE,IAAI,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC;QACpE,MAAM,WAAW,GAAG,EAAE,GAAG,eAAe,EAAE,MAAM,EAAE,IAAI,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC;QAC1E,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAChE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAClC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACtC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { CoinConfig } from "@ledgerhq/coin-framework/config";
|
|
2
|
+
import { SignerContext } from "@ledgerhq/coin-framework/signer";
|
|
3
|
+
import type { CurrencyBridge, AccountBridge } from "@ledgerhq/types-live";
|
|
4
|
+
import type { TezosAccount, TezosSigner, Transaction } from "../types";
|
|
5
|
+
import { TezosCoinConfig } from "../config";
|
|
6
|
+
export declare function createBridges(signerContext: SignerContext<TezosSigner>, coinConfig: CoinConfig<TezosCoinConfig>): {
|
|
7
|
+
currencyBridge: CurrencyBridge;
|
|
8
|
+
accountBridge: AccountBridge<Transaction, TezosAccount, import("@ledgerhq/types-live").TransactionStatusCommon>;
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAE1E,OAAO,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,WAAW,EAAqB,MAAM,UAAU,CAAC;AAW1F,OAAwB,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AA0C7D,wBAAgB,aAAa,CAC3B,aAAa,EAAE,aAAa,CAAC,WAAW,CAAC,EACzC,UAAU,EAAE,UAAU,CAAC,eAAe,CAAC;;;EAQxC"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { getSerializedAddressParameters, updateTransaction, makeAccountBridgeReceive, makeScanAccounts, } from "@ledgerhq/coin-framework/bridge/jsHelpers";
|
|
2
|
+
import getAddressWrapper from "@ledgerhq/coin-framework/bridge/getAddressWrapper";
|
|
3
|
+
import { assignFromAccountRaw, assignToAccountRaw } from "./serialization";
|
|
4
|
+
import { getPreloadStrategy, hydrate, preload } from "./preload";
|
|
5
|
+
import { estimateMaxSpendable } from "./estimateMaxSpendable";
|
|
6
|
+
import { getTransactionStatus } from "./getTransactionStatus";
|
|
7
|
+
import { prepareTransaction } from "./prepareTransaction";
|
|
8
|
+
import { getAccountShape, sync } from "./synchronization";
|
|
9
|
+
import { createTransaction } from "./createTransaction";
|
|
10
|
+
import { buildSignOperation } from "./signOperation";
|
|
11
|
+
import signerGetAddress from "../signer";
|
|
12
|
+
import { broadcast } from "./broadcast";
|
|
13
|
+
import tezosCoinConfig from "../config";
|
|
14
|
+
function buildCurrencyBridge(signerContext) {
|
|
15
|
+
const getAddress = signerGetAddress(signerContext);
|
|
16
|
+
const scanAccounts = makeScanAccounts({
|
|
17
|
+
getAccountShape,
|
|
18
|
+
getAddressFn: getAddressWrapper(getAddress),
|
|
19
|
+
});
|
|
20
|
+
return {
|
|
21
|
+
getPreloadStrategy,
|
|
22
|
+
preload,
|
|
23
|
+
hydrate,
|
|
24
|
+
scanAccounts,
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
function buildAccountBridge(signerContext) {
|
|
28
|
+
const getAddress = signerGetAddress(signerContext);
|
|
29
|
+
const receive = makeAccountBridgeReceive(getAddressWrapper(getAddress));
|
|
30
|
+
const signOperation = buildSignOperation(signerContext);
|
|
31
|
+
return {
|
|
32
|
+
estimateMaxSpendable,
|
|
33
|
+
createTransaction,
|
|
34
|
+
updateTransaction,
|
|
35
|
+
getTransactionStatus,
|
|
36
|
+
prepareTransaction,
|
|
37
|
+
sync,
|
|
38
|
+
receive,
|
|
39
|
+
signOperation,
|
|
40
|
+
broadcast,
|
|
41
|
+
assignFromAccountRaw,
|
|
42
|
+
assignToAccountRaw,
|
|
43
|
+
getSerializedAddressParameters,
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
export function createBridges(signerContext, coinConfig) {
|
|
47
|
+
tezosCoinConfig.setCoinConfig(coinConfig);
|
|
48
|
+
return {
|
|
49
|
+
currencyBridge: buildCurrencyBridge(signerContext),
|
|
50
|
+
accountBridge: buildAccountBridge(signerContext),
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,8BAA8B,EAC9B,iBAAiB,EACjB,wBAAwB,EACxB,gBAAgB,GACjB,MAAM,2CAA2C,CAAC;AAInD,OAAO,iBAAiB,MAAM,mDAAmD,CAAC;AAElF,OAAO,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACjE,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,gBAAgB,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,eAAoC,MAAM,WAAW,CAAC;AAE7D,SAAS,mBAAmB,CAAC,aAAyC;IACpE,MAAM,UAAU,GAAG,gBAAgB,CAAC,aAAa,CAAC,CAAC;IAEnD,MAAM,YAAY,GAAG,gBAAgB,CAAC;QACpC,eAAe;QACf,YAAY,EAAE,iBAAiB,CAAC,UAAU,CAAC;KAC5C,CAAC,CAAC;IAEH,OAAO;QACL,kBAAkB;QAClB,OAAO;QACP,OAAO;QACP,YAAY;KACb,CAAC;AACJ,CAAC;AAED,SAAS,kBAAkB,CACzB,aAAyC;IAEzC,MAAM,UAAU,GAAG,gBAAgB,CAAC,aAAa,CAAC,CAAC;IAEnD,MAAM,OAAO,GAAG,wBAAwB,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC,CAAC;IACxE,MAAM,aAAa,GAAG,kBAAkB,CAAC,aAAa,CAAC,CAAC;IAExD,OAAO;QACL,oBAAoB;QACpB,iBAAiB;QACjB,iBAAiB;QACjB,oBAAoB;QACpB,kBAAkB;QAClB,IAAI;QACJ,OAAO;QACP,aAAa;QACb,SAAS;QACT,oBAAoB;QACpB,kBAAkB;QAClB,8BAA8B;KAC/B,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,aAAa,CAC3B,aAAyC,EACzC,UAAuC;IAEvC,eAAe,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IAE1C,OAAO;QACL,cAAc,EAAE,mBAAmB,CAAC,aAAa,CAAC;QAClD,aAAa,EAAE,kBAAkB,CAAC,aAAa,CAAC;KACjD,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { type APIOperation } from "../network/types";
|
|
2
|
+
import { TezosAccount, TezosOperation } from "../types";
|
|
3
|
+
export declare const txToOp: ({ address, accountId }: {
|
|
4
|
+
address: string;
|
|
5
|
+
accountId: string;
|
|
6
|
+
}) => (tx: APIOperation) => TezosOperation | null | undefined;
|
|
7
|
+
export declare function reconciliatePublicKey(publicKey: string | undefined, account: TezosAccount | undefined): string;
|
|
8
|
+
export declare function encodeAddress(publicKey: Buffer): string;
|
|
9
|
+
export declare function isStringHex(s: string): boolean;
|
|
10
|
+
//# sourceMappingURL=logic.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logic.d.ts","sourceRoot":"","sources":["../../src/bridge/logic.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAExD,eAAO,MAAM,MAAM,2BACQ;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,UAC1D,YAAY,KAAG,cAAc,GAAG,IAAI,GAAG,SAqH3C,CAAC;AAEJ,wBAAgB,qBAAqB,CACnC,SAAS,EAAE,MAAM,GAAG,SAAS,EAC7B,OAAO,EAAE,YAAY,GAAG,SAAS,GAChC,MAAM,CAOR;AAED,wBAAgB,aAAa,CAAC,SAAS,EAAE,MAAM,UAiB9C;AAED,wBAAgB,WAAW,CAAC,CAAC,EAAE,MAAM,GAAG,OAAO,CAS9C"}
|