@ledgerhq/coin-internet_computer 1.9.0-nightly.6 → 1.9.0-nightly.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.turbo/turbo-build.log +1 -1
- package/CHANGELOG.md +20 -0
- package/lib/api/api.d.ts +6 -11
- package/lib/api/api.d.ts.map +1 -1
- package/lib/api/api.js +84 -64
- package/lib/api/api.js.map +1 -1
- package/lib/bridge/bridgeHelpers/account.d.ts.map +1 -1
- package/lib/bridge/bridgeHelpers/account.js +52 -33
- package/lib/bridge/bridgeHelpers/account.js.map +1 -1
- package/lib/bridge/bridgeHelpers/addresses.d.ts +0 -6
- package/lib/bridge/bridgeHelpers/addresses.d.ts.map +1 -1
- package/lib/bridge/bridgeHelpers/addresses.js +1 -29
- package/lib/bridge/bridgeHelpers/addresses.js.map +1 -1
- package/lib/bridge/broadcast.d.ts.map +1 -1
- package/lib/bridge/broadcast.js +22 -6
- package/lib/bridge/broadcast.js.map +1 -1
- package/lib/bridge/getTransactionStatus.d.ts.map +1 -1
- package/lib/bridge/getTransactionStatus.js +4 -3
- package/lib/bridge/getTransactionStatus.js.map +1 -1
- package/lib/bridge/prepareTransaction.d.ts.map +1 -1
- package/lib/bridge/prepareTransaction.js +2 -1
- package/lib/bridge/prepareTransaction.js.map +1 -1
- package/lib/bridge/signOperation.d.ts +2 -2
- package/lib/bridge/signOperation.d.ts.map +1 -1
- package/lib/bridge/signOperation.js +44 -13
- package/lib/bridge/signOperation.js.map +1 -1
- package/lib/consts.d.ts +2 -0
- package/lib/consts.d.ts.map +1 -1
- package/lib/consts.js +8 -1
- package/lib/consts.js.map +1 -1
- package/lib/hw-signMessage.d.ts.map +1 -1
- package/lib/hw-signMessage.js +1 -2
- package/lib/hw-signMessage.js.map +1 -1
- package/lib/types/signer.d.ts +1 -1
- package/lib/types/signer.d.ts.map +1 -1
- package/lib-es/api/api.d.ts +6 -11
- package/lib-es/api/api.d.ts.map +1 -1
- package/lib-es/api/api.js +81 -60
- package/lib-es/api/api.js.map +1 -1
- package/lib-es/bridge/bridgeHelpers/account.d.ts.map +1 -1
- package/lib-es/bridge/bridgeHelpers/account.js +52 -33
- package/lib-es/bridge/bridgeHelpers/account.js.map +1 -1
- package/lib-es/bridge/bridgeHelpers/addresses.d.ts +0 -6
- package/lib-es/bridge/bridgeHelpers/addresses.d.ts.map +1 -1
- package/lib-es/bridge/bridgeHelpers/addresses.js +0 -23
- package/lib-es/bridge/bridgeHelpers/addresses.js.map +1 -1
- package/lib-es/bridge/broadcast.d.ts.map +1 -1
- package/lib-es/bridge/broadcast.js +19 -6
- package/lib-es/bridge/broadcast.js.map +1 -1
- package/lib-es/bridge/getTransactionStatus.d.ts.map +1 -1
- package/lib-es/bridge/getTransactionStatus.js +2 -1
- package/lib-es/bridge/getTransactionStatus.js.map +1 -1
- package/lib-es/bridge/prepareTransaction.d.ts.map +1 -1
- package/lib-es/bridge/prepareTransaction.js +2 -1
- package/lib-es/bridge/prepareTransaction.js.map +1 -1
- package/lib-es/bridge/signOperation.d.ts +2 -2
- package/lib-es/bridge/signOperation.d.ts.map +1 -1
- package/lib-es/bridge/signOperation.js +41 -13
- package/lib-es/bridge/signOperation.js.map +1 -1
- package/lib-es/consts.d.ts +2 -0
- package/lib-es/consts.d.ts.map +1 -1
- package/lib-es/consts.js +3 -0
- package/lib-es/consts.js.map +1 -1
- package/lib-es/hw-signMessage.d.ts.map +1 -1
- package/lib-es/hw-signMessage.js +1 -2
- package/lib-es/hw-signMessage.js.map +1 -1
- package/lib-es/types/signer.d.ts +1 -1
- package/lib-es/types/signer.d.ts.map +1 -1
- package/package.json +5 -11
- package/src/api/api.ts +126 -71
- package/src/bridge/bridgeHelpers/account.ts +70 -43
- package/src/bridge/bridgeHelpers/addresses.ts +0 -25
- package/src/bridge/broadcast.ts +31 -6
- package/src/bridge/getTransactionStatus.ts +2 -1
- package/src/bridge/prepareTransaction.ts +2 -1
- package/src/bridge/signOperation.ts +68 -18
- package/src/consts.ts +10 -0
- package/src/hw-signMessage.ts +1 -6
- package/src/types/signer.ts +1 -1
- package/lib/bridge/bridgeHelpers/icpRosetta/index.d.ts +0 -30
- package/lib/bridge/bridgeHelpers/icpRosetta/index.d.ts.map +0 -1
- package/lib/bridge/bridgeHelpers/icpRosetta/index.js +0 -88
- package/lib/bridge/bridgeHelpers/icpRosetta/index.js.map +0 -1
- package/lib/bridge/bridgeHelpers/icpRosetta/types.d.ts +0 -145
- package/lib/bridge/bridgeHelpers/icpRosetta/types.d.ts.map +0 -1
- package/lib/bridge/bridgeHelpers/icpRosetta/types.js +0 -3
- package/lib/bridge/bridgeHelpers/icpRosetta/types.js.map +0 -1
- package/lib/bridge/bridgeHelpers/icpRosetta/utils.d.ts +0 -17
- package/lib/bridge/bridgeHelpers/icpRosetta/utils.d.ts.map +0 -1
- package/lib/bridge/bridgeHelpers/icpRosetta/utils.js +0 -155
- package/lib/bridge/bridgeHelpers/icpRosetta/utils.js.map +0 -1
- package/lib-es/bridge/bridgeHelpers/icpRosetta/index.d.ts +0 -30
- package/lib-es/bridge/bridgeHelpers/icpRosetta/index.d.ts.map +0 -1
- package/lib-es/bridge/bridgeHelpers/icpRosetta/index.js +0 -76
- package/lib-es/bridge/bridgeHelpers/icpRosetta/index.js.map +0 -1
- package/lib-es/bridge/bridgeHelpers/icpRosetta/types.d.ts +0 -145
- package/lib-es/bridge/bridgeHelpers/icpRosetta/types.d.ts.map +0 -1
- package/lib-es/bridge/bridgeHelpers/icpRosetta/types.js +0 -2
- package/lib-es/bridge/bridgeHelpers/icpRosetta/types.js.map +0 -1
- package/lib-es/bridge/bridgeHelpers/icpRosetta/utils.d.ts +0 -17
- package/lib-es/bridge/bridgeHelpers/icpRosetta/utils.d.ts.map +0 -1
- package/lib-es/bridge/bridgeHelpers/icpRosetta/utils.js +0 -123
- package/lib-es/bridge/bridgeHelpers/icpRosetta/utils.js.map +0 -1
- package/src/bridge/bridgeHelpers/icpRosetta/index.ts +0 -154
- package/src/bridge/bridgeHelpers/icpRosetta/types.ts +0 -166
- package/src/bridge/bridgeHelpers/icpRosetta/utils.ts +0 -151
|
@@ -1,25 +1,2 @@
|
|
|
1
|
-
import { log } from "@ledgerhq/logs";
|
|
2
|
-
import BigNumber from "bignumber.js";
|
|
3
|
-
import { MAX_MEMO_VALUE } from "../../consts";
|
|
4
|
-
import { fetchBalances } from "../../api";
|
|
5
1
|
export const getAddress = (a) => ({ address: a.freshAddress, derivationPath: a.freshAddressPath });
|
|
6
|
-
export async function validateAddress(address) {
|
|
7
|
-
try {
|
|
8
|
-
const res = await fetchBalances(address);
|
|
9
|
-
if (!res.balances)
|
|
10
|
-
throw Error(res.details?.error_message);
|
|
11
|
-
return { isValid: true };
|
|
12
|
-
}
|
|
13
|
-
catch (e) {
|
|
14
|
-
log("error", e.message ?? "Failed to validate address");
|
|
15
|
-
return { isValid: false };
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
export function validateMemo(memo) {
|
|
19
|
-
const res = BigNumber(memo ?? 0);
|
|
20
|
-
if (res.isNaN() || res.lt(0) || res.gt(BigNumber(MAX_MEMO_VALUE))) {
|
|
21
|
-
return { isValid: false };
|
|
22
|
-
}
|
|
23
|
-
return { isValid: true };
|
|
24
|
-
}
|
|
25
2
|
//# sourceMappingURL=addresses.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"addresses.js","sourceRoot":"","sources":["../../../src/bridge/bridgeHelpers/addresses.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"addresses.js","sourceRoot":"","sources":["../../../src/bridge/bridgeHelpers/addresses.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,UAAU,GAAG,CACxB,CAAU,EAIV,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,YAAY,EAAE,cAAc,EAAE,CAAC,CAAC,gBAAgB,EAAE,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAErD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAqBvC,eAAO,MAAM,SAAS,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,WAAW,CAgB7D,CAAC"}
|
|
@@ -1,8 +1,21 @@
|
|
|
1
|
-
import { broadcastTxn } from "
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
import { broadcastTxn } from "../api";
|
|
2
|
+
import { log } from "@ledgerhq/logs";
|
|
3
|
+
import invariant from "invariant";
|
|
4
|
+
import { MAINNET_LEDGER_CANISTER_ID } from "../consts";
|
|
5
|
+
// Type guard to validate rawData shape
|
|
6
|
+
function isBroadcastRawData(data) {
|
|
7
|
+
return (typeof data === "object" &&
|
|
8
|
+
data !== null &&
|
|
9
|
+
"encodedSignedCallBlob" in data &&
|
|
10
|
+
typeof data.encodedSignedCallBlob === "string");
|
|
11
|
+
}
|
|
12
|
+
// Main broadcast function for handling Internet Computer transactions
|
|
13
|
+
export const broadcast = async ({ signedOperation: { operation, rawData }, }) => {
|
|
14
|
+
log("debug", "[broadcast] Internet Computer transaction broadcast initiated");
|
|
15
|
+
// Validate rawData with type guard
|
|
16
|
+
invariant(isBroadcastRawData(rawData), "[ICP](broadcast) Invalid rawData format");
|
|
17
|
+
invariant(operation.extra, "[ICP](broadcast) Missing operation extra");
|
|
18
|
+
await broadcastTxn(Buffer.from(rawData.encodedSignedCallBlob, "hex"), MAINNET_LEDGER_CANISTER_ID, "call");
|
|
19
|
+
return operation;
|
|
7
20
|
};
|
|
8
21
|
//# sourceMappingURL=broadcast.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/bridge/broadcast.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,SAAS,MAAM,WAAW,CAAC;AAClC,OAAO,EAAE,0BAA0B,EAAE,MAAM,WAAW,CAAC;AAOvD,uCAAuC;AACvC,SAAS,kBAAkB,CAAC,IAAa;IACvC,OAAO,CACL,OAAO,IAAI,KAAK,QAAQ;QACxB,IAAI,KAAK,IAAI;QACb,uBAAuB,IAAI,IAAI;QAC/B,OAAQ,IAAY,CAAC,qBAAqB,KAAK,QAAQ,CACxD,CAAC;AACJ,CAAC;AAED,sEAAsE;AACtE,MAAM,CAAC,MAAM,SAAS,GAA4C,KAAK,EAAE,EACvE,eAAe,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,GACxC,EAAE,EAAE;IACH,GAAG,CAAC,OAAO,EAAE,+DAA+D,CAAC,CAAC;IAE9E,mCAAmC;IACnC,SAAS,CAAC,kBAAkB,CAAC,OAAO,CAAC,EAAE,yCAAyC,CAAC,CAAC;IAClF,SAAS,CAAC,SAAS,CAAC,KAAK,EAAE,0CAA0C,CAAC,CAAC;IAEvE,MAAM,YAAY,CAChB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE,KAAK,CAAC,EACjD,0BAA0B,EAC1B,MAAM,CACP,CAAC;IAEF,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getTransactionStatus.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.d.ts","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAGrD,OAAO,EAAE,WAAW,EAAqB,MAAM,UAAU,CAAC;AAG1D,eAAO,MAAM,oBAAoB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,sBAAsB,CA6DnF,CAAC"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { AmountRequired, InvalidAddress, InvalidAddressBecauseDestinationIsAlsoSource, NotEnoughBalance, RecipientRequired, } from "@ledgerhq/errors";
|
|
2
|
-
import { getAddress
|
|
2
|
+
import { getAddress } from "./bridgeHelpers/addresses";
|
|
3
|
+
import { validateAddress, validateMemo } from "@zondax/ledger-live-icp/utils";
|
|
3
4
|
import { InvalidMemoICP } from "../errors";
|
|
4
5
|
export const getTransactionStatus = async (account, transaction) => {
|
|
5
6
|
const errors = {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getTransactionStatus.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EACd,cAAc,EACd,4CAA4C,EAC5C,gBAAgB,EAChB,iBAAiB,GAClB,MAAM,kBAAkB,CAAC;AAG1B,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"getTransactionStatus.js","sourceRoot":"","sources":["../../src/bridge/getTransactionStatus.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prepareTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"prepareTransaction.d.ts","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAIvC,eAAO,MAAM,kBAAkB,EAAE,aAAa,CAAC,WAAW,CAAC,CAAC,oBAAoB,CAuB/E,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import { getAddress
|
|
1
|
+
import { getAddress } from "./bridgeHelpers/addresses";
|
|
2
|
+
import { validateAddress } from "@zondax/ledger-live-icp";
|
|
2
3
|
export const prepareTransaction = async (account, transaction) => {
|
|
3
4
|
// log("debug", "[prepareTransaction] start fn");
|
|
4
5
|
const { address } = getAddress(account);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prepareTransaction.js","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"prepareTransaction.js","sourceRoot":"","sources":["../../src/bridge/prepareTransaction.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAE1D,MAAM,CAAC,MAAM,kBAAkB,GAAqD,KAAK,EACvF,OAAO,EACP,WAAW,EACX,EAAE;IACF,iDAAiD;IAEjD,MAAM,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC;IACxC,MAAM,EAAE,SAAS,EAAE,GAAG,WAAW,CAAC;IAElC,IAAI,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC;IAChC,IAAI,SAAS,IAAI,OAAO,EAAE,CAAC;QACzB,gEAAgE;QAEhE,IAAI,CAAC,MAAM,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,IAAI,CAAC,MAAM,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;YAC3F,IAAI,WAAW,CAAC,YAAY,EAAE,CAAC;gBAC7B,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;gBAC1D,OAAO,EAAE,GAAG,WAAW,EAAE,MAAM,EAAE,CAAC;YACpC,CAAC;QACH,CAAC;IACH,CAAC;IAED,kDAAkD;IAClD,OAAO,WAAW,CAAC;AACrB,CAAC,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { AccountBridge } from "@ledgerhq/types-live";
|
|
2
2
|
import { Transaction } from "../types";
|
|
3
3
|
import { SignerContext } from "@ledgerhq/coin-framework/signer";
|
|
4
4
|
import { ICPSigner } from "../types";
|
|
5
|
-
export declare const buildSignOperation: (signerContext: SignerContext<ICPSigner>) => AccountBridge<Transaction
|
|
5
|
+
export declare const buildSignOperation: (signerContext: SignerContext<ICPSigner>) => AccountBridge<Transaction>["signOperation"];
|
|
6
6
|
//# sourceMappingURL=signOperation.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"signOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"AACA,OAAO,
|
|
1
|
+
{"version":3,"file":"signOperation.d.ts","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"AACA,OAAO,EAAW,aAAa,EAAY,MAAM,sBAAsB,CAAC;AAUxE,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AA8BrC,eAAO,MAAM,kBAAkB,kBACb,cAAc,SAAS,CAAC,KAAG,cAAc,WAAW,CAAC,CAAC,eAAe,CAgEjF,CAAC"}
|
|
@@ -1,35 +1,63 @@
|
|
|
1
1
|
import { Observable } from "rxjs";
|
|
2
2
|
import { getAddress } from "./bridgeHelpers/addresses";
|
|
3
|
-
import {
|
|
3
|
+
import { createUnsignedSendTransaction, hashTransaction, pubkeyToDer, } from "@zondax/ledger-live-icp/utils";
|
|
4
|
+
import { Cbor } from "@zondax/ledger-live-icp/agent";
|
|
4
5
|
import { buildOptimisticOperation } from "./buildOptimisticOperation";
|
|
5
6
|
import { getPath } from "../common-logic";
|
|
7
|
+
import { log } from "@ledgerhq/logs";
|
|
8
|
+
import invariant from "invariant";
|
|
9
|
+
const signICPTransaction = async (unsignedTxn, derivationPath, signerContext, account, deviceId) => {
|
|
10
|
+
const blob = Cbor.encode({ content: unsignedTxn });
|
|
11
|
+
log("debug", "[signICPTransaction] blob", Buffer.from(blob).toString("hex"));
|
|
12
|
+
const signatures = await signerContext(deviceId, signer => signer.sign(derivationPath, Buffer.from(blob)));
|
|
13
|
+
invariant(signatures.signatureRS, "[ICP](signICPTransaction) Signature not found");
|
|
14
|
+
invariant(account.xpub, "[ICP](signICPTransaction) Account xpub is required");
|
|
15
|
+
return {
|
|
16
|
+
signature: Buffer.from(signatures.signatureRS).toString("hex"),
|
|
17
|
+
callBody: {
|
|
18
|
+
content: unsignedTxn,
|
|
19
|
+
sender_pubkey: pubkeyToDer(account.xpub),
|
|
20
|
+
sender_sig: signatures.signatureRS,
|
|
21
|
+
},
|
|
22
|
+
};
|
|
23
|
+
};
|
|
6
24
|
export const buildSignOperation = (signerContext) => ({ account, transaction, deviceId }) => new Observable(o => {
|
|
7
25
|
async function main() {
|
|
26
|
+
log("debug", "[signOperation] icp start fn");
|
|
27
|
+
log("debug", "[signOperation] transaction", transaction);
|
|
8
28
|
const { xpub } = account;
|
|
29
|
+
invariant(xpub, "[ICP](signOperation) Account xpub is required");
|
|
9
30
|
const { derivationPath } = getAddress(account);
|
|
10
|
-
const {
|
|
31
|
+
const { unsignedTransaction, transferRawRequest } = createUnsignedSendTransaction(transaction, xpub);
|
|
11
32
|
o.next({
|
|
12
33
|
type: "device-signature-requested",
|
|
13
34
|
});
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
pubkey: xpub ?? "",
|
|
21
|
-
});
|
|
35
|
+
let signature = "";
|
|
36
|
+
let encodedSignedCallBlob = "";
|
|
37
|
+
const res = await signICPTransaction(unsignedTransaction, getPath(derivationPath), signerContext, account, deviceId);
|
|
38
|
+
signature = res.signature;
|
|
39
|
+
encodedSignedCallBlob = Buffer.from(Cbor.encode(res.callBody)).toString("hex");
|
|
40
|
+
invariant(signature, "[ICP](signOperation) Signature not found");
|
|
22
41
|
o.next({
|
|
23
42
|
type: "device-signature-granted",
|
|
24
43
|
});
|
|
25
|
-
const
|
|
44
|
+
const hash = hashTransaction({
|
|
45
|
+
from: account.freshAddress,
|
|
46
|
+
to: transaction.recipient,
|
|
47
|
+
amount: transferRawRequest.amount.e8s,
|
|
48
|
+
fee: transferRawRequest.fee.e8s,
|
|
49
|
+
memo: transferRawRequest.memo,
|
|
50
|
+
created_at_time: transferRawRequest.created_at_time[0]["timestamp_nanos"],
|
|
51
|
+
});
|
|
26
52
|
const operation = await buildOptimisticOperation(account, transaction, hash);
|
|
27
53
|
o.next({
|
|
28
54
|
type: "signed",
|
|
29
55
|
signedOperation: {
|
|
30
56
|
operation,
|
|
31
|
-
signature
|
|
32
|
-
|
|
57
|
+
signature,
|
|
58
|
+
rawData: {
|
|
59
|
+
encodedSignedCallBlob,
|
|
60
|
+
},
|
|
33
61
|
},
|
|
34
62
|
});
|
|
35
63
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"signOperation.js","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAElC,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,
|
|
1
|
+
{"version":3,"file":"signOperation.js","sourceRoot":"","sources":["../../src/bridge/signOperation.ts"],"names":[],"mappings":"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"}
|
package/lib-es/consts.d.ts
CHANGED
|
@@ -3,4 +3,6 @@ export declare const ICP_BLK_NAME_ROSETTA = "Internet Computer";
|
|
|
3
3
|
export declare const ICP_NET_ID_ROSETTA = "00000000000000020101";
|
|
4
4
|
export declare const ICP_FEES = 10000;
|
|
5
5
|
export declare const MAX_MEMO_VALUE: number;
|
|
6
|
+
export declare const FETCH_TXNS_LIMIT = 100;
|
|
7
|
+
export { MAINNET_GOVERNANCE_CANISTER_ID, MAINNET_LEDGER_CANISTER_ID, MAINNET_INDEX_CANISTER_ID, ICP_NETWORK_URL, } from "@zondax/ledger-live-icp/neurons";
|
|
6
8
|
//# sourceMappingURL=consts.d.ts.map
|
package/lib-es/consts.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"consts.d.ts","sourceRoot":"","sources":["../src/consts.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,iBAAiB,IAAI,CAAC;AAGnC,eAAO,MAAM,oBAAoB,sBAAsB,CAAC;AACxD,eAAO,MAAM,kBAAkB,yBAAyB,CAAC;AAGzD,eAAO,MAAM,QAAQ,QAAM,CAAC;AAG5B,eAAO,MAAM,cAAc,QAA0B,CAAC"}
|
|
1
|
+
{"version":3,"file":"consts.d.ts","sourceRoot":"","sources":["../src/consts.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,iBAAiB,IAAI,CAAC;AAGnC,eAAO,MAAM,oBAAoB,sBAAsB,CAAC;AACxD,eAAO,MAAM,kBAAkB,yBAAyB,CAAC;AAGzD,eAAO,MAAM,QAAQ,QAAM,CAAC;AAG5B,eAAO,MAAM,cAAc,QAA0B,CAAC;AAGtD,eAAO,MAAM,gBAAgB,MAAM,CAAC;AAEpC,OAAO,EACL,8BAA8B,EAC9B,0BAA0B,EAC1B,yBAAyB,EACzB,eAAe,GAChB,MAAM,iCAAiC,CAAC"}
|
package/lib-es/consts.js
CHANGED
|
@@ -6,4 +6,7 @@ export const ICP_NET_ID_ROSETTA = "00000000000000020101";
|
|
|
6
6
|
export const ICP_FEES = 1e4;
|
|
7
7
|
// Max Memo value on ICP network
|
|
8
8
|
export const MAX_MEMO_VALUE = Number.MAX_SAFE_INTEGER;
|
|
9
|
+
// API limits
|
|
10
|
+
export const FETCH_TXNS_LIMIT = 100;
|
|
11
|
+
export { MAINNET_GOVERNANCE_CANISTER_ID, MAINNET_LEDGER_CANISTER_ID, MAINNET_INDEX_CANISTER_ID, ICP_NETWORK_URL, } from "@zondax/ledger-live-icp/neurons";
|
|
9
12
|
//# sourceMappingURL=consts.js.map
|
package/lib-es/consts.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"consts.js","sourceRoot":"","sources":["../src/consts.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAEnC,kBAAkB;AAClB,MAAM,CAAC,MAAM,oBAAoB,GAAG,mBAAmB,CAAC;AACxD,MAAM,CAAC,MAAM,kBAAkB,GAAG,sBAAsB,CAAC;AAEzD,eAAe;AACf,MAAM,CAAC,MAAM,QAAQ,GAAG,GAAG,CAAC;AAE5B,gCAAgC;AAChC,MAAM,CAAC,MAAM,cAAc,GAAG,MAAM,CAAC,gBAAgB,CAAC"}
|
|
1
|
+
{"version":3,"file":"consts.js","sourceRoot":"","sources":["../src/consts.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,CAAC;AAEnC,kBAAkB;AAClB,MAAM,CAAC,MAAM,oBAAoB,GAAG,mBAAmB,CAAC;AACxD,MAAM,CAAC,MAAM,kBAAkB,GAAG,sBAAsB,CAAC;AAEzD,eAAe;AACf,MAAM,CAAC,MAAM,QAAQ,GAAG,GAAG,CAAC;AAE5B,gCAAgC;AAChC,MAAM,CAAC,MAAM,cAAc,GAAG,MAAM,CAAC,gBAAgB,CAAC;AAEtD,aAAa;AACb,MAAM,CAAC,MAAM,gBAAgB,GAAG,GAAG,CAAC;AAEpC,OAAO,EACL,8BAA8B,EAC9B,0BAA0B,EAC1B,yBAAyB,EACzB,eAAe,GAChB,MAAM,iCAAiC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hw-signMessage.d.ts","sourceRoot":"","sources":["../src/hw-signMessage.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"hw-signMessage.d.ts","sourceRoot":"","sources":["../src/hw-signMessage.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAO3D,eAAO,MAAM,WAAW,kBACN,cAAc,SAAS,CAAC,gBACvB,MAAM,WAAW,OAAO,eAAe,UAAU;;;;;;;EAuBjE,CAAC"}
|
package/lib-es/hw-signMessage.js
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { log } from "@ledgerhq/logs";
|
|
2
2
|
import { getBufferFromString } from "./common-logic/utils";
|
|
3
|
-
import { ICP_SEND_TXN_TYPE } from "./consts";
|
|
4
3
|
function bufferToArrayBuffer(buffer) {
|
|
5
4
|
const sig = buffer.buffer.slice(buffer.byteOffset, buffer.byteOffset + buffer.byteLength);
|
|
6
5
|
return Buffer.from(sig);
|
|
@@ -12,7 +11,7 @@ export const signMessage = (signerContext) => async (deviceId, account, { messag
|
|
|
12
11
|
if (typeof message !== "string")
|
|
13
12
|
throw new Error("Message must be a string");
|
|
14
13
|
const { r } = await signerContext(deviceId, async (signer) => {
|
|
15
|
-
const r = await signer.sign(account.freshAddressPath, getBufferFromString(message)
|
|
14
|
+
const r = await signer.sign(account.freshAddressPath, getBufferFromString(message));
|
|
16
15
|
return { r };
|
|
17
16
|
});
|
|
18
17
|
if (!r.signatureRS) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hw-signMessage.js","sourceRoot":"","sources":["../src/hw-signMessage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"hw-signMessage.js","sourceRoot":"","sources":["../src/hw-signMessage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAK3D,SAAS,mBAAmB,CAAC,MAAc;IACzC,MAAM,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAC1F,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC1B,CAAC;AAED,MAAM,CAAC,MAAM,WAAW,GACtB,CAAC,aAAuC,EAAE,EAAE,CAC5C,KAAK,EAAE,QAAgB,EAAE,OAAgB,EAAE,EAAE,OAAO,EAAc,EAAE,EAAE;IACpE,GAAG,CAAC,OAAO,EAAE,2BAA2B,CAAC,CAAC;IAE1C,IAAI,CAAC,OAAO;QAAE,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IACzD,IAAI,OAAO,OAAO,KAAK,QAAQ;QAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;IAE7E,MAAM,EAAE,CAAC,EAAE,GAAG,MAAM,aAAa,CAAC,QAAQ,EAAE,KAAK,EAAC,MAAM,EAAC,EAAE;QACzD,MAAM,CAAC,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,OAAO,CAAC,CAAC,CAAC;QACpF,OAAO,EAAE,CAAC,EAAE,CAAC;IACf,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;QACnB,MAAM,KAAK,CAAC,gBAAgB,CAAC,CAAC;IAChC,CAAC;IAED,OAAO;QACL,GAAG,EAAE;YACH,CAAC,EAAE,EAAE;YACL,CAAC,EAAE,EAAE;YACL,CAAC,EAAE,CAAC;SACL;QACD,SAAS,EAAE,mBAAmB,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;KAC9D,CAAC;AACJ,CAAC,CAAC"}
|
package/lib-es/types/signer.d.ts
CHANGED
|
@@ -16,6 +16,6 @@ export type ICPGetAddrResponse = {
|
|
|
16
16
|
export interface ICPSigner {
|
|
17
17
|
showAddressAndPubKey(path: string): Promise<ICPGetAddrResponse>;
|
|
18
18
|
getAddressAndPubKey(path: string): Promise<ICPGetAddrResponse>;
|
|
19
|
-
sign(path: string, message: Buffer
|
|
19
|
+
sign(path: string, message: Buffer): Promise<ICPSignature>;
|
|
20
20
|
}
|
|
21
21
|
//# sourceMappingURL=signer.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../../src/types/signer.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,YAAY,GAAG;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,MAAM,WAAW,SAAS;IACxB,oBAAoB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAChE,mBAAmB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAC/D,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../../src/types/signer.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,YAAY,GAAG;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,MAAM,WAAW,SAAS;IACxB,oBAAoB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAChE,mBAAmB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAC/D,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;CAC5D"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ledgerhq/coin-internet_computer",
|
|
3
|
-
"version": "1.9.0-nightly.
|
|
3
|
+
"version": "1.9.0-nightly.8",
|
|
4
4
|
"description": "Ledger Internet Computer integration",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"Ledger",
|
|
@@ -84,24 +84,18 @@
|
|
|
84
84
|
},
|
|
85
85
|
"license": "Apache-2.0",
|
|
86
86
|
"dependencies": {
|
|
87
|
-
"@
|
|
88
|
-
"@dfinity/candid": "^0.21.0",
|
|
89
|
-
"@dfinity/principal": "^0.15.6",
|
|
90
|
-
"big-integer": "^1.6.51",
|
|
87
|
+
"@zondax/ledger-live-icp": "1.3.2",
|
|
91
88
|
"bignumber.js": "^9.1.2",
|
|
92
89
|
"expect": "^27.4.6",
|
|
93
90
|
"invariant": "^2.2.2",
|
|
94
91
|
"lodash": "^4.17.21",
|
|
95
92
|
"rxjs": "^7.8.1",
|
|
96
|
-
"
|
|
97
|
-
"@ledgerhq/
|
|
98
|
-
"@ledgerhq/cryptoassets": "^13.31.0-nightly.6",
|
|
93
|
+
"@ledgerhq/coin-framework": "^6.7.0-nightly.8",
|
|
94
|
+
"@ledgerhq/cryptoassets": "^13.31.0-nightly.7",
|
|
99
95
|
"@ledgerhq/devices": "8.6.2-nightly.0",
|
|
100
96
|
"@ledgerhq/errors": "^6.27.0-nightly.0",
|
|
101
|
-
"@ledgerhq/live-env": "^2.19.0-nightly.1",
|
|
102
|
-
"@ledgerhq/live-network": "^2.0.20-nightly.2",
|
|
103
97
|
"@ledgerhq/logs": "^6.13.0",
|
|
104
|
-
"@ledgerhq/types-live": "^6.87.0-nightly.
|
|
98
|
+
"@ledgerhq/types-live": "^6.87.0-nightly.5"
|
|
105
99
|
},
|
|
106
100
|
"devDependencies": {
|
|
107
101
|
"@types/invariant": "^2.2.2",
|
package/src/api/api.ts
CHANGED
|
@@ -1,92 +1,147 @@
|
|
|
1
1
|
import { log } from "@ledgerhq/logs";
|
|
2
|
-
import { AxiosRequestConfig, AxiosResponse } from "axios";
|
|
3
|
-
import { getEnv } from "@ledgerhq/live-env";
|
|
4
|
-
import network from "@ledgerhq/live-network/network";
|
|
5
|
-
import { ICP_BLK_NAME_ROSETTA, ICP_NET_ID_ROSETTA } from "../consts";
|
|
6
2
|
import {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
3
|
+
FETCH_TXNS_LIMIT,
|
|
4
|
+
MAINNET_INDEX_CANISTER_ID,
|
|
5
|
+
MAINNET_LEDGER_CANISTER_ID,
|
|
6
|
+
ICP_NETWORK_URL,
|
|
7
|
+
} from "../consts";
|
|
11
8
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
9
|
+
import {
|
|
10
|
+
ledgerIdlFactory,
|
|
11
|
+
indexIdlFactory,
|
|
12
|
+
getCanisterIdlFunc,
|
|
13
|
+
Principal,
|
|
14
|
+
encodeCanisterIdlFunc,
|
|
15
|
+
decodeCanisterIdlFunc,
|
|
16
|
+
GetAccountIdentifierTransactionsResponse,
|
|
17
|
+
TransactionWithId,
|
|
18
|
+
} from "@zondax/ledger-live-icp";
|
|
19
|
+
import BigNumber from "bignumber.js";
|
|
20
|
+
import { fromNullable } from "@zondax/ledger-live-icp/utils";
|
|
21
|
+
import { getAgent } from "@zondax/ledger-live-icp/agent";
|
|
22
|
+
import invariant from "invariant";
|
|
21
23
|
|
|
22
|
-
|
|
23
|
-
const
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
24
|
+
export const fetchBlockHeight = async (): Promise<BigNumber> => {
|
|
25
|
+
const canisterId = Principal.fromText(MAINNET_LEDGER_CANISTER_ID);
|
|
26
|
+
const queryBlocksRawRequest = {
|
|
27
|
+
start: BigInt(0),
|
|
28
|
+
length: BigInt(1),
|
|
27
29
|
};
|
|
28
|
-
const rawResponse = await network(opts);
|
|
29
|
-
if (rawResponse && rawResponse.data && rawResponse.data.details?.error_message) {
|
|
30
|
-
log("error", rawResponse.data.details?.error_message);
|
|
31
|
-
}
|
|
32
30
|
|
|
33
|
-
|
|
34
|
-
const
|
|
31
|
+
const queryBlocksIdlFunc = getCanisterIdlFunc(ledgerIdlFactory, "query_blocks");
|
|
32
|
+
const queryBlocksargs = encodeCanisterIdlFunc(queryBlocksIdlFunc, [queryBlocksRawRequest]);
|
|
35
33
|
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
34
|
+
const agent = await getAgent(ICP_NETWORK_URL);
|
|
35
|
+
const blockHeightRes = await agent.query(canisterId, {
|
|
36
|
+
arg: queryBlocksargs,
|
|
37
|
+
methodName: "query_blocks",
|
|
38
|
+
});
|
|
39
39
|
|
|
40
|
-
|
|
41
|
-
return {
|
|
42
|
-
network_identifier: {
|
|
43
|
-
blockchain: ICP_BLK_NAME_ROSETTA,
|
|
44
|
-
network: ICP_NET_ID_ROSETTA,
|
|
45
|
-
},
|
|
46
|
-
};
|
|
47
|
-
};
|
|
40
|
+
invariant(blockHeightRes.status === "replied", "[ICP](fetchBlockHeight) Query failed");
|
|
48
41
|
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
getICPRosettaNetworkIdentifier(),
|
|
42
|
+
const decodedIdl = decodeCanisterIdlFunc<[{ chain_length: bigint }]>(
|
|
43
|
+
queryBlocksIdlFunc,
|
|
44
|
+
blockHeightRes.reply.arg,
|
|
53
45
|
);
|
|
54
|
-
|
|
46
|
+
const decoded = fromNullable(decodedIdl);
|
|
47
|
+
invariant(decoded, "[ICP](fetchBlockHeight) Decoding failed");
|
|
48
|
+
|
|
49
|
+
return BigNumber(decoded.chain_length.toString());
|
|
55
50
|
};
|
|
56
51
|
|
|
57
|
-
export const
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
52
|
+
export const broadcastTxn = async (
|
|
53
|
+
payload: Buffer,
|
|
54
|
+
canisterId: string,
|
|
55
|
+
type: "call" | "read_state",
|
|
56
|
+
) => {
|
|
57
|
+
log("debug", `[ICP] Broadcasting ${type} to ${canisterId}, body: ${payload.toString("hex")}`);
|
|
58
|
+
const res = await fetch(`${ICP_NETWORK_URL}/api/v3/canister/${canisterId}/${type}`, {
|
|
59
|
+
body: payload,
|
|
60
|
+
method: "POST",
|
|
61
|
+
headers: {
|
|
62
|
+
"Content-Type": "application/cbor",
|
|
63
63
|
},
|
|
64
|
-
};
|
|
65
|
-
|
|
66
|
-
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
if (res.status === 200) {
|
|
67
|
+
return await res.arrayBuffer();
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
throw new Error(`Failed to broadcast transaction: ${res.text()}`);
|
|
67
71
|
};
|
|
68
72
|
|
|
69
|
-
export const
|
|
70
|
-
const
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
73
|
+
export const fetchBalance = async (address: string): Promise<BigNumber> => {
|
|
74
|
+
const agent = await getAgent(ICP_NETWORK_URL);
|
|
75
|
+
const indexCanister = Principal.fromText(MAINNET_INDEX_CANISTER_ID);
|
|
76
|
+
const getBalanceIdlFunc = getCanisterIdlFunc(indexIdlFactory, "get_account_identifier_balance");
|
|
77
|
+
const getBalanceArgs = encodeCanisterIdlFunc(getBalanceIdlFunc, [address]);
|
|
78
|
+
|
|
79
|
+
const balanceRes = await agent.query(indexCanister, {
|
|
80
|
+
arg: getBalanceArgs,
|
|
81
|
+
methodName: "get_account_identifier_balance",
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
if (balanceRes.status !== "replied") {
|
|
85
|
+
log("debug", `[ICP](fetchBalance) Query failed: ${balanceRes.status}`);
|
|
86
|
+
return BigNumber(0);
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
const decodedBalance = decodeCanisterIdlFunc<[bigint]>(getBalanceIdlFunc, balanceRes.reply.arg);
|
|
90
|
+
const balance: bigint | undefined = fromNullable(decodedBalance);
|
|
91
|
+
if (!balance) {
|
|
92
|
+
return BigNumber(0);
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
return BigNumber(balance.toString());
|
|
79
96
|
};
|
|
80
97
|
|
|
81
|
-
export const
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
98
|
+
export const fetchTxns = async (
|
|
99
|
+
address: string,
|
|
100
|
+
startBlockHeight: bigint,
|
|
101
|
+
stopBlockHeight = BigInt(0),
|
|
102
|
+
): Promise<TransactionWithId[]> => {
|
|
103
|
+
if (startBlockHeight <= stopBlockHeight) {
|
|
104
|
+
return [];
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
const agent = await getAgent(ICP_NETWORK_URL);
|
|
108
|
+
const canisterId = Principal.fromText(MAINNET_INDEX_CANISTER_ID);
|
|
109
|
+
const transactionsRawRequest = {
|
|
110
|
+
account_identifier: address,
|
|
111
|
+
start: [startBlockHeight],
|
|
112
|
+
max_results: BigInt(FETCH_TXNS_LIMIT),
|
|
87
113
|
};
|
|
88
114
|
|
|
89
|
-
const
|
|
115
|
+
const getTransactionsIdlFunc = getCanisterIdlFunc(
|
|
116
|
+
indexIdlFactory,
|
|
117
|
+
"get_account_identifier_transactions",
|
|
118
|
+
);
|
|
119
|
+
const getTransactionsArgs = encodeCanisterIdlFunc(getTransactionsIdlFunc, [
|
|
120
|
+
transactionsRawRequest,
|
|
121
|
+
]);
|
|
122
|
+
|
|
123
|
+
const transactionsRes = await agent.query(canisterId, {
|
|
124
|
+
arg: getTransactionsArgs,
|
|
125
|
+
methodName: "get_account_identifier_transactions",
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
invariant(transactionsRes.status === "replied", "[ICP](fetchTxns) Query failed");
|
|
129
|
+
const decodedTransactions = decodeCanisterIdlFunc<
|
|
130
|
+
[{ Ok: GetAccountIdentifierTransactionsResponse }]
|
|
131
|
+
>(getTransactionsIdlFunc, transactionsRes.reply.arg);
|
|
132
|
+
|
|
133
|
+
const response = fromNullable(decodedTransactions);
|
|
134
|
+
invariant(response, "[ICP](fetchTxns) Decoding failed");
|
|
135
|
+
|
|
136
|
+
if (response.Ok.transactions.length === 0) {
|
|
137
|
+
return [];
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
const nextTxns = await fetchTxns(
|
|
141
|
+
address,
|
|
142
|
+
response.Ok.transactions.at(-1)?.id ?? BigInt(0),
|
|
143
|
+
stopBlockHeight,
|
|
144
|
+
);
|
|
90
145
|
|
|
91
|
-
return
|
|
146
|
+
return [...response.Ok.transactions, ...nextTxns];
|
|
92
147
|
};
|