@ledgerhq/coin-canton 0.5.0 → 0.5.1-nightly.1
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/CHANGELOG.md +21 -0
- package/lib/api/getBalance.integ.test.js +9 -5
- package/lib/api/getBalance.integ.test.js.map +1 -1
- package/lib/api/index.d.ts.map +1 -1
- package/lib/api/index.js +20 -25
- package/lib/api/index.js.map +1 -1
- package/lib/api/lastBlock.integ.test.js +1 -1
- package/lib/api/lastBlock.integ.test.js.map +1 -1
- package/lib/api/listOperations.integ.test.js +1 -1
- package/lib/api/listOperations.integ.test.js.map +1 -1
- package/lib/bridge/broadcast.d.ts.map +1 -1
- package/lib/bridge/broadcast.js +3 -2
- package/lib/bridge/broadcast.js.map +1 -1
- package/lib/bridge/broadcast.test.js +9 -0
- package/lib/bridge/broadcast.test.js.map +1 -1
- package/lib/bridge/createTransaction.js +1 -1
- package/lib/bridge/createTransaction.js.map +1 -1
- package/lib/bridge/getTransactionStatus.js +1 -1
- package/lib/bridge/getTransactionStatus.js.map +1 -1
- package/lib/bridge/index.d.ts.map +1 -1
- package/lib/bridge/index.js +3 -0
- package/lib/bridge/index.js.map +1 -1
- package/lib/bridge/onboard.d.ts +7 -5
- package/lib/bridge/onboard.d.ts.map +1 -1
- package/lib/bridge/onboard.integ.test.js +14 -11
- package/lib/bridge/onboard.integ.test.js.map +1 -1
- package/lib/bridge/onboard.js +110 -42
- package/lib/bridge/onboard.js.map +1 -1
- package/lib/bridge/prepareTransaction.d.ts.map +1 -1
- package/lib/bridge/prepareTransaction.js +5 -7
- package/lib/bridge/prepareTransaction.js.map +1 -1
- package/lib/bridge/serialization.d.ts +4 -0
- package/lib/bridge/serialization.d.ts.map +1 -0
- package/lib/bridge/serialization.js +31 -0
- package/lib/bridge/serialization.js.map +1 -0
- package/lib/bridge/signOperation.d.ts.map +1 -1
- package/lib/bridge/signOperation.js +14 -11
- package/lib/bridge/signOperation.js.map +1 -1
- package/lib/bridge/sync.d.ts +2 -1
- package/lib/bridge/sync.d.ts.map +1 -1
- package/lib/bridge/sync.integ.test.d.ts +2 -0
- package/lib/bridge/sync.integ.test.d.ts.map +1 -0
- package/lib/bridge/sync.integ.test.js +175 -0
- package/lib/bridge/sync.integ.test.js.map +1 -0
- package/lib/bridge/sync.js +50 -27
- package/lib/bridge/sync.js.map +1 -1
- package/lib/bridge/updateTransaction.d.ts.map +1 -1
- package/lib/bridge/updateTransaction.js +0 -4
- package/lib/bridge/updateTransaction.js.map +1 -1
- package/lib/common-logic/account/getBalance.d.ts +2 -1
- package/lib/common-logic/account/getBalance.d.ts.map +1 -1
- package/lib/common-logic/account/getBalance.js +7 -7
- package/lib/common-logic/account/getBalance.js.map +1 -1
- package/lib/common-logic/account/getBalance.unit.test.js +6 -3
- package/lib/common-logic/account/getBalance.unit.test.js.map +1 -1
- package/lib/common-logic/history/lastBlock.d.ts +2 -1
- package/lib/common-logic/history/lastBlock.d.ts.map +1 -1
- package/lib/common-logic/history/lastBlock.js +3 -3
- package/lib/common-logic/history/lastBlock.js.map +1 -1
- package/lib/common-logic/history/lastBlock.test.js +5 -2
- package/lib/common-logic/history/lastBlock.test.js.map +1 -1
- package/lib/common-logic/history/listOperations.d.ts +2 -1
- package/lib/common-logic/history/listOperations.d.ts.map +1 -1
- package/lib/common-logic/history/listOperations.js +2 -2
- package/lib/common-logic/history/listOperations.js.map +1 -1
- package/lib/common-logic/transaction/broadcast.d.ts +2 -1
- package/lib/common-logic/transaction/broadcast.d.ts.map +1 -1
- package/lib/common-logic/transaction/broadcast.js +5 -4
- package/lib/common-logic/transaction/broadcast.js.map +1 -1
- package/lib/common-logic/transaction/broadcast.test.js +8 -5
- package/lib/common-logic/transaction/broadcast.test.js.map +1 -1
- package/lib/common-logic/transaction/combine.d.ts +1 -1
- package/lib/common-logic/transaction/combine.d.ts.map +1 -1
- package/lib/common-logic/transaction/combine.js +2 -3
- package/lib/common-logic/transaction/combine.js.map +1 -1
- package/lib/common-logic/transaction/combine.test.js +3 -13
- package/lib/common-logic/transaction/combine.test.js.map +1 -1
- package/lib/common-logic/transaction/craftTransaction.d.ts +8 -4
- package/lib/common-logic/transaction/craftTransaction.d.ts.map +1 -1
- package/lib/common-logic/transaction/craftTransaction.js +15 -12
- package/lib/common-logic/transaction/craftTransaction.js.map +1 -1
- package/lib/common-logic/transaction/estimateFees.d.ts +2 -1
- package/lib/common-logic/transaction/estimateFees.d.ts.map +1 -1
- package/lib/common-logic/transaction/estimateFees.js +7 -3
- package/lib/common-logic/transaction/estimateFees.js.map +1 -1
- package/lib/config.d.ts +1 -0
- package/lib/config.d.ts.map +1 -1
- package/lib/config.js.map +1 -1
- package/lib/network/gateway.d.ts +41 -17
- package/lib/network/gateway.d.ts.map +1 -1
- package/lib/network/gateway.integ.test.js +19 -15
- package/lib/network/gateway.integ.test.js.map +1 -1
- package/lib/network/gateway.js +74 -48
- package/lib/network/gateway.js.map +1 -1
- package/lib/network/node.d.ts +2 -2
- package/lib/network/node.d.ts.map +1 -1
- package/lib/network/node.js.map +1 -1
- package/lib/network/types.d.ts +1 -1
- package/lib/network/types.d.ts.map +1 -1
- package/lib/signer/getAddress.d.ts.map +1 -1
- package/lib/signer/getAddress.js +2 -2
- package/lib/signer/getAddress.js.map +1 -1
- package/lib/types/bridge.d.ts +18 -3
- package/lib/types/bridge.d.ts.map +1 -1
- package/lib/types/index.d.ts +0 -10
- package/lib/types/index.d.ts.map +1 -1
- package/lib/types/onboard.d.ts +2 -0
- package/lib/types/onboard.d.ts.map +1 -1
- package/lib/types/onboard.js.map +1 -1
- package/lib/types/signer.d.ts +2 -1
- package/lib/types/signer.d.ts.map +1 -1
- package/lib-es/api/getBalance.integ.test.js +9 -5
- package/lib-es/api/getBalance.integ.test.js.map +1 -1
- package/lib-es/api/index.d.ts.map +1 -1
- package/lib-es/api/index.js +19 -24
- package/lib-es/api/index.js.map +1 -1
- package/lib-es/api/lastBlock.integ.test.js +1 -1
- package/lib-es/api/lastBlock.integ.test.js.map +1 -1
- package/lib-es/api/listOperations.integ.test.js +1 -1
- package/lib-es/api/listOperations.integ.test.js.map +1 -1
- package/lib-es/bridge/broadcast.d.ts.map +1 -1
- package/lib-es/bridge/broadcast.js +3 -2
- package/lib-es/bridge/broadcast.js.map +1 -1
- package/lib-es/bridge/broadcast.test.js +9 -0
- package/lib-es/bridge/broadcast.test.js.map +1 -1
- package/lib-es/bridge/createTransaction.js +1 -1
- package/lib-es/bridge/createTransaction.js.map +1 -1
- package/lib-es/bridge/getTransactionStatus.js +1 -1
- package/lib-es/bridge/getTransactionStatus.js.map +1 -1
- package/lib-es/bridge/index.d.ts.map +1 -1
- package/lib-es/bridge/index.js +3 -0
- package/lib-es/bridge/index.js.map +1 -1
- package/lib-es/bridge/onboard.d.ts +7 -5
- package/lib-es/bridge/onboard.d.ts.map +1 -1
- package/lib-es/bridge/onboard.integ.test.js +14 -11
- package/lib-es/bridge/onboard.integ.test.js.map +1 -1
- package/lib-es/bridge/onboard.js +107 -42
- package/lib-es/bridge/onboard.js.map +1 -1
- package/lib-es/bridge/prepareTransaction.d.ts.map +1 -1
- package/lib-es/bridge/prepareTransaction.js +6 -8
- package/lib-es/bridge/prepareTransaction.js.map +1 -1
- package/lib-es/bridge/serialization.d.ts +4 -0
- package/lib-es/bridge/serialization.d.ts.map +1 -0
- package/lib-es/bridge/serialization.js +27 -0
- package/lib-es/bridge/serialization.js.map +1 -0
- package/lib-es/bridge/signOperation.d.ts.map +1 -1
- package/lib-es/bridge/signOperation.js +15 -12
- package/lib-es/bridge/signOperation.js.map +1 -1
- package/lib-es/bridge/sync.d.ts +2 -1
- package/lib-es/bridge/sync.d.ts.map +1 -1
- package/lib-es/bridge/sync.integ.test.d.ts +2 -0
- package/lib-es/bridge/sync.integ.test.d.ts.map +1 -0
- package/lib-es/bridge/sync.integ.test.js +137 -0
- package/lib-es/bridge/sync.integ.test.js.map +1 -0
- package/lib-es/bridge/sync.js +51 -28
- package/lib-es/bridge/sync.js.map +1 -1
- package/lib-es/bridge/updateTransaction.d.ts.map +1 -1
- package/lib-es/bridge/updateTransaction.js +0 -4
- package/lib-es/bridge/updateTransaction.js.map +1 -1
- package/lib-es/common-logic/account/getBalance.d.ts +2 -1
- package/lib-es/common-logic/account/getBalance.d.ts.map +1 -1
- package/lib-es/common-logic/account/getBalance.js +7 -7
- package/lib-es/common-logic/account/getBalance.js.map +1 -1
- package/lib-es/common-logic/account/getBalance.unit.test.js +6 -3
- package/lib-es/common-logic/account/getBalance.unit.test.js.map +1 -1
- package/lib-es/common-logic/history/lastBlock.d.ts +2 -1
- package/lib-es/common-logic/history/lastBlock.d.ts.map +1 -1
- package/lib-es/common-logic/history/lastBlock.js +3 -3
- package/lib-es/common-logic/history/lastBlock.js.map +1 -1
- package/lib-es/common-logic/history/lastBlock.test.js +5 -2
- package/lib-es/common-logic/history/lastBlock.test.js.map +1 -1
- package/lib-es/common-logic/history/listOperations.d.ts +2 -1
- package/lib-es/common-logic/history/listOperations.d.ts.map +1 -1
- package/lib-es/common-logic/history/listOperations.js +2 -2
- package/lib-es/common-logic/history/listOperations.js.map +1 -1
- package/lib-es/common-logic/transaction/broadcast.d.ts +2 -1
- package/lib-es/common-logic/transaction/broadcast.d.ts.map +1 -1
- package/lib-es/common-logic/transaction/broadcast.js +5 -4
- package/lib-es/common-logic/transaction/broadcast.js.map +1 -1
- package/lib-es/common-logic/transaction/broadcast.test.js +8 -5
- package/lib-es/common-logic/transaction/broadcast.test.js.map +1 -1
- package/lib-es/common-logic/transaction/combine.d.ts +1 -1
- package/lib-es/common-logic/transaction/combine.d.ts.map +1 -1
- package/lib-es/common-logic/transaction/combine.js +2 -3
- package/lib-es/common-logic/transaction/combine.js.map +1 -1
- package/lib-es/common-logic/transaction/combine.test.js +3 -13
- package/lib-es/common-logic/transaction/combine.test.js.map +1 -1
- package/lib-es/common-logic/transaction/craftTransaction.d.ts +8 -4
- package/lib-es/common-logic/transaction/craftTransaction.d.ts.map +1 -1
- package/lib-es/common-logic/transaction/craftTransaction.js +15 -12
- package/lib-es/common-logic/transaction/craftTransaction.js.map +1 -1
- package/lib-es/common-logic/transaction/estimateFees.d.ts +2 -1
- package/lib-es/common-logic/transaction/estimateFees.d.ts.map +1 -1
- package/lib-es/common-logic/transaction/estimateFees.js +4 -3
- package/lib-es/common-logic/transaction/estimateFees.js.map +1 -1
- package/lib-es/config.d.ts +1 -0
- package/lib-es/config.d.ts.map +1 -1
- package/lib-es/config.js.map +1 -1
- package/lib-es/network/gateway.d.ts +41 -17
- package/lib-es/network/gateway.d.ts.map +1 -1
- package/lib-es/network/gateway.integ.test.js +19 -15
- package/lib-es/network/gateway.integ.test.js.map +1 -1
- package/lib-es/network/gateway.js +73 -48
- package/lib-es/network/gateway.js.map +1 -1
- package/lib-es/network/node.d.ts +2 -2
- package/lib-es/network/node.d.ts.map +1 -1
- package/lib-es/network/node.js.map +1 -1
- package/lib-es/network/types.d.ts +1 -1
- package/lib-es/network/types.d.ts.map +1 -1
- package/lib-es/signer/getAddress.d.ts.map +1 -1
- package/lib-es/signer/getAddress.js +2 -2
- package/lib-es/signer/getAddress.js.map +1 -1
- package/lib-es/types/bridge.d.ts +18 -3
- package/lib-es/types/bridge.d.ts.map +1 -1
- package/lib-es/types/index.d.ts +0 -10
- package/lib-es/types/index.d.ts.map +1 -1
- package/lib-es/types/onboard.d.ts +2 -0
- package/lib-es/types/onboard.d.ts.map +1 -1
- package/lib-es/types/onboard.js.map +1 -1
- package/lib-es/types/signer.d.ts +2 -1
- package/lib-es/types/signer.d.ts.map +1 -1
- package/package.json +8 -8
- package/src/api/getBalance.integ.test.ts +9 -6
- package/src/api/index.ts +22 -44
- package/src/api/lastBlock.integ.test.ts +1 -1
- package/src/api/listOperations.integ.test.ts +1 -1
- package/src/bridge/broadcast.test.ts +11 -0
- package/src/bridge/broadcast.ts +4 -2
- package/src/bridge/createTransaction.ts +1 -1
- package/src/bridge/getTransactionStatus.ts +1 -1
- package/src/bridge/index.ts +3 -0
- package/src/bridge/onboard.integ.test.ts +25 -13
- package/src/bridge/onboard.ts +143 -51
- package/src/bridge/prepareTransaction.ts +6 -15
- package/src/bridge/serialization.ts +36 -0
- package/src/bridge/signOperation.ts +26 -20
- package/src/bridge/sync.integ.test.ts +180 -0
- package/src/bridge/sync.ts +61 -33
- package/src/bridge/updateTransaction.ts +0 -5
- package/src/common-logic/account/getBalance.ts +12 -7
- package/src/common-logic/account/getBalance.unit.test.ts +8 -3
- package/src/common-logic/history/lastBlock.test.ts +7 -2
- package/src/common-logic/history/lastBlock.ts +5 -3
- package/src/common-logic/history/listOperations.ts +3 -2
- package/src/common-logic/transaction/broadcast.test.ts +10 -5
- package/src/common-logic/transaction/broadcast.ts +7 -3
- package/src/common-logic/transaction/combine.test.ts +3 -13
- package/src/common-logic/transaction/combine.ts +2 -4
- package/src/common-logic/transaction/craftTransaction.ts +30 -15
- package/src/common-logic/transaction/estimateFees.ts +8 -3
- package/src/config.ts +1 -0
- package/src/network/gateway.integ.test.ts +31 -12
- package/src/network/gateway.ts +141 -62
- package/src/network/node.ts +3 -3
- package/src/network/types.ts +1 -1
- package/src/signer/getAddress.ts +6 -4
- package/src/types/bridge.ts +21 -0
- package/src/types/index.ts +0 -11
- package/src/types/onboard.ts +3 -0
- package/src/types/signer.ts +2 -1
package/lib/bridge/sync.js
CHANGED
|
@@ -7,14 +7,21 @@ exports.getAccountShape = void 0;
|
|
|
7
7
|
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
8
8
|
const index_1 = require("@ledgerhq/coin-framework/account/index");
|
|
9
9
|
const jsHelpers_1 = require("@ledgerhq/coin-framework/bridge/jsHelpers");
|
|
10
|
-
const gateway_1 = require("../network/gateway");
|
|
11
10
|
const operation_1 = require("@ledgerhq/coin-framework/operation");
|
|
11
|
+
const gateway_1 = require("../network/gateway");
|
|
12
12
|
const config_1 = __importDefault(require("../config"));
|
|
13
|
-
const txInfoToOperationAdapter = (accountId,
|
|
14
|
-
const { transaction_hash, uid, block: { height, hash }, senders, recipients, transaction_timestamp, fee: { value: fee }, transfers: [{ value: transferValue }], } = txInfo;
|
|
15
|
-
|
|
13
|
+
const txInfoToOperationAdapter = (accountId, partyId) => (txInfo) => {
|
|
14
|
+
const { transaction_hash, uid, block: { height, hash }, senders, recipients, transaction_timestamp, fee: { value: fee }, transfers: [{ value: transferValue, details }], } = txInfo;
|
|
15
|
+
let type = "UNKNOWN";
|
|
16
|
+
if (txInfo.type === "Send") {
|
|
17
|
+
type = senders.includes(partyId) ? "OUT" : "IN";
|
|
18
|
+
}
|
|
19
|
+
else if (txInfo.type === "Receive") {
|
|
20
|
+
type = "IN";
|
|
21
|
+
}
|
|
16
22
|
const value = new bignumber_js_1.default(transferValue);
|
|
17
23
|
const feeValue = new bignumber_js_1.default(fee);
|
|
24
|
+
const memo = details.metadata.reason;
|
|
18
25
|
const op = {
|
|
19
26
|
id: (0, operation_1.encodeOperationId)(accountId, transaction_hash, type),
|
|
20
27
|
hash: transaction_hash,
|
|
@@ -30,43 +37,54 @@ const txInfoToOperationAdapter = (accountId, address) => (txInfo) => {
|
|
|
30
37
|
transactionSequenceNumber: height,
|
|
31
38
|
extra: {
|
|
32
39
|
uid,
|
|
40
|
+
memo,
|
|
33
41
|
},
|
|
34
42
|
};
|
|
35
43
|
return op;
|
|
36
44
|
};
|
|
37
|
-
const filterOperations = (transactions, accountId,
|
|
38
|
-
return transactions
|
|
39
|
-
.filter(tx => tx.type === "Receive" || tx.type === "Send")
|
|
40
|
-
.map(txInfoToOperationAdapter(accountId, address));
|
|
45
|
+
const filterOperations = (transactions, accountId, partyId) => {
|
|
46
|
+
return transactions.map(txInfoToOperationAdapter(accountId, partyId));
|
|
41
47
|
};
|
|
42
48
|
const getAccountShape = async (info) => {
|
|
43
|
-
const { address, initialAccount, currency, derivationMode } = info;
|
|
44
|
-
|
|
45
|
-
|
|
49
|
+
const { address, initialAccount, currency, derivationMode, derivationPath, rest } = info;
|
|
50
|
+
const xpubOrAddress = ((initialAccount && initialAccount.id && (0, index_1.decodeAccountId)(initialAccount.id).xpubOrAddress) ||
|
|
51
|
+
"").replace(/:/g, "_");
|
|
52
|
+
const partyId = rest?.cantonResources?.partyId ||
|
|
53
|
+
initialAccount?.cantonResources?.partyId ||
|
|
54
|
+
xpubOrAddress.replace(/_/g, ":");
|
|
46
55
|
const accountId = (0, index_1.encodeAccountId)({
|
|
47
56
|
type: "js",
|
|
48
57
|
version: "2",
|
|
49
58
|
currencyId: currency.id,
|
|
50
59
|
xpubOrAddress,
|
|
51
|
-
derivationMode
|
|
60
|
+
derivationMode,
|
|
52
61
|
});
|
|
53
|
-
// blockheight retrieval
|
|
54
|
-
const blockHeight = await (0, gateway_1.getLedgerEnd)();
|
|
55
62
|
// Account info retrieval + spendable balance calculation
|
|
56
63
|
// const accountInfo = await getAccountInfo(address);
|
|
57
|
-
const
|
|
58
|
-
const
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
const
|
|
64
|
-
const
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
64
|
+
const balances = await (0, gateway_1.getBalance)(currency, partyId);
|
|
65
|
+
const balanceData = balances.find(balance => balance.instrument_id === "Amulet") || {
|
|
66
|
+
instrument_id: "Amulet",
|
|
67
|
+
amount: 0,
|
|
68
|
+
locked: false,
|
|
69
|
+
};
|
|
70
|
+
const balance = new bignumber_js_1.default(balanceData.amount);
|
|
71
|
+
const reserveMin = config_1.default.getCoinConfig(currency).minReserve || 0;
|
|
72
|
+
const lockedAmount = balanceData.locked ? balance : new bignumber_js_1.default(0);
|
|
73
|
+
const spendableBalance = bignumber_js_1.default.max(0, balance.minus(lockedAmount).minus((0, bignumber_js_1.default)(reserveMin)));
|
|
74
|
+
let operations = [];
|
|
75
|
+
// Tx history fetching if xpubOrAddress is not empty
|
|
76
|
+
if (xpubOrAddress) {
|
|
77
|
+
const oldOperations = initialAccount?.operations || [];
|
|
78
|
+
const startAt = oldOperations.length ? (oldOperations[0].blockHeight || 0) + 1 : 0;
|
|
79
|
+
const transactionData = await (0, gateway_1.getOperations)(currency, partyId, {
|
|
80
|
+
cursor: startAt,
|
|
81
|
+
limit: 100,
|
|
82
|
+
});
|
|
83
|
+
const newOperations = filterOperations(transactionData.operations, accountId, partyId);
|
|
84
|
+
operations = (0, jsHelpers_1.mergeOps)(oldOperations, newOperations);
|
|
85
|
+
}
|
|
86
|
+
// blockheight retrieval
|
|
87
|
+
const blockHeight = await (0, gateway_1.getLedgerEnd)(currency);
|
|
70
88
|
// We return the new account shape
|
|
71
89
|
const shape = {
|
|
72
90
|
id: accountId,
|
|
@@ -76,6 +94,11 @@ const getAccountShape = async (info) => {
|
|
|
76
94
|
spendableBalance,
|
|
77
95
|
operations,
|
|
78
96
|
operationsCount: operations.length,
|
|
97
|
+
freshAddress: address,
|
|
98
|
+
freshAddressPath: derivationPath,
|
|
99
|
+
cantonResources: {
|
|
100
|
+
partyId,
|
|
101
|
+
},
|
|
79
102
|
};
|
|
80
103
|
return shape;
|
|
81
104
|
};
|
package/lib/bridge/sync.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sync.js","sourceRoot":"","sources":["../../src/bridge/sync.ts"],"names":[],"mappings":";;;;;;AAAA,gEAAqC;AAErC,
|
|
1
|
+
{"version":3,"file":"sync.js","sourceRoot":"","sources":["../../src/bridge/sync.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"updateTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/updateTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAO5C,eAAO,MAAM,iBAAiB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,mBAAmB,
|
|
1
|
+
{"version":3,"file":"updateTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/updateTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAO5C,eAAO,MAAM,iBAAiB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,mBAAmB,CAE7E,CAAC"}
|
|
@@ -7,10 +7,6 @@ const jsHelpers_1 = require("@ledgerhq/coin-framework/bridge/jsHelpers");
|
|
|
7
7
|
// NOTE: here is an example transaction updater function
|
|
8
8
|
// in this case, it resets fee to null depending on the patch content
|
|
9
9
|
const updateTransaction = (tx, patch) => {
|
|
10
|
-
// eslint-disable-next-line no-constant-condition
|
|
11
|
-
if (patch.recipient === "boilerplate1" || true) {
|
|
12
|
-
patch = { ...patch, fee: null };
|
|
13
|
-
}
|
|
14
10
|
return (0, jsHelpers_1.updateTransaction)(tx, patch);
|
|
15
11
|
};
|
|
16
12
|
exports.updateTransaction = updateTransaction;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"updateTransaction.js","sourceRoot":"","sources":["../../src/bridge/updateTransaction.ts"],"names":[],"mappings":";;;AAAA,yEAA0G;AAI1G,8DAA8D;AAC9D,8DAA8D;AAE9D,wDAAwD;AACxD,qEAAqE;AAC9D,MAAM,iBAAiB,GAAoD,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE;IAC9F,
|
|
1
|
+
{"version":3,"file":"updateTransaction.js","sourceRoot":"","sources":["../../src/bridge/updateTransaction.ts"],"names":[],"mappings":";;;AAAA,yEAA0G;AAI1G,8DAA8D;AAC9D,8DAA8D;AAE9D,wDAAwD;AACxD,qEAAqE;AAC9D,MAAM,iBAAiB,GAAoD,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE;IAC9F,OAAO,IAAA,6BAAwB,EAAC,EAAE,EAAE,KAAK,CAAC,CAAC;AAC7C,CAAC,CAAC;AAFW,QAAA,iBAAiB,qBAE5B"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
import { Balance } from "@ledgerhq/coin-framework/api/types";
|
|
2
|
-
|
|
2
|
+
import { CryptoCurrency } from "@ledgerhq/types-cryptoassets";
|
|
3
|
+
export declare function getBalance(currency: CryptoCurrency, partyId: string): Promise<Balance[]>;
|
|
3
4
|
//# sourceMappingURL=getBalance.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getBalance.d.ts","sourceRoot":"","sources":["../../../src/common-logic/account/getBalance.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,oCAAoC,CAAC;
|
|
1
|
+
{"version":3,"file":"getBalance.d.ts","sourceRoot":"","sources":["../../../src/common-logic/account/getBalance.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,oCAAoC,CAAC;AAG7D,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAkB9D,wBAAsB,UAAU,CAAC,QAAQ,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAM9F"}
|
|
@@ -6,20 +6,20 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
exports.getBalance = getBalance;
|
|
7
7
|
const gateway_1 = require("../../network/gateway");
|
|
8
8
|
const config_1 = __importDefault(require("../../config"));
|
|
9
|
-
const useGateway = () => config_1.default.getCoinConfig().useGateway === true;
|
|
10
|
-
const getNativeId = () => config_1.default.getCoinConfig().nativeInstrumentId;
|
|
11
|
-
function adaptInstrument(instrument) {
|
|
9
|
+
const useGateway = (currency) => config_1.default.getCoinConfig(currency).useGateway === true;
|
|
10
|
+
const getNativeId = (currency) => config_1.default.getCoinConfig(currency).nativeInstrumentId;
|
|
11
|
+
function adaptInstrument(currency, instrument) {
|
|
12
12
|
return {
|
|
13
13
|
value: BigInt(instrument.amount),
|
|
14
14
|
locked: instrument.locked === true ? BigInt(instrument.amount) : BigInt(0),
|
|
15
|
-
asset: getNativeId() === instrument.instrument_id
|
|
15
|
+
asset: getNativeId(currency) === instrument.instrument_id
|
|
16
16
|
? { type: "native" }
|
|
17
17
|
: { type: "token", assetReference: instrument.instrument_id },
|
|
18
18
|
};
|
|
19
19
|
}
|
|
20
|
-
async function getBalance(partyId) {
|
|
21
|
-
if (useGateway())
|
|
22
|
-
return (await (0, gateway_1.getBalance)(partyId)).map(instrument => adaptInstrument(instrument));
|
|
20
|
+
async function getBalance(currency, partyId) {
|
|
21
|
+
if (useGateway(currency))
|
|
22
|
+
return (await (0, gateway_1.getBalance)(currency, partyId)).map(instrument => adaptInstrument(currency, instrument));
|
|
23
23
|
else
|
|
24
24
|
throw new Error("Not implemented");
|
|
25
25
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getBalance.js","sourceRoot":"","sources":["../../../src/common-logic/account/getBalance.ts"],"names":[],"mappings":";;;;;
|
|
1
|
+
{"version":3,"file":"getBalance.js","sourceRoot":"","sources":["../../../src/common-logic/account/getBalance.ts"],"names":[],"mappings":";;;;;AAqBA,gCAMC;AA1BD,mDAAgG;AAChG,0DAAsC;AAGtC,MAAM,UAAU,GAAG,CAAC,QAAwB,EAAE,EAAE,CAC9C,gBAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,UAAU,KAAK,IAAI,CAAC;AACzD,MAAM,WAAW,GAAG,CAAC,QAAwB,EAAE,EAAE,CAC/C,gBAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,kBAAkB,CAAC;AAExD,SAAS,eAAe,CAAC,QAAwB,EAAE,UAA6B;IAC9E,OAAO;QACL,KAAK,EAAE,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC;QAChC,MAAM,EAAE,UAAU,CAAC,MAAM,KAAK,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;QAC1E,KAAK,EACH,WAAW,CAAC,QAAQ,CAAC,KAAK,UAAU,CAAC,aAAa;YAChD,CAAC,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE;YACpB,CAAC,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,cAAc,EAAE,UAAU,CAAC,aAAa,EAAE;KAClE,CAAC;AACJ,CAAC;AAEM,KAAK,UAAU,UAAU,CAAC,QAAwB,EAAE,OAAe;IACxE,IAAI,UAAU,CAAC,QAAQ,CAAC;QACtB,OAAO,CAAC,MAAM,IAAA,oBAAiB,EAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CACnE,eAAe,CAAC,QAAQ,EAAE,UAAU,CAAC,CACtC,CAAC;;QACC,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;AAC1C,CAAC"}
|
|
@@ -36,6 +36,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
36
36
|
const gateway_1 = require("../../network/gateway");
|
|
37
37
|
const coinConfigModule = __importStar(require("../../config"));
|
|
38
38
|
const getBalance_1 = require("./getBalance");
|
|
39
|
+
const mockCurrency = {
|
|
40
|
+
id: "canton_network",
|
|
41
|
+
};
|
|
39
42
|
jest.mock("../../network/gateway", () => ({
|
|
40
43
|
getBalance: jest.fn(),
|
|
41
44
|
}));
|
|
@@ -62,8 +65,8 @@ describe("getBalance", () => {
|
|
|
62
65
|
},
|
|
63
66
|
];
|
|
64
67
|
gateway_1.getBalance.mockResolvedValue(mockInstruments);
|
|
65
|
-
const result = await (0, getBalance_1.getBalance)("party-id");
|
|
66
|
-
expect(gateway_1.getBalance).toHaveBeenCalledWith("party-id");
|
|
68
|
+
const result = await (0, getBalance_1.getBalance)(mockCurrency, "party-id");
|
|
69
|
+
expect(gateway_1.getBalance).toHaveBeenCalledWith(mockCurrency, "party-id");
|
|
67
70
|
expect(result).toEqual([
|
|
68
71
|
{
|
|
69
72
|
value: BigInt(1000),
|
|
@@ -81,7 +84,7 @@ describe("getBalance", () => {
|
|
|
81
84
|
mockGetCoinConfig.mockReturnValue({
|
|
82
85
|
useGateway: false,
|
|
83
86
|
});
|
|
84
|
-
await expect((0, getBalance_1.getBalance)("party-id")).rejects.toThrow("Not implemented");
|
|
87
|
+
await expect((0, getBalance_1.getBalance)(mockCurrency, "party-id")).rejects.toThrow("Not implemented");
|
|
85
88
|
expect(gateway_1.getBalance).not.toHaveBeenCalled();
|
|
86
89
|
});
|
|
87
90
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getBalance.unit.test.js","sourceRoot":"","sources":["../../../src/common-logic/account/getBalance.unit.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mDAA4E;AAC5E,+DAAiD;AACjD,6CAA0C;
|
|
1
|
+
{"version":3,"file":"getBalance.unit.test.js","sourceRoot":"","sources":["../../../src/common-logic/account/getBalance.unit.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mDAA4E;AAC5E,+DAAiD;AACjD,6CAA0C;AAI1C,MAAM,YAAY,GAAG;IACnB,EAAE,EAAE,gBAAgB;CACQ,CAAC;AAE/B,IAAI,CAAC,IAAI,CAAC,uBAAuB,EAAE,GAAG,EAAE,CAAC,CAAC;IACxC,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE;CACtB,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;IAC1B,MAAM,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;IAEhF,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wDAAwD,EAAE,KAAK,IAAI,EAAE;QACtE,iBAAiB,CAAC,eAAe,CAAC;YAChC,UAAU,EAAE,IAAI;YAChB,kBAAkB,EAAE,WAAW;SACzB,CAAC,CAAC;QAEV,MAAM,eAAe,GAAG;YACtB;gBACE,aAAa,EAAE,WAAW;gBAC1B,MAAM,EAAE,MAAM;gBACd,MAAM,EAAE,KAAK;aACd;YACD;gBACE,aAAa,EAAE,WAAW;gBAC1B,MAAM,EAAE,MAAM;gBACd,MAAM,EAAE,IAAI;aACb;SACF,CAAC;QAED,oBAAmC,CAAC,iBAAiB,CAAC,eAAe,CAAC,CAAC;QAExE,MAAM,MAAM,GAAG,MAAM,IAAA,uBAAU,EAAC,YAAY,EAAE,UAAU,CAAC,CAAC;QAE1D,MAAM,CAAC,oBAAqB,CAAC,CAAC,oBAAoB,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;QAC7E,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAY;YAChC;gBACE,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC;gBACnB,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;gBACjB,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;aAC1B;YACD;gBACE,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC;gBACnB,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;gBACpB,KAAK,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE;aACtD;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;QAC1F,iBAAiB,CAAC,eAAe,CAAC;YAChC,UAAU,EAAE,KAAK;SACX,CAAC,CAAC;QAEV,MAAM,MAAM,CAAC,IAAA,uBAAU,EAAC,YAAY,EAAE,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;QACtF,MAAM,CAAC,oBAAqB,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;IACvD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
import type { BlockInfo } from "@ledgerhq/coin-framework/api/index";
|
|
2
|
-
|
|
2
|
+
import type { CryptoCurrency } from "@ledgerhq/types-cryptoassets";
|
|
3
|
+
export declare function lastBlock(currency: CryptoCurrency): Promise<BlockInfo>;
|
|
3
4
|
//# sourceMappingURL=lastBlock.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lastBlock.d.ts","sourceRoot":"","sources":["../../../src/common-logic/history/lastBlock.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAC;
|
|
1
|
+
{"version":3,"file":"lastBlock.d.ts","sourceRoot":"","sources":["../../../src/common-logic/history/lastBlock.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAC;AAIpE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAKnE,wBAAsB,SAAS,CAAC,QAAQ,EAAE,cAAc,GAAG,OAAO,CAAC,SAAS,CAAC,CAI5E"}
|
|
@@ -7,10 +7,10 @@ exports.lastBlock = lastBlock;
|
|
|
7
7
|
const node_1 = require("../../network/node");
|
|
8
8
|
const gateway_1 = require("../../network/gateway");
|
|
9
9
|
const config_1 = __importDefault(require("../../config"));
|
|
10
|
-
const useGateway = () => config_1.default.getCoinConfig().useGateway === true;
|
|
11
|
-
async function lastBlock() {
|
|
10
|
+
const useGateway = (currency) => config_1.default.getCoinConfig(currency).useGateway === true;
|
|
11
|
+
async function lastBlock(currency) {
|
|
12
12
|
return {
|
|
13
|
-
height: useGateway() ? await (0, gateway_1.getLedgerEnd)() : await (0, node_1.getLedgerEnd)(),
|
|
13
|
+
height: useGateway(currency) ? await (0, gateway_1.getLedgerEnd)(currency) : await (0, node_1.getLedgerEnd)(),
|
|
14
14
|
};
|
|
15
15
|
}
|
|
16
16
|
//# sourceMappingURL=lastBlock.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lastBlock.js","sourceRoot":"","sources":["../../../src/common-logic/history/lastBlock.ts"],"names":[],"mappings":";;;;;
|
|
1
|
+
{"version":3,"file":"lastBlock.js","sourceRoot":"","sources":["../../../src/common-logic/history/lastBlock.ts"],"names":[],"mappings":";;;;;AASA,8BAIC;AAZD,6CAAsE;AACtE,mDAAqD;AACrD,0DAAsC;AAGtC,MAAM,UAAU,GAAG,CAAC,QAAwB,EAAE,EAAE,CAC9C,gBAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,UAAU,KAAK,IAAI,CAAC;AAElD,KAAK,UAAU,SAAS,CAAC,QAAwB;IACtD,OAAO;QACL,MAAM,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,IAAA,sBAAY,EAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,IAAA,mBAAgB,GAAE;KACvF,CAAC;AACJ,CAAC"}
|
|
@@ -19,6 +19,9 @@ jest.mock("../../config", () => ({
|
|
|
19
19
|
},
|
|
20
20
|
}));
|
|
21
21
|
const config_1 = __importDefault(require("../../config"));
|
|
22
|
+
const mockCurrency = {
|
|
23
|
+
id: "canton_network",
|
|
24
|
+
};
|
|
22
25
|
describe("lastBlock", () => {
|
|
23
26
|
beforeEach(() => {
|
|
24
27
|
jest.clearAllMocks();
|
|
@@ -26,7 +29,7 @@ describe("lastBlock", () => {
|
|
|
26
29
|
it("should use gateway.getLedgerEnd when useGateway is true", async () => {
|
|
27
30
|
config_1.default.getCoinConfig.mockReturnValue({ useGateway: true });
|
|
28
31
|
gateway_1.getLedgerEnd.mockResolvedValue(100);
|
|
29
|
-
const result = await (0, lastBlock_1.lastBlock)();
|
|
32
|
+
const result = await (0, lastBlock_1.lastBlock)(mockCurrency);
|
|
30
33
|
expect(result).toEqual({ height: 100 });
|
|
31
34
|
expect(gateway_1.getLedgerEnd).toHaveBeenCalledTimes(1);
|
|
32
35
|
expect(node_1.getLedgerEnd).not.toHaveBeenCalled();
|
|
@@ -34,7 +37,7 @@ describe("lastBlock", () => {
|
|
|
34
37
|
it("should use node.getLedgerEnd when useGateway is false", async () => {
|
|
35
38
|
config_1.default.getCoinConfig.mockReturnValue({ useGateway: false });
|
|
36
39
|
node_1.getLedgerEnd.mockResolvedValue(200);
|
|
37
|
-
const result = await (0, lastBlock_1.lastBlock)();
|
|
40
|
+
const result = await (0, lastBlock_1.lastBlock)(mockCurrency);
|
|
38
41
|
expect(result).toEqual({ height: 200 });
|
|
39
42
|
expect(node_1.getLedgerEnd).toHaveBeenCalledTimes(1);
|
|
40
43
|
expect(gateway_1.getLedgerEnd).not.toHaveBeenCalled();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lastBlock.test.js","sourceRoot":"","sources":["../../../src/common-logic/history/lastBlock.test.ts"],"names":[],"mappings":";;;;;AAAA,2CAAwC;AACxC,mDAA4E;AAC5E,6CAAsE;
|
|
1
|
+
{"version":3,"file":"lastBlock.test.js","sourceRoot":"","sources":["../../../src/common-logic/history/lastBlock.test.ts"],"names":[],"mappings":";;;;;AAAA,2CAAwC;AACxC,mDAA4E;AAC5E,6CAAsE;AAGtE,IAAI,CAAC,IAAI,CAAC,uBAAuB,EAAE,GAAG,EAAE,CAAC,CAAC;IACxC,YAAY,EAAE,IAAI,CAAC,EAAE,EAAE;CACxB,CAAC,CAAC,CAAC;AACJ,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,GAAG,EAAE,CAAC,CAAC;IACrC,YAAY,EAAE,IAAI,CAAC,EAAE,EAAE;CACxB,CAAC,CAAC,CAAC;AAEJ,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,GAAG,EAAE,CAAC,CAAC;IAC/B,UAAU,EAAE,IAAI;IAChB,OAAO,EAAE;QACP,aAAa,EAAE,IAAI,CAAC,EAAE,EAAE;KACzB;CACF,CAAC,CAAC,CAAC;AAEJ,0DAAsC;AAEtC,MAAM,YAAY,GAAG;IACnB,EAAE,EAAE,gBAAgB;CACQ,CAAC;AAE/B,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,UAAU,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;QACtE,gBAAU,CAAC,aAA2B,CAAC,eAAe,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC;QAC7E,sBAAiC,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;QAE1D,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAS,EAAC,YAAY,CAAC,CAAC;QAE7C,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;QACxC,MAAM,CAAC,sBAAmB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACrD,MAAM,CAAC,mBAAgB,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;IAClD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uDAAuD,EAAE,KAAK,IAAI,EAAE;QACpE,gBAAU,CAAC,aAA2B,CAAC,eAAe,CAAC,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC;QAC9E,mBAA8B,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;QAEvD,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAS,EAAC,YAAY,CAAC,CAAC;QAE7C,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;QACxC,MAAM,CAAC,mBAAgB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,sBAAmB,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;IACrD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { Operation, Pagination } from "@ledgerhq/coin-framework/api/index";
|
|
2
|
+
import { CryptoCurrency } from "@ledgerhq/types-cryptoassets";
|
|
2
3
|
/**
|
|
3
4
|
* Returns list of operations associated to an account.
|
|
4
5
|
* @param partyId Account partyId
|
|
@@ -6,5 +7,5 @@ import type { Operation, Pagination } from "@ledgerhq/coin-framework/api/index";
|
|
|
6
7
|
* @returns Operations found and the next "id" or "index" to use for pagination (i.e. `start` property).\
|
|
7
8
|
* Impl to finalize when backend is ready
|
|
8
9
|
*/
|
|
9
|
-
export declare function listOperations(partyId: string, page: Pagination): Promise<[Operation[], string]>;
|
|
10
|
+
export declare function listOperations(currency: CryptoCurrency, partyId: string, page: Pagination): Promise<[Operation[], string]>;
|
|
10
11
|
//# sourceMappingURL=listOperations.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"listOperations.d.ts","sourceRoot":"","sources":["../../../src/common-logic/history/listOperations.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,oCAAoC,CAAC;
|
|
1
|
+
{"version":3,"file":"listOperations.d.ts","sourceRoot":"","sources":["../../../src/common-logic/history/listOperations.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,oCAAoC,CAAC;AAEhF,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAE9D;;;;;;GAMG;AACH,wBAAsB,cAAc,CAClC,QAAQ,EAAE,cAAc,EACxB,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,UAAU,GACf,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE,MAAM,CAAC,CAAC,CA6BhC"}
|
|
@@ -9,8 +9,8 @@ const gateway_1 = require("../../network/gateway");
|
|
|
9
9
|
* @returns Operations found and the next "id" or "index" to use for pagination (i.e. `start` property).\
|
|
10
10
|
* Impl to finalize when backend is ready
|
|
11
11
|
*/
|
|
12
|
-
async function listOperations(partyId, page) {
|
|
13
|
-
const { operations, next } = await (0, gateway_1.getOperations)(partyId, {
|
|
12
|
+
async function listOperations(currency, partyId, page) {
|
|
13
|
+
const { operations, next } = await (0, gateway_1.getOperations)(currency, partyId, {
|
|
14
14
|
cursor: page.pagingToken !== undefined ? parseInt(page.pagingToken) : undefined,
|
|
15
15
|
minOffset: page.minHeight,
|
|
16
16
|
limit: page.limit,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"listOperations.js","sourceRoot":"","sources":["../../../src/common-logic/history/listOperations.ts"],"names":[],"mappings":";;AAWA,
|
|
1
|
+
{"version":3,"file":"listOperations.js","sourceRoot":"","sources":["../../../src/common-logic/history/listOperations.ts"],"names":[],"mappings":";;AAWA,wCAiCC;AA3CD,mDAAsD;AAGtD;;;;;;GAMG;AACI,KAAK,UAAU,cAAc,CAClC,QAAwB,EACxB,OAAe,EACf,IAAgB;IAEhB,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,MAAM,IAAA,uBAAa,EAAC,QAAQ,EAAE,OAAO,EAAE;QAClE,MAAM,EAAE,IAAI,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,SAAS;QAC/E,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,KAAK,EAAE,IAAI,CAAC,KAAK;KAClB,CAAC,CAAC;IACH,MAAM,GAAG,GAAgB,EAAE,CAAC;IAC5B,KAAK,MAAM,EAAE,IAAI,UAAU,EAAE,CAAC;QAC5B,IAAI,EAAE,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YACvB,GAAG,CAAC,IAAI,CAAC;gBACP,EAAE,EAAE,EAAE,CAAC,GAAG;gBACV,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI;gBACjD,KAAK,EAAE,MAAM,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;gBACpC,OAAO,EAAE,EAAE,CAAC,OAAO;gBACnB,UAAU,EAAE,EAAE,CAAC,UAAU;gBACzB,KAAK,EAAE,EAAE,CAAC,KAAK;gBACf,EAAE,EAAE;oBACF,IAAI,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI;oBACnB,IAAI,EAAE,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC;oBAC1B,IAAI,EAAE,IAAI,IAAI,CAAC,EAAE,CAAC,qBAAqB,CAAC;oBACxC,KAAK,EAAE;wBACL,MAAM,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM;wBACvB,IAAI,EAAE,IAAI,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC;qBAC9B;iBACF;aACF,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IACD,OAAO,CAAC,GAAG,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;AAC1B,CAAC"}
|
|
@@ -1,2 +1,3 @@
|
|
|
1
|
-
|
|
1
|
+
import type { CryptoCurrency } from "@ledgerhq/types-cryptoassets";
|
|
2
|
+
export declare function broadcast(currency: CryptoCurrency, signedTx: string): Promise<string>;
|
|
2
3
|
//# sourceMappingURL=broadcast.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../../src/common-logic/transaction/broadcast.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../../src/common-logic/transaction/broadcast.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAKnE,wBAAsB,SAAS,CAAC,QAAQ,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAM3F"}
|
|
@@ -6,11 +6,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
exports.broadcast = broadcast;
|
|
7
7
|
const config_1 = __importDefault(require("../../config"));
|
|
8
8
|
const gateway_1 = require("../../network/gateway");
|
|
9
|
-
const useGateway = () => config_1.default.getCoinConfig().useGateway === true;
|
|
10
|
-
async function broadcast(signedTx) {
|
|
9
|
+
const useGateway = (currency) => config_1.default.getCoinConfig(currency).useGateway === true;
|
|
10
|
+
async function broadcast(currency, signedTx) {
|
|
11
11
|
const parsed = JSON.parse(signedTx);
|
|
12
|
-
|
|
13
|
-
|
|
12
|
+
const [sig, party] = parsed.signature.split("__PARTY__");
|
|
13
|
+
if (useGateway(currency))
|
|
14
|
+
return (await (0, gateway_1.submit)(currency, party, parsed.serialized, sig)).update_id;
|
|
14
15
|
else
|
|
15
16
|
throw new Error("Not implemented");
|
|
16
17
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../../src/common-logic/transaction/broadcast.ts"],"names":[],"mappings":";;;;;
|
|
1
|
+
{"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../../src/common-logic/transaction/broadcast.ts"],"names":[],"mappings":";;;;;AAOA,8BAMC;AAbD,0DAAsC;AACtC,mDAA+C;AAG/C,MAAM,UAAU,GAAG,CAAC,QAAwB,EAAE,EAAE,CAC9C,gBAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,UAAU,KAAK,IAAI,CAAC;AAElD,KAAK,UAAU,SAAS,CAAC,QAAwB,EAAE,QAAgB;IACxE,MAAM,MAAM,GAA8C,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IAC/E,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,GAAG,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IACzD,IAAI,UAAU,CAAC,QAAQ,CAAC;QACtB,OAAO,CAAC,MAAM,IAAA,gBAAM,EAAC,QAAQ,EAAE,KAAK,EAAE,MAAM,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC;;QACtE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;AAC1C,CAAC"}
|
|
@@ -41,8 +41,11 @@ jest.mock("../../network/gateway", () => ({
|
|
|
41
41
|
}));
|
|
42
42
|
const mockSerialized = JSON.stringify({
|
|
43
43
|
serialized: "serialized-tx",
|
|
44
|
-
signature: "
|
|
44
|
+
signature: "signature__PARTY__alice:123",
|
|
45
45
|
});
|
|
46
|
+
const mockCurrency = {
|
|
47
|
+
id: "canton_network",
|
|
48
|
+
};
|
|
46
49
|
describe("broadcast", () => {
|
|
47
50
|
const mockGetCoinConfig = jest.spyOn(coinConfigModule.default, "getCoinConfig");
|
|
48
51
|
afterEach(() => {
|
|
@@ -52,16 +55,16 @@ describe("broadcast", () => {
|
|
|
52
55
|
mockGetCoinConfig.mockReturnValue({
|
|
53
56
|
useGateway: true,
|
|
54
57
|
});
|
|
55
|
-
gateway_1.submit.mockResolvedValue({
|
|
56
|
-
const result = await (0, broadcast_1.broadcast)(mockSerialized);
|
|
57
|
-
expect(gateway_1.submit).toHaveBeenCalledWith("serialized-tx", "signature");
|
|
58
|
+
gateway_1.submit.mockResolvedValue({ update_id: "my-update-id" });
|
|
59
|
+
const result = await (0, broadcast_1.broadcast)(mockCurrency, mockSerialized);
|
|
60
|
+
expect(gateway_1.submit).toHaveBeenCalledWith(mockCurrency, "alice:123", "serialized-tx", "signature");
|
|
58
61
|
expect(result).toEqual("my-update-id");
|
|
59
62
|
});
|
|
60
63
|
it("should throw an error when useGateway is false (not implemented with node)", async () => {
|
|
61
64
|
mockGetCoinConfig.mockReturnValue({
|
|
62
65
|
useGateway: false,
|
|
63
66
|
});
|
|
64
|
-
await expect((0, broadcast_1.broadcast)(mockSerialized)).rejects.toThrow("Not implemented");
|
|
67
|
+
await expect((0, broadcast_1.broadcast)(mockCurrency, mockSerialized)).rejects.toThrow("Not implemented");
|
|
65
68
|
expect(gateway_1.submit).not.toHaveBeenCalled();
|
|
66
69
|
});
|
|
67
70
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"broadcast.test.js","sourceRoot":"","sources":["../../../src/common-logic/transaction/broadcast.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mDAA+C;AAC/C,+DAAiD;AACjD,2CAAwC;
|
|
1
|
+
{"version":3,"file":"broadcast.test.js","sourceRoot":"","sources":["../../../src/common-logic/transaction/broadcast.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mDAA+C;AAC/C,+DAAiD;AACjD,2CAAwC;AAGxC,IAAI,CAAC,IAAI,CAAC,uBAAuB,EAAE,GAAG,EAAE,CAAC,CAAC;IACxC,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE;CAClB,CAAC,CAAC,CAAC;AAEJ,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC;IACpC,UAAU,EAAE,eAAe;IAC3B,SAAS,EAAE,6BAA6B;CACzC,CAAC,CAAC;AAEH,MAAM,YAAY,GAAG;IACnB,EAAE,EAAE,gBAAgB;CACQ,CAAC;AAE/B,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,MAAM,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;IAEhF,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kBAAkB,EAAE,KAAK,IAAI,EAAE;QAChC,iBAAiB,CAAC,eAAe,CAAC;YAChC,UAAU,EAAE,IAAI;SACV,CAAC,CAAC;QAET,gBAAoB,CAAC,iBAAiB,CAAC,EAAE,SAAS,EAAE,cAAc,EAAE,CAAC,CAAC;QAEvE,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAS,EAAC,YAAY,EAAE,cAAc,CAAC,CAAC;QAE7D,MAAM,CAAC,gBAAM,CAAC,CAAC,oBAAoB,CAAC,YAAY,EAAE,WAAW,EAAE,eAAe,EAAE,WAAW,CAAC,CAAC;QAC7F,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;QAC1F,iBAAiB,CAAC,eAAe,CAAC;YAChC,UAAU,EAAE,KAAK;SACX,CAAC,CAAC;QAEV,MAAM,MAAM,CAAC,IAAA,qBAAS,EAAC,YAAY,EAAE,cAAc,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;QACzF,MAAM,CAAC,gBAAM,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;IACxC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export declare function combine(
|
|
1
|
+
export declare function combine(serialized: string, signature: string): string;
|
|
2
2
|
//# sourceMappingURL=combine.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"combine.d.ts","sourceRoot":"","sources":["../../../src/common-logic/transaction/combine.ts"],"names":[],"mappings":"AACA,wBAAgB,OAAO,CAAC,
|
|
1
|
+
{"version":3,"file":"combine.d.ts","sourceRoot":"","sources":["../../../src/common-logic/transaction/combine.ts"],"names":[],"mappings":"AACA,wBAAgB,OAAO,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,MAAM,CAKrE"}
|
|
@@ -2,10 +2,9 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.combine = combine;
|
|
4
4
|
// Combines signature with raw transaction
|
|
5
|
-
function combine(
|
|
6
|
-
const tx = JSON.parse(transaction);
|
|
5
|
+
function combine(serialized, signature) {
|
|
7
6
|
return JSON.stringify({
|
|
8
|
-
|
|
7
|
+
serialized,
|
|
9
8
|
signature,
|
|
10
9
|
});
|
|
11
10
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"combine.js","sourceRoot":"","sources":["../../../src/common-logic/transaction/combine.ts"],"names":[],"mappings":";;AACA,
|
|
1
|
+
{"version":3,"file":"combine.js","sourceRoot":"","sources":["../../../src/common-logic/transaction/combine.ts"],"names":[],"mappings":";;AACA,0BAKC;AAND,0CAA0C;AAC1C,SAAgB,OAAO,CAAC,UAAkB,EAAE,SAAiB;IAC3D,OAAO,IAAI,CAAC,SAAS,CAAC;QACpB,UAAU;QACV,SAAS;KACV,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -4,23 +4,13 @@ const combine_1 = require("./combine");
|
|
|
4
4
|
describe("combine", () => {
|
|
5
5
|
it("responds with a Stringify version of the payload to broadcast", () => {
|
|
6
6
|
// GIVEN
|
|
7
|
-
const transaction =
|
|
8
|
-
transaction: {
|
|
9
|
-
serialized: "SERIALIZED",
|
|
10
|
-
json: "JSON",
|
|
11
|
-
hash: "HASH",
|
|
12
|
-
},
|
|
13
|
-
};
|
|
7
|
+
const transaction = "0x000000001";
|
|
14
8
|
const signature = "SIGNATURE";
|
|
15
9
|
// WHEN
|
|
16
|
-
const result = (0, combine_1.combine)(
|
|
10
|
+
const result = (0, combine_1.combine)(transaction, signature);
|
|
17
11
|
// THEN
|
|
18
12
|
expect(JSON.parse(result)).toEqual({
|
|
19
|
-
|
|
20
|
-
serialized: "SERIALIZED",
|
|
21
|
-
json: "JSON",
|
|
22
|
-
hash: "HASH",
|
|
23
|
-
},
|
|
13
|
+
serialized: "0x000000001",
|
|
24
14
|
signature: "SIGNATURE",
|
|
25
15
|
});
|
|
26
16
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"combine.test.js","sourceRoot":"","sources":["../../../src/common-logic/transaction/combine.test.ts"],"names":[],"mappings":";;AAAA,uCAAoC;AAEpC,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;IACvB,EAAE,CAAC,+DAA+D,EAAE,GAAG,EAAE;QACvE,QAAQ;QACR,MAAM,WAAW,GAAG
|
|
1
|
+
{"version":3,"file":"combine.test.js","sourceRoot":"","sources":["../../../src/common-logic/transaction/combine.test.ts"],"names":[],"mappings":";;AAAA,uCAAoC;AAEpC,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;IACvB,EAAE,CAAC,+DAA+D,EAAE,GAAG,EAAE;QACvE,QAAQ;QACR,MAAM,WAAW,GAAG,aAAa,CAAC;QAClC,MAAM,SAAS,GAAG,WAAW,CAAC;QAE9B,OAAO;QACP,MAAM,MAAM,GAAG,IAAA,iBAAO,EAAC,WAAW,EAAE,SAAS,CAAC,CAAC;QAE/C,OAAO;QACP,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC;YACjC,UAAU,EAAE,aAAa;YACzB,SAAS,EAAE,WAAW;SACvB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,15 +1,19 @@
|
|
|
1
1
|
import BigNumber from "bignumber.js";
|
|
2
|
-
import {
|
|
3
|
-
|
|
2
|
+
import { PrepareTransferResponse } from "../../network/gateway";
|
|
3
|
+
import { CryptoCurrency } from "@ledgerhq/types-cryptoassets";
|
|
4
|
+
export declare function craftTransaction(currency: CryptoCurrency, account: {
|
|
4
5
|
address: string;
|
|
5
6
|
nextSequenceNumber?: number;
|
|
6
7
|
publicKey?: string;
|
|
7
8
|
}, transaction: {
|
|
8
9
|
recipient?: string;
|
|
9
10
|
amount: BigNumber;
|
|
10
|
-
|
|
11
|
+
tokenId: string;
|
|
12
|
+
expireInSeconds: number;
|
|
13
|
+
memo?: string;
|
|
11
14
|
}): Promise<{
|
|
12
|
-
nativeTransaction:
|
|
15
|
+
nativeTransaction: PrepareTransferResponse;
|
|
13
16
|
serializedTransaction: string;
|
|
17
|
+
hash: string;
|
|
14
18
|
}>;
|
|
15
19
|
//# sourceMappingURL=craftTransaction.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"craftTransaction.d.ts","sourceRoot":"","sources":["../../../src/common-logic/transaction/craftTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"craftTransaction.d.ts","sourceRoot":"","sources":["../../../src/common-logic/transaction/craftTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAGL,uBAAuB,EACxB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAE9D,wBAAsB,gBAAgB,CACpC,QAAQ,EAAE,cAAc,EACxB,OAAO,EAAE;IACP,OAAO,EAAE,MAAM,CAAC;IAChB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,EACD,WAAW,EAAE;IACX,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,SAAS,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,eAAe,EAAE,MAAM,CAAC;IACxB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf,GACA,OAAO,CAAC;IACT,iBAAiB,EAAE,uBAAuB,CAAC;IAC3C,qBAAqB,EAAE,MAAM,CAAC;IAC9B,IAAI,EAAE,MAAM,CAAC;CACd,CAAC,CAwBD"}
|
|
@@ -1,20 +1,23 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.craftTransaction = craftTransaction;
|
|
4
|
-
const
|
|
5
|
-
async function craftTransaction(account, transaction) {
|
|
6
|
-
const
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
Sequence: account.nextSequenceNumber || 0,
|
|
4
|
+
const gateway_1 = require("../../network/gateway");
|
|
5
|
+
async function craftTransaction(currency, account, transaction) {
|
|
6
|
+
const params = {
|
|
7
|
+
recipient: transaction.recipient || "",
|
|
8
|
+
amount: transaction.amount.toString(),
|
|
9
|
+
type: "token-transfer-request",
|
|
10
|
+
execute_before_secs: transaction.expireInSeconds,
|
|
11
|
+
instrument_id: transaction.tokenId,
|
|
13
12
|
};
|
|
14
|
-
|
|
13
|
+
if (transaction.memo) {
|
|
14
|
+
params.reason = transaction.memo;
|
|
15
|
+
}
|
|
16
|
+
const { serialized, json, hash } = await (0, gateway_1.prepareTransferRequest)(currency, account.address, params);
|
|
15
17
|
return {
|
|
16
|
-
nativeTransaction,
|
|
17
|
-
serializedTransaction,
|
|
18
|
+
nativeTransaction: json,
|
|
19
|
+
serializedTransaction: serialized,
|
|
20
|
+
hash,
|
|
18
21
|
};
|
|
19
22
|
}
|
|
20
23
|
//# sourceMappingURL=craftTransaction.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"craftTransaction.js","sourceRoot":"","sources":["../../../src/common-logic/transaction/craftTransaction.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"craftTransaction.js","sourceRoot":"","sources":["../../../src/common-logic/transaction/craftTransaction.ts"],"names":[],"mappings":";;AAQA,4CA0CC;AAjDD,mDAI+B;AAGxB,KAAK,UAAU,gBAAgB,CACpC,QAAwB,EACxB,OAIC,EACD,WAMC;IAMD,MAAM,MAAM,GAA2B;QACrC,SAAS,EAAE,WAAW,CAAC,SAAS,IAAI,EAAE;QACtC,MAAM,EAAE,WAAW,CAAC,MAAM,CAAC,QAAQ,EAAE;QACrC,IAAI,EAAE,wBAAiC;QACvC,mBAAmB,EAAE,WAAW,CAAC,eAAe;QAChD,aAAa,EAAE,WAAW,CAAC,OAAO;KACnC,CAAC;IAEF,IAAI,WAAW,CAAC,IAAI,EAAE,CAAC;QACrB,MAAM,CAAC,MAAM,GAAG,WAAW,CAAC,IAAI,CAAC;IACnC,CAAC;IAED,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,MAAM,IAAA,gCAAsB,EAC7D,QAAQ,EACR,OAAO,CAAC,OAAO,EACf,MAAM,CACP,CAAC;IAEF,OAAO;QACL,iBAAiB,EAAE,IAAI;QACvB,qBAAqB,EAAE,UAAU;QACjC,IAAI;KACL,CAAC;AACJ,CAAC"}
|
|
@@ -1,2 +1,3 @@
|
|
|
1
|
-
|
|
1
|
+
import type { CryptoCurrency } from "@ledgerhq/types-cryptoassets";
|
|
2
|
+
export declare function estimateFees(currency: CryptoCurrency): Promise<bigint>;
|
|
2
3
|
//# sourceMappingURL=estimateFees.d.ts.map
|