@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
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const bridge_fixture_1 = require("../types/bridge.fixture");
|
|
7
|
+
const config_1 = __importDefault(require("../config"));
|
|
8
|
+
const broadcast_1 = require("./broadcast");
|
|
9
|
+
const config_2 = require("../test/config");
|
|
10
|
+
const mockInjectOperation = jest.fn();
|
|
11
|
+
jest.mock("@taquito/taquito", () => ({
|
|
12
|
+
TezosToolkit: jest.fn().mockReturnValue({
|
|
13
|
+
rpc: {
|
|
14
|
+
injectOperation: () => mockInjectOperation(),
|
|
15
|
+
},
|
|
16
|
+
}),
|
|
17
|
+
}));
|
|
18
|
+
describe("broadcast", () => {
|
|
19
|
+
beforeAll(() => {
|
|
20
|
+
config_1.default.setCoinConfig(() => config_2.mockConfig);
|
|
21
|
+
});
|
|
22
|
+
it("calls 'injectOperation' from TezosToolkit and returns its hash computation", async () => {
|
|
23
|
+
// GIVEN
|
|
24
|
+
const signedOperation = {
|
|
25
|
+
operation: (0, bridge_fixture_1.createFixtureOperation)(),
|
|
26
|
+
signature: "SIGNATURE",
|
|
27
|
+
};
|
|
28
|
+
mockInjectOperation.mockResolvedValue("SIGN_HASH");
|
|
29
|
+
// WHEN
|
|
30
|
+
const op = await (0, broadcast_1.broadcast)({ signedOperation, account: {} });
|
|
31
|
+
// THEN
|
|
32
|
+
expect(mockInjectOperation).toHaveBeenCalledTimes(1);
|
|
33
|
+
expect(op.hash).toEqual("SIGN_HASH");
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
//# 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,4DAAiE;AACjE,uDAAyD;AACzD,2CAAwC;AACxC,2CAA4C;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,gBAAM,CAAC,aAAa,CAAC,GAAoB,EAAE,CAAC,mBAA6B,CAAC,CAAC;IAC7E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;QAC1F,QAAQ;QACR,MAAM,eAAe,GAAoB;YACvC,SAAS,EAAE,IAAA,uCAAsB,GAAE;YACnC,SAAS,EAAE,WAAW;SACvB,CAAC;QACF,mBAAmB,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QAEnD,OAAO;QACP,MAAM,EAAE,GAAG,MAAM,IAAA,qBAAS,EAAC,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,28 @@
|
|
|
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.buildOptimisticOperation = void 0;
|
|
7
|
+
const operation_1 = require("@ledgerhq/coin-framework/operation");
|
|
8
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
9
|
+
const buildOptimisticOperation = (account, transaction, operationType) => {
|
|
10
|
+
const txHash = ""; // resolved at broadcast time
|
|
11
|
+
const { id: accountId } = account;
|
|
12
|
+
return {
|
|
13
|
+
id: (0, operation_1.encodeOperationId)(accountId, txHash, operationType),
|
|
14
|
+
hash: txHash,
|
|
15
|
+
type: operationType,
|
|
16
|
+
value: transaction.amount,
|
|
17
|
+
fee: transaction.fees || new bignumber_js_1.default(0),
|
|
18
|
+
extra: {},
|
|
19
|
+
blockHash: null,
|
|
20
|
+
blockHeight: null,
|
|
21
|
+
senders: [account.freshAddress],
|
|
22
|
+
recipients: [transaction.recipient],
|
|
23
|
+
accountId,
|
|
24
|
+
date: new Date(),
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
exports.buildOptimisticOperation = buildOptimisticOperation;
|
|
28
|
+
//# sourceMappingURL=buildOptimisticOperation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildOptimisticOperation.js","sourceRoot":"","sources":["../../src/bridge/buildOptimisticOperation.ts"],"names":[],"mappings":";;;;;;AACA,kEAAuE;AAEvE,gEAAqC;AAE9B,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,IAAA,6BAAiB,EAAC,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,sBAAS,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;AAtBW,QAAA,wBAAwB,4BAsBnC"}
|
|
@@ -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,24 @@
|
|
|
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.createTransaction = void 0;
|
|
7
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
8
|
+
const createTransaction = () => {
|
|
9
|
+
return {
|
|
10
|
+
family: "tezos",
|
|
11
|
+
mode: "send",
|
|
12
|
+
amount: new bignumber_js_1.default(0),
|
|
13
|
+
fees: null,
|
|
14
|
+
gasLimit: null,
|
|
15
|
+
storageLimit: null,
|
|
16
|
+
recipient: "",
|
|
17
|
+
networkInfo: null,
|
|
18
|
+
useAllAmount: false,
|
|
19
|
+
taquitoError: null,
|
|
20
|
+
estimatedFees: null,
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
exports.createTransaction = createTransaction;
|
|
24
|
+
//# sourceMappingURL=createTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createTransaction.js","sourceRoot":"","sources":["../../src/bridge/createTransaction.ts"],"names":[],"mappings":";;;;;;AAAA,gEAAqC;AAI9B,MAAM,iBAAiB,GAAoD,GAAG,EAAE;IACrF,OAAO;QACL,MAAM,EAAE,OAAO;QACf,IAAI,EAAE,MAAM;QACZ,MAAM,EAAE,IAAI,sBAAS,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;AAdW,QAAA,iBAAiB,qBAc5B"}
|
|
@@ -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,30 @@
|
|
|
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.estimateMaxSpendable = void 0;
|
|
7
|
+
const index_1 = require("@ledgerhq/coin-framework/account/index");
|
|
8
|
+
const prepareTransaction_1 = require("./prepareTransaction");
|
|
9
|
+
const createTransaction_1 = require("./createTransaction");
|
|
10
|
+
const getFeesForTransaction_1 = __importDefault(require("./getFeesForTransaction"));
|
|
11
|
+
const TEZOS_BURN_ADDRESS = "tz1burnburnburnburnburnburnburjAYjjX";
|
|
12
|
+
const estimateMaxSpendable = async ({ account, parentAccount, transaction, }) => {
|
|
13
|
+
const mainAccount = (0, index_1.getMainAccount)(account, parentAccount);
|
|
14
|
+
const tx = await (0, prepareTransaction_1.prepareTransaction)(mainAccount, {
|
|
15
|
+
...(0, createTransaction_1.createTransaction)(account),
|
|
16
|
+
...transaction,
|
|
17
|
+
// estimate using a burn address that exists so we don't enter into NotEnoughBalanceBecauseDestinationNotCreated
|
|
18
|
+
recipient: transaction?.recipient || TEZOS_BURN_ADDRESS,
|
|
19
|
+
useAllAmount: true,
|
|
20
|
+
});
|
|
21
|
+
const estimation = await (0, getFeesForTransaction_1.default)({
|
|
22
|
+
account: mainAccount,
|
|
23
|
+
transaction: tx,
|
|
24
|
+
});
|
|
25
|
+
// As we use `useAllAmount`, we know we will receive an amount value.
|
|
26
|
+
return estimation.amount;
|
|
27
|
+
};
|
|
28
|
+
exports.estimateMaxSpendable = estimateMaxSpendable;
|
|
29
|
+
exports.default = exports.estimateMaxSpendable;
|
|
30
|
+
//# sourceMappingURL=estimateMaxSpendable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"estimateMaxSpendable.js","sourceRoot":"","sources":["../../src/bridge/estimateMaxSpendable.ts"],"names":[],"mappings":";;;;;;AAEA,kEAAwE;AAExE,6DAA0D;AAC1D,2DAAwD;AACxD,oFAAuD;AAEvD,MAAM,kBAAkB,GAAG,sCAAsC,CAAC;AAE3D,MAAM,oBAAoB,GAAuD,KAAK,EAAE,EAC7F,OAAO,EACP,aAAa,EACb,WAAW,GAKZ,EAAsB,EAAE;IACvB,MAAM,WAAW,GAAG,IAAA,sBAAc,EAAC,OAAO,EAAE,aAAa,CAAiB,CAAC;IAC3E,MAAM,EAAE,GAAG,MAAM,IAAA,uCAAkB,EAAC,WAAW,EAAE;QAC/C,GAAG,IAAA,qCAAiB,EAAC,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,IAAA,+BAAgB,EAAC;QACxC,OAAO,EAAE,WAAW;QACpB,WAAW,EAAE,EAAE;KAChB,CAAC,CAAC;IAEH,qEAAqE;IACrE,OAAO,UAAU,CAAC,MAAO,CAAC;AAC5B,CAAC,CAAC;AAxBW,QAAA,oBAAoB,wBAwB/B;AAEF,kBAAe,4BAAoB,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,39 @@
|
|
|
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.default = getEstimatedFees;
|
|
7
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
8
|
+
const logic_1 = require("../logic");
|
|
9
|
+
/**
|
|
10
|
+
* Fetch the transaction fees for a transaction
|
|
11
|
+
*
|
|
12
|
+
* @param {Account} a
|
|
13
|
+
* @param {Transaction} t
|
|
14
|
+
*/
|
|
15
|
+
async function getEstimatedFees({ account, transaction, }) {
|
|
16
|
+
const estimate = await (0, logic_1.estimateFees)({
|
|
17
|
+
account: {
|
|
18
|
+
xpub: account.xpub,
|
|
19
|
+
address: account.freshAddress,
|
|
20
|
+
balance: BigInt(account.balance.toString()),
|
|
21
|
+
revealed: account.tezosResources.revealed,
|
|
22
|
+
},
|
|
23
|
+
transaction: {
|
|
24
|
+
mode: transaction.mode,
|
|
25
|
+
recipient: transaction.recipient,
|
|
26
|
+
amount: BigInt(transaction.amount.toString()),
|
|
27
|
+
useAllAmount: transaction.useAllAmount,
|
|
28
|
+
},
|
|
29
|
+
});
|
|
30
|
+
return {
|
|
31
|
+
fees: (0, bignumber_js_1.default)(estimate.fees.toString()),
|
|
32
|
+
gasLimit: (0, bignumber_js_1.default)(estimate.gasLimit.toString()),
|
|
33
|
+
storageLimit: (0, bignumber_js_1.default)(estimate.storageLimit.toString()),
|
|
34
|
+
estimatedFees: (0, bignumber_js_1.default)(estimate.estimatedFees.toString()),
|
|
35
|
+
amount: estimate.amount !== undefined ? (0, bignumber_js_1.default)(estimate.amount.toString()) : (0, bignumber_js_1.default)(0),
|
|
36
|
+
taquitoError: estimate.taquitoError,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=getFeesForTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getFeesForTransaction.js","sourceRoot":"","sources":["../../src/bridge/getFeesForTransaction.ts"],"names":[],"mappings":";;;;;AAkBA,mCA8BC;AAhDD,gEAAqC;AAErC,oCAAwC;AAUxC;;;;;GAKG;AACY,KAAK,UAAU,gBAAgB,CAAC,EAC7C,OAAO,EACP,WAAW,GAIZ;IACC,MAAM,QAAQ,GAAG,MAAM,IAAA,oBAAY,EAAC;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,IAAA,sBAAS,EAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACzC,QAAQ,EAAE,IAAA,sBAAS,EAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACjD,YAAY,EAAE,IAAA,sBAAS,EAAC,QAAQ,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;QACzD,aAAa,EAAE,IAAA,sBAAS,EAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;QAC3D,MAAM,EAAE,QAAQ,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,IAAA,sBAAS,EAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,IAAA,sBAAS,EAAC,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,108 @@
|
|
|
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.getTransactionStatus = void 0;
|
|
7
|
+
const errors_1 = require("@ledgerhq/errors");
|
|
8
|
+
const logs_1 = require("@ledgerhq/logs");
|
|
9
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
10
|
+
const errors_2 = require("../types/errors");
|
|
11
|
+
const logic_1 = require("../logic");
|
|
12
|
+
const bakers_1 = require("../network/bakers");
|
|
13
|
+
const tzkt_1 = __importDefault(require("../network/tzkt"));
|
|
14
|
+
const EXISTENTIAL_DEPOSIT = new bignumber_js_1.default(275000);
|
|
15
|
+
const getTransactionStatus = async (account, transaction) => {
|
|
16
|
+
const errors = {};
|
|
17
|
+
const warnings = {};
|
|
18
|
+
let resetTotalSpent = false;
|
|
19
|
+
// Recipient validation logic
|
|
20
|
+
if (transaction.mode !== "undelegate") {
|
|
21
|
+
if (account.freshAddress === transaction.recipient) {
|
|
22
|
+
errors.recipient = new errors_1.InvalidAddressBecauseDestinationIsAlsoSource();
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
const { recipientError, recipientWarning } = await (0, logic_1.validateRecipient)(transaction.recipient);
|
|
26
|
+
if (recipientError) {
|
|
27
|
+
errors.recipient = recipientError;
|
|
28
|
+
}
|
|
29
|
+
if (recipientWarning) {
|
|
30
|
+
warnings.recipient = recipientWarning;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
// Pre validation of amount field
|
|
35
|
+
const estimatedFees = transaction.estimatedFees || new bignumber_js_1.default(0);
|
|
36
|
+
if (transaction.mode === "send") {
|
|
37
|
+
if (!errors.amount && transaction.amount.eq(0) && !transaction.useAllAmount) {
|
|
38
|
+
resetTotalSpent = true;
|
|
39
|
+
errors.amount = new errors_1.AmountRequired();
|
|
40
|
+
}
|
|
41
|
+
else if (transaction.amount.gt(0) && estimatedFees.times(10).gt(transaction.amount)) {
|
|
42
|
+
warnings.feeTooHigh = new errors_1.FeeTooHigh();
|
|
43
|
+
}
|
|
44
|
+
const thresholdWarning = 0.5 * 10 ** account.currency.units[0].magnitude;
|
|
45
|
+
if (!errors.amount &&
|
|
46
|
+
account.balance.minus(transaction.amount).minus(estimatedFees).lt(thresholdWarning)) {
|
|
47
|
+
if ((0, bakers_1.isAccountDelegating)(account)) {
|
|
48
|
+
if (transaction.useAllAmount) {
|
|
49
|
+
errors.amount = new errors_1.RecommendUndelegation();
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
warnings.amount = new errors_1.RecommendUndelegation();
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
// effective amount
|
|
58
|
+
// if we also have taquitoError, we interprete them and they override the previously inferred errors
|
|
59
|
+
if (transaction.taquitoError) {
|
|
60
|
+
(0, logs_1.log)("taquitoerror", String(transaction.taquitoError));
|
|
61
|
+
// remap taquito errors
|
|
62
|
+
if (transaction.taquitoError.endsWith("balance_too_low") ||
|
|
63
|
+
transaction.taquitoError.endsWith("subtraction_underflow")) {
|
|
64
|
+
if (transaction.mode === "send") {
|
|
65
|
+
resetTotalSpent = true;
|
|
66
|
+
errors.amount = new errors_1.NotEnoughBalance();
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
errors.amount = new errors_1.NotEnoughBalanceToDelegate();
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
else if (transaction.taquitoError.endsWith("delegate.unchanged")) {
|
|
73
|
+
errors.recipient = new errors_2.InvalidAddressBecauseAlreadyDelegated();
|
|
74
|
+
}
|
|
75
|
+
else if (!errors.amount) {
|
|
76
|
+
// unidentified error case
|
|
77
|
+
errors.amount = new Error(transaction.taquitoError);
|
|
78
|
+
resetTotalSpent = true;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
if (!errors.amount && account.balance.lte(0)) {
|
|
82
|
+
resetTotalSpent = true;
|
|
83
|
+
errors.amount = new errors_1.NotEnoughBalance();
|
|
84
|
+
}
|
|
85
|
+
if (!errors.amount && transaction.mode === "delegate" && account.balance.lte(estimatedFees)) {
|
|
86
|
+
resetTotalSpent = true;
|
|
87
|
+
errors.amount = new errors_1.NotEnoughBalance();
|
|
88
|
+
}
|
|
89
|
+
// Catch a specific case that requires a minimum amount
|
|
90
|
+
if (!errors.amount &&
|
|
91
|
+
transaction.mode === "send" &&
|
|
92
|
+
transaction.amount.lt(EXISTENTIAL_DEPOSIT) &&
|
|
93
|
+
(await tzkt_1.default.getAccountByAddress(transaction.recipient)).type === "empty") {
|
|
94
|
+
resetTotalSpent = true;
|
|
95
|
+
errors.amount = new errors_1.NotEnoughBalanceBecauseDestinationNotCreated("", {
|
|
96
|
+
minimalAmount: "0.275 XTZ",
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
return {
|
|
100
|
+
errors,
|
|
101
|
+
warnings,
|
|
102
|
+
estimatedFees,
|
|
103
|
+
amount: transaction.amount,
|
|
104
|
+
totalSpent: resetTotalSpent ? new bignumber_js_1.default(0) : transaction.amount.plus(estimatedFees),
|
|
105
|
+
};
|
|
106
|
+
};
|
|
107
|
+
exports.getTransactionStatus = getTransactionStatus;
|
|
108
|
+
//# sourceMappingURL=getTransactionStatus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.test.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
7
|
+
const getTransactionStatus_1 = require("./getTransactionStatus");
|
|
8
|
+
const logic_1 = require("../logic");
|
|
9
|
+
const bakers_1 = require("../network/bakers");
|
|
10
|
+
const tzkt_1 = __importDefault(require("../network/tzkt"));
|
|
11
|
+
const errors_1 = require("@ledgerhq/errors");
|
|
12
|
+
jest.mock("../logic", () => ({
|
|
13
|
+
validateRecipient: jest.fn(),
|
|
14
|
+
}));
|
|
15
|
+
jest.mock("../network/bakers", () => ({
|
|
16
|
+
isAccountDelegating: jest.fn(),
|
|
17
|
+
}));
|
|
18
|
+
jest.mock("../network/tzkt", () => ({
|
|
19
|
+
getAccountByAddress: jest.fn(),
|
|
20
|
+
}));
|
|
21
|
+
describe("getTransactionStatus", () => {
|
|
22
|
+
const mockAccount = {
|
|
23
|
+
type: "Account",
|
|
24
|
+
freshAddress: "tz1SourceAddress",
|
|
25
|
+
balance: new bignumber_js_1.default(1000000),
|
|
26
|
+
currency: {
|
|
27
|
+
type: "CryptoCurrency",
|
|
28
|
+
units: [
|
|
29
|
+
{
|
|
30
|
+
name: "tezos",
|
|
31
|
+
code: "XTZ",
|
|
32
|
+
magnitude: 6,
|
|
33
|
+
},
|
|
34
|
+
],
|
|
35
|
+
},
|
|
36
|
+
tezosResources: {
|
|
37
|
+
revealed: true,
|
|
38
|
+
counter: 0,
|
|
39
|
+
},
|
|
40
|
+
};
|
|
41
|
+
const mockTransaction = {
|
|
42
|
+
family: "tezos",
|
|
43
|
+
mode: "send",
|
|
44
|
+
amount: new bignumber_js_1.default(500000),
|
|
45
|
+
recipient: "tz1RecipientAddress",
|
|
46
|
+
estimatedFees: new bignumber_js_1.default(1000),
|
|
47
|
+
useAllAmount: false,
|
|
48
|
+
};
|
|
49
|
+
beforeEach(() => {
|
|
50
|
+
jest.clearAllMocks();
|
|
51
|
+
logic_1.validateRecipient.mockResolvedValue({
|
|
52
|
+
recipientError: null,
|
|
53
|
+
recipientWarning: null,
|
|
54
|
+
});
|
|
55
|
+
tzkt_1.default.getAccountByAddress.mockResolvedValue({ type: "empty" });
|
|
56
|
+
});
|
|
57
|
+
it("should return an error if the recipient is the same as the source address", async () => {
|
|
58
|
+
const transaction = { ...mockTransaction, recipient: mockAccount.freshAddress };
|
|
59
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockAccount, transaction);
|
|
60
|
+
expect(result.errors.recipient).toBeInstanceOf(errors_1.InvalidAddressBecauseDestinationIsAlsoSource);
|
|
61
|
+
});
|
|
62
|
+
it("should return an error if the amount is zero and useAllAmount is false", async () => {
|
|
63
|
+
const transaction = { ...mockTransaction, amount: new bignumber_js_1.default(0) };
|
|
64
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockAccount, transaction);
|
|
65
|
+
expect(result.errors.amount).toBeInstanceOf(errors_1.AmountRequired);
|
|
66
|
+
});
|
|
67
|
+
it("should return a warning if the fees are too high compared to the amount", async () => {
|
|
68
|
+
const transaction = { ...mockTransaction, amount: new bignumber_js_1.default(1000) };
|
|
69
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockAccount, transaction);
|
|
70
|
+
expect(result.warnings.feeTooHigh).toBeInstanceOf(errors_1.FeeTooHigh);
|
|
71
|
+
});
|
|
72
|
+
it("should return a warning if the balance after transaction is below the threshold", async () => {
|
|
73
|
+
bakers_1.isAccountDelegating.mockReturnValue(true);
|
|
74
|
+
const transaction = { ...mockTransaction, amount: new bignumber_js_1.default(999000) };
|
|
75
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockAccount, transaction);
|
|
76
|
+
expect(result.warnings.amount).toBeInstanceOf(errors_1.RecommendUndelegation);
|
|
77
|
+
});
|
|
78
|
+
it("should map taquito errors to appropriate errors", async () => {
|
|
79
|
+
const transaction = { ...mockTransaction, taquitoError: "balance_too_low" };
|
|
80
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockAccount, transaction);
|
|
81
|
+
expect(result.errors.amount).toBeInstanceOf(errors_1.NotEnoughBalance);
|
|
82
|
+
});
|
|
83
|
+
it("should return an error if the account balance is zero or less", async () => {
|
|
84
|
+
const account = { ...mockAccount, balance: new bignumber_js_1.default(0) };
|
|
85
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(account, mockTransaction);
|
|
86
|
+
expect(result.errors.amount).toBeInstanceOf(errors_1.NotEnoughBalance);
|
|
87
|
+
});
|
|
88
|
+
it("should return an error if the account balance is less than the estimated fees for delegation", async () => {
|
|
89
|
+
const transaction = { ...mockTransaction, mode: "delegate" };
|
|
90
|
+
const account = { ...mockAccount, balance: new bignumber_js_1.default(500) };
|
|
91
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(account, transaction);
|
|
92
|
+
expect(result.errors.amount).toBeInstanceOf(errors_1.NotEnoughBalance);
|
|
93
|
+
});
|
|
94
|
+
it("should return an error if the recipient account is empty and the amount is below the existential deposit", async () => {
|
|
95
|
+
const transaction = { ...mockTransaction, amount: new bignumber_js_1.default(100000) };
|
|
96
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(mockAccount, transaction);
|
|
97
|
+
expect(result.errors.amount).toBeInstanceOf(errors_1.NotEnoughBalanceBecauseDestinationNotCreated);
|
|
98
|
+
});
|
|
99
|
+
it("should return no errors or warnings for a valid transaction", async () => {
|
|
100
|
+
const account = { ...mockAccount, balance: new bignumber_js_1.default(2000000) };
|
|
101
|
+
const transaction = { ...mockTransaction, amount: new bignumber_js_1.default(500000) };
|
|
102
|
+
const result = await (0, getTransactionStatus_1.getTransactionStatus)(account, transaction);
|
|
103
|
+
expect(result.errors).toEqual({});
|
|
104
|
+
expect(result.warnings).toEqual({});
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
//# 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,gEAAqC;AACrC,iEAA8D;AAC9D,oCAA6C;AAC7C,8CAAwD;AACxD,2DAAkC;AAClC,6CAO0B;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,sBAAS,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,sBAAS,CAAC,MAAM,CAAC;QAC7B,SAAS,EAAE,qBAAqB;QAChC,aAAa,EAAE,IAAI,sBAAS,CAAC,IAAI,CAAC;QAClC,YAAY,EAAE,KAAK;KACL,CAAC;IAEjB,UAAU,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;QACpB,yBAA+B,CAAC,iBAAiB,CAAC;YACjD,cAAc,EAAE,IAAI;YACpB,gBAAgB,EAAE,IAAI;SACvB,CAAC,CAAC;QACF,cAAG,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,IAAA,2CAAoB,EAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,cAAc,CAAC,qDAA4C,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,sBAAS,CAAC,CAAC,CAAC,EAAE,CAAC;QACrE,MAAM,MAAM,GAAG,MAAM,IAAA,2CAAoB,EAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,uBAAc,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,sBAAS,CAAC,IAAI,CAAC,EAAE,CAAC;QACxE,MAAM,MAAM,GAAG,MAAM,IAAA,2CAAoB,EAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,cAAc,CAAC,mBAAU,CAAC,CAAC;IAChE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iFAAiF,EAAE,KAAK,IAAI,EAAE;QAC9F,4BAAiC,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QACzD,MAAM,WAAW,GAAG,EAAE,GAAG,eAAe,EAAE,MAAM,EAAE,IAAI,sBAAS,CAAC,MAAM,CAAC,EAAE,CAAC;QAC1E,MAAM,MAAM,GAAG,MAAM,IAAA,2CAAoB,EAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,8BAAqB,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,IAAA,2CAAoB,EAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,yBAAgB,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,sBAAS,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9D,MAAM,MAAM,GAAG,MAAM,IAAA,2CAAoB,EAAC,OAAO,EAAE,eAAe,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,yBAAgB,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,sBAAS,CAAC,GAAG,CAAC,EAAE,CAAC;QAChE,MAAM,MAAM,GAAG,MAAM,IAAA,2CAAoB,EAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAChE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,yBAAgB,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,sBAAS,CAAC,MAAM,CAAC,EAAE,CAAC;QAC1E,MAAM,MAAM,GAAG,MAAM,IAAA,2CAAoB,EAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACpE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,qDAA4C,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,sBAAS,CAAC,OAAO,CAAC,EAAE,CAAC;QACpE,MAAM,WAAW,GAAG,EAAE,GAAG,eAAe,EAAE,MAAM,EAAE,IAAI,sBAAS,CAAC,MAAM,CAAC,EAAE,CAAC;QAC1E,MAAM,MAAM,GAAG,MAAM,IAAA,2CAAoB,EAAC,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,59 @@
|
|
|
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.createBridges = createBridges;
|
|
7
|
+
const jsHelpers_1 = require("@ledgerhq/coin-framework/bridge/jsHelpers");
|
|
8
|
+
const getAddressWrapper_1 = __importDefault(require("@ledgerhq/coin-framework/bridge/getAddressWrapper"));
|
|
9
|
+
const serialization_1 = require("./serialization");
|
|
10
|
+
const preload_1 = require("./preload");
|
|
11
|
+
const estimateMaxSpendable_1 = require("./estimateMaxSpendable");
|
|
12
|
+
const getTransactionStatus_1 = require("./getTransactionStatus");
|
|
13
|
+
const prepareTransaction_1 = require("./prepareTransaction");
|
|
14
|
+
const synchronization_1 = require("./synchronization");
|
|
15
|
+
const createTransaction_1 = require("./createTransaction");
|
|
16
|
+
const signOperation_1 = require("./signOperation");
|
|
17
|
+
const signer_1 = __importDefault(require("../signer"));
|
|
18
|
+
const broadcast_1 = require("./broadcast");
|
|
19
|
+
const config_1 = __importDefault(require("../config"));
|
|
20
|
+
function buildCurrencyBridge(signerContext) {
|
|
21
|
+
const getAddress = (0, signer_1.default)(signerContext);
|
|
22
|
+
const scanAccounts = (0, jsHelpers_1.makeScanAccounts)({
|
|
23
|
+
getAccountShape: synchronization_1.getAccountShape,
|
|
24
|
+
getAddressFn: (0, getAddressWrapper_1.default)(getAddress),
|
|
25
|
+
});
|
|
26
|
+
return {
|
|
27
|
+
getPreloadStrategy: preload_1.getPreloadStrategy,
|
|
28
|
+
preload: preload_1.preload,
|
|
29
|
+
hydrate: preload_1.hydrate,
|
|
30
|
+
scanAccounts,
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
function buildAccountBridge(signerContext) {
|
|
34
|
+
const getAddress = (0, signer_1.default)(signerContext);
|
|
35
|
+
const receive = (0, jsHelpers_1.makeAccountBridgeReceive)((0, getAddressWrapper_1.default)(getAddress));
|
|
36
|
+
const signOperation = (0, signOperation_1.buildSignOperation)(signerContext);
|
|
37
|
+
return {
|
|
38
|
+
estimateMaxSpendable: estimateMaxSpendable_1.estimateMaxSpendable,
|
|
39
|
+
createTransaction: createTransaction_1.createTransaction,
|
|
40
|
+
updateTransaction: jsHelpers_1.updateTransaction,
|
|
41
|
+
getTransactionStatus: getTransactionStatus_1.getTransactionStatus,
|
|
42
|
+
prepareTransaction: prepareTransaction_1.prepareTransaction,
|
|
43
|
+
sync: synchronization_1.sync,
|
|
44
|
+
receive,
|
|
45
|
+
signOperation,
|
|
46
|
+
broadcast: broadcast_1.broadcast,
|
|
47
|
+
assignFromAccountRaw: serialization_1.assignFromAccountRaw,
|
|
48
|
+
assignToAccountRaw: serialization_1.assignToAccountRaw,
|
|
49
|
+
getSerializedAddressParameters: jsHelpers_1.getSerializedAddressParameters,
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
function createBridges(signerContext, coinConfig) {
|
|
53
|
+
config_1.default.setCoinConfig(coinConfig);
|
|
54
|
+
return {
|
|
55
|
+
currencyBridge: buildCurrencyBridge(signerContext),
|
|
56
|
+
accountBridge: buildAccountBridge(signerContext),
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/bridge/index.ts"],"names":[],"mappings":";;;;;AA+DA,sCAUC;AAzED,yEAKmD;AAInD,0GAAkF;AAElF,mDAA2E;AAC3E,uCAAiE;AACjE,iEAA8D;AAC9D,iEAA8D;AAC9D,6DAA0D;AAC1D,uDAA0D;AAC1D,2DAAwD;AACxD,mDAAqD;AACrD,uDAAyC;AACzC,2CAAwC;AACxC,uDAA6D;AAE7D,SAAS,mBAAmB,CAAC,aAAyC;IACpE,MAAM,UAAU,GAAG,IAAA,gBAAgB,EAAC,aAAa,CAAC,CAAC;IAEnD,MAAM,YAAY,GAAG,IAAA,4BAAgB,EAAC;QACpC,eAAe,EAAf,iCAAe;QACf,YAAY,EAAE,IAAA,2BAAiB,EAAC,UAAU,CAAC;KAC5C,CAAC,CAAC;IAEH,OAAO;QACL,kBAAkB,EAAlB,4BAAkB;QAClB,OAAO,EAAP,iBAAO;QACP,OAAO,EAAP,iBAAO;QACP,YAAY;KACb,CAAC;AACJ,CAAC;AAED,SAAS,kBAAkB,CACzB,aAAyC;IAEzC,MAAM,UAAU,GAAG,IAAA,gBAAgB,EAAC,aAAa,CAAC,CAAC;IAEnD,MAAM,OAAO,GAAG,IAAA,oCAAwB,EAAC,IAAA,2BAAiB,EAAC,UAAU,CAAC,CAAC,CAAC;IACxE,MAAM,aAAa,GAAG,IAAA,kCAAkB,EAAC,aAAa,CAAC,CAAC;IAExD,OAAO;QACL,oBAAoB,EAApB,2CAAoB;QACpB,iBAAiB,EAAjB,qCAAiB;QACjB,iBAAiB,EAAjB,6BAAiB;QACjB,oBAAoB,EAApB,2CAAoB;QACpB,kBAAkB,EAAlB,uCAAkB;QAClB,IAAI,EAAJ,sBAAI;QACJ,OAAO;QACP,aAAa;QACb,SAAS,EAAT,qBAAS;QACT,oBAAoB,EAApB,oCAAoB;QACpB,kBAAkB,EAAlB,kCAAkB;QAClB,8BAA8B,EAA9B,0CAA8B;KAC/B,CAAC;AACJ,CAAC;AAED,SAAgB,aAAa,CAC3B,aAAyC,EACzC,UAAuC;IAEvC,gBAAe,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"}
|