@ledgerhq/coin-canton 0.3.0 → 0.4.0-nightly.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/.env.integ.test.example +2 -2
- package/.eslintrc.js +1 -0
- package/.unimportedrc.json +5 -10
- package/CHANGELOG.md +17 -0
- package/README.md +11 -0
- package/jest.config.js +1 -0
- package/lib/api/getBalance.integ.test.d.ts +2 -0
- package/lib/api/getBalance.integ.test.d.ts.map +1 -0
- package/lib/api/getBalance.integ.test.js +24 -0
- package/lib/api/getBalance.integ.test.js.map +1 -0
- package/lib/api/lastBlock.integ.test.d.ts +2 -0
- package/lib/api/lastBlock.integ.test.d.ts.map +1 -0
- package/lib/api/lastBlock.integ.test.js +35 -0
- package/lib/api/lastBlock.integ.test.js.map +1 -0
- package/lib/bridge/createTransaction.test.js +1 -1
- package/lib/bridge/createTransaction.test.js.map +1 -1
- package/lib/bridge/getTransactionStatus.js +1 -1
- package/lib/bridge/getTransactionStatus.js.map +1 -1
- package/lib/bridge/sync.d.ts.map +1 -1
- package/lib/bridge/sync.js +3 -3
- package/lib/bridge/sync.js.map +1 -1
- package/lib/common-logic/account/getBalance.d.ts +1 -1
- package/lib/common-logic/account/getBalance.d.ts.map +1 -1
- package/lib/common-logic/account/getBalance.js +21 -5
- package/lib/common-logic/account/getBalance.js.map +1 -1
- package/lib/common-logic/account/getBalance.unit.test.d.ts +2 -0
- package/lib/common-logic/account/getBalance.unit.test.d.ts.map +1 -0
- package/lib/common-logic/account/getBalance.unit.test.js +88 -0
- package/lib/common-logic/account/getBalance.unit.test.js.map +1 -0
- package/lib/common-logic/history/lastBlock.d.ts.map +1 -1
- package/lib/common-logic/history/lastBlock.js +7 -4
- package/lib/common-logic/history/lastBlock.js.map +1 -1
- package/lib/common-logic/history/lastBlock.test.d.ts +2 -0
- package/lib/common-logic/history/lastBlock.test.d.ts.map +1 -0
- package/lib/common-logic/history/lastBlock.test.js +43 -0
- package/lib/common-logic/history/lastBlock.test.js.map +1 -0
- package/lib/config.d.ts +11 -5
- package/lib/config.d.ts.map +1 -1
- package/lib/config.js.map +1 -1
- package/lib/network/gateway.d.ts +77 -0
- package/lib/network/gateway.d.ts.map +1 -0
- package/lib/network/gateway.integ.test.d.ts +2 -0
- package/lib/network/gateway.integ.test.d.ts.map +1 -0
- package/lib/network/gateway.integ.test.js +61 -0
- package/lib/network/gateway.integ.test.js.map +1 -0
- package/lib/network/gateway.js +77 -0
- package/lib/network/gateway.js.map +1 -0
- package/lib/network/node.d.ts +2 -6
- package/lib/network/node.d.ts.map +1 -1
- package/lib/network/node.integ.test.d.ts +2 -0
- package/lib/network/node.integ.test.d.ts.map +1 -0
- package/lib/network/node.integ.test.js +42 -0
- package/lib/network/node.integ.test.js.map +1 -0
- package/lib/network/node.js +47 -24
- package/lib/network/node.js.map +1 -1
- package/lib/network/node.unit.test.d.ts +2 -0
- package/lib/network/node.unit.test.d.ts.map +1 -0
- package/lib/network/node.unit.test.js +31 -0
- package/lib/network/node.unit.test.js.map +1 -0
- package/lib/types/bridge.d.ts.map +1 -1
- package/lib-es/api/getBalance.integ.test.d.ts +2 -0
- package/lib-es/api/getBalance.integ.test.d.ts.map +1 -0
- package/lib-es/api/getBalance.integ.test.js +22 -0
- package/lib-es/api/getBalance.integ.test.js.map +1 -0
- package/lib-es/api/lastBlock.integ.test.d.ts +2 -0
- package/lib-es/api/lastBlock.integ.test.d.ts.map +1 -0
- package/lib-es/api/lastBlock.integ.test.js +33 -0
- package/lib-es/api/lastBlock.integ.test.js.map +1 -0
- package/lib-es/bridge/createTransaction.test.js +1 -1
- package/lib-es/bridge/createTransaction.test.js.map +1 -1
- package/lib-es/bridge/getTransactionStatus.js +1 -1
- package/lib-es/bridge/getTransactionStatus.js.map +1 -1
- package/lib-es/bridge/sync.d.ts.map +1 -1
- package/lib-es/bridge/sync.js +4 -4
- package/lib-es/bridge/sync.js.map +1 -1
- package/lib-es/common-logic/account/getBalance.d.ts +1 -1
- package/lib-es/common-logic/account/getBalance.d.ts.map +1 -1
- package/lib-es/common-logic/account/getBalance.js +18 -5
- package/lib-es/common-logic/account/getBalance.js.map +1 -1
- package/lib-es/common-logic/account/getBalance.unit.test.d.ts +2 -0
- package/lib-es/common-logic/account/getBalance.unit.test.d.ts.map +1 -0
- package/lib-es/common-logic/account/getBalance.unit.test.js +53 -0
- package/lib-es/common-logic/account/getBalance.unit.test.js.map +1 -0
- package/lib-es/common-logic/history/lastBlock.d.ts.map +1 -1
- package/lib-es/common-logic/history/lastBlock.js +5 -5
- package/lib-es/common-logic/history/lastBlock.js.map +1 -1
- package/lib-es/common-logic/history/lastBlock.test.d.ts +2 -0
- package/lib-es/common-logic/history/lastBlock.test.d.ts.map +1 -0
- package/lib-es/common-logic/history/lastBlock.test.js +38 -0
- package/lib-es/common-logic/history/lastBlock.test.js.map +1 -0
- package/lib-es/config.d.ts +11 -5
- package/lib-es/config.d.ts.map +1 -1
- package/lib-es/config.js.map +1 -1
- package/lib-es/network/gateway.d.ts +77 -0
- package/lib-es/network/gateway.d.ts.map +1 -0
- package/lib-es/network/gateway.integ.test.d.ts +2 -0
- package/lib-es/network/gateway.integ.test.d.ts.map +1 -0
- package/lib-es/network/gateway.integ.test.js +56 -0
- package/lib-es/network/gateway.integ.test.js.map +1 -0
- package/lib-es/network/gateway.js +65 -0
- package/lib-es/network/gateway.js.map +1 -0
- package/lib-es/network/node.d.ts +2 -6
- package/lib-es/network/node.d.ts.map +1 -1
- package/lib-es/network/node.integ.test.d.ts +2 -0
- package/lib-es/network/node.integ.test.d.ts.map +1 -0
- package/lib-es/network/node.integ.test.js +37 -0
- package/lib-es/network/node.integ.test.js.map +1 -0
- package/lib-es/network/node.js +40 -17
- package/lib-es/network/node.js.map +1 -1
- package/lib-es/network/node.unit.test.d.ts +2 -0
- package/lib-es/network/node.unit.test.d.ts.map +1 -0
- package/lib-es/network/node.unit.test.js +26 -0
- package/lib-es/network/node.unit.test.js.map +1 -0
- package/lib-es/types/bridge.d.ts.map +1 -1
- package/package.json +8 -8
- package/src/api/getBalance.integ.test.ts +28 -0
- package/src/api/lastBlock.integ.test.ts +39 -0
- package/src/bridge/createTransaction.test.ts +1 -1
- package/src/bridge/getTransactionStatus.ts +1 -1
- package/src/bridge/sync.ts +6 -4
- package/src/common-logic/account/getBalance.ts +20 -5
- package/src/common-logic/account/getBalance.unit.test.ts +63 -0
- package/src/common-logic/history/lastBlock.test.ts +47 -0
- package/src/common-logic/history/lastBlock.ts +6 -5
- package/src/config.ts +14 -4
- package/src/network/gateway.integ.test.ts +76 -0
- package/src/network/gateway.ts +168 -0
- package/src/network/node.integ.test.ts +40 -0
- package/src/network/node.ts +45 -23
- package/src/network/node.unit.test.ts +29 -0
- package/src/types/bridge.ts +0 -1
|
@@ -1,7 +1,20 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
import { getBalance as gatewayGetBalance } from "../../network/gateway";
|
|
2
|
+
import coinConfig from "../../config";
|
|
3
|
+
const useGateway = () => coinConfig.getCoinConfig().useGateway === true;
|
|
4
|
+
const getNativeId = () => coinConfig.getCoinConfig().nativeInstrumentId;
|
|
5
|
+
function adaptInstrument(instrument) {
|
|
6
|
+
return {
|
|
7
|
+
value: BigInt(instrument.amount),
|
|
8
|
+
locked: instrument.locked === true ? BigInt(instrument.amount) : BigInt(0),
|
|
9
|
+
asset: getNativeId() === instrument.instrumentId
|
|
10
|
+
? { type: "native" }
|
|
11
|
+
: { type: "token", assetReference: instrument.instrumentId },
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
export async function getBalance(partyId) {
|
|
15
|
+
if (useGateway())
|
|
16
|
+
return (await gatewayGetBalance(partyId)).map(instrument => adaptInstrument(instrument));
|
|
17
|
+
else
|
|
18
|
+
throw new Error("Not implemented");
|
|
6
19
|
}
|
|
7
20
|
//# sourceMappingURL=getBalance.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getBalance.js","sourceRoot":"","sources":["../../../src/common-logic/account/getBalance.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"getBalance.js","sourceRoot":"","sources":["../../../src/common-logic/account/getBalance.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,IAAI,iBAAiB,EAA0B,MAAM,uBAAuB,CAAC;AAChG,OAAO,UAAU,MAAM,cAAc,CAAC;AAEtC,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,UAAU,KAAK,IAAI,CAAC;AACxE,MAAM,WAAW,GAAG,GAAG,EAAE,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,kBAAkB,CAAC;AAExE,SAAS,eAAe,CAAC,UAA6B;IACpD,OAAO;QACL,KAAK,EAAE,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC;QAChC,MAAM,EAAE,UAAU,CAAC,MAAM,KAAK,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;QAC1E,KAAK,EACH,WAAW,EAAE,KAAK,UAAU,CAAC,YAAY;YACvC,CAAC,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE;YACpB,CAAC,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,cAAc,EAAE,UAAU,CAAC,YAAY,EAAE;KACjE,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,OAAe;IAC9C,IAAI,UAAU,EAAE;QACd,OAAO,CAAC,MAAM,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC;;QACtF,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;AAC1C,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getBalance.unit.test.d.ts","sourceRoot":"","sources":["../../../src/common-logic/account/getBalance.unit.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { getBalance as getBalanceFromNetwork } from "../../network/gateway";
|
|
2
|
+
import * as coinConfigModule from "../../config";
|
|
3
|
+
import { getBalance } from "./getBalance";
|
|
4
|
+
jest.mock("../../network/gateway", () => ({
|
|
5
|
+
getBalance: jest.fn(),
|
|
6
|
+
}));
|
|
7
|
+
describe("getBalance", () => {
|
|
8
|
+
const mockGetCoinConfig = jest.spyOn(coinConfigModule.default, "getCoinConfig");
|
|
9
|
+
afterEach(() => {
|
|
10
|
+
jest.clearAllMocks();
|
|
11
|
+
});
|
|
12
|
+
it("should return adapted balances when useGateway is true", async () => {
|
|
13
|
+
mockGetCoinConfig.mockReturnValue({
|
|
14
|
+
useGateway: true,
|
|
15
|
+
nativeInstrumentId: "native-id",
|
|
16
|
+
});
|
|
17
|
+
const mockInstruments = [
|
|
18
|
+
{
|
|
19
|
+
instrumentId: "native-id",
|
|
20
|
+
amount: "1000",
|
|
21
|
+
locked: false,
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
instrumentId: "token-123",
|
|
25
|
+
amount: "5000",
|
|
26
|
+
locked: true,
|
|
27
|
+
},
|
|
28
|
+
];
|
|
29
|
+
getBalanceFromNetwork.mockResolvedValue(mockInstruments);
|
|
30
|
+
const result = await getBalance("party-id");
|
|
31
|
+
expect(getBalanceFromNetwork).toHaveBeenCalledWith("party-id");
|
|
32
|
+
expect(result).toEqual([
|
|
33
|
+
{
|
|
34
|
+
value: BigInt(1000),
|
|
35
|
+
locked: BigInt(0),
|
|
36
|
+
asset: { type: "native" },
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
value: BigInt(5000),
|
|
40
|
+
locked: BigInt(5000),
|
|
41
|
+
asset: { type: "token", assetReference: "token-123" },
|
|
42
|
+
},
|
|
43
|
+
]);
|
|
44
|
+
});
|
|
45
|
+
it("should throw an error when useGateway is false (not implemented with node)", async () => {
|
|
46
|
+
mockGetCoinConfig.mockReturnValue({
|
|
47
|
+
useGateway: false,
|
|
48
|
+
});
|
|
49
|
+
await expect(getBalance("party-id")).rejects.toThrow("Not implemented");
|
|
50
|
+
expect(getBalanceFromNetwork).not.toHaveBeenCalled();
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
//# sourceMappingURL=getBalance.unit.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getBalance.unit.test.js","sourceRoot":"","sources":["../../../src/common-logic/account/getBalance.unit.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,IAAI,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC5E,OAAO,KAAK,gBAAgB,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAG1C,IAAI,CAAC,IAAI,CAAC,uBAAuB,EAAE,GAAG,EAAE,CAAC,CAAC;IACxC,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE;CACtB,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;IAC1B,MAAM,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;IAEhF,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wDAAwD,EAAE,KAAK,IAAI,EAAE;QACtE,iBAAiB,CAAC,eAAe,CAAC;YAChC,UAAU,EAAE,IAAI;YAChB,kBAAkB,EAAE,WAAW;SACzB,CAAC,CAAC;QAEV,MAAM,eAAe,GAAG;YACtB;gBACE,YAAY,EAAE,WAAW;gBACzB,MAAM,EAAE,MAAM;gBACd,MAAM,EAAE,KAAK;aACd;YACD;gBACE,YAAY,EAAE,WAAW;gBACzB,MAAM,EAAE,MAAM;gBACd,MAAM,EAAE,IAAI;aACb;SACF,CAAC;QAED,qBAAmC,CAAC,iBAAiB,CAAC,eAAe,CAAC,CAAC;QAExE,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,UAAU,CAAC,CAAC;QAE5C,MAAM,CAAC,qBAAqB,CAAC,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;QAC/D,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAY;YAChC;gBACE,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC;gBACnB,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;gBACjB,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;aAC1B;YACD;gBACE,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC;gBACnB,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;gBACpB,KAAK,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE;aACtD;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4EAA4E,EAAE,KAAK,IAAI,EAAE;QAC1F,iBAAiB,CAAC,eAAe,CAAC;YAChC,UAAU,EAAE,KAAK;SACX,CAAC,CAAC;QAEV,MAAM,MAAM,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;QACxE,MAAM,CAAC,qBAAqB,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;IACvD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lastBlock.d.ts","sourceRoot":"","sources":["../../../src/common-logic/history/lastBlock.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAC;
|
|
1
|
+
{"version":3,"file":"lastBlock.d.ts","sourceRoot":"","sources":["../../../src/common-logic/history/lastBlock.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAC;AAOpE,wBAAsB,SAAS,IAAI,OAAO,CAAC,SAAS,CAAC,CAIpD"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { getLedgerEnd as nodeGetLedgerEnd } from "../../network/node";
|
|
2
|
+
import { getLedgerEnd } from "../../network/gateway";
|
|
3
|
+
import coinConfig from "../../config";
|
|
4
|
+
const useGateway = () => coinConfig.getCoinConfig().useGateway === true;
|
|
2
5
|
export async function lastBlock() {
|
|
3
|
-
const result = await getLastBlock();
|
|
4
6
|
return {
|
|
5
|
-
height:
|
|
6
|
-
hash: result.blockHash,
|
|
7
|
-
time: new Date(result.timestamp),
|
|
7
|
+
height: useGateway() ? await getLedgerEnd() : await nodeGetLedgerEnd(),
|
|
8
8
|
};
|
|
9
9
|
}
|
|
10
10
|
//# sourceMappingURL=lastBlock.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lastBlock.js","sourceRoot":"","sources":["../../../src/common-logic/history/lastBlock.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"lastBlock.js","sourceRoot":"","sources":["../../../src/common-logic/history/lastBlock.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtE,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,UAAU,MAAM,cAAc,CAAC;AAEtC,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,UAAU,KAAK,IAAI,CAAC;AAExE,MAAM,CAAC,KAAK,UAAU,SAAS;IAC7B,OAAO;QACL,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,MAAM,YAAY,EAAE,CAAC,CAAC,CAAC,MAAM,gBAAgB,EAAE;KACvE,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lastBlock.test.d.ts","sourceRoot":"","sources":["../../../src/common-logic/history/lastBlock.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { lastBlock } from "./lastBlock";
|
|
2
|
+
import { getLedgerEnd as gatewayGetLedgerEnd } from "../../network/gateway";
|
|
3
|
+
import { getLedgerEnd as nodeGetLedgerEnd } from "../../network/node";
|
|
4
|
+
jest.mock("../../network/gateway", () => ({
|
|
5
|
+
getLedgerEnd: jest.fn(),
|
|
6
|
+
}));
|
|
7
|
+
jest.mock("../../network/node", () => ({
|
|
8
|
+
getLedgerEnd: jest.fn(),
|
|
9
|
+
}));
|
|
10
|
+
jest.mock("../../config", () => ({
|
|
11
|
+
__esModule: true,
|
|
12
|
+
default: {
|
|
13
|
+
getCoinConfig: jest.fn(),
|
|
14
|
+
},
|
|
15
|
+
}));
|
|
16
|
+
import coinConfig from "../../config";
|
|
17
|
+
describe("lastBlock", () => {
|
|
18
|
+
beforeEach(() => {
|
|
19
|
+
jest.clearAllMocks();
|
|
20
|
+
});
|
|
21
|
+
it("should use gateway.getLedgerEnd when useGateway is true", async () => {
|
|
22
|
+
coinConfig.getCoinConfig.mockReturnValue({ useGateway: true });
|
|
23
|
+
gatewayGetLedgerEnd.mockResolvedValue(100);
|
|
24
|
+
const result = await lastBlock();
|
|
25
|
+
expect(result).toEqual({ height: 100 });
|
|
26
|
+
expect(gatewayGetLedgerEnd).toHaveBeenCalledTimes(1);
|
|
27
|
+
expect(nodeGetLedgerEnd).not.toHaveBeenCalled();
|
|
28
|
+
});
|
|
29
|
+
it("should use node.getLedgerEnd when useGateway is false", async () => {
|
|
30
|
+
coinConfig.getCoinConfig.mockReturnValue({ useGateway: false });
|
|
31
|
+
nodeGetLedgerEnd.mockResolvedValue(200);
|
|
32
|
+
const result = await lastBlock();
|
|
33
|
+
expect(result).toEqual({ height: 200 });
|
|
34
|
+
expect(nodeGetLedgerEnd).toHaveBeenCalledTimes(1);
|
|
35
|
+
expect(gatewayGetLedgerEnd).not.toHaveBeenCalled();
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
//# sourceMappingURL=lastBlock.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lastBlock.test.js","sourceRoot":"","sources":["../../../src/common-logic/history/lastBlock.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,YAAY,IAAI,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5E,OAAO,EAAE,YAAY,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEtE,IAAI,CAAC,IAAI,CAAC,uBAAuB,EAAE,GAAG,EAAE,CAAC,CAAC;IACxC,YAAY,EAAE,IAAI,CAAC,EAAE,EAAE;CACxB,CAAC,CAAC,CAAC;AACJ,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,GAAG,EAAE,CAAC,CAAC;IACrC,YAAY,EAAE,IAAI,CAAC,EAAE,EAAE;CACxB,CAAC,CAAC,CAAC;AAEJ,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,GAAG,EAAE,CAAC,CAAC;IAC/B,UAAU,EAAE,IAAI;IAChB,OAAO,EAAE;QACP,aAAa,EAAE,IAAI,CAAC,EAAE,EAAE;KACzB;CACF,CAAC,CAAC,CAAC;AAEJ,OAAO,UAAU,MAAM,cAAc,CAAC;AAEtC,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,UAAU,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;QACtE,UAAU,CAAC,aAA2B,CAAC,eAAe,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC;QAC7E,mBAAiC,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;QAE1D,MAAM,MAAM,GAAG,MAAM,SAAS,EAAE,CAAC;QAEjC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;QACxC,MAAM,CAAC,mBAAmB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QACrD,MAAM,CAAC,gBAAgB,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;IAClD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uDAAuD,EAAE,KAAK,IAAI,EAAE;QACpE,UAAU,CAAC,aAA2B,CAAC,eAAe,CAAC,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC;QAC9E,gBAA8B,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;QAEvD,MAAM,MAAM,GAAG,MAAM,SAAS,EAAE,CAAC;QAEjC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;QACxC,MAAM,CAAC,gBAAgB,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAClD,MAAM,CAAC,mBAAmB,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;IACrD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
package/lib-es/config.d.ts
CHANGED
|
@@ -1,12 +1,18 @@
|
|
|
1
|
-
import { type CurrencyConfig } from "@ledgerhq/coin-framework/config";
|
|
1
|
+
import { CoinConfig, type CurrencyConfig } from "@ledgerhq/coin-framework/config";
|
|
2
|
+
import { CryptoCurrency } from "@ledgerhq/types-cryptoassets";
|
|
2
3
|
export type CantonConfig = {
|
|
3
|
-
nodeUrl
|
|
4
|
-
|
|
4
|
+
nodeUrl?: string;
|
|
5
|
+
nodeId?: string;
|
|
6
|
+
gatewayUrl?: string;
|
|
7
|
+
minReserve?: number;
|
|
8
|
+
networkType: "mainnet" | "devnet" | "localnet";
|
|
9
|
+
useGateway?: boolean;
|
|
10
|
+
nativeInstrumentId?: string;
|
|
5
11
|
};
|
|
6
12
|
export type CantonCoinConfig = CurrencyConfig & CantonConfig;
|
|
7
13
|
declare const coinConfig: {
|
|
8
|
-
setCoinConfig: (config:
|
|
9
|
-
getCoinConfig: (currency?:
|
|
14
|
+
setCoinConfig: (config: CoinConfig<CantonCoinConfig>) => void;
|
|
15
|
+
getCoinConfig: (currency?: CryptoCurrency) => CantonCoinConfig;
|
|
10
16
|
};
|
|
11
17
|
export default coinConfig;
|
|
12
18
|
//# sourceMappingURL=config.d.ts.map
|
package/lib-es/config.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAwB,EAAE,KAAK,cAAc,EAAE,MAAM,iCAAiC,CAAC;
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAwB,EAAE,UAAU,EAAE,KAAK,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACnG,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAE9D,MAAM,MAAM,YAAY,GAAG;IACzB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,SAAS,GAAG,QAAQ,GAAG,UAAU,CAAC;IAC/C,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC7B,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG,cAAc,GAAG,YAAY,CAAC;AAE7D,QAAA,MAAM,UAAU,EAAE;IAChB,aAAa,EAAE,CAAC,MAAM,EAAE,UAAU,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAC;IAC9D,aAAa,EAAE,CAAC,QAAQ,CAAC,EAAE,cAAc,KAAK,gBAAgB,CAAC;CAC1B,CAAC;AAExC,eAAe,UAAU,CAAC"}
|
package/lib-es/config.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,eAAoD,MAAM,iCAAiC,CAAC;AAgBnG,MAAM,UAAU,GAGZ,eAAe,EAAoB,CAAC;AAExC,eAAe,UAAU,CAAC"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
type OnboardingPrepareResponse = {
|
|
2
|
+
party_id: string;
|
|
3
|
+
party_name: string;
|
|
4
|
+
public_key_fingerprint: string;
|
|
5
|
+
topology_transactions_hash: string;
|
|
6
|
+
};
|
|
7
|
+
type OnboardingPrepareRequest = {
|
|
8
|
+
public_key: string;
|
|
9
|
+
public_key_type: string;
|
|
10
|
+
};
|
|
11
|
+
type OnboardingSubmitResponse = {
|
|
12
|
+
party: {
|
|
13
|
+
party_id: string;
|
|
14
|
+
public_key: string;
|
|
15
|
+
};
|
|
16
|
+
};
|
|
17
|
+
export type InstrumentBalance = {
|
|
18
|
+
instrumentId: string;
|
|
19
|
+
amount: number;
|
|
20
|
+
locked: boolean;
|
|
21
|
+
};
|
|
22
|
+
type PartyInfo = {
|
|
23
|
+
party_id: string;
|
|
24
|
+
public_key: string;
|
|
25
|
+
};
|
|
26
|
+
type Timestamp = {
|
|
27
|
+
seconds: number;
|
|
28
|
+
nanos: number;
|
|
29
|
+
};
|
|
30
|
+
type BaseEvent = {
|
|
31
|
+
type: string;
|
|
32
|
+
contractId: string;
|
|
33
|
+
details: string;
|
|
34
|
+
};
|
|
35
|
+
type CreatedEvent = BaseEvent & {
|
|
36
|
+
templateId: {
|
|
37
|
+
packageId: string;
|
|
38
|
+
moduleName: string;
|
|
39
|
+
entityName: string;
|
|
40
|
+
};
|
|
41
|
+
signatories: string[];
|
|
42
|
+
observers: string[];
|
|
43
|
+
};
|
|
44
|
+
type ExercisedEvent = BaseEvent & {
|
|
45
|
+
templateId: {
|
|
46
|
+
packageId: string;
|
|
47
|
+
moduleName: string;
|
|
48
|
+
entityName: string;
|
|
49
|
+
};
|
|
50
|
+
choice: string;
|
|
51
|
+
consuming: boolean;
|
|
52
|
+
actingParties: string[];
|
|
53
|
+
};
|
|
54
|
+
type Event = BaseEvent | CreatedEvent | ExercisedEvent;
|
|
55
|
+
type TxInfo = {
|
|
56
|
+
updateId: string;
|
|
57
|
+
commandId: string;
|
|
58
|
+
workflowId: string;
|
|
59
|
+
effectiveAt: Timestamp;
|
|
60
|
+
offset: number;
|
|
61
|
+
synchronizerId: string;
|
|
62
|
+
recordTime: Timestamp;
|
|
63
|
+
events: Event[];
|
|
64
|
+
traceContext: string;
|
|
65
|
+
};
|
|
66
|
+
export declare function prepareOnboarding(pubKey: string, pubKeyType: string): Promise<OnboardingPrepareResponse>;
|
|
67
|
+
export declare function submitOnboarding(prepareRequest: OnboardingPrepareRequest, prepareResponse: OnboardingPrepareResponse, signature: string): Promise<OnboardingSubmitResponse>;
|
|
68
|
+
export declare function getBalance(partyId: string): Promise<InstrumentBalance[]>;
|
|
69
|
+
export declare function getPartyById(partyId: string): Promise<PartyInfo>;
|
|
70
|
+
export declare function getPartyByPubKey(pubKey: string): Promise<PartyInfo>;
|
|
71
|
+
export declare function getTransactions(partyId: string): Promise<{
|
|
72
|
+
next: number;
|
|
73
|
+
transactions: TxInfo[];
|
|
74
|
+
}>;
|
|
75
|
+
export declare function getLedgerEnd(): Promise<number>;
|
|
76
|
+
export {};
|
|
77
|
+
//# sourceMappingURL=gateway.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gateway.d.ts","sourceRoot":"","sources":["../../src/network/gateway.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gateway.integ.test.d.ts","sourceRoot":"","sources":["../../src/network/gateway.integ.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import coinConfig from "../config";
|
|
2
|
+
import { getLedgerEnd, prepareOnboarding, getBalance, getTransactions, getPartyById, getPartyByPubKey, } from "./gateway";
|
|
3
|
+
describe("gateway (devnet)", () => {
|
|
4
|
+
beforeAll(() => {
|
|
5
|
+
coinConfig.setCoinConfig(() => ({
|
|
6
|
+
gatewayUrl: "https://canton-gateway.api.live.ledger-test.com",
|
|
7
|
+
useGateway: true,
|
|
8
|
+
networkType: "devnet",
|
|
9
|
+
status: {
|
|
10
|
+
type: "active",
|
|
11
|
+
},
|
|
12
|
+
}));
|
|
13
|
+
});
|
|
14
|
+
describe("prepareOnboarding", () => {
|
|
15
|
+
it("should prepare onboarding", async () => {
|
|
16
|
+
const response = await prepareOnboarding("c59f7f29374d24506dd6490a5db472cf00958e195e146f3dc9c97f96d5c51097", "ed25519");
|
|
17
|
+
expect(response).toHaveProperty("party_id");
|
|
18
|
+
expect(response).toHaveProperty("party_name");
|
|
19
|
+
expect(response).toHaveProperty("public_key_fingerprint");
|
|
20
|
+
expect(response).toHaveProperty("topology_transactions_hash");
|
|
21
|
+
}, 30000);
|
|
22
|
+
});
|
|
23
|
+
describe("getLedgerEnd", () => {
|
|
24
|
+
it("should return ledger end", async () => {
|
|
25
|
+
const end = await getLedgerEnd();
|
|
26
|
+
expect(end).toBeGreaterThanOrEqual(0);
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
describe("getBalance", () => {
|
|
30
|
+
it("should return user balance", async () => {
|
|
31
|
+
const balance = await getBalance("party-4f2e1485107adf5f::122027c6dbbbdbffe0fa3122ae05175f3b9328e879e9ce96b670354deb64a45683c1");
|
|
32
|
+
expect(balance.length).toBeGreaterThanOrEqual(1);
|
|
33
|
+
expect(balance[0].amount).toBeGreaterThanOrEqual(0);
|
|
34
|
+
expect(balance[0].instrumentId.includes("Splice")).toBe(true);
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
describe("getPartyById", () => {
|
|
38
|
+
it.skip("should return party info", async () => {
|
|
39
|
+
const party = await getPartyById("4f2e1485107adf5f");
|
|
40
|
+
expect(party).toBeDefined();
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
describe("getPartyByPubKey", () => {
|
|
44
|
+
it.skip("should return party info", async () => {
|
|
45
|
+
const party = await getPartyByPubKey("122027c6dbbbdbffe0fa3122ae05175f3b9328e879e9ce96b670354deb64a45683c1");
|
|
46
|
+
expect(party).toBeDefined();
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
describe("getTransactions", () => {
|
|
50
|
+
it("should return user transactions", async () => {
|
|
51
|
+
const { transactions } = await getTransactions("party-5f29bb32e9939939::12202becd8062a1d170209956cfd977fca76fcb4d2a892d08c77a7483f35a11d6440");
|
|
52
|
+
expect(transactions.length).toBeGreaterThanOrEqual(0);
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
//# sourceMappingURL=gateway.integ.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gateway.integ.test.js","sourceRoot":"","sources":["../../src/network/gateway.integ.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import network from "@ledgerhq/live-network";
|
|
2
|
+
import coinConfig from "../config";
|
|
3
|
+
const getGatewayUrl = () => coinConfig.getCoinConfig().gatewayUrl;
|
|
4
|
+
const getNodeId = () => coinConfig.getCoinConfig().nodeId || "ledger-live-devnet-prd";
|
|
5
|
+
export async function prepareOnboarding(pubKey, pubKeyType) {
|
|
6
|
+
const { data } = await network({
|
|
7
|
+
method: "POST",
|
|
8
|
+
url: `${getGatewayUrl()}/v1/node/${getNodeId()}/onboarding/prepare`,
|
|
9
|
+
data: {
|
|
10
|
+
public_key: pubKey,
|
|
11
|
+
public_key_type: pubKeyType,
|
|
12
|
+
},
|
|
13
|
+
});
|
|
14
|
+
return data;
|
|
15
|
+
}
|
|
16
|
+
export async function submitOnboarding(prepareRequest, prepareResponse, signature) {
|
|
17
|
+
const { data } = await network({
|
|
18
|
+
method: "POST",
|
|
19
|
+
url: `${getGatewayUrl()}/v1/node/${getNodeId()}/onboarding/submit`,
|
|
20
|
+
data: {
|
|
21
|
+
prepare_request: prepareRequest,
|
|
22
|
+
prepare_response: prepareResponse,
|
|
23
|
+
signature,
|
|
24
|
+
},
|
|
25
|
+
});
|
|
26
|
+
return data;
|
|
27
|
+
}
|
|
28
|
+
export async function getBalance(partyId) {
|
|
29
|
+
const { data } = await network({
|
|
30
|
+
method: "GET",
|
|
31
|
+
url: `${getGatewayUrl()}/v1/node/${getNodeId()}/party/${partyId}/balance`,
|
|
32
|
+
});
|
|
33
|
+
return data;
|
|
34
|
+
}
|
|
35
|
+
export async function getPartyById(partyId) {
|
|
36
|
+
return await getParty(partyId, "ID");
|
|
37
|
+
}
|
|
38
|
+
export async function getPartyByPubKey(pubKey) {
|
|
39
|
+
return await getParty(pubKey, "PK");
|
|
40
|
+
}
|
|
41
|
+
async function getParty(identifier, by) {
|
|
42
|
+
const { data } = await network({
|
|
43
|
+
method: "GET",
|
|
44
|
+
url: `${getGatewayUrl()}/v1/node/${getNodeId()}/party/${identifier}`,
|
|
45
|
+
data: {
|
|
46
|
+
by,
|
|
47
|
+
},
|
|
48
|
+
});
|
|
49
|
+
return data;
|
|
50
|
+
}
|
|
51
|
+
export async function getTransactions(partyId) {
|
|
52
|
+
const { data } = await network({
|
|
53
|
+
method: "GET",
|
|
54
|
+
url: `${getGatewayUrl()}/v1/node/${getNodeId()}/party/${partyId}/transactions`,
|
|
55
|
+
});
|
|
56
|
+
return data;
|
|
57
|
+
}
|
|
58
|
+
export async function getLedgerEnd() {
|
|
59
|
+
const { data } = await network({
|
|
60
|
+
method: "GET",
|
|
61
|
+
url: `${getGatewayUrl()}/v1/node/${getNodeId()}/ledger-end`,
|
|
62
|
+
});
|
|
63
|
+
return data;
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=gateway.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gateway.js","sourceRoot":"","sources":["../../src/network/gateway.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,wBAAwB,CAAC;AAC7C,OAAO,UAAU,MAAM,WAAW,CAAC;AAoFnC,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,UAAU,CAAC;AAClE,MAAM,SAAS,GAAG,GAAG,EAAE,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,MAAM,IAAI,wBAAwB,CAAC;AAEtF,MAAM,CAAC,KAAK,UAAU,iBAAiB,CACrC,MAAc,EACd,UAAkB;IAElB,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,OAAO,CAA4B;QACxD,MAAM,EAAE,MAAM;QACd,GAAG,EAAE,GAAG,aAAa,EAAE,YAAY,SAAS,EAAE,qBAAqB;QACnE,IAAI,EAAE;YACJ,UAAU,EAAE,MAAM;YAClB,eAAe,EAAE,UAAU;SACO;KACrC,CAAC,CAAC;IACH,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,cAAwC,EACxC,eAA0C,EAC1C,SAAiB;IAEjB,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,OAAO,CAA2B;QACvD,MAAM,EAAE,MAAM;QACd,GAAG,EAAE,GAAG,aAAa,EAAE,YAAY,SAAS,EAAE,oBAAoB;QAClE,IAAI,EAAE;YACJ,eAAe,EAAE,cAAc;YAC/B,gBAAgB,EAAE,eAAe;YACjC,SAAS;SACwB;KACpC,CAAC,CAAC;IACH,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,OAAe;IAC9C,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,OAAO,CAAsB;QAClD,MAAM,EAAE,KAAK;QACb,GAAG,EAAE,GAAG,aAAa,EAAE,YAAY,SAAS,EAAE,UAAU,OAAO,UAAU;KAC1E,CAAC,CAAC;IACH,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,OAAe;IAChD,OAAO,MAAM,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;AACvC,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,MAAc;IACnD,OAAO,MAAM,QAAQ,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;AACtC,CAAC;AAED,KAAK,UAAU,QAAQ,CAAC,UAAkB,EAAE,EAAe;IACzD,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,OAAO,CAAY;QACxC,MAAM,EAAE,KAAK;QACb,GAAG,EAAE,GAAG,aAAa,EAAE,YAAY,SAAS,EAAE,UAAU,UAAU,EAAE;QACpE,IAAI,EAAE;YACJ,EAAE;SACH;KACF,CAAC,CAAC;IACH,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,OAAe;IAInD,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,OAAO,CAG3B;QACD,MAAM,EAAE,KAAK;QACb,GAAG,EAAE,GAAG,aAAa,EAAE,YAAY,SAAS,EAAE,UAAU,OAAO,eAAe;KAC/E,CAAC,CAAC;IACH,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,YAAY;IAChC,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,OAAO,CAAS;QACrC,MAAM,EAAE,KAAK;QACb,GAAG,EAAE,GAAG,aAAa,EAAE,YAAY,SAAS,EAAE,aAAa;KAC5D,CAAC,CAAC;IACH,OAAO,IAAI,CAAC;AACd,CAAC"}
|
package/lib-es/network/node.d.ts
CHANGED
|
@@ -1,12 +1,8 @@
|
|
|
1
1
|
import { AccountInfoResponse, SubmitReponse } from "./types";
|
|
2
|
+
export declare const generateJWT: () => string;
|
|
2
3
|
export declare const simulate: (serializedTx: string) => Promise<number>;
|
|
3
4
|
export declare const getNextSequence: (address: string) => Promise<number>;
|
|
4
|
-
export declare const
|
|
5
|
-
export declare const getLastBlock: () => Promise<{
|
|
6
|
-
blockHeight: number;
|
|
7
|
-
blockHash: string;
|
|
8
|
-
timestamp: number;
|
|
9
|
-
}>;
|
|
5
|
+
export declare const getLedgerEnd: () => Promise<number>;
|
|
10
6
|
export declare const submit: (signedTx: string) => Promise<SubmitReponse>;
|
|
11
7
|
export declare const getAccountInfo: (address: string) => Promise<AccountInfoResponse>;
|
|
12
8
|
//# sourceMappingURL=node.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"node.d.ts","sourceRoot":"","sources":["../../src/network/node.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"node.d.ts","sourceRoot":"","sources":["../../src/network/node.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAO7D,eAAO,MAAM,WAAW,cAoBvB,CAAC;AAeF,eAAO,MAAM,QAAQ,GAAU,cAAc,MAAM,KAAG,OAAO,CAAC,MAAM,CAcnE,CAAC;AAGF,eAAO,MAAM,eAAe,GAAU,SAAS,MAAM,KAAG,OAAO,CAAC,MAAM,CAYrE,CAAC;AAEF,eAAO,MAAM,YAAY,QAAa,OAAO,CAAC,MAAM,CAQnD,CAAC;AAEF,eAAO,MAAM,MAAM,GAAU,UAAU,MAAM,KAAG,OAAO,CAAC,aAAa,CAQpE,CAAC;AAEF,eAAO,MAAM,cAAc,GAAU,SAAS,MAAM,KAAG,OAAO,CAAC,mBAAmB,CAiBjF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.integ.test.d.ts","sourceRoot":"","sources":["../../src/network/node.integ.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import coinConfig from "../config";
|
|
2
|
+
import { getLedgerEnd } from "./node";
|
|
3
|
+
// enable manually, as it requires a running node locally
|
|
4
|
+
describe.skip("Node (localnet)", () => {
|
|
5
|
+
beforeAll(() => {
|
|
6
|
+
coinConfig.setCoinConfig(() => ({
|
|
7
|
+
gatewayUrl: "http://gateway.url",
|
|
8
|
+
nodeUrl: "http://localhost:2975/v2",
|
|
9
|
+
networkType: "localnet",
|
|
10
|
+
status: { type: "active" },
|
|
11
|
+
}));
|
|
12
|
+
});
|
|
13
|
+
describe("getLedgerEnd", () => {
|
|
14
|
+
it("should return ledger end", async () => {
|
|
15
|
+
const end = await getLedgerEnd();
|
|
16
|
+
expect(end).toBeGreaterThan(0);
|
|
17
|
+
});
|
|
18
|
+
});
|
|
19
|
+
});
|
|
20
|
+
// enable manually, as it requires an auth token in env variable
|
|
21
|
+
describe.skip("Node (devnet)", () => {
|
|
22
|
+
beforeAll(() => {
|
|
23
|
+
coinConfig.setCoinConfig(() => ({
|
|
24
|
+
nodeUrl: "https://wallet-validator-devnet-canton.ledger-test.com/v2",
|
|
25
|
+
networkType: "devnet",
|
|
26
|
+
status: { type: "active" },
|
|
27
|
+
gatewayUrl: "http://gateway.url",
|
|
28
|
+
}));
|
|
29
|
+
});
|
|
30
|
+
describe("getLedgerEnd", () => {
|
|
31
|
+
it("should return ledger end", async () => {
|
|
32
|
+
const end = await getLedgerEnd();
|
|
33
|
+
expect(end).toBeGreaterThan(0);
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
//# sourceMappingURL=node.integ.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.integ.test.js","sourceRoot":"","sources":["../../src/network/node.integ.test.ts"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,yDAAyD;AACzD,QAAQ,CAAC,IAAI,CAAC,iBAAiB,EAAE,GAAG,EAAE;IACpC,SAAS,CAAC,GAAG,EAAE;QACb,UAAU,CAAC,aAAa,CAAC,GAAG,EAAE,CAAC,CAAC;YAC9B,UAAU,EAAE,oBAAoB;YAChC,OAAO,EAAE,0BAA0B;YACnC,WAAW,EAAE,UAAU;YACvB,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;SAC3B,CAAC,CAAC,CAAC;IACN,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;QAC5B,EAAE,CAAC,0BAA0B,EAAE,KAAK,IAAI,EAAE;YACxC,MAAM,GAAG,GAAG,MAAM,YAAY,EAAE,CAAC;YACjC,MAAM,CAAC,GAAG,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,gEAAgE;AAChE,QAAQ,CAAC,IAAI,CAAC,eAAe,EAAE,GAAG,EAAE;IAClC,SAAS,CAAC,GAAG,EAAE;QACb,UAAU,CAAC,aAAa,CAAC,GAAG,EAAE,CAAC,CAAC;YAC9B,OAAO,EAAE,2DAA2D;YACpE,WAAW,EAAE,QAAQ;YACrB,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;YAC1B,UAAU,EAAE,oBAAoB;SACjC,CAAC,CAAC,CAAC;IACN,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;QAC5B,EAAE,CAAC,0BAA0B,EAAE,KAAK,IAAI,EAAE;YACxC,MAAM,GAAG,GAAG,MAAM,YAAY,EAAE,CAAC;YACjC,MAAM,CAAC,GAAG,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
package/lib-es/network/node.js
CHANGED
|
@@ -1,9 +1,42 @@
|
|
|
1
1
|
import { SimulationError } from "../types/errors";
|
|
2
|
-
import network from "@ledgerhq/live-network
|
|
2
|
+
import network from "@ledgerhq/live-network";
|
|
3
3
|
import { getEnv } from "@ledgerhq/live-env";
|
|
4
4
|
import coinConfig from "../config";
|
|
5
|
-
|
|
6
|
-
|
|
5
|
+
import crypto from "crypto";
|
|
6
|
+
const getNodeUrl = () => coinConfig.getCoinConfig().nodeUrl || "";
|
|
7
|
+
const getNetworkType = () => coinConfig.getCoinConfig().networkType;
|
|
8
|
+
// JWT generation for localnet
|
|
9
|
+
export const generateJWT = () => {
|
|
10
|
+
const encode = (obj) => Buffer.from(JSON.stringify(obj))
|
|
11
|
+
.toString("base64")
|
|
12
|
+
.replace(/[+/=]/g, c => ({ "+": "-", "/": "_", "=": "" })[c] || "");
|
|
13
|
+
const header = encode({ alg: "HS256", typ: "JWT" });
|
|
14
|
+
const payload = encode({
|
|
15
|
+
sub: "ledger-api-user",
|
|
16
|
+
aud: "https://canton.network.global",
|
|
17
|
+
iss: "unsafe-issuer",
|
|
18
|
+
exp: Math.floor(Date.now() / 1000) + 3600,
|
|
19
|
+
iat: Math.floor(Date.now() / 1000),
|
|
20
|
+
});
|
|
21
|
+
const data = `${header}.${payload}`;
|
|
22
|
+
const signature = crypto
|
|
23
|
+
.createHmac("sha256", "unsafe")
|
|
24
|
+
.update(data)
|
|
25
|
+
.digest("base64")
|
|
26
|
+
.replace(/[+/=]/g, c => ({ "+": "-", "/": "_", "=": "" })[c] || "");
|
|
27
|
+
return `${data}.${signature}`;
|
|
28
|
+
};
|
|
29
|
+
const networkW = (req) => {
|
|
30
|
+
const envJwt = process.env[getNetworkType().toUpperCase() + "_JWT"];
|
|
31
|
+
const bearerJwt = envJwt !== undefined ? envJwt : generateJWT();
|
|
32
|
+
return network({
|
|
33
|
+
...req,
|
|
34
|
+
headers: {
|
|
35
|
+
...(req.headers || {}),
|
|
36
|
+
Authorization: `Bearer ${bearerJwt}`,
|
|
37
|
+
},
|
|
38
|
+
});
|
|
39
|
+
};
|
|
7
40
|
// txPayload needs to be unsigned
|
|
8
41
|
export const simulate = async (serializedTx) => {
|
|
9
42
|
// @ts-expect-error: add NODE_BOILERPLATE to libs/env/src/env.ts
|
|
@@ -35,23 +68,13 @@ export const getNextSequence = async (address) => {
|
|
|
35
68
|
return 0;
|
|
36
69
|
}
|
|
37
70
|
};
|
|
38
|
-
export const
|
|
39
|
-
|
|
40
|
-
const
|
|
41
|
-
const { data } = await network({
|
|
42
|
-
url,
|
|
43
|
-
method: "GET",
|
|
44
|
-
});
|
|
45
|
-
return data.blockHeight;
|
|
46
|
-
};
|
|
47
|
-
export const getLastBlock = async () => {
|
|
48
|
-
// @ts-expect-error: add NODE_BOILERPLATE to libs/env/src/env.ts
|
|
49
|
-
const url = `${getEnv("NODE_BOILERPLATE")}/block/current`;
|
|
50
|
-
const { data } = await network({
|
|
71
|
+
export const getLedgerEnd = async () => {
|
|
72
|
+
const url = `${getNodeUrl()}/state/ledger-end`;
|
|
73
|
+
const { data } = await networkW({
|
|
51
74
|
url,
|
|
52
75
|
method: "GET",
|
|
53
76
|
});
|
|
54
|
-
return data;
|
|
77
|
+
return data.offset;
|
|
55
78
|
};
|
|
56
79
|
export const submit = async (signedTx) => {
|
|
57
80
|
// @ts-expect-error: add NODE_BOILERPLATE to libs/env/src/env.ts
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"node.js","sourceRoot":"","sources":["../../src/network/node.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,OAAO,MAAM,
|
|
1
|
+
{"version":3,"file":"node.js","sourceRoot":"","sources":["../../src/network/node.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,OAAO,MAAM,wBAAwB,CAAC;AAE7C,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,OAAO,UAAU,MAAM,WAAW,CAAC;AAEnC,OAAO,MAAM,MAAM,QAAQ,CAAC;AAE5B,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,OAAO,IAAI,EAAE,CAAC;AAClE,MAAM,cAAc,GAAG,GAAG,EAAE,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,WAAW,CAAC;AAEpE,8BAA8B;AAC9B,MAAM,CAAC,MAAM,WAAW,GAAG,GAAG,EAAE;IAC9B,MAAM,MAAM,GAAG,CAAC,GAA4B,EAAE,EAAE,CAC9C,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;SAC7B,QAAQ,CAAC,QAAQ,CAAC;SAClB,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;IACxE,MAAM,MAAM,GAAG,MAAM,CAAC,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC;IACpD,MAAM,OAAO,GAAG,MAAM,CAAC;QACrB,GAAG,EAAE,iBAAiB;QACtB,GAAG,EAAE,+BAA+B;QACpC,GAAG,EAAE,eAAe;QACpB,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,IAAI;QACzC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC;KACnC,CAAC,CAAC;IACH,MAAM,IAAI,GAAG,GAAG,MAAM,IAAI,OAAO,EAAE,CAAC;IACpC,MAAM,SAAS,GAAG,MAAM;SACrB,UAAU,CAAC,QAAQ,EAAE,QAAQ,CAAC;SAC9B,MAAM,CAAC,IAAI,CAAC;SACZ,MAAM,CAAC,QAAQ,CAAC;SAChB,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;IACtE,OAAO,GAAG,IAAI,IAAI,SAAS,EAAE,CAAC;AAChC,CAAC,CAAC;AAEF,MAAM,QAAQ,GAAG,CAAI,GAA0B,EAAE,EAAE;IACjD,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,CAAC,WAAW,EAAE,GAAG,MAAM,CAAC,CAAC;IACpE,MAAM,SAAS,GAAG,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;IAChE,OAAO,OAAO,CAAI;QAChB,GAAG,GAAG;QACN,OAAO,EAAE;YACP,GAAG,CAAC,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC;YACtB,aAAa,EAAE,UAAU,SAAS,EAAE;SACrC;KACF,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,iCAAiC;AACjC,MAAM,CAAC,MAAM,QAAQ,GAAG,KAAK,EAAE,YAAoB,EAAmB,EAAE;IACtE,gEAAgE;IAChE,MAAM,GAAG,GAAG,GAAG,MAAM,CAAC,kBAAkB,CAAC,WAAW,CAAC;IACrD,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,OAAO,CAAkC;QAC9D,GAAG;QACH,MAAM,EAAE,MAAM;QACd,IAAI,EAAE;YACJ,SAAS,EAAE,YAAY;SACxB;KACF,CAAC,CAAC;IACH,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,MAAM,IAAI,eAAe,EAAE,CAAC;IAC9B,CAAC;IACD,OAAO,IAAI,CAAC,IAAI,CAAC;AACnB,CAAC,CAAC;AAEF,kCAAkC;AAClC,MAAM,CAAC,MAAM,eAAe,GAAG,KAAK,EAAE,OAAe,EAAmB,EAAE;IACxE,gEAAgE;IAChE,MAAM,GAAG,GAAG,GAAG,MAAM,CAAC,kBAAkB,CAAC,IAAI,OAAO,WAAW,CAAC;IAChE,IAAI,CAAC;QACH,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,OAAO,CAAuB;YACnD,GAAG;YACH,MAAM,EAAE,KAAK;SACd,CAAC,CAAC;QACH,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,CAAC,CAAC;IACX,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,KAAK,IAAqB,EAAE;IACtD,MAAM,GAAG,GAAG,GAAG,UAAU,EAAE,mBAAmB,CAAC;IAC/C,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,QAAQ,CAAqB;QAClD,GAAG;QACH,MAAM,EAAE,KAAK;KACd,CAAC,CAAC;IAEH,OAAO,IAAI,CAAC,MAAM,CAAC;AACrB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,EAAE,QAAgB,EAA0B,EAAE;IACvE,gEAAgE;IAChE,MAAM,GAAG,GAAG,GAAG,MAAM,CAAC,kBAAkB,CAAC,SAAS,CAAC;IACnD,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,OAAO,CAAgB;QAC5C,GAAG;QACH,MAAM,EAAE,KAAK;KACd,CAAC,CAAC;IACH,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG,KAAK,EAAE,OAAe,EAAgC,EAAE;IACpF,MAAM,EACJ,IAAI,EAAE,EAAE,MAAM,EAAE,GACjB,GAAG,MAAM,OAAO,CAAkC;QACjD,MAAM,EAAE,MAAM;QACd,GAAG,EAAE,UAAU,EAAE;QACjB,IAAI,EAAE;YACJ,MAAM,EAAE,cAAc;YACtB,MAAM,EAAE;gBACN;oBACE,OAAO,EAAE,OAAO;iBACjB;aACF;SACF;KACF,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.unit.test.d.ts","sourceRoot":"","sources":["../../src/network/node.unit.test.ts"],"names":[],"mappings":""}
|