@ledgerhq/live-common 34.37.0-nightly.4 → 34.38.0-next.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/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/featureFlags/stakePrograms/index.d.ts +8 -2
- package/lib/featureFlags/stakePrograms/index.d.ts.map +1 -1
- package/lib/featureFlags/stakePrograms/index.js +3 -2
- package/lib/featureFlags/stakePrograms/index.js.map +1 -1
- package/lib/featureFlags/stakePrograms/index.test.js +4 -4
- package/lib/featureFlags/stakePrograms/index.test.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/hw/connectAppEventMapper.d.ts.map +1 -1
- package/lib/hw/connectAppEventMapper.js +4 -4
- package/lib/hw/connectAppEventMapper.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/featureFlags/stakePrograms/index.d.ts +8 -2
- package/lib-es/featureFlags/stakePrograms/index.d.ts.map +1 -1
- package/lib-es/featureFlags/stakePrograms/index.js +3 -2
- package/lib-es/featureFlags/stakePrograms/index.js.map +1 -1
- package/lib-es/featureFlags/stakePrograms/index.test.js +4 -4
- package/lib-es/featureFlags/stakePrograms/index.test.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/lib-es/hw/connectAppEventMapper.d.ts.map +1 -1
- package/lib-es/hw/connectAppEventMapper.js +5 -5
- package/lib-es/hw/connectAppEventMapper.js.map +1 -1
- package/package.json +66 -66
- 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/featureFlags/stakePrograms/index.test.ts +4 -4
- package/src/featureFlags/stakePrograms/index.ts +5 -6
- package/src/generated/bridge/js.ts +2 -0
- package/src/hw/connectAppEventMapper.ts +4 -4
- 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 +0,0 @@
|
|
1
|
-
{"version":3,"file":"estimateMaxSpendable.test.js","sourceRoot":"","sources":["../../../../src/bridge/generic-alpaca/tests/estimateMaxSpendable.test.ts"],"names":[],"mappings":"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"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"prepareTransaction.test.d.ts","sourceRoot":"","sources":["../../../../src/bridge/generic-alpaca/tests/prepareTransaction.test.ts"],"names":[],"mappings":""}
|
@@ -1,48 +0,0 @@
|
|
1
|
-
import { genericPrepareTransaction } from "../prepareTransaction";
|
2
|
-
import { getAlpacaApi } from "../alpaca";
|
3
|
-
import { transactionToIntent } from "../utils";
|
4
|
-
import BigNumber from "bignumber.js";
|
5
|
-
jest.mock("../alpaca", () => ({
|
6
|
-
getAlpacaApi: jest.fn(),
|
7
|
-
}));
|
8
|
-
jest.mock("../utils", () => ({
|
9
|
-
transactionToIntent: jest.fn(),
|
10
|
-
}));
|
11
|
-
describe("genericPrepareTransaction", () => {
|
12
|
-
const network = "testnet";
|
13
|
-
const kind = "local";
|
14
|
-
const account = {
|
15
|
-
id: "test-account",
|
16
|
-
address: "0xabc",
|
17
|
-
};
|
18
|
-
const baseTransaction = {
|
19
|
-
amount: new BigNumber(100_000),
|
20
|
-
fees: new BigNumber(500),
|
21
|
-
recipient: "0xrecipient",
|
22
|
-
};
|
23
|
-
const txIntent = { mock: "intent" };
|
24
|
-
beforeEach(() => {
|
25
|
-
jest.clearAllMocks();
|
26
|
-
transactionToIntent.mockReturnValue(txIntent);
|
27
|
-
});
|
28
|
-
it("updates fees if they differ", async () => {
|
29
|
-
const newFee = new BigNumber(700);
|
30
|
-
getAlpacaApi.mockReturnValue({
|
31
|
-
estimateFees: jest.fn().mockResolvedValue({ value: newFee }),
|
32
|
-
});
|
33
|
-
const prepareTransaction = genericPrepareTransaction(network, kind);
|
34
|
-
const result = await prepareTransaction(account, { ...baseTransaction });
|
35
|
-
expect(result.fees.toString()).toBe(newFee.toString());
|
36
|
-
expect(transactionToIntent).toHaveBeenCalledWith(account, expect.objectContaining(baseTransaction));
|
37
|
-
});
|
38
|
-
it("returns original transaction if fees are the same", async () => {
|
39
|
-
const sameFee = baseTransaction.fees;
|
40
|
-
getAlpacaApi.mockReturnValue({
|
41
|
-
estimateFees: jest.fn().mockResolvedValue({ value: sameFee }),
|
42
|
-
});
|
43
|
-
const prepareTransaction = genericPrepareTransaction(network, kind);
|
44
|
-
const result = await prepareTransaction(account, { ...baseTransaction });
|
45
|
-
expect(result).toStrictEqual(baseTransaction);
|
46
|
-
});
|
47
|
-
});
|
48
|
-
//# sourceMappingURL=prepareTransaction.test.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"prepareTransaction.test.js","sourceRoot":"","sources":["../../../../src/bridge/generic-alpaca/tests/prepareTransaction.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAC/C,OAAO,SAAS,MAAM,cAAc,CAAC;AAGrC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE,CAAC,CAAC;IAC5B,YAAY,EAAE,IAAI,CAAC,EAAE,EAAE;CACxB,CAAC,CAAC,CAAC;AAEJ,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,CAAC;IAC3B,mBAAmB,EAAE,IAAI,CAAC,EAAE,EAAE;CAC/B,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,MAAM,OAAO,GAAG,SAAS,CAAC;IAC1B,MAAM,IAAI,GAAG,OAAO,CAAC;IAErB,MAAM,OAAO,GAAG;QACd,EAAE,EAAE,cAAc;QAClB,OAAO,EAAE,OAAO;KACV,CAAC;IAET,MAAM,eAAe,GAA4C;QAC/D,MAAM,EAAE,IAAI,SAAS,CAAC,OAAO,CAAC;QAC9B,IAAI,EAAE,IAAI,SAAS,CAAC,GAAG,CAAC;QACxB,SAAS,EAAE,aAAa;KACzB,CAAC;IAEF,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;IAEpC,UAAU,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;QACpB,mBAAiC,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6BAA6B,EAAE,KAAK,IAAI,EAAE;QAC3C,MAAM,MAAM,GAAG,IAAI,SAAS,CAAC,GAAG,CAAC,CAAC;QAEjC,YAA0B,CAAC,eAAe,CAAC;YAC1C,YAAY,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;SAC7D,CAAC,CAAC;QAEH,MAAM,kBAAkB,GAAG,yBAAyB,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QACpE,MAAM,MAAM,GAAG,MAAM,kBAAkB,CAAC,OAAO,EAAE,EAAE,GAAG,eAAe,EAAE,CAAC,CAAC;QAEzE,MAAM,CAAE,MAAc,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;QAChE,MAAM,CAAC,mBAAmB,CAAC,CAAC,oBAAoB,CAC9C,OAAO,EACP,MAAM,CAAC,gBAAgB,CAAC,eAAe,CAAC,CACzC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mDAAmD,EAAE,KAAK,IAAI,EAAE;QACjE,MAAM,OAAO,GAAG,eAAe,CAAC,IAAI,CAAC;QAEpC,YAA0B,CAAC,eAAe,CAAC;YAC1C,YAAY,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC;SAC9D,CAAC,CAAC;QAEH,MAAM,kBAAkB,GAAG,yBAAyB,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QACpE,MAAM,MAAM,GAAG,MAAM,kBAAkB,CAAC,OAAO,EAAE,EAAE,GAAG,eAAe,EAAE,CAAC,CAAC;QAEzE,MAAM,CAAC,MAAM,CAAC,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"signOperation.test.d.ts","sourceRoot":"","sources":["../../../../src/bridge/generic-alpaca/tests/signOperation.test.ts"],"names":[],"mappings":""}
|
@@ -1,77 +0,0 @@
|
|
1
|
-
import { lastValueFrom } from "rxjs";
|
2
|
-
import { toArray } from "rxjs/operators";
|
3
|
-
import { genericSignOperation } from "../signOperation";
|
4
|
-
import { FeeNotLoaded } from "@ledgerhq/errors";
|
5
|
-
import { getAlpacaApi } from "../alpaca";
|
6
|
-
import { buildOptimisticOperation, transactionToIntent } from "../utils";
|
7
|
-
jest.mock("../alpaca", () => ({
|
8
|
-
getAlpacaApi: jest.fn(),
|
9
|
-
}));
|
10
|
-
jest.mock("../utils", () => ({
|
11
|
-
buildOptimisticOperation: jest.fn(),
|
12
|
-
transactionToIntent: jest.fn(),
|
13
|
-
}));
|
14
|
-
describe("genericSignOperation", () => {
|
15
|
-
const network = "xrp";
|
16
|
-
const kind = "local";
|
17
|
-
const mockSignerContext = jest.fn();
|
18
|
-
const mockSigner = {
|
19
|
-
getAddress: jest.fn(),
|
20
|
-
signTransaction: jest.fn(),
|
21
|
-
};
|
22
|
-
const account = {
|
23
|
-
freshAddressPath: "44'/144'/0'/0/0",
|
24
|
-
address: "rTestAddress",
|
25
|
-
};
|
26
|
-
const transaction = {
|
27
|
-
amount: 100000n,
|
28
|
-
fees: 500n,
|
29
|
-
tag: 1234,
|
30
|
-
};
|
31
|
-
const deviceId = "mockDevice";
|
32
|
-
const txIntent = {
|
33
|
-
memo: {
|
34
|
-
type: "map",
|
35
|
-
memos: new Map(),
|
36
|
-
},
|
37
|
-
};
|
38
|
-
const unsignedTx = "unsignedTx";
|
39
|
-
const signedTx = "signedTx";
|
40
|
-
const pubKey = "pubKey";
|
41
|
-
beforeEach(() => {
|
42
|
-
jest.clearAllMocks();
|
43
|
-
getAlpacaApi.mockReturnValue({
|
44
|
-
craftTransaction: jest.fn().mockResolvedValue(unsignedTx),
|
45
|
-
combine: jest.fn().mockResolvedValue(signedTx),
|
46
|
-
});
|
47
|
-
transactionToIntent.mockReturnValue(txIntent);
|
48
|
-
buildOptimisticOperation.mockReturnValue({ id: "mock-op" });
|
49
|
-
mockSigner.getAddress.mockResolvedValue({ publicKey: pubKey });
|
50
|
-
mockSigner.signTransaction.mockResolvedValue("sig");
|
51
|
-
mockSignerContext.mockImplementation(async (_deviceId, cb) => cb(mockSigner));
|
52
|
-
});
|
53
|
-
it("emits full sign operation flow", async () => {
|
54
|
-
const signOperation = genericSignOperation(network, kind)(mockSignerContext);
|
55
|
-
const observable = signOperation({ account, transaction, deviceId });
|
56
|
-
const events = await lastValueFrom(observable.pipe(toArray()));
|
57
|
-
expect(events[0]).toEqual({ type: "device-signature-requested" });
|
58
|
-
expect(events[1]).toEqual({ type: "device-signature-granted" });
|
59
|
-
expect(events[2]).toEqual({
|
60
|
-
type: "signed",
|
61
|
-
signedOperation: {
|
62
|
-
operation: { id: "mock-op" },
|
63
|
-
signature: signedTx,
|
64
|
-
},
|
65
|
-
});
|
66
|
-
expect(transactionToIntent).toHaveBeenCalledWith(account, transaction);
|
67
|
-
expect(txIntent.memo.memos.get("destinationTag")).toBe("1234");
|
68
|
-
});
|
69
|
-
it("throws FeeNotLoaded if fees are missing", async () => {
|
70
|
-
const txWithoutFees = { ...transaction };
|
71
|
-
delete txWithoutFees.fees;
|
72
|
-
const signOperation = genericSignOperation(network, kind)(mockSignerContext);
|
73
|
-
const observable = signOperation({ account, transaction: txWithoutFees, deviceId });
|
74
|
-
await expect(observable.toPromise()).rejects.toThrow(FeeNotLoaded);
|
75
|
-
});
|
76
|
-
});
|
77
|
-
//# sourceMappingURL=signOperation.test.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"signOperation.test.js","sourceRoot":"","sources":["../../../../src/bridge/generic-alpaca/tests/signOperation.test.ts"],"names":[],"mappings":"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"}
|
@@ -1,6 +0,0 @@
|
|
1
|
-
import { Account, Operation, TransactionCommon } from "@ledgerhq/types-live";
|
2
|
-
import { Operation as CoreOperation, Asset, TransactionIntent } from "@ledgerhq/coin-framework/api/types";
|
3
|
-
export declare function adaptCoreOperationToLiveOperation(accountId: string, op: CoreOperation<Asset>): Operation;
|
4
|
-
export declare function transactionToIntent(_account: Account, transaction: TransactionCommon): TransactionIntent<any>;
|
5
|
-
export declare const buildOptimisticOperation: (account: Account, transaction: TransactionCommon) => Operation;
|
6
|
-
//# sourceMappingURL=utils.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/bridge/generic-alpaca/utils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,SAAS,EAAiB,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAC5F,OAAO,EACL,SAAS,IAAI,aAAa,EAC1B,KAAK,EACL,iBAAiB,EAClB,MAAM,oCAAoC,CAAC;AAI5C,wBAAgB,iCAAiC,CAC/C,SAAS,EAAE,MAAM,EACjB,EAAE,EAAE,aAAa,CAAC,KAAK,CAAC,GACvB,SAAS,CAgBX;AAED,wBAAgB,mBAAmB,CACjC,QAAQ,EAAE,OAAO,EACjB,WAAW,EAAE,iBAAiB,GAC7B,iBAAiB,CAAC,GAAG,CAAC,CAQxB;AAED,eAAO,MAAM,wBAAwB,YAC1B,OAAO,eACH,iBAAiB,KAC7B,SAeF,CAAC"}
|
@@ -1,46 +0,0 @@
|
|
1
|
-
import { encodeOperationId } from "@ledgerhq/coin-framework/operation";
|
2
|
-
import BigNumber from "bignumber.js";
|
3
|
-
import { fromBigNumberToBigInt } from "@ledgerhq/coin-framework/utils";
|
4
|
-
export function adaptCoreOperationToLiveOperation(accountId, op) {
|
5
|
-
return {
|
6
|
-
id: encodeOperationId(accountId, op.tx.hash, op.type),
|
7
|
-
hash: op.tx.hash,
|
8
|
-
accountId,
|
9
|
-
type: op.type,
|
10
|
-
value: new BigNumber(op.value.toString()),
|
11
|
-
fee: new BigNumber(op.tx.fees.toString()),
|
12
|
-
blockHash: op.tx.block.hash,
|
13
|
-
blockHeight: op.tx.block.height,
|
14
|
-
senders: op.senders,
|
15
|
-
recipients: op.recipients,
|
16
|
-
date: op.tx.date,
|
17
|
-
transactionSequenceNumber: op.details?.sequence,
|
18
|
-
extra: {},
|
19
|
-
};
|
20
|
-
}
|
21
|
-
export function transactionToIntent(_account, transaction) {
|
22
|
-
return {
|
23
|
-
type: "Payment",
|
24
|
-
sender: _account.freshAddress,
|
25
|
-
recipient: transaction.recipient,
|
26
|
-
amount: fromBigNumberToBigInt(transaction.amount, BigInt(0)),
|
27
|
-
asset: null,
|
28
|
-
};
|
29
|
-
}
|
30
|
-
export const buildOptimisticOperation = (account, transaction) => {
|
31
|
-
return {
|
32
|
-
id: encodeOperationId(account.id, "", "OUT"),
|
33
|
-
hash: "",
|
34
|
-
type: "OUT",
|
35
|
-
value: transaction.amount,
|
36
|
-
fee: transaction["fees"] ?? BigNumber(0),
|
37
|
-
blockHash: null,
|
38
|
-
blockHeight: null,
|
39
|
-
senders: [account.freshAddress.toString()],
|
40
|
-
recipients: [transaction.recipient],
|
41
|
-
accountId: account.id,
|
42
|
-
date: new Date(),
|
43
|
-
extra: {},
|
44
|
-
};
|
45
|
-
};
|
46
|
-
//# sourceMappingURL=utils.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/bridge/generic-alpaca/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AAOvE,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AAEvE,MAAM,UAAU,iCAAiC,CAC/C,SAAiB,EACjB,EAAwB;IAExB,OAAO;QACL,EAAE,EAAE,iBAAiB,CAAC,SAAS,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC;QACrD,IAAI,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI;QAChB,SAAS;QACT,IAAI,EAAE,EAAE,CAAC,IAAqB;QAC9B,KAAK,EAAE,IAAI,SAAS,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QACzC,GAAG,EAAE,IAAI,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACzC,SAAS,EAAE,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI;QAC3B,WAAW,EAAE,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM;QAC/B,OAAO,EAAE,EAAE,CAAC,OAAO;QACnB,UAAU,EAAE,EAAE,CAAC,UAAU;QACzB,IAAI,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI;QAChB,yBAAyB,EAAE,EAAE,CAAC,OAAO,EAAE,QAAkB;QACzD,KAAK,EAAE,EAAE;KACV,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,mBAAmB,CACjC,QAAiB,EACjB,WAA8B;IAE9B,OAAO;QACL,IAAI,EAAE,SAAS;QACf,MAAM,EAAE,QAAQ,CAAC,YAAY;QAC7B,SAAS,EAAE,WAAW,CAAC,SAAS;QAChC,MAAM,EAAE,qBAAqB,CAAC,WAAW,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;QAC5D,KAAK,EAAE,IAAI;KACZ,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,MAAM,wBAAwB,GAAG,CACtC,OAAgB,EAChB,WAA8B,EACnB,EAAE;IACb,OAAO;QACL,EAAE,EAAE,iBAAiB,CAAC,OAAO,CAAC,EAAE,EAAE,EAAE,EAAE,KAAK,CAAC;QAC5C,IAAI,EAAE,EAAE;QACR,IAAI,EAAE,KAAK;QACX,KAAK,EAAE,WAAW,CAAC,MAAM;QACzB,GAAG,EAAE,WAAW,CAAC,MAAM,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC;QACxC,SAAS,EAAE,IAAI;QACf,WAAW,EAAE,IAAI;QACjB,OAAO,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;QAC1C,UAAU,EAAE,CAAC,WAAW,CAAC,SAAS,CAAC;QACnC,SAAS,EAAE,OAAO,CAAC,EAAE;QACrB,IAAI,EAAE,IAAI,IAAI,EAAE;QAChB,KAAK,EAAE,EAAE;KACV,CAAC;AACJ,CAAC,CAAC"}
|
@@ -1,13 +0,0 @@
|
|
1
|
-
export declare class UserAddressSanctionedError extends Error {
|
2
|
-
constructor();
|
3
|
-
}
|
4
|
-
export declare class UserAddressSanctionedForSendError extends Error {
|
5
|
-
constructor();
|
6
|
-
}
|
7
|
-
export declare class UserAddressSanctionedForStakingError extends Error {
|
8
|
-
constructor();
|
9
|
-
}
|
10
|
-
export declare class RecipientAddressSanctionedError extends Error {
|
11
|
-
constructor();
|
12
|
-
}
|
13
|
-
//# sourceMappingURL=errors.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/sanction/errors.ts"],"names":[],"mappings":"AAAA,qBAAa,0BAA2B,SAAQ,KAAK;;CAMpD;AAED,qBAAa,iCAAkC,SAAQ,KAAK;;CAM3D;AAED,qBAAa,oCAAqC,SAAQ,KAAK;;CAM9D;AAED,qBAAa,+BAAgC,SAAQ,KAAK;;CAMzD"}
|
@@ -1,29 +0,0 @@
|
|
1
|
-
export class UserAddressSanctionedError extends Error {
|
2
|
-
constructor() {
|
3
|
-
super();
|
4
|
-
this.message = this.constructor.name;
|
5
|
-
this.name = this.constructor.name;
|
6
|
-
}
|
7
|
-
}
|
8
|
-
export class UserAddressSanctionedForSendError extends Error {
|
9
|
-
constructor() {
|
10
|
-
super();
|
11
|
-
this.message = this.constructor.name;
|
12
|
-
this.name = this.constructor.name;
|
13
|
-
}
|
14
|
-
}
|
15
|
-
export class UserAddressSanctionedForStakingError extends Error {
|
16
|
-
constructor() {
|
17
|
-
super();
|
18
|
-
this.message = this.constructor.name;
|
19
|
-
this.name = this.constructor.name;
|
20
|
-
}
|
21
|
-
}
|
22
|
-
export class RecipientAddressSanctionedError extends Error {
|
23
|
-
constructor() {
|
24
|
-
super();
|
25
|
-
this.message = this.constructor.name;
|
26
|
-
this.name = this.constructor.name;
|
27
|
-
}
|
28
|
-
}
|
29
|
-
//# sourceMappingURL=errors.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/sanction/errors.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,0BAA2B,SAAQ,KAAK;IACnD;QACE,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QACrC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;IACpC,CAAC;CACF;AAED,MAAM,OAAO,iCAAkC,SAAQ,KAAK;IAC1D;QACE,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QACrC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;IACpC,CAAC;CACF;AAED,MAAM,OAAO,oCAAqC,SAAQ,KAAK;IAC7D;QACE,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QACrC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;IACpC,CAAC;CACF;AAED,MAAM,OAAO,+BAAgC,SAAQ,KAAK;IACxD;QACE,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QACrC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;IACpC,CAAC;CACF"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/sanction/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAa9D,wBAAsB,mBAAmB,CACvC,QAAQ,EAAE,cAAc,EACxB,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,OAAO,CAAC,CAiBlB"}
|
package/lib-es/sanction/index.js
DELETED
@@ -1,44 +0,0 @@
|
|
1
|
-
import { LiveConfig } from "@ledgerhq/live-config/LiveConfig";
|
2
|
-
import axios from "axios";
|
3
|
-
import { hours, makeLRUCache } from "@ledgerhq/live-network/cache";
|
4
|
-
import { getCurrencyConfiguration, getSharedConfiguration } from "../config";
|
5
|
-
const cache = makeLRUCache(fetchSanctionedAddresses, () => "all_sanctioned_addresses", hours(12));
|
6
|
-
async function fetchSanctionedAddresses() {
|
7
|
-
const { data } = await axios.get("https://ofac-compliance.pages.dev/all_sanctioned_addresses.json");
|
8
|
-
return data;
|
9
|
-
}
|
10
|
-
export async function isAddressSanctioned(currency, address) {
|
11
|
-
if (!isCheckBlacklistAddressEnabled(currency)) {
|
12
|
-
return false;
|
13
|
-
}
|
14
|
-
// Only for testing, should be deleted after
|
15
|
-
const temporarySanctionedAddresses = LiveConfig.getValueByKey(`tmp_sanctioned_addresses`);
|
16
|
-
const data = await cache();
|
17
|
-
const addresses = data[currency.ticker] || [];
|
18
|
-
if (temporarySanctionedAddresses) {
|
19
|
-
return addresses.concat(temporarySanctionedAddresses).includes(address);
|
20
|
-
}
|
21
|
-
return addresses.includes(address);
|
22
|
-
}
|
23
|
-
function isCheckBlacklistAddressEnabled(currency) {
|
24
|
-
const currencyConfig = tryGetCurrencyConfig(currency);
|
25
|
-
if (currencyConfig && "checkBlacklistAddress" in currencyConfig) {
|
26
|
-
return currencyConfig.checkBlacklistAddress === true;
|
27
|
-
}
|
28
|
-
else {
|
29
|
-
const sharedConfiguration = getSharedConfiguration();
|
30
|
-
if ("checkBlacklistAddress" in sharedConfiguration) {
|
31
|
-
return sharedConfiguration.checkBlacklistAddress === true;
|
32
|
-
}
|
33
|
-
}
|
34
|
-
return false;
|
35
|
-
}
|
36
|
-
function tryGetCurrencyConfig(currency) {
|
37
|
-
try {
|
38
|
-
return getCurrencyConfiguration(currency);
|
39
|
-
}
|
40
|
-
catch (error) {
|
41
|
-
return undefined;
|
42
|
-
}
|
43
|
-
}
|
44
|
-
//# sourceMappingURL=index.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/sanction/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kCAAkC,CAAC;AAC9D,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAEnE,OAAO,EAAE,wBAAwB,EAAE,sBAAsB,EAAE,MAAM,WAAW,CAAC;AAG7E,MAAM,KAAK,GAAG,YAAY,CAAC,wBAAwB,EAAE,GAAG,EAAE,CAAC,0BAA0B,EAAE,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;AAElG,KAAK,UAAU,wBAAwB;IACrC,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,KAAK,CAAC,GAAG,CAC9B,iEAAiE,CAClE,CAAC;IACF,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,mBAAmB,CACvC,QAAwB,EACxB,OAAe;IAEf,IAAI,CAAC,8BAA8B,CAAC,QAAQ,CAAC,EAAE;QAC7C,OAAO,KAAK,CAAC;KACd;IAED,4CAA4C;IAC5C,MAAM,4BAA4B,GAChC,UAAU,CAAC,aAAa,CAAC,0BAA0B,CAAC,CAAC;IAEvD,MAAM,IAAI,GAA6B,MAAM,KAAK,EAAE,CAAC;IACrD,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IAE9C,IAAI,4BAA4B,EAAE;QAChC,OAAO,SAAS,CAAC,MAAM,CAAC,4BAA4B,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;KACzE;IAED,OAAO,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;AACrC,CAAC;AAED,SAAS,8BAA8B,CAAC,QAAwB;IAC9D,MAAM,cAAc,GAAG,oBAAoB,CAAC,QAAQ,CAAC,CAAC;IACtD,IAAI,cAAc,IAAI,uBAAuB,IAAI,cAAc,EAAE;QAC/D,OAAO,cAAc,CAAC,qBAAqB,KAAK,IAAI,CAAC;KACtD;SAAM;QACL,MAAM,mBAAmB,GAAG,sBAAsB,EAAE,CAAC;QACrD,IAAI,uBAAuB,IAAI,mBAAmB,EAAE;YAClD,OAAO,mBAAmB,CAAC,qBAAqB,KAAK,IAAI,CAAC;SAC3D;KACF;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,oBAAoB,CAAC,QAAwB;IACpD,IAAI;QACF,OAAO,wBAAwB,CAAC,QAAQ,CAAC,CAAC;KAC3C;IAAC,OAAO,KAAK,EAAE;QACd,OAAO,SAAS,CAAC;KAClB;AACH,CAAC"}
|
@@ -1,32 +0,0 @@
|
|
1
|
-
import { AccountBridge } from "@ledgerhq/types-live";
|
2
|
-
import { makeSync } from "../jsHelpers";
|
3
|
-
import { genericGetAccountShape } from "./getAccountShape";
|
4
|
-
import {
|
5
|
-
getSerializedAddressParameters,
|
6
|
-
makeAccountBridgeReceive,
|
7
|
-
updateTransaction,
|
8
|
-
} from "@ledgerhq/coin-framework/bridge/jsHelpers";
|
9
|
-
import getAddressWrapper from "@ledgerhq/coin-framework/bridge/getAddressWrapper";
|
10
|
-
import { getSigner } from "./signer";
|
11
|
-
import { genericPrepareTransaction } from "./prepareTransaction";
|
12
|
-
import { genericGetTransactionStatus } from "./getTransactionStatus";
|
13
|
-
import { genericEstimateMaxSpendable } from "./estimateMaxSpendable";
|
14
|
-
import { createTransaction } from "./createTransaction";
|
15
|
-
import { genericBroadcast } from "./broadcast";
|
16
|
-
import { genericSignOperation } from "./signOperation";
|
17
|
-
|
18
|
-
export function getAlpacaAccountBridge(network: string, kind: string): AccountBridge<any> {
|
19
|
-
const signer = getSigner(network);
|
20
|
-
return {
|
21
|
-
sync: makeSync({ getAccountShape: genericGetAccountShape(network, kind) }),
|
22
|
-
receive: makeAccountBridgeReceive(getAddressWrapper(signer.getAddress)),
|
23
|
-
createTransaction: createTransaction,
|
24
|
-
updateTransaction: updateTransaction<any>,
|
25
|
-
prepareTransaction: genericPrepareTransaction(network, kind),
|
26
|
-
getTransactionStatus: genericGetTransactionStatus(network, kind),
|
27
|
-
estimateMaxSpendable: genericEstimateMaxSpendable(network, kind),
|
28
|
-
broadcast: genericBroadcast(network, kind),
|
29
|
-
signOperation: genericSignOperation(network, kind)(signer.context),
|
30
|
-
getSerializedAddressParameters, // NOTE: check wether it should be exposed by coin-module's api instead?
|
31
|
-
} satisfies Partial<AccountBridge<any>> as AccountBridge<any>;
|
32
|
-
}
|
@@ -1,20 +0,0 @@
|
|
1
|
-
import { createApi as createXrpApi } from "@ledgerhq/coin-xrp/api/index";
|
2
|
-
import { getCurrencyConfiguration } from "../../../config";
|
3
|
-
import { getCryptoCurrencyById } from "@ledgerhq/cryptoassets/currencies";
|
4
|
-
import { getNetworkAlpacaApi } from "./network/network-alpaca";
|
5
|
-
import { Api } from "@ledgerhq/coin-framework/api/types";
|
6
|
-
import { XrpCoinConfig } from "@ledgerhq/coin-xrp/config";
|
7
|
-
|
8
|
-
export function getAlpacaApi(network: string, kind: "local" | "remote"): Api<any, any> {
|
9
|
-
if (kind === "local") {
|
10
|
-
switch (network) {
|
11
|
-
case "ripple":
|
12
|
-
case "xrp":
|
13
|
-
return createXrpApi(
|
14
|
-
getCurrencyConfiguration<XrpCoinConfig>(getCryptoCurrencyById("ripple")),
|
15
|
-
) as Api<any, any>;
|
16
|
-
// as unknown as Api<any>; // FIXME: createXrpApi returns a strongly typed Api<XrpSender>, fix Api<any> to allow it
|
17
|
-
}
|
18
|
-
}
|
19
|
-
return getNetworkAlpacaApi(network) satisfies Partial<Api<any, any>> as Api<any, any>;
|
20
|
-
}
|
@@ -1,182 +0,0 @@
|
|
1
|
-
import type {
|
2
|
-
// Api,
|
3
|
-
Account,
|
4
|
-
Balance,
|
5
|
-
BlockInfo,
|
6
|
-
Operation,
|
7
|
-
FeeEstimation,
|
8
|
-
Pagination,
|
9
|
-
TransactionIntent,
|
10
|
-
Transaction,
|
11
|
-
TransactionValidation,
|
12
|
-
Api,
|
13
|
-
} from "@ledgerhq/coin-framework/api/index";
|
14
|
-
import network from "@ledgerhq/live-network";
|
15
|
-
|
16
|
-
function adaptOp(backendOp: any): Operation<any> {
|
17
|
-
const { date } = backendOp.tx;
|
18
|
-
const newDate = new Date(date);
|
19
|
-
|
20
|
-
return {
|
21
|
-
...backendOp,
|
22
|
-
value: BigInt(backendOp.value),
|
23
|
-
tx: { ...backendOp.tx, fees: BigInt(backendOp.tx.fees), date: newDate },
|
24
|
-
};
|
25
|
-
}
|
26
|
-
|
27
|
-
const ALPACA_URL = "https://localhost:3000";
|
28
|
-
|
29
|
-
const buildBroadcast = networkFamily =>
|
30
|
-
async function broadcast(signedOperation: string): Promise<string> {
|
31
|
-
const { data } = await network<
|
32
|
-
{
|
33
|
-
transactionIdentifier: string;
|
34
|
-
},
|
35
|
-
{
|
36
|
-
rawTransaction: string;
|
37
|
-
}
|
38
|
-
>({
|
39
|
-
method: "POST",
|
40
|
-
url: `${ALPACA_URL}/${networkFamily}/transaction/broadcast`,
|
41
|
-
data: {
|
42
|
-
rawTransaction: signedOperation,
|
43
|
-
},
|
44
|
-
});
|
45
|
-
return data.transactionIdentifier;
|
46
|
-
};
|
47
|
-
|
48
|
-
const buildCombine = networkFamily =>
|
49
|
-
async function combine(tx: string, signature: string, pubKey?: string): Promise<string> {
|
50
|
-
const { data } = await network<
|
51
|
-
{
|
52
|
-
signedTransaction: string;
|
53
|
-
},
|
54
|
-
unknown
|
55
|
-
>({
|
56
|
-
method: "POST",
|
57
|
-
url: `${ALPACA_URL}/${networkFamily}/transaction/combine`,
|
58
|
-
data: {
|
59
|
-
raw_transaction: tx,
|
60
|
-
signature: signature,
|
61
|
-
pubkey: pubKey,
|
62
|
-
},
|
63
|
-
});
|
64
|
-
return data.signedTransaction;
|
65
|
-
};
|
66
|
-
|
67
|
-
const buildEstimateFees = networkFamily =>
|
68
|
-
async function estimateFees(intent: TransactionIntent<any>): Promise<FeeEstimation> {
|
69
|
-
const { data } = await network<{ fee: string }, unknown>({
|
70
|
-
method: "POST",
|
71
|
-
url: `${ALPACA_URL}/${networkFamily}/transaction/estimate`,
|
72
|
-
data: {
|
73
|
-
intent: {
|
74
|
-
...intent,
|
75
|
-
amount: intent.amount.toString(10),
|
76
|
-
},
|
77
|
-
},
|
78
|
-
});
|
79
|
-
return {
|
80
|
-
value: BigInt(data.fee),
|
81
|
-
};
|
82
|
-
};
|
83
|
-
|
84
|
-
const buildValidateIntent = networkFamily =>
|
85
|
-
async function validateIntent(
|
86
|
-
account: Account,
|
87
|
-
transaction: Transaction,
|
88
|
-
): Promise<TransactionValidation> {
|
89
|
-
const { data } = await network<
|
90
|
-
{
|
91
|
-
errors: Record<string, Error>;
|
92
|
-
warnings: Record<string, Error>;
|
93
|
-
estimatedFees: bigint;
|
94
|
-
amount: bigint;
|
95
|
-
totalSpent: bigint;
|
96
|
-
},
|
97
|
-
unknown
|
98
|
-
>({
|
99
|
-
method: "POST",
|
100
|
-
url: `${ALPACA_URL}/${networkFamily}/transaction/validate`,
|
101
|
-
data: {
|
102
|
-
transaction,
|
103
|
-
account,
|
104
|
-
},
|
105
|
-
});
|
106
|
-
return data;
|
107
|
-
};
|
108
|
-
|
109
|
-
// FIXME: shouldn't hardcode
|
110
|
-
type AssetInfo = {
|
111
|
-
type: "native"; // or "token" if applicable
|
112
|
-
};
|
113
|
-
|
114
|
-
const buildGetBalance = (networkFamily: string) =>
|
115
|
-
async function getBalance(address: string): Promise<Balance<AssetInfo>[]> {
|
116
|
-
const { data } = await network<Balance<AssetInfo>, unknown>({
|
117
|
-
method: "GET",
|
118
|
-
url: `${ALPACA_URL}/${networkFamily}/account/${address}/balance`,
|
119
|
-
});
|
120
|
-
|
121
|
-
return [
|
122
|
-
{
|
123
|
-
value: BigInt(data.value),
|
124
|
-
asset: data.asset,
|
125
|
-
},
|
126
|
-
];
|
127
|
-
};
|
128
|
-
|
129
|
-
const buildListOperations = networkFamily =>
|
130
|
-
async function listOperations(
|
131
|
-
address: string,
|
132
|
-
pagination: Pagination,
|
133
|
-
): Promise<[Operation<any>[], string]> {
|
134
|
-
const { data } = await network<{ operations: Operation<any>[] }, unknown>({
|
135
|
-
method: "GET",
|
136
|
-
url: `${ALPACA_URL}/${networkFamily}/account/${address}/operations`,
|
137
|
-
data: {
|
138
|
-
from: pagination.minHeight,
|
139
|
-
},
|
140
|
-
});
|
141
|
-
return [data.operations.map(op => adaptOp(op)), ""];
|
142
|
-
};
|
143
|
-
|
144
|
-
const buildLastBlock = networkFamily =>
|
145
|
-
async function lastBlock(): Promise<BlockInfo> {
|
146
|
-
const { data } = await network<any, unknown>({
|
147
|
-
method: "GET",
|
148
|
-
url: `${ALPACA_URL}/${networkFamily}/lastblock`,
|
149
|
-
});
|
150
|
-
return {
|
151
|
-
height: data.height,
|
152
|
-
time: new Date(data.time),
|
153
|
-
hash: data.hash,
|
154
|
-
};
|
155
|
-
};
|
156
|
-
|
157
|
-
const buildCraftTransaction = networkFamily =>
|
158
|
-
async function craftTransaction(intent: TransactionIntent<any>): Promise<string> {
|
159
|
-
const { data } = await network<any, unknown>({
|
160
|
-
method: "POST",
|
161
|
-
url: `${ALPACA_URL}/${networkFamily}/transaction/encode`,
|
162
|
-
data: {
|
163
|
-
intent: {
|
164
|
-
...intent,
|
165
|
-
amount: intent.amount.toString(10),
|
166
|
-
},
|
167
|
-
},
|
168
|
-
});
|
169
|
-
return data.rawTransaction;
|
170
|
-
};
|
171
|
-
|
172
|
-
export const getNetworkAlpacaApi = (networkFamily: string) =>
|
173
|
-
({
|
174
|
-
broadcast: buildBroadcast(networkFamily),
|
175
|
-
combine: buildCombine(networkFamily),
|
176
|
-
validateIntent: buildValidateIntent(networkFamily),
|
177
|
-
estimateFees: buildEstimateFees(networkFamily),
|
178
|
-
getBalance: buildGetBalance(networkFamily),
|
179
|
-
listOperations: buildListOperations(networkFamily),
|
180
|
-
lastBlock: buildLastBlock(networkFamily),
|
181
|
-
craftTransaction: buildCraftTransaction(networkFamily),
|
182
|
-
}) satisfies Api<any>;
|
@@ -1,11 +0,0 @@
|
|
1
|
-
import { AccountBridge, TransactionCommon } from "@ledgerhq/types-live";
|
2
|
-
import { patchOperationWithHash } from "../../operation";
|
3
|
-
import { getAlpacaApi } from "./alpaca";
|
4
|
-
|
5
|
-
export const genericBroadcast: (network, kind) => AccountBridge<TransactionCommon>["broadcast"] =
|
6
|
-
(network, kind) =>
|
7
|
-
async ({ signedOperation: { signature, operation } }) => {
|
8
|
-
const hash = await getAlpacaApi(network, kind).broadcast(signature);
|
9
|
-
|
10
|
-
return patchOperationWithHash(operation, hash);
|
11
|
-
};
|
@@ -1,27 +0,0 @@
|
|
1
|
-
import { Account, TransactionCommon } from "@ledgerhq/types-live";
|
2
|
-
import BigNumber from "bignumber.js";
|
3
|
-
import type { Unit } from "@ledgerhq/types-cryptoassets";
|
4
|
-
|
5
|
-
export type NetworkInfo = {
|
6
|
-
family: "xrp";
|
7
|
-
serverFee: BigNumber;
|
8
|
-
baseReserve: BigNumber;
|
9
|
-
};
|
10
|
-
|
11
|
-
export function createTransaction(account: Account): TransactionCommon & {
|
12
|
-
family: string;
|
13
|
-
fee: BigNumber | null | undefined;
|
14
|
-
networkInfo: NetworkInfo | null | undefined;
|
15
|
-
tag: number | null | undefined;
|
16
|
-
feeCustomUnit: Unit | null | undefined;
|
17
|
-
} {
|
18
|
-
return {
|
19
|
-
family: account.currency.family,
|
20
|
-
amount: BigNumber(0),
|
21
|
-
recipient: "",
|
22
|
-
fee: null,
|
23
|
-
tag: undefined,
|
24
|
-
networkInfo: null,
|
25
|
-
feeCustomUnit: null,
|
26
|
-
};
|
27
|
-
}
|
@@ -1,17 +0,0 @@
|
|
1
|
-
import { makeScanAccounts } from "@ledgerhq/coin-framework/bridge/jsHelpers";
|
2
|
-
import { CurrencyBridge } from "@ledgerhq/types-live";
|
3
|
-
import { genericGetAccountShape } from "./getAccountShape";
|
4
|
-
import { getSigner } from "./signer";
|
5
|
-
|
6
|
-
export function getAlpacaCurrencyBridge(network: string, kind: string): CurrencyBridge {
|
7
|
-
return {
|
8
|
-
preload: () => Promise.resolve({}),
|
9
|
-
hydrate: () => {
|
10
|
-
return;
|
11
|
-
},
|
12
|
-
scanAccounts: makeScanAccounts({
|
13
|
-
getAccountShape: genericGetAccountShape(network, kind),
|
14
|
-
getAddressFn: getSigner(network).getAddress,
|
15
|
-
}),
|
16
|
-
};
|
17
|
-
}
|