@bitgo-beta/sdk-coin-icp 1.0.1-beta.80 → 1.0.1-beta.801

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.
Files changed (68) hide show
  1. package/dist/resources/messageCompiled.d.ts +797 -0
  2. package/dist/resources/messageCompiled.js +1859 -0
  3. package/dist/src/icp.d.ts +55 -2
  4. package/dist/src/icp.d.ts.map +1 -1
  5. package/dist/src/icp.js +300 -9
  6. package/dist/src/lib/icpAgent.d.ts +36 -0
  7. package/dist/src/lib/icpAgent.d.ts.map +1 -0
  8. package/dist/src/lib/icpAgent.js +90 -0
  9. package/dist/src/lib/iface.d.ts +191 -0
  10. package/dist/src/lib/iface.d.ts.map +1 -0
  11. package/dist/src/lib/iface.js +44 -0
  12. package/dist/src/lib/index.d.ts +4 -0
  13. package/dist/src/lib/index.d.ts.map +1 -1
  14. package/dist/src/lib/index.js +12 -2
  15. package/dist/src/lib/keyPair.js +4 -4
  16. package/dist/src/lib/signedTransactionBuilder.d.ts +9 -0
  17. package/dist/src/lib/signedTransactionBuilder.d.ts.map +1 -0
  18. package/dist/src/lib/signedTransactionBuilder.js +64 -0
  19. package/dist/src/lib/transaction.d.ts +54 -0
  20. package/dist/src/lib/transaction.d.ts.map +1 -0
  21. package/dist/src/lib/transaction.js +255 -0
  22. package/dist/src/lib/transactionBuilder.d.ts +58 -28
  23. package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
  24. package/dist/src/lib/transactionBuilder.js +127 -40
  25. package/dist/src/lib/transactionBuilderFactory.d.ts +15 -14
  26. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
  27. package/dist/src/lib/transactionBuilderFactory.js +43 -27
  28. package/dist/src/lib/transferBuilder.d.ts +7 -24
  29. package/dist/src/lib/transferBuilder.d.ts.map +1 -1
  30. package/dist/src/lib/transferBuilder.js +88 -43
  31. package/dist/src/lib/unsignedTransactionBuilder.d.ts +13 -0
  32. package/dist/src/lib/unsignedTransactionBuilder.d.ts.map +1 -0
  33. package/dist/src/lib/unsignedTransactionBuilder.js +90 -0
  34. package/dist/src/lib/utils.d.ts +285 -7
  35. package/dist/src/lib/utils.d.ts.map +1 -1
  36. package/dist/src/lib/utils.js +607 -52
  37. package/dist/src/ticp.d.ts +0 -4
  38. package/dist/src/ticp.d.ts.map +1 -1
  39. package/dist/src/ticp.js +1 -7
  40. package/dist/test/resources/icp.d.ts +268 -0
  41. package/dist/test/resources/icp.d.ts.map +1 -0
  42. package/dist/test/resources/icp.js +377 -0
  43. package/dist/test/unit/getBuilderFactory.d.ts +3 -0
  44. package/dist/test/unit/getBuilderFactory.d.ts.map +1 -0
  45. package/dist/test/unit/getBuilderFactory.js +10 -0
  46. package/dist/test/unit/icp.d.ts +2 -0
  47. package/dist/test/unit/icp.d.ts.map +1 -0
  48. package/dist/test/unit/icp.js +246 -0
  49. package/dist/test/unit/keyPair.d.ts +2 -0
  50. package/dist/test/unit/keyPair.d.ts.map +1 -0
  51. package/dist/test/unit/keyPair.js +107 -0
  52. package/dist/test/unit/transaction.d.ts +2 -0
  53. package/dist/test/unit/transaction.d.ts.map +1 -0
  54. package/dist/test/unit/transaction.js +109 -0
  55. package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts +2 -0
  56. package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts.map +1 -0
  57. package/dist/test/unit/transactionBuilder/transactionBuilder.js +274 -0
  58. package/dist/test/unit/transactionBuilder/transactionRecover.d.ts +2 -0
  59. package/dist/test/unit/transactionBuilder/transactionRecover.d.ts.map +1 -0
  60. package/dist/test/unit/transactionBuilder/transactionRecover.js +188 -0
  61. package/dist/test/unit/utils.d.ts +2 -0
  62. package/dist/test/unit/utils.d.ts.map +1 -0
  63. package/dist/test/unit/utils.js +206 -0
  64. package/dist/tsconfig.tsbuildinfo +1 -0
  65. package/package.json +23 -12
  66. package/.eslintignore +0 -4
  67. package/.mocharc.yml +0 -8
  68. package/CHANGELOG.md +0 -44
package/dist/src/icp.d.ts CHANGED
@@ -1,5 +1,8 @@
1
- import { BaseCoin, BitGoBase, MPCAlgorithm, VerifyTransactionOptions, TssVerifyAddressOptions, ParseTransactionOptions, ParsedTransaction, KeyPair, SignTransactionOptions, SignedTransaction } from '@bitgo-beta/sdk-core';
1
+ import { AuditDecryptedKeyParams, BaseBroadcastTransactionOptions, BaseBroadcastTransactionResult, BaseCoin, BitGoBase, KeyPair, MPCAlgorithm, MultisigType, ParsedTransaction, ParseTransactionOptions, SignedTransaction, SignTransactionOptions, TssVerifyAddressOptions, VerifyTransactionOptions } from '@bitgo-beta/sdk-core';
2
2
  import { BaseCoin as StaticsBaseCoin } from '@bitgo-beta/statics';
3
+ import BigNumber from 'bignumber.js';
4
+ import { Hash } from 'crypto';
5
+ import { PayloadsData, RecoveryOptions, RecoveryTransaction, Signatures, IcpTransactionExplanation, TransactionHexParams, UnsignedSweepRecoveryTransaction } from './lib/iface';
3
6
  /**
4
7
  * Class representing the Internet Computer (ICP) coin.
5
8
  * Extends the BaseCoin class and provides specific implementations for ICP.
@@ -16,6 +19,7 @@ export declare class Icp extends BaseCoin {
16
19
  getFamily(): string;
17
20
  getFullName(): string;
18
21
  getBaseFactor(): number;
22
+ explainTransaction(params: TransactionHexParams): Promise<IcpTransactionExplanation>;
19
23
  verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;
20
24
  isWalletAddress(params: TssVerifyAddressOptions): Promise<boolean>;
21
25
  parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction>;
@@ -25,15 +29,64 @@ export declare class Icp extends BaseCoin {
25
29
  */
26
30
  generateKeyPair(seed?: Buffer): KeyPair;
27
31
  isValidAddress(address: string): boolean;
28
- signTransaction(_: SignTransactionOptions): Promise<SignedTransaction>;
32
+ signTransaction(params: SignTransactionOptions & {
33
+ txPrebuild: {
34
+ txHex: string;
35
+ };
36
+ prv: string;
37
+ }): Promise<SignedTransaction>;
29
38
  isValidPub(key: string): boolean;
30
39
  isValidPrv(key: string): boolean;
31
40
  /** @inheritDoc */
32
41
  supportsTss(): boolean;
42
+ /** inherited doc */
43
+ getDefaultMultisigType(): MultisigType;
33
44
  /** @inheritDoc */
34
45
  getMPCAlgorithm(): MPCAlgorithm;
46
+ /** @inheritDoc **/
47
+ getHashFunction(): Hash;
35
48
  private getAddressFromPublicKey;
36
49
  /** @inheritDoc **/
37
50
  protected getPublicNodeUrl(): string;
51
+ /** @inheritDoc **/
52
+ broadcastTransaction(payload: BaseBroadcastTransactionOptions): Promise<BaseBroadcastTransactionResult>;
53
+ private getPublicNodeBroadcastEndpoint;
54
+ /**
55
+ * Fetches the account balance for a given public key.
56
+ * @param publicKeyHex - Hex-encoded public key of the account.
57
+ * @returns Promise resolving to the account balance as a string.
58
+ * @throws Error if the balance could not be fetched.
59
+ */
60
+ protected getAccountBalance(publicKeyHex: string): Promise<BigNumber>;
61
+ /**
62
+ * Retrieves the current transaction fee data from the ICP public node.
63
+ *
64
+ * This method creates an instance of `IcpAgent` using the public node URL,
65
+ * then queries the node for the current fee information.
66
+ *
67
+ * @returns A promise that resolves to a `BigNumber` representing the current transaction fee.
68
+ * @throws Will propagate any errors encountered while communicating with the ICP node.
69
+ */
70
+ protected getFeeData(): Promise<BigNumber>;
71
+ private getBuilderFactory;
72
+ /**
73
+ * Generates an array of signatures for the provided payloads using MPC
74
+ *
75
+ * @param payloadsData - The data containing the payloads to be signed.
76
+ * @param senderPublicKey - The public key of the sender in hexadecimal format.
77
+ * @param userKeyShare - The user's key share as a Buffer.
78
+ * @param backupKeyShare - The backup key share as a Buffer.
79
+ * @param commonKeyChain - The common key chain identifier used for MPC signing.
80
+ * @returns A promise that resolves to an array of `Signatures` objects, each containing the signing payload,
81
+ * signature type, public key, and the generated signature in hexadecimal format.
82
+ */
83
+ signatures(payloadsData: PayloadsData, senderPublicKey: string, userKeyShare: Buffer<ArrayBufferLike>, backupKeyShare: Buffer<ArrayBufferLike>, commonKeyChain: string): Promise<Signatures[]>;
84
+ /**
85
+ * Builds a funds recovery transaction without BitGo
86
+ * @param params
87
+ */
88
+ recover(params: RecoveryOptions): Promise<RecoveryTransaction | UnsignedSweepRecoveryTransaction>;
89
+ /** @inheritDoc */
90
+ auditDecryptedKey({ multiSigType, prv, publicKey }: AuditDecryptedKeyParams): void;
38
91
  }
39
92
  //# sourceMappingURL=icp.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"icp.d.ts","sourceRoot":"","sources":["../../src/icp.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EACR,SAAS,EACT,YAAY,EACZ,wBAAwB,EACxB,uBAAuB,EACvB,uBAAuB,EACvB,iBAAiB,EACjB,OAAO,EACP,sBAAsB,EACtB,iBAAiB,EAElB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,QAAQ,IAAI,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAGlE;;;;;;GAMG;AACH,qBAAa,GAAI,SAAQ,QAAQ;IAC/B,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;IAC3D,SAAS,aAAa,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC;IAU/E,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC,GAAG,QAAQ;IAI1F,QAAQ,IAAI,MAAM;IAIlB,YAAY,IAAI,MAAM;IAItB,SAAS,IAAI,MAAM;IAInB,WAAW,IAAI,MAAM;IAIrB,aAAa,IAAI,MAAM;IAIjB,iBAAiB,CAAC,MAAM,EAAE,wBAAwB,GAAG,OAAO,CAAC,OAAO,CAAC;IAIrE,eAAe,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,OAAO,CAAC;IAIlE,gBAAgB,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAInF;;;OAGG;IACI,eAAe,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO;IAI9C,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAIxC,eAAe,CAAC,CAAC,EAAE,sBAAsB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAItE,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIhC,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIhC,kBAAkB;IAClB,WAAW,IAAI,OAAO;IAItB,kBAAkB;IAClB,eAAe,IAAI,YAAY;YAIjB,uBAAuB;IAIrC,mBAAmB;IACnB,SAAS,CAAC,gBAAgB,IAAI,MAAM;CAGrC"}
1
+ {"version":3,"file":"icp.d.ts","sourceRoot":"","sources":["../../src/icp.ts"],"names":[],"mappings":"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"}
package/dist/src/icp.js CHANGED
@@ -1,11 +1,55 @@
1
1
  "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
2
35
  var __importDefault = (this && this.__importDefault) || function (mod) {
3
36
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
37
  };
5
38
  Object.defineProperty(exports, "__esModule", { value: true });
6
39
  exports.Icp = void 0;
40
+ const assert_1 = __importDefault(require("assert"));
7
41
  const sdk_core_1 = require("@bitgo-beta/sdk-core");
42
+ const statics_1 = require("@bitgo-beta/statics");
43
+ const principal_1 = require("@dfinity/principal");
44
+ const axios_1 = __importDefault(require("axios"));
45
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
46
+ const crypto_1 = require("crypto");
47
+ const mpc = __importStar(require("@bitgo-beta/sdk-lib-mpc"));
48
+ const iface_1 = require("./lib/iface");
49
+ const transactionBuilderFactory_1 = require("./lib/transactionBuilderFactory");
8
50
  const utils_1 = __importDefault(require("./lib/utils"));
51
+ const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
52
+ const icpAgent_1 = require("./lib/icpAgent");
9
53
  /**
10
54
  * Class representing the Internet Computer (ICP) coin.
11
55
  * Extends the BaseCoin class and provides specific implementations for ICP.
@@ -31,7 +75,7 @@ class Icp extends sdk_core_1.BaseCoin {
31
75
  return 'icp';
32
76
  }
33
77
  getFamily() {
34
- return 'icp';
78
+ return this._staticsCoin.family;
35
79
  }
36
80
  getFullName() {
37
81
  return 'Internet Computer';
@@ -39,14 +83,50 @@ class Icp extends sdk_core_1.BaseCoin {
39
83
  getBaseFactor() {
40
84
  return Math.pow(10, this._staticsCoin.decimalPlaces);
41
85
  }
86
+ async explainTransaction(params) {
87
+ const factory = this.getBuilderFactory();
88
+ const txBuilder = await factory.from(params.transactionHex);
89
+ const transaction = await txBuilder.build();
90
+ if (params.signableHex !== undefined) {
91
+ const generatedSignableHex = txBuilder.transaction.payloadsData.payloads[0].hex_bytes;
92
+ if (generatedSignableHex !== params.signableHex) {
93
+ throw new Error('generated signableHex is not equal to params.signableHex');
94
+ }
95
+ }
96
+ return transaction.explainTransaction();
97
+ }
42
98
  async verifyTransaction(params) {
43
- throw new Error('Method not implemented.');
99
+ const { txParams, txPrebuild } = params;
100
+ const txHex = txPrebuild?.txHex;
101
+ if (!txHex) {
102
+ throw new Error('txHex is required');
103
+ }
104
+ const txHexParams = {
105
+ transactionHex: txHex,
106
+ };
107
+ if (txPrebuild.txInfo && txPrebuild.txInfo !== undefined && typeof txPrebuild.txInfo === 'string') {
108
+ txHexParams.signableHex = txPrebuild.txInfo;
109
+ }
110
+ const explainedTx = await this.explainTransaction(txHexParams);
111
+ if (Array.isArray(txParams.recipients) && txParams.recipients.length > 0) {
112
+ if (txParams.recipients.length > 1) {
113
+ throw new Error(`${this.getChain()} doesn't support sending to more than 1 destination address within a single transaction. Try again, using only a single recipient.`);
114
+ }
115
+ (0, assert_1.default)(explainedTx.outputs.length === 1, 'Tx outputs does not match with expected txParams recipients');
116
+ const output = explainedTx.outputs[0];
117
+ const recipient = txParams.recipients[0];
118
+ (0, assert_1.default)(typeof recipient.address === 'string' &&
119
+ typeof output.address === 'string' &&
120
+ output.address === recipient.address &&
121
+ (0, bignumber_js_1.default)(output.amount).eq((0, bignumber_js_1.default)(recipient.amount)), 'Tx outputs does not match with expected txParams recipients');
122
+ }
123
+ return true;
44
124
  }
45
125
  async isWalletAddress(params) {
46
- throw new Error('Method not implemented.');
126
+ return this.isValidAddress(params.address);
47
127
  }
48
128
  async parseTransaction(params) {
49
- throw new Error('Method not implemented.');
129
+ return {};
50
130
  }
51
131
  /**
52
132
  * Generate a new keypair for this coin.
@@ -56,10 +136,25 @@ class Icp extends sdk_core_1.BaseCoin {
56
136
  return utils_1.default.generateKeyPair(seed);
57
137
  }
58
138
  isValidAddress(address) {
59
- throw new Error('Method not implemented.');
139
+ return utils_1.default.isValidAddress(address);
60
140
  }
61
- signTransaction(_) {
62
- throw new Error('Method not implemented.');
141
+ async signTransaction(params) {
142
+ const txHex = params?.txPrebuild?.txHex;
143
+ const privateKey = params?.prv;
144
+ if (!txHex) {
145
+ throw new sdk_core_1.SigningError('missing required txPrebuild parameter: params.txPrebuild.txHex');
146
+ }
147
+ if (!privateKey) {
148
+ throw new sdk_core_1.SigningError('missing required prv parameter: params.prv');
149
+ }
150
+ const factory = this.getBuilderFactory();
151
+ const txBuilder = await factory.from(params.txPrebuild.txHex);
152
+ txBuilder.sign({ key: params.prv });
153
+ txBuilder.combine();
154
+ const serializedTx = txBuilder.transaction.toBroadcastFormat();
155
+ return {
156
+ txHex: serializedTx,
157
+ };
63
158
  }
64
159
  isValidPub(key) {
65
160
  return utils_1.default.isValidPublicKey(key);
@@ -71,17 +166,213 @@ class Icp extends sdk_core_1.BaseCoin {
71
166
  supportsTss() {
72
167
  return true;
73
168
  }
169
+ /** inherited doc */
170
+ getDefaultMultisigType() {
171
+ return sdk_core_1.multisigTypes.tss;
172
+ }
74
173
  /** @inheritDoc */
75
174
  getMPCAlgorithm() {
76
175
  return 'ecdsa';
77
176
  }
177
+ /** @inheritDoc **/
178
+ getHashFunction() {
179
+ return (0, crypto_1.createHash)('sha256');
180
+ }
78
181
  async getAddressFromPublicKey(hexEncodedPublicKey) {
79
182
  return utils_1.default.getAddressFromPublicKey(hexEncodedPublicKey);
80
183
  }
81
184
  /** @inheritDoc **/
82
185
  getPublicNodeUrl() {
83
- return sdk_core_1.Environments[this.bitgo.getEnv()].rosettaNodeURL;
186
+ return sdk_core_1.Environments[this.bitgo.getEnv()].icpNodeUrl;
187
+ }
188
+ /** @inheritDoc **/
189
+ // this method calls the public node to broadcast the transaction and not the rosetta node
190
+ async broadcastTransaction(payload) {
191
+ const endpoint = this.getPublicNodeBroadcastEndpoint();
192
+ try {
193
+ const bodyBytes = utils_1.default.blobFromHex(payload.serializedSignedTransaction);
194
+ const response = await axios_1.default.post(endpoint, bodyBytes, {
195
+ headers: { 'Content-Type': 'application/cbor' },
196
+ responseType: 'arraybuffer', // This ensures you get a Buffer, not a string
197
+ });
198
+ if (response.status !== 200) {
199
+ throw new Error(`Transaction broadcast failed with status: ${response.status} - ${response.statusText}`);
200
+ }
201
+ const decodedResponse = utils_1.default.cborDecode(response.data);
202
+ if (decodedResponse.status === 'replied') {
203
+ // it is considered a success because ICP returns response in a CBOR map with a status of 'replied'
204
+ return {}; // returned empty object as ICP does not return a txid
205
+ }
206
+ else {
207
+ throw new Error(`Unexpected response status from node: ${decodedResponse.status}`);
208
+ }
209
+ }
210
+ catch (error) {
211
+ throw new Error(`Transaction broadcast error: ${error?.message || JSON.stringify(error)}`);
212
+ }
213
+ }
214
+ getPublicNodeBroadcastEndpoint() {
215
+ const nodeUrl = this.getPublicNodeUrl();
216
+ const ledgerCanisterId = this._staticsCoin.network.type === statics_1.NetworkType.TESTNET ? iface_1.TESTNET_LEDGER_CANISTER_ID : iface_1.LEDGER_CANISTER_ID;
217
+ const principal = principal_1.Principal.fromUint8Array(ledgerCanisterId);
218
+ const canisterIdHex = principal.toText();
219
+ const endpoint = `${nodeUrl}${iface_1.PUBLIC_NODE_REQUEST_ENDPOINT}${canisterIdHex}/call`;
220
+ return endpoint;
221
+ }
222
+ /**
223
+ * Fetches the account balance for a given public key.
224
+ * @param publicKeyHex - Hex-encoded public key of the account.
225
+ * @returns Promise resolving to the account balance as a string.
226
+ * @throws Error if the balance could not be fetched.
227
+ */
228
+ async getAccountBalance(publicKeyHex) {
229
+ const principalId = utils_1.default.getPrincipalIdFromPublicKey(publicKeyHex).toText();
230
+ const agent = new icpAgent_1.IcpAgent(this.getPublicNodeUrl(), this._staticsCoin);
231
+ return agent.getBalance(principalId);
232
+ }
233
+ /**
234
+ * Retrieves the current transaction fee data from the ICP public node.
235
+ *
236
+ * This method creates an instance of `IcpAgent` using the public node URL,
237
+ * then queries the node for the current fee information.
238
+ *
239
+ * @returns A promise that resolves to a `BigNumber` representing the current transaction fee.
240
+ * @throws Will propagate any errors encountered while communicating with the ICP node.
241
+ */
242
+ async getFeeData() {
243
+ const agent = new icpAgent_1.IcpAgent(this.getPublicNodeUrl(), this._staticsCoin);
244
+ return await agent.getFee();
245
+ }
246
+ getBuilderFactory() {
247
+ return new transactionBuilderFactory_1.TransactionBuilderFactory(statics_1.coins.get(this.getBaseChain()));
248
+ }
249
+ /**
250
+ * Generates an array of signatures for the provided payloads using MPC
251
+ *
252
+ * @param payloadsData - The data containing the payloads to be signed.
253
+ * @param senderPublicKey - The public key of the sender in hexadecimal format.
254
+ * @param userKeyShare - The user's key share as a Buffer.
255
+ * @param backupKeyShare - The backup key share as a Buffer.
256
+ * @param commonKeyChain - The common key chain identifier used for MPC signing.
257
+ * @returns A promise that resolves to an array of `Signatures` objects, each containing the signing payload,
258
+ * signature type, public key, and the generated signature in hexadecimal format.
259
+ */
260
+ async signatures(payloadsData, senderPublicKey, userKeyShare, backupKeyShare, commonKeyChain) {
261
+ try {
262
+ const payload = payloadsData.payloads[0];
263
+ const message = Buffer.from(payload.hex_bytes, 'hex');
264
+ const messageHash = (0, crypto_1.createHash)('sha256').update(message).digest();
265
+ const signature = await sdk_core_1.ECDSAUtils.signRecoveryMpcV2(messageHash, userKeyShare, backupKeyShare, commonKeyChain);
266
+ const signaturePayload = {
267
+ signing_payload: payload,
268
+ signature_type: payload.signature_type,
269
+ public_key: {
270
+ hex_bytes: senderPublicKey,
271
+ curve_type: iface_1.CurveType.SECP256K1,
272
+ },
273
+ hex_bytes: signature.r + signature.s,
274
+ };
275
+ return [signaturePayload];
276
+ }
277
+ catch (error) {
278
+ throw new Error(`Error generating signatures: ${error.message || error}`);
279
+ }
280
+ }
281
+ /**
282
+ * Builds a funds recovery transaction without BitGo
283
+ * @param params
284
+ */
285
+ async recover(params) {
286
+ try {
287
+ if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {
288
+ throw new Error('invalid recoveryDestination');
289
+ }
290
+ const isUnsignedSweep = !params.userKey && !params.backupKey && !params.walletPassphrase;
291
+ let publicKey;
292
+ let userKeyShare, backupKeyShare, commonKeyChain;
293
+ const MPC = new sdk_core_1.Ecdsa();
294
+ if (!isUnsignedSweep) {
295
+ if (!params.userKey) {
296
+ throw new Error('missing userKey');
297
+ }
298
+ if (!params.backupKey) {
299
+ throw new Error('missing backupKey');
300
+ }
301
+ if (!params.walletPassphrase) {
302
+ throw new Error('missing wallet passphrase');
303
+ }
304
+ const userKey = params.userKey.replace(/\s/g, '');
305
+ const backupKey = params.backupKey.replace(/\s/g, '');
306
+ ({ userKeyShare, backupKeyShare, commonKeyChain } = await sdk_core_1.ECDSAUtils.getMpcV2RecoveryKeyShares(userKey, backupKey, params.walletPassphrase));
307
+ publicKey = MPC.deriveUnhardened(commonKeyChain, iface_1.ROOT_PATH).slice(0, 66);
308
+ }
309
+ else {
310
+ const bitgoKey = params.bitgoKey;
311
+ if (!bitgoKey) {
312
+ throw new Error('missing bitgoKey');
313
+ }
314
+ const hdTree = new mpc.Secp256k1Bip32HdTree();
315
+ const derivationPath = 'm/0';
316
+ const derivedPub = hdTree.publicDerive({
317
+ pk: mpc.bigIntFromBufferBE(Buffer.from(bitgoKey.slice(0, 66), 'hex')),
318
+ chaincode: mpc.bigIntFromBufferBE(Buffer.from(bitgoKey.slice(66), 'hex')),
319
+ }, derivationPath);
320
+ publicKey = mpc.bigIntToBufferBE(derivedPub.pk).toString('hex');
321
+ }
322
+ if (!publicKey) {
323
+ throw new Error('failed to derive public key');
324
+ }
325
+ const senderAddress = await this.getAddressFromPublicKey(publicKey);
326
+ const balance = await this.getAccountBalance(publicKey);
327
+ const feeData = await this.getFeeData();
328
+ const actualBalance = balance.minus(feeData);
329
+ if (actualBalance.isLessThanOrEqualTo(0)) {
330
+ throw new Error('Did not have enough funds to recover');
331
+ }
332
+ const factory = this.getBuilderFactory();
333
+ const txBuilder = factory.getTransferBuilder();
334
+ txBuilder.sender(senderAddress, publicKey);
335
+ txBuilder.receiverId(params.recoveryDestination);
336
+ txBuilder.amount(actualBalance.toString());
337
+ if (params.memo !== undefined && utils_1.default.validateMemo(params.memo)) {
338
+ txBuilder.memo(Number(params.memo));
339
+ }
340
+ await txBuilder.build();
341
+ if (txBuilder.transaction.payloadsData.payloads.length === 0) {
342
+ throw new Error('Missing payloads to generate signatures');
343
+ }
344
+ if (isUnsignedSweep) {
345
+ return {
346
+ txHex: txBuilder.transaction.unsignedTransaction,
347
+ coin: this.getChain(),
348
+ };
349
+ }
350
+ const signatures = await this.signatures(txBuilder.transaction.payloadsData, publicKey, userKeyShare, backupKeyShare, commonKeyChain);
351
+ if (!signatures || signatures.length === 0) {
352
+ throw new Error('Failed to generate signatures');
353
+ }
354
+ txBuilder.transaction.addSignature(signatures);
355
+ txBuilder.combine();
356
+ const broadcastableTxn = txBuilder.transaction.toBroadcastFormat();
357
+ await this.broadcastTransaction({ serializedSignedTransaction: broadcastableTxn });
358
+ const txId = txBuilder.transaction.id;
359
+ const recoveredTransaction = {
360
+ id: txId,
361
+ tx: broadcastableTxn,
362
+ };
363
+ return recoveredTransaction;
364
+ }
365
+ catch (error) {
366
+ throw new Error(`Error during ICP recovery: ${error.message || error}`);
367
+ }
368
+ }
369
+ /** @inheritDoc */
370
+ auditDecryptedKey({ multiSigType, prv, publicKey }) {
371
+ if (multiSigType !== 'tss') {
372
+ throw new Error('Unsupported multisigtype ');
373
+ }
374
+ (0, sdk_lib_mpc_1.auditEcdsaPrivateKey)(prv, publicKey);
84
375
  }
85
376
  }
86
377
  exports.Icp = Icp;
87
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ljcC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxtREFZOEI7QUFFOUIsd0RBQWdDO0FBRWhDOzs7Ozs7R0FNRztBQUNILE1BQWEsR0FBSSxTQUFRLG1CQUFRO0lBRS9CLFlBQXNCLEtBQWdCLEVBQUUsV0FBdUM7UUFDN0UsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRWIsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ2pCLE1BQU0sSUFBSSxLQUFLLENBQUMsb0RBQW9ELENBQUMsQ0FBQztRQUN4RSxDQUFDO1FBRUQsSUFBSSxDQUFDLFlBQVksR0FBRyxXQUFXLENBQUM7SUFDbEMsQ0FBQztJQUVELE1BQU0sQ0FBQyxjQUFjLENBQUMsS0FBZ0IsRUFBRSxXQUF1QztRQUM3RSxPQUFPLElBQUksR0FBRyxDQUFDLEtBQUssRUFBRSxXQUFXLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQsUUFBUTtRQUNOLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVELFlBQVk7UUFDVixPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7SUFFRCxTQUFTO1FBQ1AsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0lBRUQsV0FBVztRQUNULE9BQU8sbUJBQW1CLENBQUM7SUFDN0IsQ0FBQztJQUVELGFBQWE7UUFDWCxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVELEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxNQUFnQztRQUN0RCxNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVELEtBQUssQ0FBQyxlQUFlLENBQUMsTUFBK0I7UUFDbkQsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFFRCxLQUFLLENBQUMsZ0JBQWdCLENBQUMsTUFBK0I7UUFDcEQsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFFRDs7O09BR0c7SUFDSSxlQUFlLENBQUMsSUFBYTtRQUNsQyxPQUFPLGVBQUssQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVELGNBQWMsQ0FBQyxPQUFlO1FBQzVCLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsZUFBZSxDQUFDLENBQXlCO1FBQ3ZDLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsVUFBVSxDQUFDLEdBQVc7UUFDcEIsT0FBTyxlQUFLLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVELFVBQVUsQ0FBQyxHQUFXO1FBQ3BCLE9BQU8sZUFBSyxDQUFDLGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxrQkFBa0I7SUFDbEIsV0FBVztRQUNULE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELGtCQUFrQjtJQUNsQixlQUFlO1FBQ2IsT0FBTyxPQUFPLENBQUM7SUFDakIsQ0FBQztJQUVPLEtBQUssQ0FBQyx1QkFBdUIsQ0FBQyxtQkFBMkI7UUFDL0QsT0FBTyxlQUFLLENBQUMsdUJBQXVCLENBQUMsbUJBQW1CLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRUQsbUJBQW1CO0lBQ1QsZ0JBQWdCO1FBQ3hCLE9BQU8sdUJBQVksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUMsY0FBYyxDQUFDO0lBQzFELENBQUM7Q0FDRjtBQTFGRCxrQkEwRkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBCYXNlQ29pbixcbiAgQml0R29CYXNlLFxuICBNUENBbGdvcml0aG0sXG4gIFZlcmlmeVRyYW5zYWN0aW9uT3B0aW9ucyxcbiAgVHNzVmVyaWZ5QWRkcmVzc09wdGlvbnMsXG4gIFBhcnNlVHJhbnNhY3Rpb25PcHRpb25zLFxuICBQYXJzZWRUcmFuc2FjdGlvbixcbiAgS2V5UGFpcixcbiAgU2lnblRyYW5zYWN0aW9uT3B0aW9ucyxcbiAgU2lnbmVkVHJhbnNhY3Rpb24sXG4gIEVudmlyb25tZW50cyxcbn0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgQmFzZUNvaW4gYXMgU3RhdGljc0Jhc2VDb2luIH0gZnJvbSAnQGJpdGdvLWJldGEvc3RhdGljcyc7XG5pbXBvcnQgdXRpbHMgZnJvbSAnLi9saWIvdXRpbHMnO1xuXG4vKipcbiAqIENsYXNzIHJlcHJlc2VudGluZyB0aGUgSW50ZXJuZXQgQ29tcHV0ZXIgKElDUCkgY29pbi5cbiAqIEV4dGVuZHMgdGhlIEJhc2VDb2luIGNsYXNzIGFuZCBwcm92aWRlcyBzcGVjaWZpYyBpbXBsZW1lbnRhdGlvbnMgZm9yIElDUC5cbiAqXG4gKiBAc2VlIHtAbGluayBodHRwczovL2ludGVybmV0Y29tcHV0ZXIub3JnL31cbiAqIEBzZWUge0BsaW5rIGh0dHBzOi8vaW50ZXJuZXRjb21wdXRlci5vcmcvZG9jcy9jdXJyZW50L2RldmVsb3Blci1kb2NzL2RlZmkvcm9zZXR0YS9pY3Bfcm9zZXR0YS9kYXRhX2FwaS99XG4gKi9cbmV4cG9ydCBjbGFzcyBJY3AgZXh0ZW5kcyBCYXNlQ29pbiB7XG4gIHByb3RlY3RlZCByZWFkb25seSBfc3RhdGljc0NvaW46IFJlYWRvbmx5PFN0YXRpY3NCYXNlQ29pbj47XG4gIHByb3RlY3RlZCBjb25zdHJ1Y3RvcihiaXRnbzogQml0R29CYXNlLCBzdGF0aWNzQ29pbj86IFJlYWRvbmx5PFN0YXRpY3NCYXNlQ29pbj4pIHtcbiAgICBzdXBlcihiaXRnbyk7XG5cbiAgICBpZiAoIXN0YXRpY3NDb2luKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ21pc3NpbmcgcmVxdWlyZWQgY29uc3RydWN0b3IgcGFyYW1ldGVyIHN0YXRpY3NDb2luJyk7XG4gICAgfVxuXG4gICAgdGhpcy5fc3RhdGljc0NvaW4gPSBzdGF0aWNzQ29pbjtcbiAgfVxuXG4gIHN0YXRpYyBjcmVhdGVJbnN0YW5jZShiaXRnbzogQml0R29CYXNlLCBzdGF0aWNzQ29pbj86IFJlYWRvbmx5PFN0YXRpY3NCYXNlQ29pbj4pOiBCYXNlQ29pbiB7XG4gICAgcmV0dXJuIG5ldyBJY3AoYml0Z28sIHN0YXRpY3NDb2luKTtcbiAgfVxuXG4gIGdldENoYWluKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuICdpY3AnO1xuICB9XG5cbiAgZ2V0QmFzZUNoYWluKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuICdpY3AnO1xuICB9XG5cbiAgZ2V0RmFtaWx5KCk6IHN0cmluZyB7XG4gICAgcmV0dXJuICdpY3AnO1xuICB9XG5cbiAgZ2V0RnVsbE5hbWUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gJ0ludGVybmV0IENvbXB1dGVyJztcbiAgfVxuXG4gIGdldEJhc2VGYWN0b3IoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gTWF0aC5wb3coMTAsIHRoaXMuX3N0YXRpY3NDb2luLmRlY2ltYWxQbGFjZXMpO1xuICB9XG5cbiAgYXN5bmMgdmVyaWZ5VHJhbnNhY3Rpb24ocGFyYW1zOiBWZXJpZnlUcmFuc2FjdGlvbk9wdGlvbnMpOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cblxuICBhc3luYyBpc1dhbGxldEFkZHJlc3MocGFyYW1zOiBUc3NWZXJpZnlBZGRyZXNzT3B0aW9ucyk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICAgIHRocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcbiAgfVxuXG4gIGFzeW5jIHBhcnNlVHJhbnNhY3Rpb24ocGFyYW1zOiBQYXJzZVRyYW5zYWN0aW9uT3B0aW9ucyk6IFByb21pc2U8UGFyc2VkVHJhbnNhY3Rpb24+IHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cblxuICAvKipcbiAgICogR2VuZXJhdGUgYSBuZXcga2V5cGFpciBmb3IgdGhpcyBjb2luLlxuICAgKiBAcGFyYW0gc2VlZCBTZWVkIGZyb20gd2hpY2ggdGhlIG5ldyBrZXlwYWlyIHNob3VsZCBiZSBnZW5lcmF0ZWQsIG90aGVyd2lzZSBhIHJhbmRvbSBzZWVkIGlzIHVzZWRcbiAgICovXG4gIHB1YmxpYyBnZW5lcmF0ZUtleVBhaXIoc2VlZD86IEJ1ZmZlcik6IEtleVBhaXIge1xuICAgIHJldHVybiB1dGlscy5nZW5lcmF0ZUtleVBhaXIoc2VlZCk7XG4gIH1cblxuICBpc1ZhbGlkQWRkcmVzcyhhZGRyZXNzOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cblxuICBzaWduVHJhbnNhY3Rpb24oXzogU2lnblRyYW5zYWN0aW9uT3B0aW9ucyk6IFByb21pc2U8U2lnbmVkVHJhbnNhY3Rpb24+IHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cblxuICBpc1ZhbGlkUHViKGtleTogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHV0aWxzLmlzVmFsaWRQdWJsaWNLZXkoa2V5KTtcbiAgfVxuXG4gIGlzVmFsaWRQcnYoa2V5OiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdXRpbHMuaXNWYWxpZFByaXZhdGVLZXkoa2V5KTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdERvYyAqL1xuICBzdXBwb3J0c1RzcygpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdERvYyAqL1xuICBnZXRNUENBbGdvcml0aG0oKTogTVBDQWxnb3JpdGhtIHtcbiAgICByZXR1cm4gJ2VjZHNhJztcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgZ2V0QWRkcmVzc0Zyb21QdWJsaWNLZXkoaGV4RW5jb2RlZFB1YmxpY0tleTogc3RyaW5nKSB7XG4gICAgcmV0dXJuIHV0aWxzLmdldEFkZHJlc3NGcm9tUHVibGljS2V5KGhleEVuY29kZWRQdWJsaWNLZXkpO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0RG9jICoqL1xuICBwcm90ZWN0ZWQgZ2V0UHVibGljTm9kZVVybCgpOiBzdHJpbmcge1xuICAgIHJldHVybiBFbnZpcm9ubWVudHNbdGhpcy5iaXRnby5nZXRFbnYoKV0ucm9zZXR0YU5vZGVVUkw7XG4gIH1cbn1cbiJdfQ==
378
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icp.js","sourceRoot":"","sources":["../../src/icp.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport {\n  AuditDecryptedKeyParams,\n  BaseBroadcastTransactionOptions,\n  BaseBroadcastTransactionResult,\n  BaseCoin,\n  BitGoBase,\n  Ecdsa,\n  ECDSAUtils,\n  Environments,\n  KeyPair,\n  MPCAlgorithm,\n  MultisigType,\n  multisigTypes,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SigningError,\n  SignTransactionOptions,\n  TssVerifyAddressOptions,\n  VerifyTransactionOptions,\n} from '@bitgo-beta/sdk-core';\nimport { coins, NetworkType, BaseCoin as StaticsBaseCoin } from '@bitgo-beta/statics';\nimport { Principal } from '@dfinity/principal';\nimport axios from 'axios';\nimport BigNumber from 'bignumber.js';\nimport { createHash, Hash } from 'crypto';\nimport * as mpc from '@bitgo-beta/sdk-lib-mpc';\n\nimport {\n  CurveType,\n  LEDGER_CANISTER_ID,\n  TESTNET_LEDGER_CANISTER_ID,\n  PayloadsData,\n  PUBLIC_NODE_REQUEST_ENDPOINT,\n  PublicNodeSubmitResponse,\n  RecoveryOptions,\n  RecoveryTransaction,\n  ROOT_PATH,\n  Signatures,\n  SigningPayload,\n  IcpTransactionExplanation,\n  TransactionHexParams,\n  UnsignedSweepRecoveryTransaction,\n} from './lib/iface';\nimport { TransactionBuilderFactory } from './lib/transactionBuilderFactory';\nimport utils from './lib/utils';\nimport { auditEcdsaPrivateKey } from '@bitgo-beta/sdk-lib-mpc';\nimport { IcpAgent } from './lib/icpAgent';\n\n/**\n * Class representing the Internet Computer (ICP) coin.\n * Extends the BaseCoin class and provides specific implementations for ICP.\n *\n * @see {@link https://internetcomputer.org/}\n * @see {@link https://internetcomputer.org/docs/current/developer-docs/defi/rosetta/icp_rosetta/data_api/}\n */\nexport class Icp extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n  protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Icp(bitgo, staticsCoin);\n  }\n\n  getChain(): string {\n    return 'icp';\n  }\n\n  getBaseChain(): string {\n    return 'icp';\n  }\n\n  getFamily(): string {\n    return this._staticsCoin.family;\n  }\n\n  getFullName(): string {\n    return 'Internet Computer';\n  }\n\n  getBaseFactor(): number {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  async explainTransaction(params: TransactionHexParams): Promise<IcpTransactionExplanation> {\n    const factory = this.getBuilderFactory();\n    const txBuilder = await factory.from(params.transactionHex);\n    const transaction = await txBuilder.build();\n    if (params.signableHex !== undefined) {\n      const generatedSignableHex = txBuilder.transaction.payloadsData.payloads[0].hex_bytes;\n      if (generatedSignableHex !== params.signableHex) {\n        throw new Error('generated signableHex is not equal to params.signableHex');\n      }\n    }\n    return transaction.explainTransaction();\n  }\n\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    const { txParams, txPrebuild } = params;\n    const txHex = txPrebuild?.txHex;\n    if (!txHex) {\n      throw new Error('txHex is required');\n    }\n    const txHexParams: TransactionHexParams = {\n      transactionHex: txHex,\n    };\n\n    if (txPrebuild.txInfo && txPrebuild.txInfo !== undefined && typeof txPrebuild.txInfo === 'string') {\n      txHexParams.signableHex = txPrebuild.txInfo;\n    }\n\n    const explainedTx = await this.explainTransaction(txHexParams);\n\n    if (Array.isArray(txParams.recipients) && txParams.recipients.length > 0) {\n      if (txParams.recipients.length > 1) {\n        throw new Error(\n          `${this.getChain()} doesn't support sending to more than 1 destination address within a single transaction. Try again, using only a single recipient.`\n        );\n      }\n      assert(explainedTx.outputs.length === 1, 'Tx outputs does not match with expected txParams recipients');\n\n      const output = explainedTx.outputs[0];\n      const recipient = txParams.recipients[0];\n      assert(\n        typeof recipient.address === 'string' &&\n          typeof output.address === 'string' &&\n          output.address === recipient.address &&\n          BigNumber(output.amount).eq(BigNumber(recipient.amount)),\n        'Tx outputs does not match with expected txParams recipients'\n      );\n    }\n    return true;\n  }\n\n  async isWalletAddress(params: TssVerifyAddressOptions): Promise<boolean> {\n    return this.isValidAddress(params.address);\n  }\n\n  async parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    return {};\n  }\n\n  /**\n   * Generate a new keypair for this coin.\n   * @param seed Seed from which the new keypair should be generated, otherwise a random seed is used\n   */\n  public generateKeyPair(seed?: Buffer): KeyPair {\n    return utils.generateKeyPair(seed);\n  }\n\n  isValidAddress(address: string): boolean {\n    return utils.isValidAddress(address);\n  }\n\n  async signTransaction(\n    params: SignTransactionOptions & { txPrebuild: { txHex: string }; prv: string }\n  ): Promise<SignedTransaction> {\n    const txHex = params?.txPrebuild?.txHex;\n    const privateKey = params?.prv;\n    if (!txHex) {\n      throw new SigningError('missing required txPrebuild parameter: params.txPrebuild.txHex');\n    }\n    if (!privateKey) {\n      throw new SigningError('missing required prv parameter: params.prv');\n    }\n    const factory = this.getBuilderFactory();\n    const txBuilder = await factory.from(params.txPrebuild.txHex);\n    txBuilder.sign({ key: params.prv });\n    txBuilder.combine();\n    const serializedTx = txBuilder.transaction.toBroadcastFormat();\n    return {\n      txHex: serializedTx,\n    };\n  }\n\n  isValidPub(key: string): boolean {\n    return utils.isValidPublicKey(key);\n  }\n\n  isValidPrv(key: string): boolean {\n    return utils.isValidPrivateKey(key);\n  }\n\n  /** @inheritDoc */\n  supportsTss(): boolean {\n    return true;\n  }\n\n  /** inherited doc */\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.tss;\n  }\n\n  /** @inheritDoc */\n  getMPCAlgorithm(): MPCAlgorithm {\n    return 'ecdsa';\n  }\n\n  /** @inheritDoc **/\n  getHashFunction(): Hash {\n    return createHash('sha256');\n  }\n\n  private async getAddressFromPublicKey(hexEncodedPublicKey: string) {\n    return utils.getAddressFromPublicKey(hexEncodedPublicKey);\n  }\n\n  /** @inheritDoc **/\n  protected getPublicNodeUrl(): string {\n    return Environments[this.bitgo.getEnv()].icpNodeUrl;\n  }\n\n  /** @inheritDoc **/\n  // this method calls the public node to broadcast the transaction and not the rosetta node\n  public async broadcastTransaction(payload: BaseBroadcastTransactionOptions): Promise<BaseBroadcastTransactionResult> {\n    const endpoint = this.getPublicNodeBroadcastEndpoint();\n\n    try {\n      const bodyBytes = utils.blobFromHex(payload.serializedSignedTransaction);\n      const response = await axios.post(endpoint, bodyBytes, {\n        headers: { 'Content-Type': 'application/cbor' },\n        responseType: 'arraybuffer', // This ensures you get a Buffer, not a string\n      });\n\n      if (response.status !== 200) {\n        throw new Error(`Transaction broadcast failed with status: ${response.status} - ${response.statusText}`);\n      }\n\n      const decodedResponse = utils.cborDecode(response.data) as PublicNodeSubmitResponse;\n\n      if (decodedResponse.status === 'replied') {\n        // it is considered a success because ICP returns response in a CBOR map with a status of 'replied'\n        return {}; // returned empty object as ICP does not return a txid\n      } else {\n        throw new Error(`Unexpected response status from node: ${decodedResponse.status}`);\n      }\n    } catch (error) {\n      throw new Error(`Transaction broadcast error: ${error?.message || JSON.stringify(error)}`);\n    }\n  }\n\n  private getPublicNodeBroadcastEndpoint(): string {\n    const nodeUrl = this.getPublicNodeUrl();\n    const ledgerCanisterId =\n      this._staticsCoin.network.type === NetworkType.TESTNET ? TESTNET_LEDGER_CANISTER_ID : LEDGER_CANISTER_ID;\n    const principal = Principal.fromUint8Array(ledgerCanisterId);\n    const canisterIdHex = principal.toText();\n    const endpoint = `${nodeUrl}${PUBLIC_NODE_REQUEST_ENDPOINT}${canisterIdHex}/call`;\n    return endpoint;\n  }\n\n  /**\n   * Fetches the account balance for a given public key.\n   * @param publicKeyHex - Hex-encoded public key of the account.\n   * @returns Promise resolving to the account balance as a string.\n   * @throws Error if the balance could not be fetched.\n   */\n  protected async getAccountBalance(publicKeyHex: string): Promise<BigNumber> {\n    const principalId = utils.getPrincipalIdFromPublicKey(publicKeyHex).toText();\n    const agent = new IcpAgent(this.getPublicNodeUrl(), this._staticsCoin);\n    return agent.getBalance(principalId);\n  }\n\n  /**\n   * Retrieves the current transaction fee data from the ICP public node.\n   *\n   * This method creates an instance of `IcpAgent` using the public node URL,\n   * then queries the node for the current fee information.\n   *\n   * @returns A promise that resolves to a `BigNumber` representing the current transaction fee.\n   * @throws Will propagate any errors encountered while communicating with the ICP node.\n   */\n  protected async getFeeData(): Promise<BigNumber> {\n    const agent = new IcpAgent(this.getPublicNodeUrl(), this._staticsCoin);\n    return await agent.getFee();\n  }\n\n  private getBuilderFactory(): TransactionBuilderFactory {\n    return new TransactionBuilderFactory(coins.get(this.getBaseChain()));\n  }\n\n  /**\n   * Generates an array of signatures for the provided payloads using MPC\n   *\n   * @param payloadsData - The data containing the payloads to be signed.\n   * @param senderPublicKey - The public key of the sender in hexadecimal format.\n   * @param userKeyShare - The user's key share as a Buffer.\n   * @param backupKeyShare - The backup key share as a Buffer.\n   * @param commonKeyChain - The common key chain identifier used for MPC signing.\n   * @returns A promise that resolves to an array of `Signatures` objects, each containing the signing payload,\n   *          signature type, public key, and the generated signature in hexadecimal format.\n   */\n  async signatures(\n    payloadsData: PayloadsData,\n    senderPublicKey: string,\n    userKeyShare: Buffer<ArrayBufferLike>,\n    backupKeyShare: Buffer<ArrayBufferLike>,\n    commonKeyChain: string\n  ): Promise<Signatures[]> {\n    try {\n      const payload = payloadsData.payloads[0] as SigningPayload;\n      const message = Buffer.from(payload.hex_bytes, 'hex');\n      const messageHash = createHash('sha256').update(message).digest();\n      const signature = await ECDSAUtils.signRecoveryMpcV2(messageHash, userKeyShare, backupKeyShare, commonKeyChain);\n      const signaturePayload: Signatures = {\n        signing_payload: payload,\n        signature_type: payload.signature_type,\n        public_key: {\n          hex_bytes: senderPublicKey,\n          curve_type: CurveType.SECP256K1,\n        },\n        hex_bytes: signature.r + signature.s,\n      };\n\n      return [signaturePayload];\n    } catch (error) {\n      throw new Error(`Error generating signatures: ${error.message || error}`);\n    }\n  }\n\n  /**\n   * Builds a funds recovery transaction without BitGo\n   * @param params\n   */\n  async recover(params: RecoveryOptions): Promise<RecoveryTransaction | UnsignedSweepRecoveryTransaction> {\n    try {\n      if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {\n        throw new Error('invalid recoveryDestination');\n      }\n\n      const isUnsignedSweep = !params.userKey && !params.backupKey && !params.walletPassphrase;\n\n      let publicKey: string | undefined;\n      let userKeyShare, backupKeyShare, commonKeyChain;\n      const MPC = new Ecdsa();\n\n      if (!isUnsignedSweep) {\n        if (!params.userKey) {\n          throw new Error('missing userKey');\n        }\n\n        if (!params.backupKey) {\n          throw new Error('missing backupKey');\n        }\n\n        if (!params.walletPassphrase) {\n          throw new Error('missing wallet passphrase');\n        }\n\n        const userKey = params.userKey.replace(/\\s/g, '');\n        const backupKey = params.backupKey.replace(/\\s/g, '');\n\n        ({ userKeyShare, backupKeyShare, commonKeyChain } = await ECDSAUtils.getMpcV2RecoveryKeyShares(\n          userKey,\n          backupKey,\n          params.walletPassphrase\n        ));\n        publicKey = MPC.deriveUnhardened(commonKeyChain, ROOT_PATH).slice(0, 66);\n      } else {\n        const bitgoKey = params.bitgoKey;\n        if (!bitgoKey) {\n          throw new Error('missing bitgoKey');\n        }\n\n        const hdTree = new mpc.Secp256k1Bip32HdTree();\n        const derivationPath = 'm/0';\n        const derivedPub = hdTree.publicDerive(\n          {\n            pk: mpc.bigIntFromBufferBE(Buffer.from(bitgoKey.slice(0, 66), 'hex')),\n            chaincode: mpc.bigIntFromBufferBE(Buffer.from(bitgoKey.slice(66), 'hex')),\n          },\n          derivationPath\n        );\n\n        publicKey = mpc.bigIntToBufferBE(derivedPub.pk).toString('hex');\n      }\n\n      if (!publicKey) {\n        throw new Error('failed to derive public key');\n      }\n\n      const senderAddress = await this.getAddressFromPublicKey(publicKey);\n      const balance = await this.getAccountBalance(publicKey);\n      const feeData = await this.getFeeData();\n      const actualBalance = balance.minus(feeData);\n      if (actualBalance.isLessThanOrEqualTo(0)) {\n        throw new Error('Did not have enough funds to recover');\n      }\n\n      const factory = this.getBuilderFactory();\n      const txBuilder = factory.getTransferBuilder();\n      txBuilder.sender(senderAddress, publicKey as string);\n      txBuilder.receiverId(params.recoveryDestination);\n      txBuilder.amount(actualBalance.toString());\n      if (params.memo !== undefined && utils.validateMemo(params.memo)) {\n        txBuilder.memo(Number(params.memo));\n      }\n      await txBuilder.build();\n      if (txBuilder.transaction.payloadsData.payloads.length === 0) {\n        throw new Error('Missing payloads to generate signatures');\n      }\n\n      if (isUnsignedSweep) {\n        return {\n          txHex: txBuilder.transaction.unsignedTransaction,\n          coin: this.getChain(),\n        };\n      }\n\n      const signatures = await this.signatures(\n        txBuilder.transaction.payloadsData,\n        publicKey,\n        userKeyShare,\n        backupKeyShare,\n        commonKeyChain\n      );\n      if (!signatures || signatures.length === 0) {\n        throw new Error('Failed to generate signatures');\n      }\n      txBuilder.transaction.addSignature(signatures);\n      txBuilder.combine();\n      const broadcastableTxn = txBuilder.transaction.toBroadcastFormat();\n      await this.broadcastTransaction({ serializedSignedTransaction: broadcastableTxn });\n      const txId = txBuilder.transaction.id;\n      const recoveredTransaction: RecoveryTransaction = {\n        id: txId,\n        tx: broadcastableTxn,\n      };\n      return recoveredTransaction;\n    } catch (error) {\n      throw new Error(`Error during ICP recovery: ${error.message || error}`);\n    }\n  }\n\n  /** @inheritDoc */\n  auditDecryptedKey({ multiSigType, prv, publicKey }: AuditDecryptedKeyParams) {\n    if (multiSigType !== 'tss') {\n      throw new Error('Unsupported multisigtype ');\n    }\n    auditEcdsaPrivateKey(prv as string, publicKey as string);\n  }\n}\n"]}
@@ -0,0 +1,36 @@
1
+ import BigNumber from 'bignumber.js';
2
+ import { BaseCoin as StaticsBaseCoin } from '@bitgo-beta/statics';
3
+ export declare class IcpAgent {
4
+ private readonly host;
5
+ private readonly staticsCoin;
6
+ constructor(host: string, staticsCoin: Readonly<StaticsBaseCoin>);
7
+ /**
8
+ * Creates a new HTTP agent for communicating with the Internet Computer.
9
+ * @returns An instance of HttpAgent.
10
+ */
11
+ private createAgent;
12
+ /**
13
+ * Retrieves an instance of the ledger canister agent.
14
+ *
15
+ * This method creates a new agent using `createAgent()`, initializes a replica interface
16
+ * with the agent (configured for local use), and returns an `AgentCanister` instance
17
+ * for the ledger canister identified by `LEDGER_CANISTER_ID`.
18
+ *
19
+ * @returns {AgentCanister} An agent interface for interacting with the ledger canister.
20
+ */
21
+ private getLedger;
22
+ /**
23
+ * Fetches the account balance for a given principal ID.
24
+ * @param principalId - The principal ID of the account.
25
+ * @returns Promise resolving to the account balance as a string.
26
+ * @throws Error if the balance could not be fetched.
27
+ */
28
+ getBalance(principalId: string): Promise<BigNumber>;
29
+ /**
30
+ * Fetches the transaction fee from the ledger.
31
+ * @returns Promise resolving to the transaction fee as a string.
32
+ * @throws Error if the fee could not be fetched.
33
+ */
34
+ getFee(): Promise<BigNumber>;
35
+ }
36
+ //# sourceMappingURL=icpAgent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icpAgent.d.ts","sourceRoot":"","sources":["../../../src/lib/icpAgent.ts"],"names":[],"mappings":"AAWA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAe,QAAQ,IAAI,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAE/E,qBAAa,QAAQ;IACnB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAS;IAC9B,OAAO,CAAC,QAAQ,CAAC,WAAW,CAA4B;gBAE5C,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,QAAQ,CAAC,eAAe,CAAC;IAKhE;;;OAGG;IACH,OAAO,CAAC,WAAW;IAQnB;;;;;;;;OAQG;IACH,OAAO,CAAC,SAAS;IAQjB;;;;;OAKG;IACU,UAAU,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC;IAmBhE;;;;OAIG;IACU,MAAM,IAAI,OAAO,CAAC,SAAS,CAAC;CAmB1C"}