@bitgo-beta/sdk-coin-icp 1.0.1-beta.84 → 1.0.1-beta.840
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/dist/resources/messageCompiled.d.ts +797 -0
- package/dist/resources/messageCompiled.js +1859 -0
- package/dist/src/icp.d.ts +64 -3
- package/dist/src/icp.d.ts.map +1 -1
- package/dist/src/icp.js +332 -10
- package/dist/src/lib/icpAgent.d.ts +36 -0
- package/dist/src/lib/icpAgent.d.ts.map +1 -0
- package/dist/src/lib/icpAgent.js +90 -0
- package/dist/src/lib/iface.d.ts +195 -0
- package/dist/src/lib/iface.d.ts.map +1 -0
- package/dist/src/lib/iface.js +44 -0
- package/dist/src/lib/index.d.ts +4 -0
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +12 -2
- package/dist/src/lib/signedTransactionBuilder.d.ts +9 -0
- package/dist/src/lib/signedTransactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/signedTransactionBuilder.js +64 -0
- package/dist/src/lib/transaction.d.ts +54 -0
- package/dist/src/lib/transaction.d.ts.map +1 -0
- package/dist/src/lib/transaction.js +255 -0
- package/dist/src/lib/transactionBuilder.d.ts +58 -28
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +127 -40
- package/dist/src/lib/transactionBuilderFactory.d.ts +15 -14
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +43 -27
- package/dist/src/lib/transferBuilder.d.ts +7 -24
- package/dist/src/lib/transferBuilder.d.ts.map +1 -1
- package/dist/src/lib/transferBuilder.js +88 -43
- package/dist/src/lib/unsignedTransactionBuilder.d.ts +13 -0
- package/dist/src/lib/unsignedTransactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/unsignedTransactionBuilder.js +90 -0
- package/dist/src/lib/utils.d.ts +286 -8
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +615 -53
- package/dist/src/ticp.d.ts +0 -4
- package/dist/src/ticp.d.ts.map +1 -1
- package/dist/src/ticp.js +1 -7
- package/dist/test/resources/icp.d.ts +268 -0
- package/dist/test/resources/icp.d.ts.map +1 -0
- package/dist/test/resources/icp.js +377 -0
- package/dist/test/unit/getBuilderFactory.d.ts +3 -0
- package/dist/test/unit/getBuilderFactory.d.ts.map +1 -0
- package/dist/test/unit/getBuilderFactory.js +10 -0
- package/dist/test/unit/icp.d.ts +2 -0
- package/dist/test/unit/icp.d.ts.map +1 -0
- package/dist/test/unit/icp.js +418 -0
- package/dist/test/unit/keyPair.d.ts +2 -0
- package/dist/test/unit/keyPair.d.ts.map +1 -0
- package/dist/test/unit/keyPair.js +107 -0
- package/dist/test/unit/transaction.d.ts +2 -0
- package/dist/test/unit/transaction.d.ts.map +1 -0
- package/dist/test/unit/transaction.js +109 -0
- package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/transactionBuilder.js +274 -0
- package/dist/test/unit/transactionBuilder/transactionRecover.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/transactionRecover.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/transactionRecover.js +188 -0
- package/dist/test/unit/utils.d.ts +2 -0
- package/dist/test/unit/utils.d.ts.map +1 -0
- package/dist/test/unit/utils.js +206 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +23 -12
- package/.eslintignore +0 -4
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -54
package/dist/src/icp.d.ts
CHANGED
|
@@ -1,5 +1,8 @@
|
|
|
1
|
-
import { BaseCoin, BitGoBase, MPCAlgorithm,
|
|
1
|
+
import { AuditDecryptedKeyParams, BaseBroadcastTransactionOptions, BaseBroadcastTransactionResult, BaseCoin, BitGoBase, KeyPair, MPCAlgorithm, MultisigType, ParsedTransaction, ParseTransactionOptions, SignedTransaction, SignTransactionOptions, 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, TssVerifyIcpAddressOptions, 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,8 +19,17 @@ 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
|
+
/**
|
|
25
|
+
* Verify that an address belongs to this wallet.
|
|
26
|
+
*
|
|
27
|
+
* @param {TssVerifyIcpAddressOptions} params - Verification parameters
|
|
28
|
+
* @returns {Promise<boolean>} True if address belongs to wallet
|
|
29
|
+
* @throws {InvalidAddressError} If address format is invalid or doesn't match derived address
|
|
30
|
+
* @throws {Error} If invalid wallet version or missing parameters
|
|
31
|
+
*/
|
|
32
|
+
isWalletAddress(params: TssVerifyIcpAddressOptions): Promise<boolean>;
|
|
21
33
|
parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction>;
|
|
22
34
|
/**
|
|
23
35
|
* Generate a new keypair for this coin.
|
|
@@ -25,15 +37,64 @@ export declare class Icp extends BaseCoin {
|
|
|
25
37
|
*/
|
|
26
38
|
generateKeyPair(seed?: Buffer): KeyPair;
|
|
27
39
|
isValidAddress(address: string): boolean;
|
|
28
|
-
signTransaction(
|
|
40
|
+
signTransaction(params: SignTransactionOptions & {
|
|
41
|
+
txPrebuild: {
|
|
42
|
+
txHex: string;
|
|
43
|
+
};
|
|
44
|
+
prv: string;
|
|
45
|
+
}): Promise<SignedTransaction>;
|
|
29
46
|
isValidPub(key: string): boolean;
|
|
30
47
|
isValidPrv(key: string): boolean;
|
|
31
48
|
/** @inheritDoc */
|
|
32
49
|
supportsTss(): boolean;
|
|
50
|
+
/** inherited doc */
|
|
51
|
+
getDefaultMultisigType(): MultisigType;
|
|
33
52
|
/** @inheritDoc */
|
|
34
53
|
getMPCAlgorithm(): MPCAlgorithm;
|
|
54
|
+
/** @inheritDoc **/
|
|
55
|
+
getHashFunction(): Hash;
|
|
35
56
|
private getAddressFromPublicKey;
|
|
36
57
|
/** @inheritDoc **/
|
|
37
58
|
protected getPublicNodeUrl(): string;
|
|
59
|
+
/** @inheritDoc **/
|
|
60
|
+
broadcastTransaction(payload: BaseBroadcastTransactionOptions): Promise<BaseBroadcastTransactionResult>;
|
|
61
|
+
private getPublicNodeBroadcastEndpoint;
|
|
62
|
+
/**
|
|
63
|
+
* Fetches the account balance for a given public key.
|
|
64
|
+
* @param publicKeyHex - Hex-encoded public key of the account.
|
|
65
|
+
* @returns Promise resolving to the account balance as a string.
|
|
66
|
+
* @throws Error if the balance could not be fetched.
|
|
67
|
+
*/
|
|
68
|
+
protected getAccountBalance(publicKeyHex: string): Promise<BigNumber>;
|
|
69
|
+
/**
|
|
70
|
+
* Retrieves the current transaction fee data from the ICP public node.
|
|
71
|
+
*
|
|
72
|
+
* This method creates an instance of `IcpAgent` using the public node URL,
|
|
73
|
+
* then queries the node for the current fee information.
|
|
74
|
+
*
|
|
75
|
+
* @returns A promise that resolves to a `BigNumber` representing the current transaction fee.
|
|
76
|
+
* @throws Will propagate any errors encountered while communicating with the ICP node.
|
|
77
|
+
*/
|
|
78
|
+
protected getFeeData(): Promise<BigNumber>;
|
|
79
|
+
private getBuilderFactory;
|
|
80
|
+
/**
|
|
81
|
+
* Generates an array of signatures for the provided payloads using MPC
|
|
82
|
+
*
|
|
83
|
+
* @param payloadsData - The data containing the payloads to be signed.
|
|
84
|
+
* @param senderPublicKey - The public key of the sender in hexadecimal format.
|
|
85
|
+
* @param userKeyShare - The user's key share as a Buffer.
|
|
86
|
+
* @param backupKeyShare - The backup key share as a Buffer.
|
|
87
|
+
* @param commonKeyChain - The common key chain identifier used for MPC signing.
|
|
88
|
+
* @returns A promise that resolves to an array of `Signatures` objects, each containing the signing payload,
|
|
89
|
+
* signature type, public key, and the generated signature in hexadecimal format.
|
|
90
|
+
*/
|
|
91
|
+
signatures(payloadsData: PayloadsData, senderPublicKey: string, userKeyShare: Buffer<ArrayBufferLike>, backupKeyShare: Buffer<ArrayBufferLike>, commonKeyChain: string): Promise<Signatures[]>;
|
|
92
|
+
/**
|
|
93
|
+
* Builds a funds recovery transaction without BitGo
|
|
94
|
+
* @param params
|
|
95
|
+
*/
|
|
96
|
+
recover(params: RecoveryOptions): Promise<RecoveryTransaction | UnsignedSweepRecoveryTransaction>;
|
|
97
|
+
/** @inheritDoc */
|
|
98
|
+
auditDecryptedKey({ multiSigType, prv, publicKey }: AuditDecryptedKeyParams): void;
|
|
38
99
|
}
|
|
39
100
|
//# sourceMappingURL=icp.d.ts.map
|
package/dist/src/icp.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"icp.d.ts","sourceRoot":"","sources":["../../src/icp.ts"],"names":[],"mappings":"
|
|
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
|
|
78
|
+
return this._staticsCoin.family;
|
|
35
79
|
}
|
|
36
80
|
getFullName() {
|
|
37
81
|
return 'Internet Computer';
|
|
@@ -39,14 +83,81 @@ 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
|
-
|
|
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
|
}
|
|
125
|
+
/**
|
|
126
|
+
* Verify that an address belongs to this wallet.
|
|
127
|
+
*
|
|
128
|
+
* @param {TssVerifyIcpAddressOptions} params - Verification parameters
|
|
129
|
+
* @returns {Promise<boolean>} True if address belongs to wallet
|
|
130
|
+
* @throws {InvalidAddressError} If address format is invalid or doesn't match derived address
|
|
131
|
+
* @throws {Error} If invalid wallet version or missing parameters
|
|
132
|
+
*/
|
|
45
133
|
async isWalletAddress(params) {
|
|
46
|
-
|
|
134
|
+
const { address, rootAddress, walletVersion } = params;
|
|
135
|
+
if (!this.isValidAddress(address)) {
|
|
136
|
+
throw new sdk_core_1.InvalidAddressError(`invalid address: ${address}`);
|
|
137
|
+
}
|
|
138
|
+
let addressToVerify = address;
|
|
139
|
+
if (walletVersion === 1) {
|
|
140
|
+
if (!rootAddress) {
|
|
141
|
+
throw new Error('rootAddress is required for wallet version 1');
|
|
142
|
+
}
|
|
143
|
+
const extractedRootAddress = utils_1.default.validateMemoAndReturnRootAddress(address);
|
|
144
|
+
if (!extractedRootAddress || extractedRootAddress === address) {
|
|
145
|
+
throw new Error('memoId is required for wallet version 1 addresses');
|
|
146
|
+
}
|
|
147
|
+
if (extractedRootAddress.toLowerCase() !== rootAddress.toLowerCase()) {
|
|
148
|
+
throw new sdk_core_1.UnexpectedAddressError(`address validation failure: expected ${rootAddress} but got ${extractedRootAddress}`);
|
|
149
|
+
}
|
|
150
|
+
addressToVerify = rootAddress;
|
|
151
|
+
}
|
|
152
|
+
const indexToVerify = walletVersion === 1 ? 0 : params.index;
|
|
153
|
+
const result = await (0, sdk_core_1.verifyMPCWalletAddress)({ ...params, address: addressToVerify, index: indexToVerify, keyCurve: 'secp256k1' }, this.isValidAddress.bind(this), (pubKey) => utils_1.default.getAddressFromPublicKey(pubKey));
|
|
154
|
+
if (!result) {
|
|
155
|
+
throw new sdk_core_1.UnexpectedAddressError(`address validation failure: address ${addressToVerify} is not a wallet address`);
|
|
156
|
+
}
|
|
157
|
+
return true;
|
|
47
158
|
}
|
|
48
159
|
async parseTransaction(params) {
|
|
49
|
-
|
|
160
|
+
return {};
|
|
50
161
|
}
|
|
51
162
|
/**
|
|
52
163
|
* Generate a new keypair for this coin.
|
|
@@ -56,10 +167,25 @@ class Icp extends sdk_core_1.BaseCoin {
|
|
|
56
167
|
return utils_1.default.generateKeyPair(seed);
|
|
57
168
|
}
|
|
58
169
|
isValidAddress(address) {
|
|
59
|
-
|
|
170
|
+
return utils_1.default.isValidAddress(address);
|
|
60
171
|
}
|
|
61
|
-
signTransaction(
|
|
62
|
-
|
|
172
|
+
async signTransaction(params) {
|
|
173
|
+
const txHex = params?.txPrebuild?.txHex;
|
|
174
|
+
const privateKey = params?.prv;
|
|
175
|
+
if (!txHex) {
|
|
176
|
+
throw new sdk_core_1.SigningError('missing required txPrebuild parameter: params.txPrebuild.txHex');
|
|
177
|
+
}
|
|
178
|
+
if (!privateKey) {
|
|
179
|
+
throw new sdk_core_1.SigningError('missing required prv parameter: params.prv');
|
|
180
|
+
}
|
|
181
|
+
const factory = this.getBuilderFactory();
|
|
182
|
+
const txBuilder = await factory.from(params.txPrebuild.txHex);
|
|
183
|
+
txBuilder.sign({ key: params.prv });
|
|
184
|
+
txBuilder.combine();
|
|
185
|
+
const serializedTx = txBuilder.transaction.toBroadcastFormat();
|
|
186
|
+
return {
|
|
187
|
+
txHex: serializedTx,
|
|
188
|
+
};
|
|
63
189
|
}
|
|
64
190
|
isValidPub(key) {
|
|
65
191
|
return utils_1.default.isValidPublicKey(key);
|
|
@@ -71,17 +197,213 @@ class Icp extends sdk_core_1.BaseCoin {
|
|
|
71
197
|
supportsTss() {
|
|
72
198
|
return true;
|
|
73
199
|
}
|
|
200
|
+
/** inherited doc */
|
|
201
|
+
getDefaultMultisigType() {
|
|
202
|
+
return sdk_core_1.multisigTypes.tss;
|
|
203
|
+
}
|
|
74
204
|
/** @inheritDoc */
|
|
75
205
|
getMPCAlgorithm() {
|
|
76
206
|
return 'ecdsa';
|
|
77
207
|
}
|
|
78
|
-
|
|
208
|
+
/** @inheritDoc **/
|
|
209
|
+
getHashFunction() {
|
|
210
|
+
return (0, crypto_1.createHash)('sha256');
|
|
211
|
+
}
|
|
212
|
+
getAddressFromPublicKey(hexEncodedPublicKey) {
|
|
79
213
|
return utils_1.default.getAddressFromPublicKey(hexEncodedPublicKey);
|
|
80
214
|
}
|
|
81
215
|
/** @inheritDoc **/
|
|
82
216
|
getPublicNodeUrl() {
|
|
83
|
-
return sdk_core_1.Environments[this.bitgo.getEnv()].
|
|
217
|
+
return sdk_core_1.Environments[this.bitgo.getEnv()].icpNodeUrl;
|
|
218
|
+
}
|
|
219
|
+
/** @inheritDoc **/
|
|
220
|
+
// this method calls the public node to broadcast the transaction and not the rosetta node
|
|
221
|
+
async broadcastTransaction(payload) {
|
|
222
|
+
const endpoint = this.getPublicNodeBroadcastEndpoint();
|
|
223
|
+
try {
|
|
224
|
+
const bodyBytes = utils_1.default.blobFromHex(payload.serializedSignedTransaction);
|
|
225
|
+
const response = await axios_1.default.post(endpoint, bodyBytes, {
|
|
226
|
+
headers: { 'Content-Type': 'application/cbor' },
|
|
227
|
+
responseType: 'arraybuffer', // This ensures you get a Buffer, not a string
|
|
228
|
+
});
|
|
229
|
+
if (response.status !== 200) {
|
|
230
|
+
throw new Error(`Transaction broadcast failed with status: ${response.status} - ${response.statusText}`);
|
|
231
|
+
}
|
|
232
|
+
const decodedResponse = utils_1.default.cborDecode(response.data);
|
|
233
|
+
if (decodedResponse.status === 'replied') {
|
|
234
|
+
// it is considered a success because ICP returns response in a CBOR map with a status of 'replied'
|
|
235
|
+
return {}; // returned empty object as ICP does not return a txid
|
|
236
|
+
}
|
|
237
|
+
else {
|
|
238
|
+
throw new Error(`Unexpected response status from node: ${decodedResponse.status}`);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
catch (error) {
|
|
242
|
+
throw new Error(`Transaction broadcast error: ${error?.message || JSON.stringify(error)}`);
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
getPublicNodeBroadcastEndpoint() {
|
|
246
|
+
const nodeUrl = this.getPublicNodeUrl();
|
|
247
|
+
const ledgerCanisterId = this._staticsCoin.network.type === statics_1.NetworkType.TESTNET ? iface_1.TESTNET_LEDGER_CANISTER_ID : iface_1.LEDGER_CANISTER_ID;
|
|
248
|
+
const principal = principal_1.Principal.fromUint8Array(ledgerCanisterId);
|
|
249
|
+
const canisterIdHex = principal.toText();
|
|
250
|
+
const endpoint = `${nodeUrl}${iface_1.PUBLIC_NODE_REQUEST_ENDPOINT}${canisterIdHex}/call`;
|
|
251
|
+
return endpoint;
|
|
252
|
+
}
|
|
253
|
+
/**
|
|
254
|
+
* Fetches the account balance for a given public key.
|
|
255
|
+
* @param publicKeyHex - Hex-encoded public key of the account.
|
|
256
|
+
* @returns Promise resolving to the account balance as a string.
|
|
257
|
+
* @throws Error if the balance could not be fetched.
|
|
258
|
+
*/
|
|
259
|
+
async getAccountBalance(publicKeyHex) {
|
|
260
|
+
const principalId = utils_1.default.getPrincipalIdFromPublicKey(publicKeyHex).toText();
|
|
261
|
+
const agent = new icpAgent_1.IcpAgent(this.getPublicNodeUrl(), this._staticsCoin);
|
|
262
|
+
return agent.getBalance(principalId);
|
|
263
|
+
}
|
|
264
|
+
/**
|
|
265
|
+
* Retrieves the current transaction fee data from the ICP public node.
|
|
266
|
+
*
|
|
267
|
+
* This method creates an instance of `IcpAgent` using the public node URL,
|
|
268
|
+
* then queries the node for the current fee information.
|
|
269
|
+
*
|
|
270
|
+
* @returns A promise that resolves to a `BigNumber` representing the current transaction fee.
|
|
271
|
+
* @throws Will propagate any errors encountered while communicating with the ICP node.
|
|
272
|
+
*/
|
|
273
|
+
async getFeeData() {
|
|
274
|
+
const agent = new icpAgent_1.IcpAgent(this.getPublicNodeUrl(), this._staticsCoin);
|
|
275
|
+
return await agent.getFee();
|
|
276
|
+
}
|
|
277
|
+
getBuilderFactory() {
|
|
278
|
+
return new transactionBuilderFactory_1.TransactionBuilderFactory(statics_1.coins.get(this.getBaseChain()));
|
|
279
|
+
}
|
|
280
|
+
/**
|
|
281
|
+
* Generates an array of signatures for the provided payloads using MPC
|
|
282
|
+
*
|
|
283
|
+
* @param payloadsData - The data containing the payloads to be signed.
|
|
284
|
+
* @param senderPublicKey - The public key of the sender in hexadecimal format.
|
|
285
|
+
* @param userKeyShare - The user's key share as a Buffer.
|
|
286
|
+
* @param backupKeyShare - The backup key share as a Buffer.
|
|
287
|
+
* @param commonKeyChain - The common key chain identifier used for MPC signing.
|
|
288
|
+
* @returns A promise that resolves to an array of `Signatures` objects, each containing the signing payload,
|
|
289
|
+
* signature type, public key, and the generated signature in hexadecimal format.
|
|
290
|
+
*/
|
|
291
|
+
async signatures(payloadsData, senderPublicKey, userKeyShare, backupKeyShare, commonKeyChain) {
|
|
292
|
+
try {
|
|
293
|
+
const payload = payloadsData.payloads[0];
|
|
294
|
+
const message = Buffer.from(payload.hex_bytes, 'hex');
|
|
295
|
+
const messageHash = (0, crypto_1.createHash)('sha256').update(message).digest();
|
|
296
|
+
const signature = await sdk_core_1.ECDSAUtils.signRecoveryMpcV2(messageHash, userKeyShare, backupKeyShare, commonKeyChain);
|
|
297
|
+
const signaturePayload = {
|
|
298
|
+
signing_payload: payload,
|
|
299
|
+
signature_type: payload.signature_type,
|
|
300
|
+
public_key: {
|
|
301
|
+
hex_bytes: senderPublicKey,
|
|
302
|
+
curve_type: iface_1.CurveType.SECP256K1,
|
|
303
|
+
},
|
|
304
|
+
hex_bytes: signature.r + signature.s,
|
|
305
|
+
};
|
|
306
|
+
return [signaturePayload];
|
|
307
|
+
}
|
|
308
|
+
catch (error) {
|
|
309
|
+
throw new Error(`Error generating signatures: ${error.message || error}`);
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
/**
|
|
313
|
+
* Builds a funds recovery transaction without BitGo
|
|
314
|
+
* @param params
|
|
315
|
+
*/
|
|
316
|
+
async recover(params) {
|
|
317
|
+
try {
|
|
318
|
+
if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {
|
|
319
|
+
throw new Error('invalid recoveryDestination');
|
|
320
|
+
}
|
|
321
|
+
const isUnsignedSweep = !params.userKey && !params.backupKey && !params.walletPassphrase;
|
|
322
|
+
let publicKey;
|
|
323
|
+
let userKeyShare, backupKeyShare, commonKeyChain;
|
|
324
|
+
const MPC = new sdk_core_1.Ecdsa();
|
|
325
|
+
if (!isUnsignedSweep) {
|
|
326
|
+
if (!params.userKey) {
|
|
327
|
+
throw new Error('missing userKey');
|
|
328
|
+
}
|
|
329
|
+
if (!params.backupKey) {
|
|
330
|
+
throw new Error('missing backupKey');
|
|
331
|
+
}
|
|
332
|
+
if (!params.walletPassphrase) {
|
|
333
|
+
throw new Error('missing wallet passphrase');
|
|
334
|
+
}
|
|
335
|
+
const userKey = params.userKey.replace(/\s/g, '');
|
|
336
|
+
const backupKey = params.backupKey.replace(/\s/g, '');
|
|
337
|
+
({ userKeyShare, backupKeyShare, commonKeyChain } = await sdk_core_1.ECDSAUtils.getMpcV2RecoveryKeyShares(userKey, backupKey, params.walletPassphrase));
|
|
338
|
+
publicKey = MPC.deriveUnhardened(commonKeyChain, iface_1.ROOT_PATH).slice(0, 66);
|
|
339
|
+
}
|
|
340
|
+
else {
|
|
341
|
+
const bitgoKey = params.bitgoKey;
|
|
342
|
+
if (!bitgoKey) {
|
|
343
|
+
throw new Error('missing bitgoKey');
|
|
344
|
+
}
|
|
345
|
+
const hdTree = new mpc.Secp256k1Bip32HdTree();
|
|
346
|
+
const derivationPath = 'm/0';
|
|
347
|
+
const derivedPub = hdTree.publicDerive({
|
|
348
|
+
pk: mpc.bigIntFromBufferBE(Buffer.from(bitgoKey.slice(0, 66), 'hex')),
|
|
349
|
+
chaincode: mpc.bigIntFromBufferBE(Buffer.from(bitgoKey.slice(66), 'hex')),
|
|
350
|
+
}, derivationPath);
|
|
351
|
+
publicKey = mpc.bigIntToBufferBE(derivedPub.pk).toString('hex');
|
|
352
|
+
}
|
|
353
|
+
if (!publicKey) {
|
|
354
|
+
throw new Error('failed to derive public key');
|
|
355
|
+
}
|
|
356
|
+
const senderAddress = this.getAddressFromPublicKey(publicKey);
|
|
357
|
+
const balance = await this.getAccountBalance(publicKey);
|
|
358
|
+
const feeData = await this.getFeeData();
|
|
359
|
+
const actualBalance = balance.minus(feeData);
|
|
360
|
+
if (actualBalance.isLessThanOrEqualTo(0)) {
|
|
361
|
+
throw new Error('Did not have enough funds to recover');
|
|
362
|
+
}
|
|
363
|
+
const factory = this.getBuilderFactory();
|
|
364
|
+
const txBuilder = factory.getTransferBuilder();
|
|
365
|
+
txBuilder.sender(senderAddress, publicKey);
|
|
366
|
+
txBuilder.receiverId(params.recoveryDestination);
|
|
367
|
+
txBuilder.amount(actualBalance.toString());
|
|
368
|
+
if (params.memo !== undefined && utils_1.default.validateMemo(params.memo)) {
|
|
369
|
+
txBuilder.memo(Number(params.memo));
|
|
370
|
+
}
|
|
371
|
+
await txBuilder.build();
|
|
372
|
+
if (txBuilder.transaction.payloadsData.payloads.length === 0) {
|
|
373
|
+
throw new Error('Missing payloads to generate signatures');
|
|
374
|
+
}
|
|
375
|
+
if (isUnsignedSweep) {
|
|
376
|
+
return {
|
|
377
|
+
txHex: txBuilder.transaction.unsignedTransaction,
|
|
378
|
+
coin: this.getChain(),
|
|
379
|
+
};
|
|
380
|
+
}
|
|
381
|
+
const signatures = await this.signatures(txBuilder.transaction.payloadsData, publicKey, userKeyShare, backupKeyShare, commonKeyChain);
|
|
382
|
+
if (!signatures || signatures.length === 0) {
|
|
383
|
+
throw new Error('Failed to generate signatures');
|
|
384
|
+
}
|
|
385
|
+
txBuilder.transaction.addSignature(signatures);
|
|
386
|
+
txBuilder.combine();
|
|
387
|
+
const broadcastableTxn = txBuilder.transaction.toBroadcastFormat();
|
|
388
|
+
await this.broadcastTransaction({ serializedSignedTransaction: broadcastableTxn });
|
|
389
|
+
const txId = txBuilder.transaction.id;
|
|
390
|
+
const recoveredTransaction = {
|
|
391
|
+
id: txId,
|
|
392
|
+
tx: broadcastableTxn,
|
|
393
|
+
};
|
|
394
|
+
return recoveredTransaction;
|
|
395
|
+
}
|
|
396
|
+
catch (error) {
|
|
397
|
+
throw new Error(`Error during ICP recovery: ${error.message || error}`);
|
|
398
|
+
}
|
|
399
|
+
}
|
|
400
|
+
/** @inheritDoc */
|
|
401
|
+
auditDecryptedKey({ multiSigType, prv, publicKey }) {
|
|
402
|
+
if (multiSigType !== 'tss') {
|
|
403
|
+
throw new Error('Unsupported multisigtype ');
|
|
404
|
+
}
|
|
405
|
+
(0, sdk_lib_mpc_1.auditEcdsaPrivateKey)(prv, publicKey);
|
|
84
406
|
}
|
|
85
407
|
}
|
|
86
408
|
exports.Icp = Icp;
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ljcC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxtREFZOEI7QUFFOUIsd0RBQWdDO0FBRWhDOzs7Ozs7R0FNRztBQUNILE1BQWEsR0FBSSxTQUFRLG1CQUFRO0lBRS9CLFlBQXNCLEtBQWdCLEVBQUUsV0FBdUM7UUFDN0UsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRWIsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ2pCLE1BQU0sSUFBSSxLQUFLLENBQUMsb0RBQW9ELENBQUMsQ0FBQztRQUN4RSxDQUFDO1FBRUQsSUFBSSxDQUFDLFlBQVksR0FBRyxXQUFXLENBQUM7SUFDbEMsQ0FBQztJQUVELE1BQU0sQ0FBQyxjQUFjLENBQUMsS0FBZ0IsRUFBRSxXQUF1QztRQUM3RSxPQUFPLElBQUksR0FBRyxDQUFDLEtBQUssRUFBRSxXQUFXLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQsUUFBUTtRQUNOLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVELFlBQVk7UUFDVixPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7SUFFRCxTQUFTO1FBQ1AsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0lBRUQsV0FBVztRQUNULE9BQU8sbUJBQW1CLENBQUM7SUFDN0IsQ0FBQztJQUVELGFBQWE7UUFDWCxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVELEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxNQUFnQztRQUN0RCxNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVELEtBQUssQ0FBQyxlQUFlLENBQUMsTUFBK0I7UUFDbkQsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFFRCxLQUFLLENBQUMsZ0JBQWdCLENBQUMsTUFBK0I7UUFDcEQsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFFRDs7O09BR0c7SUFDSSxlQUFlLENBQUMsSUFBYTtRQUNsQyxPQUFPLGVBQUssQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVELGNBQWMsQ0FBQyxPQUFlO1FBQzVCLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsZUFBZSxDQUFDLENBQXlCO1FBQ3ZDLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsVUFBVSxDQUFDLEdBQVc7UUFDcEIsT0FBTyxlQUFLLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVELFVBQVUsQ0FBQyxHQUFXO1FBQ3BCLE9BQU8sZUFBSyxDQUFDLGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxrQkFBa0I7SUFDbEIsV0FBVztRQUNULE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELGtCQUFrQjtJQUNsQixlQUFlO1FBQ2IsT0FBTyxPQUFPLENBQUM7SUFDakIsQ0FBQztJQUVPLEtBQUssQ0FBQyx1QkFBdUIsQ0FBQyxtQkFBMkI7UUFDL0QsT0FBTyxlQUFLLENBQUMsdUJBQXVCLENBQUMsbUJBQW1CLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRUQsbUJBQW1CO0lBQ1QsZ0JBQWdCO1FBQ3hCLE9BQU8sdUJBQVksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUMsY0FBYyxDQUFDO0lBQzFELENBQUM7Q0FDRjtBQTFGRCxrQkEwRkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBCYXNlQ29pbixcbiAgQml0R29CYXNlLFxuICBNUENBbGdvcml0aG0sXG4gIFZlcmlmeVRyYW5zYWN0aW9uT3B0aW9ucyxcbiAgVHNzVmVyaWZ5QWRkcmVzc09wdGlvbnMsXG4gIFBhcnNlVHJhbnNhY3Rpb25PcHRpb25zLFxuICBQYXJzZWRUcmFuc2FjdGlvbixcbiAgS2V5UGFpcixcbiAgU2lnblRyYW5zYWN0aW9uT3B0aW9ucyxcbiAgU2lnbmVkVHJhbnNhY3Rpb24sXG4gIEVudmlyb25tZW50cyxcbn0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgQmFzZUNvaW4gYXMgU3RhdGljc0Jhc2VDb2luIH0gZnJvbSAnQGJpdGdvLWJldGEvc3RhdGljcyc7XG5pbXBvcnQgdXRpbHMgZnJvbSAnLi9saWIvdXRpbHMnO1xuXG4vKipcbiAqIENsYXNzIHJlcHJlc2VudGluZyB0aGUgSW50ZXJuZXQgQ29tcHV0ZXIgKElDUCkgY29pbi5cbiAqIEV4dGVuZHMgdGhlIEJhc2VDb2luIGNsYXNzIGFuZCBwcm92aWRlcyBzcGVjaWZpYyBpbXBsZW1lbnRhdGlvbnMgZm9yIElDUC5cbiAqXG4gKiBAc2VlIHtAbGluayBodHRwczovL2ludGVybmV0Y29tcHV0ZXIub3JnL31cbiAqIEBzZWUge0BsaW5rIGh0dHBzOi8vaW50ZXJuZXRjb21wdXRlci5vcmcvZG9jcy9jdXJyZW50L2RldmVsb3Blci1kb2NzL2RlZmkvcm9zZXR0YS9pY3Bfcm9zZXR0YS9kYXRhX2FwaS99XG4gKi9cbmV4cG9ydCBjbGFzcyBJY3AgZXh0ZW5kcyBCYXNlQ29pbiB7XG4gIHByb3RlY3RlZCByZWFkb25seSBfc3RhdGljc0NvaW46IFJlYWRvbmx5PFN0YXRpY3NCYXNlQ29pbj47XG4gIHByb3RlY3RlZCBjb25zdHJ1Y3RvcihiaXRnbzogQml0R29CYXNlLCBzdGF0aWNzQ29pbj86IFJlYWRvbmx5PFN0YXRpY3NCYXNlQ29pbj4pIHtcbiAgICBzdXBlcihiaXRnbyk7XG5cbiAgICBpZiAoIXN0YXRpY3NDb2luKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ21pc3NpbmcgcmVxdWlyZWQgY29uc3RydWN0b3IgcGFyYW1ldGVyIHN0YXRpY3NDb2luJyk7XG4gICAgfVxuXG4gICAgdGhpcy5fc3RhdGljc0NvaW4gPSBzdGF0aWNzQ29pbjtcbiAgfVxuXG4gIHN0YXRpYyBjcmVhdGVJbnN0YW5jZShiaXRnbzogQml0R29CYXNlLCBzdGF0aWNzQ29pbj86IFJlYWRvbmx5PFN0YXRpY3NCYXNlQ29pbj4pOiBCYXNlQ29pbiB7XG4gICAgcmV0dXJuIG5ldyBJY3AoYml0Z28sIHN0YXRpY3NDb2luKTtcbiAgfVxuXG4gIGdldENoYWluKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuICdpY3AnO1xuICB9XG5cbiAgZ2V0QmFzZUNoYWluKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuICdpY3AnO1xuICB9XG5cbiAgZ2V0RmFtaWx5KCk6IHN0cmluZyB7XG4gICAgcmV0dXJuICdpY3AnO1xuICB9XG5cbiAgZ2V0RnVsbE5hbWUoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gJ0ludGVybmV0IENvbXB1dGVyJztcbiAgfVxuXG4gIGdldEJhc2VGYWN0b3IoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gTWF0aC5wb3coMTAsIHRoaXMuX3N0YXRpY3NDb2luLmRlY2ltYWxQbGFjZXMpO1xuICB9XG5cbiAgYXN5bmMgdmVyaWZ5VHJhbnNhY3Rpb24ocGFyYW1zOiBWZXJpZnlUcmFuc2FjdGlvbk9wdGlvbnMpOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cblxuICBhc3luYyBpc1dhbGxldEFkZHJlc3MocGFyYW1zOiBUc3NWZXJpZnlBZGRyZXNzT3B0aW9ucyk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICAgIHRocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcbiAgfVxuXG4gIGFzeW5jIHBhcnNlVHJhbnNhY3Rpb24ocGFyYW1zOiBQYXJzZVRyYW5zYWN0aW9uT3B0aW9ucyk6IFByb21pc2U8UGFyc2VkVHJhbnNhY3Rpb24+IHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cblxuICAvKipcbiAgICogR2VuZXJhdGUgYSBuZXcga2V5cGFpciBmb3IgdGhpcyBjb2luLlxuICAgKiBAcGFyYW0gc2VlZCBTZWVkIGZyb20gd2hpY2ggdGhlIG5ldyBrZXlwYWlyIHNob3VsZCBiZSBnZW5lcmF0ZWQsIG90aGVyd2lzZSBhIHJhbmRvbSBzZWVkIGlzIHVzZWRcbiAgICovXG4gIHB1YmxpYyBnZW5lcmF0ZUtleVBhaXIoc2VlZD86IEJ1ZmZlcik6IEtleVBhaXIge1xuICAgIHJldHVybiB1dGlscy5nZW5lcmF0ZUtleVBhaXIoc2VlZCk7XG4gIH1cblxuICBpc1ZhbGlkQWRkcmVzcyhhZGRyZXNzOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cblxuICBzaWduVHJhbnNhY3Rpb24oXzogU2lnblRyYW5zYWN0aW9uT3B0aW9ucyk6IFByb21pc2U8U2lnbmVkVHJhbnNhY3Rpb24+IHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ01ldGhvZCBub3QgaW1wbGVtZW50ZWQuJyk7XG4gIH1cblxuICBpc1ZhbGlkUHViKGtleTogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHV0aWxzLmlzVmFsaWRQdWJsaWNLZXkoa2V5KTtcbiAgfVxuXG4gIGlzVmFsaWRQcnYoa2V5OiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdXRpbHMuaXNWYWxpZFByaXZhdGVLZXkoa2V5KTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdERvYyAqL1xuICBzdXBwb3J0c1RzcygpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdERvYyAqL1xuICBnZXRNUENBbGdvcml0aG0oKTogTVBDQWxnb3JpdGhtIHtcbiAgICByZXR1cm4gJ2VjZHNhJztcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgZ2V0QWRkcmVzc0Zyb21QdWJsaWNLZXkoaGV4RW5jb2RlZFB1YmxpY0tleTogc3RyaW5nKSB7XG4gICAgcmV0dXJuIHV0aWxzLmdldEFkZHJlc3NGcm9tUHVibGljS2V5KGhleEVuY29kZWRQdWJsaWNLZXkpO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0RG9jICoqL1xuICBwcm90ZWN0ZWQgZ2V0UHVibGljTm9kZVVybCgpOiBzdHJpbmcge1xuICAgIHJldHVybiBFbnZpcm9ubWVudHNbdGhpcy5iaXRnby5nZXRFbnYoKV0ucm9zZXR0YU5vZGVVUkw7XG4gIH1cbn1cbiJdfQ==
|
|
409
|
+
//# 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  InvalidAddressError,\n  KeyPair,\n  MPCAlgorithm,\n  MultisigType,\n  multisigTypes,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SigningError,\n  SignTransactionOptions,\n  VerifyTransactionOptions,\n  verifyMPCWalletAddress,\n  UnexpectedAddressError,\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  TssVerifyIcpAddressOptions,\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  /**\n   * Verify that an address belongs to this wallet.\n   *\n   * @param {TssVerifyIcpAddressOptions} params - Verification parameters\n   * @returns {Promise<boolean>} True if address belongs to wallet\n   * @throws {InvalidAddressError} If address format is invalid or doesn't match derived address\n   * @throws {Error} If invalid wallet version or missing parameters\n   */\n  async isWalletAddress(params: TssVerifyIcpAddressOptions): Promise<boolean> {\n    const { address, rootAddress, walletVersion } = params;\n\n    if (!this.isValidAddress(address)) {\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n\n    let addressToVerify = address;\n    if (walletVersion === 1) {\n      if (!rootAddress) {\n        throw new Error('rootAddress is required for wallet version 1');\n      }\n      const extractedRootAddress = utils.validateMemoAndReturnRootAddress(address);\n      if (!extractedRootAddress || extractedRootAddress === address) {\n        throw new Error('memoId is required for wallet version 1 addresses');\n      }\n      if (extractedRootAddress.toLowerCase() !== rootAddress.toLowerCase()) {\n        throw new UnexpectedAddressError(\n          `address validation failure: expected ${rootAddress} but got ${extractedRootAddress}`\n        );\n      }\n      addressToVerify = rootAddress;\n    }\n\n    const indexToVerify = walletVersion === 1 ? 0 : params.index;\n    const result = await verifyMPCWalletAddress(\n      { ...params, address: addressToVerify, index: indexToVerify, keyCurve: 'secp256k1' },\n      this.isValidAddress.bind(this),\n      (pubKey) => utils.getAddressFromPublicKey(pubKey)\n    );\n\n    if (!result) {\n      throw new UnexpectedAddressError(\n        `address validation failure: address ${addressToVerify} is not a wallet address`\n      );\n    }\n\n    return true;\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 getAddressFromPublicKey(hexEncodedPublicKey: string): 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 = 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"}
|