@ledgerhq/live-common 34.37.0-next.1 → 34.37.0-next.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/__tests__/test-helpers/bridge.d.ts.map +1 -1
- package/lib/__tests__/test-helpers/bridge.js +4 -4
- package/lib/__tests__/test-helpers/bridge.js.map +1 -1
- package/lib/bridge/impl.d.ts.map +1 -1
- package/lib/bridge/impl.js +3 -59
- package/lib/bridge/impl.js.map +1 -1
- package/lib/config/index.d.ts +2 -3
- package/lib/config/index.d.ts.map +1 -1
- package/lib/config/index.js +1 -9
- package/lib/config/index.js.map +1 -1
- package/lib/config/sharedConfig.d.ts.map +1 -1
- package/lib/config/sharedConfig.js +0 -7
- package/lib/config/sharedConfig.js.map +1 -1
- package/lib/families/xrp/setup.d.ts +6 -3
- package/lib/families/xrp/setup.d.ts.map +1 -1
- package/lib/families/xrp/setup.js +7 -1
- package/lib/families/xrp/setup.js.map +1 -1
- package/lib/generated/bridge/js.d.ts +1 -0
- package/lib/generated/bridge/js.d.ts.map +1 -1
- package/lib/generated/bridge/js.js +6 -4
- package/lib/generated/bridge/js.js.map +1 -1
- package/lib-es/__tests__/test-helpers/bridge.d.ts.map +1 -1
- package/lib-es/__tests__/test-helpers/bridge.js +4 -4
- package/lib-es/__tests__/test-helpers/bridge.js.map +1 -1
- package/lib-es/bridge/impl.d.ts.map +1 -1
- package/lib-es/bridge/impl.js +3 -59
- package/lib-es/bridge/impl.js.map +1 -1
- package/lib-es/config/index.d.ts +2 -3
- package/lib-es/config/index.d.ts.map +1 -1
- package/lib-es/config/index.js +1 -8
- package/lib-es/config/index.js.map +1 -1
- package/lib-es/config/sharedConfig.d.ts.map +1 -1
- package/lib-es/config/sharedConfig.js +0 -7
- package/lib-es/config/sharedConfig.js.map +1 -1
- package/lib-es/families/xrp/setup.d.ts +6 -3
- package/lib-es/families/xrp/setup.d.ts.map +1 -1
- package/lib-es/families/xrp/setup.js +7 -2
- package/lib-es/families/xrp/setup.js.map +1 -1
- package/lib-es/generated/bridge/js.d.ts +1 -0
- package/lib-es/generated/bridge/js.d.ts.map +1 -1
- package/lib-es/generated/bridge/js.js +2 -0
- package/lib-es/generated/bridge/js.js.map +1 -1
- package/package.json +44 -44
- package/src/__tests__/test-helpers/bridge.ts +4 -2
- package/src/bridge/impl.ts +5 -87
- package/src/config/index.ts +2 -11
- package/src/config/sharedConfig.ts +0 -8
- package/src/families/xrp/setup.ts +15 -2
- package/src/generated/bridge/js.ts +2 -0
- package/lib/bridge/generic-alpaca/accountBridge.d.ts +0 -3
- package/lib/bridge/generic-alpaca/accountBridge.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/accountBridge.js +0 -34
- package/lib/bridge/generic-alpaca/accountBridge.js.map +0 -1
- package/lib/bridge/generic-alpaca/alpaca/index.d.ts +0 -3
- package/lib/bridge/generic-alpaca/alpaca/index.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/alpaca/index.js +0 -20
- package/lib/bridge/generic-alpaca/alpaca/index.js.map +0 -1
- package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts +0 -16
- package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.js +0 -123
- package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.js.map +0 -1
- package/lib/bridge/generic-alpaca/broadcast.d.ts +0 -3
- package/lib/bridge/generic-alpaca/broadcast.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/broadcast.js +0 -11
- package/lib/bridge/generic-alpaca/broadcast.js.map +0 -1
- package/lib/bridge/generic-alpaca/createTransaction.d.ts +0 -16
- package/lib/bridge/generic-alpaca/createTransaction.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/createTransaction.js +0 -20
- package/lib/bridge/generic-alpaca/createTransaction.js.map +0 -1
- package/lib/bridge/generic-alpaca/currencyBridge.d.ts +0 -3
- package/lib/bridge/generic-alpaca/currencyBridge.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/currencyBridge.js +0 -20
- package/lib/bridge/generic-alpaca/currencyBridge.js.map +0 -1
- package/lib/bridge/generic-alpaca/estimateMaxSpendable.d.ts +0 -3
- package/lib/bridge/generic-alpaca/estimateMaxSpendable.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/estimateMaxSpendable.js +0 -26
- package/lib/bridge/generic-alpaca/estimateMaxSpendable.js.map +0 -1
- package/lib/bridge/generic-alpaca/getAccountShape.d.ts +0 -3
- package/lib/bridge/generic-alpaca/getAccountShape.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/getAccountShape.js +0 -58
- package/lib/bridge/generic-alpaca/getAccountShape.js.map +0 -1
- package/lib/bridge/generic-alpaca/getTransactionStatus.d.ts +0 -3
- package/lib/bridge/generic-alpaca/getTransactionStatus.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/getTransactionStatus.js +0 -36
- package/lib/bridge/generic-alpaca/getTransactionStatus.js.map +0 -1
- package/lib/bridge/generic-alpaca/prepareTransaction.d.ts +0 -3
- package/lib/bridge/generic-alpaca/prepareTransaction.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/prepareTransaction.js +0 -21
- package/lib/bridge/generic-alpaca/prepareTransaction.js.map +0 -1
- package/lib/bridge/generic-alpaca/signOperation.d.ts +0 -7
- package/lib/bridge/generic-alpaca/signOperation.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/signOperation.js +0 -49
- package/lib/bridge/generic-alpaca/signOperation.js.map +0 -1
- package/lib/bridge/generic-alpaca/signer/index.d.ts +0 -11
- package/lib/bridge/generic-alpaca/signer/index.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/signer/index.js +0 -28
- package/lib/bridge/generic-alpaca/signer/index.js.map +0 -1
- package/lib/bridge/generic-alpaca/signer/signTransaction.d.ts +0 -5
- package/lib/bridge/generic-alpaca/signer/signTransaction.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/signer/signTransaction.js +0 -11
- package/lib/bridge/generic-alpaca/signer/signTransaction.js.map +0 -1
- package/lib/bridge/generic-alpaca/signer/types.d.ts +0 -5
- package/lib/bridge/generic-alpaca/signer/types.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/signer/types.js +0 -3
- package/lib/bridge/generic-alpaca/signer/types.js.map +0 -1
- package/lib/bridge/generic-alpaca/tests/estimateMaxSpendable.test.d.ts +0 -2
- package/lib/bridge/generic-alpaca/tests/estimateMaxSpendable.test.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/tests/estimateMaxSpendable.test.js +0 -90
- package/lib/bridge/generic-alpaca/tests/estimateMaxSpendable.test.js.map +0 -1
- package/lib/bridge/generic-alpaca/tests/prepareTransaction.test.d.ts +0 -2
- package/lib/bridge/generic-alpaca/tests/prepareTransaction.test.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/tests/prepareTransaction.test.js +0 -53
- package/lib/bridge/generic-alpaca/tests/prepareTransaction.test.js.map +0 -1
- package/lib/bridge/generic-alpaca/tests/signOperation.test.d.ts +0 -2
- package/lib/bridge/generic-alpaca/tests/signOperation.test.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/tests/signOperation.test.js +0 -79
- package/lib/bridge/generic-alpaca/tests/signOperation.test.js.map +0 -1
- package/lib/bridge/generic-alpaca/utils.d.ts +0 -6
- package/lib/bridge/generic-alpaca/utils.d.ts.map +0 -1
- package/lib/bridge/generic-alpaca/utils.js +0 -55
- package/lib/bridge/generic-alpaca/utils.js.map +0 -1
- package/lib/sanction/errors.d.ts +0 -13
- package/lib/sanction/errors.d.ts.map +0 -1
- package/lib/sanction/errors.js +0 -36
- package/lib/sanction/errors.js.map +0 -1
- package/lib/sanction/index.d.ts +0 -3
- package/lib/sanction/index.d.ts.map +0 -1
- package/lib/sanction/index.js +0 -51
- package/lib/sanction/index.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/accountBridge.d.ts +0 -3
- package/lib-es/bridge/generic-alpaca/accountBridge.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/accountBridge.js +0 -27
- package/lib-es/bridge/generic-alpaca/accountBridge.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/alpaca/index.d.ts +0 -3
- package/lib-es/bridge/generic-alpaca/alpaca/index.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/alpaca/index.js +0 -16
- package/lib-es/bridge/generic-alpaca/alpaca/index.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts +0 -16
- package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.js +0 -116
- package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/broadcast.d.ts +0 -3
- package/lib-es/bridge/generic-alpaca/broadcast.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/broadcast.js +0 -7
- package/lib-es/bridge/generic-alpaca/broadcast.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/createTransaction.d.ts +0 -16
- package/lib-es/bridge/generic-alpaca/createTransaction.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/createTransaction.js +0 -13
- package/lib-es/bridge/generic-alpaca/createTransaction.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/currencyBridge.d.ts +0 -3
- package/lib-es/bridge/generic-alpaca/currencyBridge.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/currencyBridge.js +0 -16
- package/lib-es/bridge/generic-alpaca/currencyBridge.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/estimateMaxSpendable.d.ts +0 -3
- package/lib-es/bridge/generic-alpaca/estimateMaxSpendable.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/estimateMaxSpendable.js +0 -19
- package/lib-es/bridge/generic-alpaca/estimateMaxSpendable.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/getAccountShape.d.ts +0 -3
- package/lib-es/bridge/generic-alpaca/getAccountShape.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/getAccountShape.js +0 -51
- package/lib-es/bridge/generic-alpaca/getAccountShape.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/getTransactionStatus.d.ts +0 -3
- package/lib-es/bridge/generic-alpaca/getTransactionStatus.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/getTransactionStatus.js +0 -29
- package/lib-es/bridge/generic-alpaca/getTransactionStatus.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/prepareTransaction.d.ts +0 -3
- package/lib-es/bridge/generic-alpaca/prepareTransaction.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/prepareTransaction.js +0 -14
- package/lib-es/bridge/generic-alpaca/prepareTransaction.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/signOperation.d.ts +0 -7
- package/lib-es/bridge/generic-alpaca/signOperation.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/signOperation.js +0 -45
- package/lib-es/bridge/generic-alpaca/signOperation.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/signer/index.d.ts +0 -11
- package/lib-es/bridge/generic-alpaca/signer/index.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/signer/index.js +0 -21
- package/lib-es/bridge/generic-alpaca/signer/index.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/signer/signTransaction.d.ts +0 -5
- package/lib-es/bridge/generic-alpaca/signer/signTransaction.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/signer/signTransaction.js +0 -7
- package/lib-es/bridge/generic-alpaca/signer/signTransaction.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/signer/types.d.ts +0 -5
- package/lib-es/bridge/generic-alpaca/signer/types.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/signer/types.js +0 -2
- package/lib-es/bridge/generic-alpaca/signer/types.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/tests/estimateMaxSpendable.test.d.ts +0 -2
- package/lib-es/bridge/generic-alpaca/tests/estimateMaxSpendable.test.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/tests/estimateMaxSpendable.test.js +0 -62
- package/lib-es/bridge/generic-alpaca/tests/estimateMaxSpendable.test.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/tests/prepareTransaction.test.d.ts +0 -2
- package/lib-es/bridge/generic-alpaca/tests/prepareTransaction.test.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/tests/prepareTransaction.test.js +0 -48
- package/lib-es/bridge/generic-alpaca/tests/prepareTransaction.test.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/tests/signOperation.test.d.ts +0 -2
- package/lib-es/bridge/generic-alpaca/tests/signOperation.test.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/tests/signOperation.test.js +0 -77
- package/lib-es/bridge/generic-alpaca/tests/signOperation.test.js.map +0 -1
- package/lib-es/bridge/generic-alpaca/utils.d.ts +0 -6
- package/lib-es/bridge/generic-alpaca/utils.d.ts.map +0 -1
- package/lib-es/bridge/generic-alpaca/utils.js +0 -46
- package/lib-es/bridge/generic-alpaca/utils.js.map +0 -1
- package/lib-es/sanction/errors.d.ts +0 -13
- package/lib-es/sanction/errors.d.ts.map +0 -1
- package/lib-es/sanction/errors.js +0 -29
- package/lib-es/sanction/errors.js.map +0 -1
- package/lib-es/sanction/index.d.ts +0 -3
- package/lib-es/sanction/index.d.ts.map +0 -1
- package/lib-es/sanction/index.js +0 -44
- package/lib-es/sanction/index.js.map +0 -1
- package/src/bridge/generic-alpaca/accountBridge.ts +0 -32
- package/src/bridge/generic-alpaca/alpaca/index.ts +0 -20
- package/src/bridge/generic-alpaca/alpaca/network/network-alpaca.ts +0 -182
- package/src/bridge/generic-alpaca/broadcast.ts +0 -11
- package/src/bridge/generic-alpaca/createTransaction.ts +0 -27
- package/src/bridge/generic-alpaca/currencyBridge.ts +0 -17
- package/src/bridge/generic-alpaca/estimateMaxSpendable.ts +0 -27
- package/src/bridge/generic-alpaca/getAccountShape.ts +0 -62
- package/src/bridge/generic-alpaca/getTransactionStatus.ts +0 -38
- package/src/bridge/generic-alpaca/prepareTransaction.ts +0 -22
- package/src/bridge/generic-alpaca/signOperation.ts +0 -83
- package/src/bridge/generic-alpaca/signer/index.ts +0 -33
- package/src/bridge/generic-alpaca/signer/signTransaction.ts +0 -13
- package/src/bridge/generic-alpaca/signer/types.ts +0 -4
- package/src/bridge/generic-alpaca/tests/estimateMaxSpendable.test.ts +0 -76
- package/src/bridge/generic-alpaca/tests/prepareTransaction.test.ts +0 -66
- package/src/bridge/generic-alpaca/tests/signOperation.test.ts +0 -96
- package/src/bridge/generic-alpaca/utils.ts +0 -63
- package/src/sanction/errors.ts +0 -31
- package/src/sanction/index.ts +0 -59
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"impl.d.ts","sourceRoot":"","sources":["../../src/bridge/impl.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"impl.d.ts","sourceRoot":"","sources":["../../src/bridge/impl.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAE3F,eAAO,MAAM,iBAAiB,aAAc,cAAc,KAAG,cAiB5D,CAAC;AAEF,eAAO,MAAM,gBAAgB,YAClB,WAAW,kBACJ,OAAO,GAAG,IAAI,KAC7B,cAAc,GAAG,CAgBnB,CAAC;AAEF,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,aAAa,CAAC,GAAG,CAAC,CAe/F"}
|
package/lib-es/bridge/impl.js
CHANGED
@@ -1,18 +1,9 @@
|
|
1
|
-
import { isAddressSanctioned } from "../sanction";
|
2
1
|
import { CurrencyNotSupported } from "@ledgerhq/errors";
|
3
|
-
import { getEnv } from "@ledgerhq/live-env";
|
4
2
|
import { decodeAccountId, getMainAccount } from "../account";
|
3
|
+
import { getEnv } from "@ledgerhq/live-env";
|
5
4
|
import { checkAccountSupported } from "../account/index";
|
6
5
|
import jsBridges from "../generated/bridge/js";
|
7
6
|
import mockBridges from "../generated/bridge/mock";
|
8
|
-
import { RecipientAddressSanctionedError, UserAddressSanctionedError } from "../sanction/errors";
|
9
|
-
import { getAlpacaCurrencyBridge } from "./generic-alpaca/currencyBridge";
|
10
|
-
import { getAlpacaAccountBridge } from "./generic-alpaca/accountBridge";
|
11
|
-
const alpacaized = {
|
12
|
-
xrp: true,
|
13
|
-
};
|
14
|
-
let accountBridgeInstance = null;
|
15
|
-
let currencyBridgeInstance = null;
|
16
7
|
export const getCurrencyBridge = (currency) => {
|
17
8
|
if (getEnv("MOCK")) {
|
18
9
|
const mockBridge = mockBridges[currency.family];
|
@@ -22,12 +13,6 @@ export const getCurrencyBridge = (currency) => {
|
|
22
13
|
currencyName: currency.id,
|
23
14
|
});
|
24
15
|
}
|
25
|
-
if (alpacaized[currency.family]) {
|
26
|
-
if (!currencyBridgeInstance) {
|
27
|
-
currencyBridgeInstance = getAlpacaCurrencyBridge(currency.family, "local");
|
28
|
-
}
|
29
|
-
return currencyBridgeInstance;
|
30
|
-
}
|
31
16
|
const jsBridge = jsBridges[currency.family];
|
32
17
|
if (jsBridge) {
|
33
18
|
return jsBridge.currencyBridge;
|
@@ -61,51 +46,10 @@ export function getAccountBridgeByFamily(family, accountId) {
|
|
61
46
|
return mockBridge.accountBridge;
|
62
47
|
}
|
63
48
|
}
|
64
|
-
if (alpacaized[family]) {
|
65
|
-
if (!accountBridgeInstance) {
|
66
|
-
accountBridgeInstance = getAlpacaAccountBridge(family, "local");
|
67
|
-
}
|
68
|
-
return accountBridgeInstance;
|
69
|
-
}
|
70
49
|
const jsBridge = jsBridges[family];
|
71
50
|
if (!jsBridge) {
|
72
|
-
throw new CurrencyNotSupported("
|
73
|
-
}
|
74
|
-
return wrapAccountBridge(jsBridge.accountBridge);
|
75
|
-
}
|
76
|
-
function wrapAccountBridge(bridge) {
|
77
|
-
return {
|
78
|
-
...bridge,
|
79
|
-
getTransactionStatus: async (...args) => {
|
80
|
-
const blockchainSpecific = await bridge.getTransactionStatus(...args);
|
81
|
-
const common = await commonGetTransactionStatus(...args);
|
82
|
-
const merged = mergeResults(blockchainSpecific, common);
|
83
|
-
return merged;
|
84
|
-
},
|
85
|
-
};
|
86
|
-
}
|
87
|
-
function mergeResults(blockchainSpecific, common) {
|
88
|
-
const errors = { ...blockchainSpecific.errors, ...common.errors };
|
89
|
-
const warnings = { ...blockchainSpecific.warnings, ...common.warnings };
|
90
|
-
return { ...blockchainSpecific, errors, warnings };
|
91
|
-
}
|
92
|
-
async function commonGetTransactionStatus(account, transaction) {
|
93
|
-
const errors = {};
|
94
|
-
const warnings = {};
|
95
|
-
let recipientIsBlacklisted = false;
|
96
|
-
if (transaction.recipient && transaction.recipient !== "") {
|
97
|
-
recipientIsBlacklisted = await isAddressSanctioned(account.currency, transaction.recipient);
|
98
|
-
if (recipientIsBlacklisted) {
|
99
|
-
errors.recipient = new RecipientAddressSanctionedError();
|
100
|
-
}
|
101
|
-
}
|
102
|
-
const userIsBlacklisted = await isAddressSanctioned(account.currency, account.freshAddress);
|
103
|
-
if (userIsBlacklisted) {
|
104
|
-
errors.amount = new UserAddressSanctionedError();
|
105
|
-
}
|
106
|
-
if (userIsBlacklisted || recipientIsBlacklisted) {
|
107
|
-
// Send log
|
51
|
+
throw new CurrencyNotSupported("currency bridge not found " + family);
|
108
52
|
}
|
109
|
-
return
|
53
|
+
return jsBridge.accountBridge;
|
110
54
|
}
|
111
55
|
//# sourceMappingURL=impl.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"impl.js","sourceRoot":"","sources":["../../src/bridge/impl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
1
|
+
{"version":3,"file":"impl.js","sourceRoot":"","sources":["../../src/bridge/impl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAC7D,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAC/C,OAAO,WAAW,MAAM,0BAA0B,CAAC;AAInD,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,QAAwB,EAAkB,EAAE;IAC5E,IAAI,MAAM,CAAC,MAAM,CAAC,EAAE;QAClB,MAAM,UAAU,GAAG,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAChD,IAAI,UAAU;YAAE,OAAO,UAAU,CAAC,cAAc,CAAC;QACjD,MAAM,IAAI,oBAAoB,CAAC,gDAAgD,GAAG,QAAQ,CAAC,EAAE,EAAE;YAC7F,YAAY,EAAE,QAAQ,CAAC,EAAE;SAC1B,CAAC,CAAC;KACJ;IAED,MAAM,QAAQ,GAAG,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IAC5C,IAAI,QAAQ,EAAE;QACZ,OAAO,QAAQ,CAAC,cAAc,CAAC;KAChC;IAED,MAAM,IAAI,oBAAoB,CAAC,2CAA2C,GAAG,QAAQ,CAAC,EAAE,EAAE;QACxF,YAAY,EAAE,QAAQ,CAAC,EAAE;KAC1B,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAC9B,OAAoB,EACpB,aAA8B,EACV,EAAE;IACtB,MAAM,WAAW,GAAG,cAAc,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;IAC3D,MAAM,EAAE,QAAQ,EAAE,GAAG,WAAW,CAAC;IACjC,MAAM,cAAc,GAAG,qBAAqB,CAAC,WAAW,CAAC,CAAC;IAE1D,IAAI,cAAc,EAAE;QAClB,MAAM,cAAc,CAAC;KACtB;IAED,IAAI;QACF,OAAO,wBAAwB,CAAC,QAAQ,CAAC,MAAM,EAAE,WAAW,CAAC,EAAE,CAAC,CAAC;KAClE;IAAC,MAAM;QACN,MAAM,IAAI,oBAAoB,CAAC,yBAAyB,GAAG,QAAQ,CAAC,EAAE,EAAE;YACtE,YAAY,EAAE,QAAQ,CAAC,EAAE;SAC1B,CAAC,CAAC;KACJ;AACH,CAAC,CAAC;AAEF,MAAM,UAAU,wBAAwB,CAAC,MAAc,EAAE,SAAkB;IACzE,IAAI,SAAS,EAAE;QACb,MAAM,EAAE,IAAI,EAAE,GAAG,eAAe,CAAC,SAAS,CAAC,CAAC;QAE5C,IAAI,IAAI,KAAK,MAAM,EAAE;YACnB,MAAM,UAAU,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC;YACvC,IAAI,UAAU;gBAAE,OAAO,UAAU,CAAC,aAAa,CAAC;SACjD;KACF;IAED,MAAM,QAAQ,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;IACnC,IAAI,CAAC,QAAQ,EAAE;QACb,MAAM,IAAI,oBAAoB,CAAC,4BAA4B,GAAG,MAAM,CAAC,CAAC;KACvE;IACD,OAAO,QAAQ,CAAC,aAAa,CAAC;AAChC,CAAC"}
|
package/lib-es/config/index.d.ts
CHANGED
@@ -1,8 +1,7 @@
|
|
1
1
|
import { CryptoCurrency, CryptoCurrencyId } from "@ledgerhq/types-cryptoassets";
|
2
2
|
import { ConfigInfo } from "@ledgerhq/live-config/LiveConfig";
|
3
|
-
import { CurrencyConfig
|
3
|
+
import { CurrencyConfig } from "@ledgerhq/coin-framework/config";
|
4
4
|
export type CurrencyLiveConfigDefinition = Partial<Record<`config_currency_${CryptoCurrencyId}`, ConfigInfo>>;
|
5
|
-
declare const getSharedConfiguration: () => SharedConfig;
|
6
5
|
declare const getCurrencyConfiguration: <T extends CurrencyConfig>(currency: CryptoCurrency) => T & Record<string, unknown>;
|
7
|
-
export { getCurrencyConfiguration
|
6
|
+
export { getCurrencyConfiguration };
|
8
7
|
//# sourceMappingURL=index.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChF,OAAO,EAAE,UAAU,EAAc,MAAM,kCAAkC,CAAC;AAC1E,OAAO,EAAE,cAAc,EAAE,
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChF,OAAO,EAAE,UAAU,EAAc,MAAM,kCAAkC,CAAC;AAC1E,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAEjE,MAAM,MAAM,4BAA4B,GAAG,OAAO,CAChD,MAAM,CAAC,mBAAmB,gBAAgB,EAAE,EAAE,UAAU,CAAC,CAC1D,CAAC;AAEF,QAAA,MAAM,wBAAwB,uCAClB,cAAc,gCAQzB,CAAC;AAEF,OAAO,EAAE,wBAAwB,EAAE,CAAC"}
|
package/lib-es/config/index.js
CHANGED
@@ -1,11 +1,4 @@
|
|
1
1
|
import { LiveConfig } from "@ledgerhq/live-config/LiveConfig";
|
2
|
-
const getSharedConfiguration = () => {
|
3
|
-
const config = LiveConfig.getValueByKey("config_currency");
|
4
|
-
if (!config) {
|
5
|
-
throw new Error("Configuration config_currency not found, please check Firebase Remote Config");
|
6
|
-
}
|
7
|
-
return config;
|
8
|
-
};
|
9
2
|
const getCurrencyConfiguration = (currency) => {
|
10
3
|
const currencyData = LiveConfig.getValueByKey(`config_currency_${currency.id}`);
|
11
4
|
if (!currencyData) {
|
@@ -13,5 +6,5 @@ const getCurrencyConfiguration = (currency) => {
|
|
13
6
|
}
|
14
7
|
return currencyData;
|
15
8
|
};
|
16
|
-
export { getCurrencyConfiguration
|
9
|
+
export { getCurrencyConfiguration };
|
17
10
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAc,UAAU,EAAE,MAAM,kCAAkC,CAAC;AAO1E,MAAM,
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAc,UAAU,EAAE,MAAM,kCAAkC,CAAC;AAO1E,MAAM,wBAAwB,GAAG,CAC/B,QAAwB,EACK,EAAE;IAC/B,MAAM,YAAY,GAAG,UAAU,CAAC,aAAa,CAAC,mBAAmB,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC;IAChF,IAAI,CAAC,YAAY,EAAE;QACjB,MAAM,IAAI,KAAK,CAAC,2CAA2C,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC;KAC3E;IAED,OAAO,YAAY,CAAC;AACtB,CAAC,CAAC;AAEF,OAAO,EAAE,wBAAwB,EAAE,CAAC"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"sharedConfig.d.ts","sourceRoot":"","sources":["../../src/config/sharedConfig.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;
|
1
|
+
{"version":3,"file":"sharedConfig.d.ts","sourceRoot":"","sources":["../../src/config/sharedConfig.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AA0ChE,eAAO,MAAM,UAAU,EAAE,YA2BxB,CAAC"}
|
@@ -33,12 +33,6 @@ const countervaluesConfig = {
|
|
33
33
|
default: 20,
|
34
34
|
},
|
35
35
|
};
|
36
|
-
const sharedCurrencyConfig = {
|
37
|
-
config_currency: {
|
38
|
-
type: "object",
|
39
|
-
default: {},
|
40
|
-
},
|
41
|
-
};
|
42
36
|
const liveCommonConfig = {
|
43
37
|
...appConfig,
|
44
38
|
};
|
@@ -69,6 +63,5 @@ export const liveConfig = {
|
|
69
63
|
...iconConfig,
|
70
64
|
...tonConfig,
|
71
65
|
...suiConfig,
|
72
|
-
...sharedCurrencyConfig,
|
73
66
|
};
|
74
67
|
//# sourceMappingURL=sharedConfig.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"sharedConfig.js","sourceRoot":"","sources":["../../src/config/sharedConfig.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjE,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,sBAAsB,EAAE,MAAM,sCAAsC,CAAC;AAC9E,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,mBAAmB,GAAiB;IACxC,gCAAgC,EAAE;QAChC,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,EAAE,GAAG,IAAI;KACnB;IACD,+CAA+C,EAAE;QAC/C,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,EAAE;KACZ;CACF,CAAC;AAEF,MAAM,
|
1
|
+
{"version":3,"file":"sharedConfig.js","sourceRoot":"","sources":["../../src/config/sharedConfig.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjE,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,sBAAsB,EAAE,MAAM,sCAAsC,CAAC;AAC9E,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAEnD,MAAM,mBAAmB,GAAiB;IACxC,gCAAgC,EAAE;QAChC,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,EAAE,GAAG,IAAI;KACnB;IACD,+CAA+C,EAAE;QAC/C,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,EAAE;KACZ;CACF,CAAC;AAEF,MAAM,gBAAgB,GAAiB;IACrC,GAAG,SAAS;CACb,CAAC;AAEF,MAAM,CAAC,MAAM,UAAU,GAAiB;IACtC,GAAG,mBAAmB;IACtB,GAAG,gBAAgB;IACnB,GAAG,cAAc;IACjB,GAAG,aAAa;IAChB,GAAG,aAAa;IAChB,GAAG,YAAY;IACf,GAAG,UAAU;IACb,GAAG,YAAY;IACf,GAAG,gBAAgB;IACnB,GAAG,SAAS;IACZ,GAAG,cAAc;IACjB,GAAG,YAAY;IACf,GAAG,sBAAsB;IACzB,GAAG,UAAU;IACb,GAAG,UAAU;IACb,GAAG,cAAc;IACjB,GAAG,SAAS;IACZ,GAAG,YAAY;IACf,GAAG,YAAY;IACf,GAAG,aAAa;IAChB,GAAG,WAAW;IACd,GAAG,UAAU;IACb,GAAG,aAAa;IAChB,GAAG,UAAU;IACb,GAAG,SAAS;IACZ,GAAG,SAAS;CACb,CAAC"}
|
@@ -1,4 +1,7 @@
|
|
1
|
+
import { Bridge } from "@ledgerhq/types-live";
|
2
|
+
import { Transaction as XrpTransaction } from "@ledgerhq/coin-xrp/types";
|
1
3
|
import { Resolver } from "../../hw/getAddress/types";
|
4
|
+
declare const bridge: Bridge<XrpTransaction>;
|
2
5
|
declare const resolver: Resolver;
|
3
6
|
declare const cliTools: {
|
4
7
|
options: ({
|
@@ -12,13 +15,13 @@ declare const cliTools: {
|
|
12
15
|
})[];
|
13
16
|
inferTransactions: (transactions: {
|
14
17
|
account: import("@ledgerhq/types-live").AccountLike;
|
15
|
-
transaction:
|
18
|
+
transaction: XrpTransaction;
|
16
19
|
}[], opts: {
|
17
20
|
tag?: number | null | undefined;
|
18
21
|
fee?: string | undefined;
|
19
22
|
}, { inferAmount, }: {
|
20
23
|
inferAmount: (account: import("@ledgerhq/types-live").AccountLike, fee?: string | undefined) => import("bignumber.js").BigNumber | null | undefined;
|
21
|
-
}) =>
|
24
|
+
}) => XrpTransaction[];
|
22
25
|
};
|
23
|
-
export { cliTools, resolver };
|
26
|
+
export { bridge, cliTools, resolver };
|
24
27
|
//# sourceMappingURL=setup.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"setup.d.ts","sourceRoot":"","sources":["../../../src/families/xrp/setup.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"setup.d.ts","sourceRoot":"","sources":["../../../src/families/xrp/setup.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAK9C,OAAO,EAAE,WAAW,IAAI,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAIzE,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AASrD,QAAA,MAAM,MAAM,EAAE,MAAM,CAAC,cAAc,CAGlC,CAAC;AAEF,QAAA,MAAM,QAAQ,EAAE,QAAoD,CAAC;AAErE,QAAA,MAAM,QAAQ;;;;;;;;;;;;;;;;;;;CAAiB,CAAC;AAEhC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC"}
|
@@ -1,12 +1,17 @@
|
|
1
1
|
// Goal of this file is to inject all necessary device/signer dependency to coin-modules
|
2
2
|
import Xrp from "@ledgerhq/hw-app-xrp";
|
3
|
+
import { createBridges } from "@ledgerhq/coin-xrp";
|
3
4
|
import xrpResolver from "@ledgerhq/coin-xrp/signer/index";
|
4
5
|
import makeCliTools from "@ledgerhq/coin-xrp/test/cli";
|
5
|
-
import {
|
6
|
+
import { getCryptoCurrencyById } from "@ledgerhq/cryptoassets/currencies";
|
7
|
+
import { createResolver, executeWithSigner } from "../../bridge/setup";
|
8
|
+
import { getCurrencyConfiguration } from "../../config";
|
6
9
|
const createSigner = (transport) => {
|
7
10
|
return new Xrp(transport);
|
8
11
|
};
|
12
|
+
const getCoinConfig = () => getCurrencyConfiguration(getCryptoCurrencyById("ripple"));
|
13
|
+
const bridge = createBridges(executeWithSigner(createSigner), getCoinConfig);
|
9
14
|
const resolver = createResolver(createSigner, xrpResolver);
|
10
15
|
const cliTools = makeCliTools();
|
11
|
-
export { cliTools, resolver };
|
16
|
+
export { bridge, cliTools, resolver };
|
12
17
|
//# sourceMappingURL=setup.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"setup.js","sourceRoot":"","sources":["../../../src/families/xrp/setup.ts"],"names":[],"mappings":"AAAA,wFAAwF;AAExF,OAAO,GAAG,MAAM,sBAAsB,CAAC;
|
1
|
+
{"version":3,"file":"setup.js","sourceRoot":"","sources":["../../../src/families/xrp/setup.ts"],"names":[],"mappings":"AAAA,wFAAwF;AAExF,OAAO,GAAG,MAAM,sBAAsB,CAAC;AAGvC,OAAO,EAAE,aAAa,EAAsB,MAAM,oBAAoB,CAAC;AACvE,OAAO,WAAW,MAAM,iCAAiC,CAAC;AAC1D,OAAO,YAAY,MAAM,6BAA6B,CAAC;AAEvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAgB,cAAc,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACrF,OAAO,EAAE,wBAAwB,EAAE,MAAM,cAAc,CAAC;AAGxD,MAAM,YAAY,GAAsB,CAAC,SAAoB,EAAE,EAAE;IAC/D,OAAO,IAAI,GAAG,CAAC,SAAS,CAAC,CAAC;AAC5B,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG,GAAG,EAAE,CACzB,wBAAwB,CAAgB,qBAAqB,CAAC,QAAQ,CAAC,CAAC,CAAC;AAE3E,MAAM,MAAM,GAA2B,aAAa,CAClD,iBAAiB,CAAC,YAAY,CAAC,EAC/B,aAAa,CACd,CAAC;AAEF,MAAM,QAAQ,GAAa,cAAc,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;AAErE,MAAM,QAAQ,GAAG,YAAY,EAAE,CAAC;AAEhC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC"}
|
@@ -21,6 +21,7 @@ declare const _default: {
|
|
21
21
|
ton: import("@ledgerhq/types-live").Bridge<import("@ledgerhq/coin-ton/lib/types").Transaction, import("@ledgerhq/coin-ton/lib/types").TonAccount>;
|
22
22
|
tron: import("@ledgerhq/types-live").Bridge<import("@ledgerhq/coin-tron/lib/index").Transaction, import("@ledgerhq/coin-tron/lib/index").TronAccount>;
|
23
23
|
vechain: import("@ledgerhq/types-live").Bridge<import("@ledgerhq/coin-vechain/lib/types/bridge").Transaction>;
|
24
|
+
xrp: import("@ledgerhq/types-live").Bridge<import("@ledgerhq/coin-xrp/lib/index").Transaction>;
|
24
25
|
sui: import("@ledgerhq/types-live").Bridge<import("@ledgerhq/coin-sui/lib/index").Transaction, import("@ledgerhq/coin-sui/lib/index").SuiAccount, import("@ledgerhq/types-live").TransactionStatusCommon>;
|
25
26
|
mina: import("@ledgerhq/types-live").Bridge<import("@ledgerhq/coin-mina/lib/types/common").Transaction>;
|
26
27
|
};
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"js.d.ts","sourceRoot":"","sources":["../../../src/generated/bridge/js.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"js.d.ts","sourceRoot":"","sources":["../../../src/generated/bridge/js.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AA0BA,wBA0BE"}
|
@@ -20,6 +20,7 @@ import { bridge as tezos } from "../../families/tezos/setup";
|
|
20
20
|
import { bridge as ton } from "../../families/ton/setup";
|
21
21
|
import { bridge as tron } from "../../families/tron/setup";
|
22
22
|
import { bridge as vechain } from "../../families/vechain/setup";
|
23
|
+
import { bridge as xrp } from "../../families/xrp/setup";
|
23
24
|
import { bridge as sui } from "../../families/sui/setup";
|
24
25
|
import { bridge as mina } from "../../families/mina/setup";
|
25
26
|
export default {
|
@@ -45,6 +46,7 @@ export default {
|
|
45
46
|
ton,
|
46
47
|
tron,
|
47
48
|
vechain,
|
49
|
+
xrp,
|
48
50
|
sui,
|
49
51
|
mina,
|
50
52
|
};
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"js.js","sourceRoot":"","sources":["../../../src/generated/bridge/js.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,QAAQ,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,MAAM,IAAI,KAAK,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,MAAM,IAAI,OAAO,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,MAAM,IAAI,OAAO,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,MAAM,IAAI,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,MAAM,IAAI,IAAI,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,MAAM,IAAI,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,MAAM,IAAI,GAAG,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,MAAM,IAAI,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,MAAM,IAAI,QAAQ,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,MAAM,IAAI,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AACrF,OAAO,EAAE,MAAM,IAAI,IAAI,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,MAAM,IAAI,UAAU,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,MAAM,IAAI,IAAI,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,MAAM,IAAI,QAAQ,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,MAAM,IAAI,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,MAAM,IAAI,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,MAAM,IAAI,OAAO,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,MAAM,IAAI,KAAK,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,MAAM,IAAI,GAAG,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,MAAM,IAAI,IAAI,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,MAAM,IAAI,OAAO,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,MAAM,IAAI,GAAG,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,MAAM,IAAI,IAAI,EAAE,MAAM,2BAA2B,CAAC;AAE3D,eAAe;IACb,QAAQ;IACR,KAAK;IACL,OAAO;IACP,OAAO;IACP,MAAM;IACN,IAAI;IACJ,MAAM;IACN,GAAG;IACH,MAAM;IACN,QAAQ;IACR,iBAAiB;IACjB,IAAI;IACJ,UAAU;IACV,IAAI;IACJ,QAAQ;IACR,MAAM;IACN,MAAM;IACN,OAAO;IACP,KAAK;IACL,GAAG;IACH,IAAI;IACJ,OAAO;IACP,GAAG;IACH,IAAI;CACL,CAAC"}
|
1
|
+
{"version":3,"file":"js.js","sourceRoot":"","sources":["../../../src/generated/bridge/js.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,QAAQ,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,MAAM,IAAI,KAAK,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,MAAM,IAAI,OAAO,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,MAAM,IAAI,OAAO,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,MAAM,IAAI,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,MAAM,IAAI,IAAI,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,MAAM,IAAI,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,MAAM,IAAI,GAAG,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,MAAM,IAAI,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,MAAM,IAAI,QAAQ,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,MAAM,IAAI,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AACrF,OAAO,EAAE,MAAM,IAAI,IAAI,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,MAAM,IAAI,UAAU,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,MAAM,IAAI,IAAI,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,MAAM,IAAI,QAAQ,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,MAAM,IAAI,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,MAAM,IAAI,MAAM,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,MAAM,IAAI,OAAO,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,MAAM,IAAI,KAAK,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,MAAM,IAAI,GAAG,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,MAAM,IAAI,IAAI,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,MAAM,IAAI,OAAO,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,MAAM,IAAI,GAAG,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,MAAM,IAAI,GAAG,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,MAAM,IAAI,IAAI,EAAE,MAAM,2BAA2B,CAAC;AAE3D,eAAe;IACb,QAAQ;IACR,KAAK;IACL,OAAO;IACP,OAAO;IACP,MAAM;IACN,IAAI;IACJ,MAAM;IACN,GAAG;IACH,MAAM;IACN,QAAQ;IACR,iBAAiB;IACjB,IAAI;IACJ,UAAU;IACV,IAAI;IACJ,QAAQ;IACR,MAAM;IACN,MAAM;IACN,OAAO;IACP,KAAK;IACL,GAAG;IACH,IAAI;IACJ,OAAO;IACP,GAAG;IACH,GAAG;IACH,IAAI;CACL,CAAC"}
|
package/package.json
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
{
|
2
2
|
"name": "@ledgerhq/live-common",
|
3
3
|
"description": "Common ground for the Ledger Live apps",
|
4
|
-
"version": "34.37.0-next.
|
4
|
+
"version": "34.37.0-next.3",
|
5
5
|
"repository": {
|
6
6
|
"type": "git",
|
7
7
|
"url": "https://github.com/LedgerHQ/ledger-live.git"
|
@@ -162,74 +162,74 @@
|
|
162
162
|
"xstate": "^5.19.2",
|
163
163
|
"yargs": "^17.0.0",
|
164
164
|
"zod": "^3.22.4",
|
165
|
-
"@ledgerhq/coin-
|
166
|
-
"@ledgerhq/coin-
|
167
|
-
"@ledgerhq/coin-bitcoin": "^0.16.0-next.
|
168
|
-
"@ledgerhq/coin-cardano": "^0.8.9-next.
|
169
|
-
"@ledgerhq/coin-casper": "^2.0.0-next.
|
170
|
-
"@ledgerhq/coin-celo": "^1.1.7-next.
|
171
|
-
"@ledgerhq/coin-cosmos": "^0.15.1-next.
|
172
|
-
"@ledgerhq/coin-evm": "^2.22.3-next.
|
173
|
-
"@ledgerhq/coin-filecoin": "^1.9.9-next.
|
174
|
-
"@ledgerhq/coin-framework": "^5.3.0-next.
|
175
|
-
"@ledgerhq/coin-hedera": "^1.7.1-next.
|
176
|
-
"@ledgerhq/coin-icon": "^0.10.9-next.
|
177
|
-
"@ledgerhq/coin-internet_computer": "^1.7.9-next.
|
178
|
-
"@ledgerhq/coin-mina": "^1.1.8-next.
|
179
|
-
"@ledgerhq/coin-multiversx": "^0.4.9-next.
|
180
|
-
"@ledgerhq/coin-near": "^0.11.9-next.
|
181
|
-
"@ledgerhq/coin-
|
182
|
-
"@ledgerhq/coin-
|
183
|
-
"@ledgerhq/coin-
|
184
|
-
"@ledgerhq/coin-stellar": "^5.2.0-next.
|
185
|
-
"@ledgerhq/coin-sui": "^0.5.0-next.
|
186
|
-
"@ledgerhq/coin-tezos": "^5.3.0-next.
|
187
|
-
"@ledgerhq/coin-ton": "^0.12.1-next.
|
188
|
-
"@ledgerhq/coin-tron": "^4.2.0-next.
|
189
|
-
"@ledgerhq/coin-vechain": "^2.7.9-next.
|
190
|
-
"@ledgerhq/coin-xrp": "^6.2.0-next.
|
165
|
+
"@ledgerhq/coin-aptos": "^2.2.0-next.1",
|
166
|
+
"@ledgerhq/coin-algorand": "^0.9.9-next.1",
|
167
|
+
"@ledgerhq/coin-bitcoin": "^0.16.0-next.1",
|
168
|
+
"@ledgerhq/coin-cardano": "^0.8.9-next.1",
|
169
|
+
"@ledgerhq/coin-casper": "^2.0.0-next.1",
|
170
|
+
"@ledgerhq/coin-celo": "^1.1.7-next.1",
|
171
|
+
"@ledgerhq/coin-cosmos": "^0.15.1-next.1",
|
172
|
+
"@ledgerhq/coin-evm": "^2.22.3-next.1",
|
173
|
+
"@ledgerhq/coin-filecoin": "^1.9.9-next.1",
|
174
|
+
"@ledgerhq/coin-framework": "^5.3.0-next.1",
|
175
|
+
"@ledgerhq/coin-hedera": "^1.7.1-next.1",
|
176
|
+
"@ledgerhq/coin-icon": "^0.10.9-next.1",
|
177
|
+
"@ledgerhq/coin-internet_computer": "^1.7.9-next.1",
|
178
|
+
"@ledgerhq/coin-mina": "^1.1.8-next.1",
|
179
|
+
"@ledgerhq/coin-multiversx": "^0.4.9-next.1",
|
180
|
+
"@ledgerhq/coin-near": "^0.11.9-next.1",
|
181
|
+
"@ledgerhq/coin-polkadot": "^6.2.0-next.1",
|
182
|
+
"@ledgerhq/coin-solana": "^0.25.1-next.1",
|
183
|
+
"@ledgerhq/coin-stacks": "^0.8.9-next.1",
|
184
|
+
"@ledgerhq/coin-stellar": "^5.2.0-next.1",
|
185
|
+
"@ledgerhq/coin-sui": "^0.5.0-next.1",
|
186
|
+
"@ledgerhq/coin-tezos": "^5.3.0-next.1",
|
187
|
+
"@ledgerhq/coin-ton": "^0.12.1-next.1",
|
188
|
+
"@ledgerhq/coin-tron": "^4.2.0-next.1",
|
189
|
+
"@ledgerhq/coin-vechain": "^2.7.9-next.1",
|
190
|
+
"@ledgerhq/coin-xrp": "^6.2.0-next.1",
|
191
|
+
"@ledgerhq/cryptoassets": "^13.18.1-next.0",
|
191
192
|
"@ledgerhq/crypto-icons-ui": "^1.14.0",
|
192
193
|
"@ledgerhq/device-core": "^0.4.27-next.0",
|
193
194
|
"@ledgerhq/devices": "8.4.6",
|
194
|
-
"@ledgerhq/cryptoassets": "^13.18.1-next.0",
|
195
195
|
"@ledgerhq/errors": "^6.21.0",
|
196
|
+
"@ledgerhq/hw-app-algorand": "^6.31.2",
|
197
|
+
"@ledgerhq/hw-app-aptos": "^6.34.2",
|
196
198
|
"@ledgerhq/hw-app-btc": "^10.9.2",
|
197
|
-
"@ledgerhq/hw-app-cosmos": "^6.32.2",
|
198
199
|
"@ledgerhq/hw-app-celo": "^6.33.5-next.0",
|
200
|
+
"@ledgerhq/hw-app-cosmos": "^6.32.2",
|
199
201
|
"@ledgerhq/hw-app-eth": "^6.45.7-next.0",
|
200
202
|
"@ledgerhq/hw-app-exchange": "^0.10.2",
|
201
203
|
"@ledgerhq/hw-app-hedera": "^1.2.2",
|
202
|
-
"@ledgerhq/hw-app-algorand": "^6.31.2",
|
203
204
|
"@ledgerhq/hw-app-icon": "^1.3.2",
|
204
205
|
"@ledgerhq/hw-app-multiversx": "^6.24.2",
|
205
|
-
"@ledgerhq/hw-app-
|
206
|
+
"@ledgerhq/hw-app-near": "^6.31.2",
|
206
207
|
"@ledgerhq/hw-app-str": "^7.2.2",
|
208
|
+
"@ledgerhq/hw-app-polkadot": "^6.34.2",
|
207
209
|
"@ledgerhq/hw-app-sui": "^1.1.0",
|
208
|
-
"@ledgerhq/hw-app-near": "^6.31.2",
|
209
210
|
"@ledgerhq/hw-app-tezos": "^6.31.2",
|
210
211
|
"@ledgerhq/hw-app-trx": "^6.31.2",
|
211
212
|
"@ledgerhq/hw-app-vet": "^0.5.6-next.0",
|
212
|
-
"@ledgerhq/hw-app-xrp": "^6.32.0-next.
|
213
|
+
"@ledgerhq/hw-app-xrp": "^6.32.0-next.1",
|
213
214
|
"@ledgerhq/hw-transport": "^6.31.6",
|
214
|
-
"@ledgerhq/ledger-cal-service": "^0.5.1-next.0",
|
215
215
|
"@ledgerhq/hw-transport-mocker": "^6.29.6",
|
216
|
+
"@ledgerhq/ledger-cal-service": "^0.5.1-next.0",
|
216
217
|
"@ledgerhq/live-config": "^3.1.0",
|
217
|
-
"@ledgerhq/live-countervalues": "^0.5.9-next.
|
218
|
+
"@ledgerhq/live-countervalues": "^0.5.9-next.1",
|
218
219
|
"@ledgerhq/live-dmk-shared": "^0.9.0",
|
219
|
-
"@ledgerhq/live-countervalues-react": "^0.2.38-next.
|
220
|
+
"@ledgerhq/live-countervalues-react": "^0.2.38-next.1",
|
220
221
|
"@ledgerhq/live-env": "^2.10.0-next.0",
|
222
|
+
"@ledgerhq/live-hooks": "0.1.0",
|
221
223
|
"@ledgerhq/live-network": "^2.0.10-next.0",
|
222
|
-
"@ledgerhq/live-nft": "^0.8.9-next.
|
224
|
+
"@ledgerhq/live-nft": "^0.8.9-next.1",
|
223
225
|
"@ledgerhq/live-promise": "^0.1.1",
|
224
|
-
"@ledgerhq/live-
|
225
|
-
"@ledgerhq/live-signer-
|
226
|
-
"@ledgerhq/live-
|
227
|
-
"@ledgerhq/live-wallet": "^0.11.0-next.0",
|
226
|
+
"@ledgerhq/live-signer-evm": "^0.5.2-next.1",
|
227
|
+
"@ledgerhq/live-signer-solana": "^0.2.1-next.1",
|
228
|
+
"@ledgerhq/live-wallet": "^0.11.0-next.1",
|
228
229
|
"@ledgerhq/logs": "^6.13.0",
|
229
|
-
"@ledgerhq/speculos-transport": "^0.2.3-next.0",
|
230
|
-
"@ledgerhq/wallet-api-exchange-module": "^0.13.0",
|
231
230
|
"@ledgerhq/wallet-api-acre-module": "^0.5.0",
|
232
|
-
"@ledgerhq/
|
231
|
+
"@ledgerhq/speculos-transport": "^0.2.3-next.0",
|
232
|
+
"@ledgerhq/wallet-api-exchange-module": "^0.13.0"
|
233
233
|
},
|
234
234
|
"devDependencies": {
|
235
235
|
"@solana/web3.js": "1.95.4",
|
@@ -383,6 +383,10 @@ export function testBridge<T extends TransactionCommon>(data: DatasetTest<T>): v
|
|
383
383
|
}
|
384
384
|
}
|
385
385
|
|
386
|
+
makeTest("bridge ref equality", async () => {
|
387
|
+
const account = await getSynced();
|
388
|
+
expect(bridge).toBe(getAccountBridge(account, null));
|
389
|
+
});
|
386
390
|
makeTest("account have no NaN values", async () => {
|
387
391
|
const account = await getSynced();
|
388
392
|
[account, ...(account.subAccounts || [])].forEach(a => {
|
@@ -424,7 +428,6 @@ export function testBridge<T extends TransactionCommon>(data: DatasetTest<T>): v
|
|
424
428
|
blockHeight: 0,
|
425
429
|
};
|
426
430
|
const synced = await syncAccount(bridge, copy);
|
427
|
-
if (initialAccount.id.includes("ripple")) return; // ripple wont work because of the current implementation of pagination
|
428
431
|
expect(synced.operations.length).toBe(account.operations.length);
|
429
432
|
// same ops are restored
|
430
433
|
expect(synced.operations).toEqual(account.operations);
|
@@ -437,7 +440,6 @@ export function testBridge<T extends TransactionCommon>(data: DatasetTest<T>): v
|
|
437
440
|
});
|
438
441
|
makeTest("pendingOperations are cleaned up", async () => {
|
439
442
|
const account = await getSynced();
|
440
|
-
if (initialAccount.id.includes("ripple")) return; // ripple wont work because of the current implementation of pagination
|
441
443
|
|
442
444
|
if (account.operations.length) {
|
443
445
|
const operations = account.operations.slice(1);
|
package/src/bridge/impl.ts
CHANGED
@@ -1,29 +1,11 @@
|
|
1
|
-
import { isAddressSanctioned } from "../sanction";
|
2
1
|
import { CurrencyNotSupported } from "@ledgerhq/errors";
|
3
|
-
import { getEnv } from "@ledgerhq/live-env";
|
4
|
-
import type { CryptoCurrency } from "@ledgerhq/types-cryptoassets";
|
5
|
-
import {
|
6
|
-
Account,
|
7
|
-
AccountBridge,
|
8
|
-
AccountLike,
|
9
|
-
CurrencyBridge,
|
10
|
-
TransactionStatusCommon,
|
11
|
-
} from "@ledgerhq/types-live";
|
12
2
|
import { decodeAccountId, getMainAccount } from "../account";
|
3
|
+
import { getEnv } from "@ledgerhq/live-env";
|
13
4
|
import { checkAccountSupported } from "../account/index";
|
14
5
|
import jsBridges from "../generated/bridge/js";
|
15
6
|
import mockBridges from "../generated/bridge/mock";
|
16
|
-
import {
|
17
|
-
import {
|
18
|
-
import { getAlpacaAccountBridge } from "./generic-alpaca/accountBridge";
|
19
|
-
import { TransactionCommon } from "@ledgerhq/types-live";
|
20
|
-
|
21
|
-
const alpacaized = {
|
22
|
-
xrp: true,
|
23
|
-
};
|
24
|
-
|
25
|
-
let accountBridgeInstance: AccountBridge<any> | null = null;
|
26
|
-
let currencyBridgeInstance: CurrencyBridge | null = null;
|
7
|
+
import type { CryptoCurrency } from "@ledgerhq/types-cryptoassets";
|
8
|
+
import { Account, AccountBridge, AccountLike, CurrencyBridge } from "@ledgerhq/types-live";
|
27
9
|
|
28
10
|
export const getCurrencyBridge = (currency: CryptoCurrency): CurrencyBridge => {
|
29
11
|
if (getEnv("MOCK")) {
|
@@ -34,13 +16,6 @@ export const getCurrencyBridge = (currency: CryptoCurrency): CurrencyBridge => {
|
|
34
16
|
});
|
35
17
|
}
|
36
18
|
|
37
|
-
if (alpacaized[currency.family]) {
|
38
|
-
if (!currencyBridgeInstance) {
|
39
|
-
currencyBridgeInstance = getAlpacaCurrencyBridge(currency.family, "local");
|
40
|
-
}
|
41
|
-
return currencyBridgeInstance;
|
42
|
-
}
|
43
|
-
|
44
19
|
const jsBridge = jsBridges[currency.family];
|
45
20
|
if (jsBridge) {
|
46
21
|
return jsBridge.currencyBridge;
|
@@ -82,66 +57,9 @@ export function getAccountBridgeByFamily(family: string, accountId?: string): Ac
|
|
82
57
|
}
|
83
58
|
}
|
84
59
|
|
85
|
-
if (alpacaized[family]) {
|
86
|
-
if (!accountBridgeInstance) {
|
87
|
-
accountBridgeInstance = getAlpacaAccountBridge(family, "local");
|
88
|
-
}
|
89
|
-
return accountBridgeInstance;
|
90
|
-
}
|
91
|
-
|
92
60
|
const jsBridge = jsBridges[family];
|
93
61
|
if (!jsBridge) {
|
94
|
-
throw new CurrencyNotSupported("
|
62
|
+
throw new CurrencyNotSupported("currency bridge not found " + family);
|
95
63
|
}
|
96
|
-
return
|
97
|
-
}
|
98
|
-
|
99
|
-
function wrapAccountBridge<T extends TransactionCommon>(
|
100
|
-
bridge: AccountBridge<T>,
|
101
|
-
): AccountBridge<T> {
|
102
|
-
return {
|
103
|
-
...bridge,
|
104
|
-
getTransactionStatus: async (...args) => {
|
105
|
-
const blockchainSpecific = await bridge.getTransactionStatus(...args);
|
106
|
-
const common = await commonGetTransactionStatus(...args);
|
107
|
-
const merged = mergeResults(blockchainSpecific, common);
|
108
|
-
return merged;
|
109
|
-
},
|
110
|
-
};
|
111
|
-
}
|
112
|
-
|
113
|
-
function mergeResults(
|
114
|
-
blockchainSpecific: TransactionStatusCommon,
|
115
|
-
common: Partial<TransactionStatusCommon>,
|
116
|
-
): TransactionStatusCommon {
|
117
|
-
const errors = { ...blockchainSpecific.errors, ...common.errors };
|
118
|
-
const warnings = { ...blockchainSpecific.warnings, ...common.warnings };
|
119
|
-
return { ...blockchainSpecific, errors, warnings };
|
120
|
-
}
|
121
|
-
|
122
|
-
async function commonGetTransactionStatus(
|
123
|
-
account: Account,
|
124
|
-
transaction: TransactionCommon,
|
125
|
-
): Promise<Partial<TransactionStatusCommon>> {
|
126
|
-
const errors: Record<string, Error> = {};
|
127
|
-
const warnings: Record<string, Error> = {};
|
128
|
-
|
129
|
-
let recipientIsBlacklisted = false;
|
130
|
-
if (transaction.recipient && transaction.recipient !== "") {
|
131
|
-
recipientIsBlacklisted = await isAddressSanctioned(account.currency, transaction.recipient);
|
132
|
-
if (recipientIsBlacklisted) {
|
133
|
-
errors.recipient = new RecipientAddressSanctionedError();
|
134
|
-
}
|
135
|
-
}
|
136
|
-
|
137
|
-
const userIsBlacklisted = await isAddressSanctioned(account.currency, account.freshAddress);
|
138
|
-
if (userIsBlacklisted) {
|
139
|
-
errors.amount = new UserAddressSanctionedError();
|
140
|
-
}
|
141
|
-
|
142
|
-
if (userIsBlacklisted || recipientIsBlacklisted) {
|
143
|
-
// Send log
|
144
|
-
}
|
145
|
-
|
146
|
-
return { errors, warnings };
|
64
|
+
return jsBridge.accountBridge;
|
147
65
|
}
|
package/src/config/index.ts
CHANGED
@@ -1,20 +1,11 @@
|
|
1
1
|
import { CryptoCurrency, CryptoCurrencyId } from "@ledgerhq/types-cryptoassets";
|
2
2
|
import { ConfigInfo, LiveConfig } from "@ledgerhq/live-config/LiveConfig";
|
3
|
-
import { CurrencyConfig
|
3
|
+
import { CurrencyConfig } from "@ledgerhq/coin-framework/config";
|
4
4
|
|
5
5
|
export type CurrencyLiveConfigDefinition = Partial<
|
6
6
|
Record<`config_currency_${CryptoCurrencyId}`, ConfigInfo>
|
7
7
|
>;
|
8
8
|
|
9
|
-
const getSharedConfiguration = (): SharedConfig => {
|
10
|
-
const config = LiveConfig.getValueByKey("config_currency");
|
11
|
-
if (!config) {
|
12
|
-
throw new Error("Configuration config_currency not found, please check Firebase Remote Config");
|
13
|
-
}
|
14
|
-
|
15
|
-
return config;
|
16
|
-
};
|
17
|
-
|
18
9
|
const getCurrencyConfiguration = <T extends CurrencyConfig>(
|
19
10
|
currency: CryptoCurrency,
|
20
11
|
): T & Record<string, unknown> => {
|
@@ -26,4 +17,4 @@ const getCurrencyConfiguration = <T extends CurrencyConfig>(
|
|
26
17
|
return currencyData;
|
27
18
|
};
|
28
19
|
|
29
|
-
export { getCurrencyConfiguration
|
20
|
+
export { getCurrencyConfiguration };
|
@@ -36,13 +36,6 @@ const countervaluesConfig: ConfigSchema = {
|
|
36
36
|
},
|
37
37
|
};
|
38
38
|
|
39
|
-
const sharedCurrencyConfig: ConfigSchema = {
|
40
|
-
config_currency: {
|
41
|
-
type: "object",
|
42
|
-
default: {},
|
43
|
-
},
|
44
|
-
};
|
45
|
-
|
46
39
|
const liveCommonConfig: ConfigSchema = {
|
47
40
|
...appConfig,
|
48
41
|
};
|
@@ -74,5 +67,4 @@ export const liveConfig: ConfigSchema = {
|
|
74
67
|
...iconConfig,
|
75
68
|
...tonConfig,
|
76
69
|
...suiConfig,
|
77
|
-
...sharedCurrencyConfig,
|
78
70
|
};
|