PHP WebShell
Текущая директория: /opt/BitGoJS/modules/sdk-coin-sui/dist/src
Просмотр файла: sui.js
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.Sui = void 0;
const sdk_core_1 = require("@bitgo/sdk-core");
const statics_1 = require("@bitgo/statics");
const bignumber_js_1 = __importDefault(require("bignumber.js"));
const lib_1 = require("./lib");
const utils_1 = __importDefault(require("./lib/utils"));
const _ = __importStar(require("lodash"));
const iface_1 = require("./lib/iface");
const constants_1 = require("./lib/constants");
const sdk_lib_mpc_1 = require("@bitgo/sdk-lib-mpc");
class Sui extends sdk_core_1.BaseCoin {
constructor(bitgo, staticsCoin) {
super(bitgo);
if (!staticsCoin) {
throw new Error('missing required constructor parameter staticsCoin');
}
this._staticsCoin = staticsCoin;
}
static createInstance(bitgo, staticsCoin) {
return new Sui(bitgo, staticsCoin);
}
/**
* Factor between the coin's base unit and its smallest subdivison
*/
getBaseFactor() {
return 1e9;
}
getChain() {
return 'sui';
}
getFamily() {
return 'sui';
}
getFullName() {
return 'Sui';
}
getNetwork() {
return this._staticsCoin.network;
}
/** @inheritDoc */
supportsTss() {
return true;
}
/** inherited doc */
getDefaultMultisigType() {
return sdk_core_1.multisigTypes.tss;
}
getMPCAlgorithm() {
return 'eddsa';
}
allowsAccountConsolidations() {
return true;
}
async verifyTransaction(params) {
let totalAmount = new bignumber_js_1.default(0);
const coinConfig = statics_1.coins.get(this.getChain());
const { txPrebuild: txPrebuild, txParams: txParams } = params;
const transaction = new lib_1.TransferTransaction(coinConfig);
const rawTx = txPrebuild.txHex;
if (!rawTx) {
throw new Error('missing required tx prebuild property txHex');
}
transaction.fromRawTransaction(Buffer.from(rawTx, 'hex').toString('base64'));
const explainedTx = transaction.explainTransaction();
if (txParams.recipients && txParams.recipients.length > 0) {
const filteredRecipients = txParams.recipients?.map((recipient) => {
const filteredRecipient = _.pick(recipient, ['address', 'amount']);
filteredRecipient.amount = new bignumber_js_1.default(filteredRecipient.amount).toFixed();
return filteredRecipient;
});
const filteredOutputs = explainedTx.outputs.map((output) => {
const filteredOutput = _.pick(output, ['address', 'amount']);
filteredOutput.amount = new bignumber_js_1.default(filteredOutput.amount).toFixed();
return filteredOutput;
});
if (!_.isEqual(filteredOutputs, filteredRecipients)) {
throw new Error('Tx outputs does not match with expected txParams recipients');
}
for (const recipients of txParams.recipients) {
totalAmount = totalAmount.plus(recipients.amount);
}
if (!totalAmount.isEqualTo(explainedTx.outputAmount)) {
throw new Error('Tx total amount does not match with expected total amount field');
}
}
return true;
}
async isWalletAddress(params) {
const { address: newAddress } = params;
if (!this.isValidAddress(newAddress)) {
throw new sdk_core_1.InvalidAddressError(`invalid address: ${newAddress}`);
}
return true;
}
async parseTransaction(params) {
const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });
if (!transactionExplanation) {
throw new Error('Invalid transaction');
}
let fee = new bignumber_js_1.default(0);
const suiTransaction = transactionExplanation;
if (suiTransaction.outputs.length <= 0) {
return {
inputs: [],
outputs: [],
fee,
};
}
const senderAddress = suiTransaction.outputs[0].address;
if (suiTransaction.fee.fee !== '') {
fee = new bignumber_js_1.default(suiTransaction.fee.fee);
}
// assume 1 sender, who is also the fee payer
const inputs = [
{
address: senderAddress,
amount: new bignumber_js_1.default(suiTransaction.outputAmount).plus(fee).toFixed(),
},
];
const outputs = suiTransaction.outputs.map((output) => {
return {
address: output.address,
amount: new bignumber_js_1.default(output.amount).toFixed(),
};
});
return {
inputs,
outputs,
fee,
};
}
generateKeyPair(seed) {
const keyPair = seed ? new lib_1.KeyPair({ seed }) : new lib_1.KeyPair();
const keys = keyPair.getKeys();
if (!keys.prv) {
throw new Error('Missing prv in key generation.');
}
return {
pub: keys.pub,
prv: keys.prv,
};
}
isValidPub(_) {
throw new Error('Method not implemented.');
}
isValidPrv(_) {
throw new Error('Method not implemented.');
}
isValidAddress(address) {
return utils_1.default.isValidAddress(address);
}
signTransaction(_) {
throw new Error('Method not implemented.');
}
/**
* Explain a Sui transaction
* @param params
*/
async explainTransaction(params) {
const factory = this.getBuilder();
let rebuiltTransaction;
try {
const transactionBuilder = factory.from(Buffer.from(params.txHex, 'hex').toString('base64'));
rebuiltTransaction = await transactionBuilder.build();
}
catch {
throw new Error('Invalid transaction');
}
return rebuiltTransaction.explainTransaction();
}
getBuilder() {
return new lib_1.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
}
getAddressFromPublicKey(derivedPublicKey) {
// TODO(BG-59016) replace with account lib implementation
return utils_1.default.getAddressFromPublicKey(derivedPublicKey);
}
/** @inheritDoc */
async getSignablePayload(serializedTx) {
const factory = this.getBuilder();
const rebuiltTransaction = await factory.from(serializedTx).build();
return rebuiltTransaction.signablePayload;
}
getPublicNodeUrl() {
return sdk_core_1.Environments[this.bitgo.getEnv()].suiNodeUrl;
}
async getBalance(owner, coinType) {
const url = this.getPublicNodeUrl();
return await utils_1.default.getBalance(url, owner, coinType);
}
async getInputCoins(owner, coinType) {
const url = this.getPublicNodeUrl();
return await utils_1.default.getInputCoins(url, owner, coinType);
}
async getFeeEstimate(txHex) {
const url = this.getPublicNodeUrl();
return await utils_1.default.getFeeEstimate(url, txHex);
}
/**
* Builds funds recovery transaction(s) without BitGo
*
* @param {MPCRecoveryOptions} params parameters needed to construct and
* (maybe) sign the transaction
*
* @returns {MPCTx | MPCSweepTxs} array of the serialized transaction hex strings and indices
* of the addresses being swept
*/
async recover(params) {
if (!params.bitgoKey) {
throw new Error('missing bitgoKey');
}
if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {
throw new Error('invalid recoveryDestination');
}
const startIdx = utils_1.default.validateNonNegativeNumber(0, 'Invalid starting index to scan for addresses', params.startingScanIndex);
const numIterations = utils_1.default.validateNonNegativeNumber(20, 'Invalid scanning factor', params.scan);
const endIdx = startIdx + numIterations;
const bitgoKey = params.bitgoKey.replace(/\s/g, '');
const MPC = await sdk_core_1.EDDSAMethods.getInitializedMpcInstance();
for (let idx = startIdx; idx < endIdx; idx++) {
const derivationPath = (params.seed ? (0, sdk_lib_mpc_1.getDerivationPath)(params.seed) : 'm') + `/${idx}`;
const derivedPublicKey = MPC.deriveUnhardened(bitgoKey, derivationPath).slice(0, 64);
const senderAddress = this.getAddressFromPublicKey(derivedPublicKey);
let availableBalance = new bignumber_js_1.default(0);
try {
availableBalance = new bignumber_js_1.default(await this.getBalance(senderAddress));
}
catch (e) {
continue;
}
if (availableBalance.minus(constants_1.MAX_GAS_BUDGET).toNumber() <= 0) {
continue;
}
// check for possible token recovery, recover the token provide by user
if (params.tokenContractAddress) {
const token = utils_1.default.getSuiTokenFromAddress(params.tokenContractAddress, this.getNetwork());
if (!token) {
throw new Error(`Sui Token Package ID not supported.`);
}
const coinType = `${token.packageId}::${token.module}::${token.symbol}`;
try {
const availableTokenBalance = new bignumber_js_1.default(await this.getBalance(senderAddress, coinType));
if (availableTokenBalance.toNumber() <= 0) {
continue;
}
}
catch (e) {
continue;
}
return this.recoverSuiToken(params, token, senderAddress, derivationPath, derivedPublicKey, idx, bitgoKey);
}
let inputCoins = await this.getInputCoins(senderAddress);
inputCoins = inputCoins.sort((a, b) => {
return b.balance.minus(a.balance).toNumber();
});
if (inputCoins.length > constants_1.MAX_OBJECT_LIMIT) {
inputCoins = inputCoins.slice(0, constants_1.MAX_OBJECT_LIMIT);
}
let netAmount = inputCoins.reduce((acc, obj) => acc.plus(obj.balance), new bignumber_js_1.default(0));
netAmount = netAmount.minus(constants_1.MAX_GAS_BUDGET);
const recipients = [
{
address: params.recoveryDestination,
amount: netAmount.toString(),
},
];
// first build the unsigned txn
const factory = new lib_1.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
const txBuilder = factory
.getTransferBuilder()
.type(iface_1.SuiTransactionType.Transfer)
.sender(senderAddress)
.send(recipients)
.gasData({
owner: senderAddress,
price: constants_1.DEFAULT_GAS_PRICE,
budget: constants_1.MAX_GAS_BUDGET,
payment: inputCoins,
});
const tempTx = (await txBuilder.build());
const feeEstimate = await this.getFeeEstimate(tempTx.toBroadcastFormat());
const gasBudget = Math.trunc(feeEstimate.toNumber() * constants_1.DEFAULT_GAS_OVERHEAD);
netAmount = netAmount.plus(constants_1.MAX_GAS_BUDGET).minus(gasBudget);
recipients[0].amount = netAmount.toString();
txBuilder.send(recipients);
txBuilder.gasData({
owner: senderAddress,
price: constants_1.DEFAULT_GAS_PRICE,
budget: gasBudget,
payment: inputCoins,
});
const isUnsignedSweep = !params.userKey && !params.backupKey && !params.walletPassphrase;
if (isUnsignedSweep) {
return this.buildUnsignedSweepTransaction(txBuilder, senderAddress, bitgoKey, idx, derivationPath);
}
await this.signRecoveryTransaction(txBuilder, params, derivationPath, derivedPublicKey, false);
const tx = (await txBuilder.build());
return {
transactions: [
{
scanIndex: idx,
recoveryAmount: netAmount.toString(),
serializedTx: tx.toBroadcastFormat(),
signature: Buffer.from(tx.serializedSig).toString('base64'),
coin: this.getChain(),
},
],
lastScanIndex: idx,
};
}
throw new Error(`Did not find an address with sufficient funds to recover. Please start the next scan at address index ${endIdx}. If it is token transaction, please keep sufficient Sui balance in the address for the transaction fee.`);
}
async recoverSuiToken(params, token, senderAddress, derivationPath, derivedPublicKey, idx, bitgoKey) {
const coinType = `${token.packageId}::${token.module}::${token.symbol}`;
let tokenObjects = await this.getInputCoins(senderAddress, coinType);
tokenObjects = tokenObjects.sort((a, b) => {
return b.balance.minus(a.balance).toNumber();
});
if (tokenObjects.length > constants_1.TOKEN_OBJECT_LIMIT) {
tokenObjects = tokenObjects.slice(0, constants_1.TOKEN_OBJECT_LIMIT);
}
const netAmount = tokenObjects.reduce((acc, obj) => acc.plus(obj.balance), new bignumber_js_1.default(0));
const recipients = [
{
address: params.recoveryDestination,
amount: netAmount.toString(),
},
];
const gasAmount = new bignumber_js_1.default(constants_1.MAX_GAS_BUDGET);
let gasObjects = await this.getInputCoins(senderAddress);
gasObjects = utils_1.default.selectObjectsInDescOrderOfBalance(gasObjects, gasAmount);
if (gasObjects.length >= constants_1.MAX_GAS_OBJECTS) {
gasObjects = gasObjects.slice(0, constants_1.MAX_GAS_OBJECTS - 1);
}
// first build the unsigned txn
const factory = new lib_1.TransactionBuilderFactory(token);
const txBuilder = factory
.getTokenTransferBuilder()
.type(iface_1.SuiTransactionType.TokenTransfer)
.sender(senderAddress)
.send(recipients)
.inputObjects(tokenObjects)
.gasData({
owner: senderAddress,
price: constants_1.DEFAULT_GAS_PRICE,
budget: constants_1.MAX_GAS_BUDGET,
payment: gasObjects,
});
const tempTx = (await txBuilder.build());
const feeEstimate = await this.getFeeEstimate(tempTx.toBroadcastFormat());
const gasBudget = Math.trunc(feeEstimate.toNumber() * constants_1.DEFAULT_GAS_OVERHEAD);
txBuilder.gasData({
owner: senderAddress,
price: constants_1.DEFAULT_GAS_PRICE,
budget: gasBudget,
payment: gasObjects,
});
const isUnsignedSweep = !params.userKey && !params.backupKey && !params.walletPassphrase;
if (isUnsignedSweep) {
return this.buildUnsignedSweepTransaction(txBuilder, senderAddress, bitgoKey, idx, derivationPath, token);
}
await this.signRecoveryTransaction(txBuilder, params, derivationPath, derivedPublicKey, true);
const tx = (await txBuilder.build());
return {
transactions: [
{
scanIndex: idx,
recoveryAmount: netAmount.toString(),
serializedTx: tx.toBroadcastFormat(),
signature: Buffer.from(tx.serializedSig).toString('base64'),
coin: token.name,
},
],
lastScanIndex: idx,
};
}
async buildUnsignedSweepTransaction(txBuilder, senderAddress, bitgoKey, index, derivationPath, token) {
const isTokenTransaction = !!token;
const unsignedTransaction = isTokenTransaction
? (await txBuilder.build())
: (await txBuilder.build());
const serializedTx = unsignedTransaction.toBroadcastFormat();
const serializedTxHex = Buffer.from(serializedTx, 'base64').toString('hex');
const parsedTx = await this.parseTransaction({ txHex: serializedTxHex });
const walletCoin = isTokenTransaction ? token.name : this.getChain();
const output = parsedTx.outputs[0];
const inputs = [
{
address: senderAddress,
valueString: output.amount,
value: new bignumber_js_1.default(output.amount),
},
];
const outputs = [
{
address: output.address,
valueString: output.amount,
coinName: walletCoin,
},
];
const spendAmount = output.amount;
const completedParsedTx = {
inputs: inputs,
outputs: outputs,
spendAmount: spendAmount,
type: isTokenTransaction ? iface_1.SuiTransactionType.TokenTransfer : iface_1.SuiTransactionType.Transfer,
};
const fee = parsedTx.fee;
const feeInfo = { fee: fee.toNumber(), feeString: fee.toString() };
const coinSpecific = { commonKeychain: bitgoKey };
const transaction = {
serializedTx: serializedTxHex,
scanIndex: index,
coin: walletCoin,
signableHex: unsignedTransaction.signablePayload.toString('hex'),
derivationPath,
parsedTx: completedParsedTx,
feeInfo: feeInfo,
coinSpecific: coinSpecific,
};
const unsignedTx = { unsignedTx: transaction, signatureShares: [] };
const transactions = [unsignedTx];
const txRequest = {
transactions: transactions,
walletCoin: walletCoin,
};
return { txRequests: [txRequest] };
}
async signRecoveryTransaction(txBuilder, params, derivationPath, derivedPublicKey, isTokenTransaction) {
// TODO(BG-51092): This looks like a common part which can be extracted out too
const unsignedTx = isTokenTransaction
? (await txBuilder.build())
: (await txBuilder.build());
if (!params.userKey) {
throw new Error('missing userKey');
}
if (!params.backupKey) {
throw new Error('missing backupKey');
}
if (!params.walletPassphrase) {
throw new Error('missing wallet passphrase');
}
// Clean up whitespace from entered values
const userKey = params.userKey.replace(/\s/g, '');
const backupKey = params.backupKey.replace(/\s/g, '');
// Decrypt private keys from KeyCard values
let userPrv;
try {
userPrv = this.bitgo.decrypt({
input: userKey,
password: params.walletPassphrase,
});
}
catch (e) {
throw new Error(`Error decrypting user keychain: ${e.message}`);
}
/** TODO BG-52419 Implement Codec for parsing */
const userSigningMaterial = JSON.parse(userPrv);
let backupPrv;
try {
backupPrv = this.bitgo.decrypt({
input: backupKey,
password: params.walletPassphrase,
});
}
catch (e) {
throw new Error(`Error decrypting backup keychain: ${e.message}`);
}
const backupSigningMaterial = JSON.parse(backupPrv);
/* ********************** END ***********************************/
// add signature
const signatureHex = await sdk_core_1.EDDSAMethods.getTSSSignature(userSigningMaterial, backupSigningMaterial, derivationPath, unsignedTx);
txBuilder.addSignature({ pub: derivedPublicKey }, signatureHex);
}
async broadcastTransaction({ transactions, }) {
const txIds = [];
const url = this.getPublicNodeUrl();
let digest = '';
if (!!transactions) {
for (const txn of transactions) {
try {
digest = await utils_1.default.executeTransactionBlock(url, txn.serializedTx, [txn.signature]);
}
catch (e) {
throw new Error(`Failed to broadcast transaction, error: ${e.message}`);
}
txIds.push(digest);
}
}
return { txIds };
}
/** inherited doc */
async createBroadcastableSweepTransaction(params) {
const req = params.signatureShares;
const broadcastableTransactions = [];
let lastScanIndex = 0;
for (let i = 0; i < req.length; i++) {
const MPC = await sdk_core_1.EDDSAMethods.getInitializedMpcInstance();
const transaction = req[i].txRequest.transactions[0].unsignedTx;
if (!req[i].ovc || !req[i].ovc[0].eddsaSignature) {
throw new Error('Missing signature(s)');
}
const signature = req[i].ovc[0].eddsaSignature;
if (!transaction.signableHex) {
throw new Error('Missing signable hex');
}
const messageBuffer = Buffer.from(transaction.signableHex, 'hex');
const result = MPC.verify(messageBuffer, signature);
if (!result) {
throw new Error('Invalid signature');
}
const signatureHex = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);
const serializedTxBase64 = Buffer.from(transaction.serializedTx, 'hex').toString('base64');
const txBuilder = this.getBuilder().from(serializedTxBase64);
if (!transaction.coinSpecific?.commonKeychain) {
throw new Error('Missing common keychain');
}
const commonKeychain = transaction.coinSpecific.commonKeychain;
if (!transaction.derivationPath) {
throw new Error('Missing derivation path');
}
const derivationPath = transaction.derivationPath;
const derivedPublicKey = MPC.deriveUnhardened(commonKeychain, derivationPath).slice(0, 64);
// add combined signature from ovc
txBuilder.addSignature({ pub: derivedPublicKey }, signatureHex);
const signedTransaction = (await txBuilder.build());
const serializedTx = signedTransaction.toBroadcastFormat();
const outputAmount = signedTransaction.explainTransaction().outputAmount;
broadcastableTransactions.push({
serializedTx: serializedTx,
scanIndex: transaction.scanIndex,
signature: Buffer.from(signedTransaction.serializedSig).toString('base64'),
recoveryAmount: outputAmount.toString(),
});
if (i === req.length - 1 && transaction.coinSpecific.lastScanIndex) {
lastScanIndex = transaction.coinSpecific.lastScanIndex;
}
}
return { transactions: broadcastableTransactions, lastScanIndex };
}
/**
* Builds native SUI recoveries of receive addresses in batch without BitGo.
* Funds will be recovered to base address first. You need to initiate another sweep txn after that.
*
* @param {MPCConsolidationRecoveryOptions} params - options for consolidation recovery.
* @param {string} [params.startingScanIndex] - receive address index to start scanning from. default to 1 (inclusive).
* @param {string} [params.endingScanIndex] - receive address index to end scanning at. default to startingScanIndex + 20 (exclusive).
*/
async recoverConsolidations(params) {
const isUnsignedSweep = !params.userKey && !params.backupKey && !params.walletPassphrase;
const startIdx = utils_1.default.validateNonNegativeNumber(1, 'Invalid starting index to scan for addresses', params.startingScanIndex);
const endIdx = utils_1.default.validateNonNegativeNumber(startIdx + constants_1.DEFAULT_SCAN_FACTOR, 'Invalid ending index to scan for addresses', params.endingScanIndex);
if (startIdx < 1 || endIdx <= startIdx || endIdx - startIdx > 10 * constants_1.DEFAULT_SCAN_FACTOR) {
throw new Error(`Invalid starting or ending index to scan for addresses. startingScanIndex: ${startIdx}, endingScanIndex: ${endIdx}.`);
}
const bitgoKey = params.bitgoKey.replace(/\s/g, '');
const MPC = await sdk_core_1.EDDSAMethods.getInitializedMpcInstance();
const derivationPath = (params.seed ? (0, sdk_lib_mpc_1.getDerivationPath)(params.seed) : 'm') + '/0';
const derivedPublicKey = MPC.deriveUnhardened(bitgoKey, derivationPath).slice(0, 64);
const baseAddress = this.getAddressFromPublicKey(derivedPublicKey);
const consolidationTransactions = [];
let lastScanIndex = startIdx;
for (let idx = startIdx; idx < endIdx; idx++) {
const recoverParams = {
userKey: params.userKey,
backupKey: params.backupKey,
bitgoKey: params.bitgoKey,
walletPassphrase: params.walletPassphrase,
seed: params.seed,
tokenContractAddress: params.tokenContractAddress,
recoveryDestination: baseAddress,
startingScanIndex: idx,
scan: 1,
};
let recoveryTransaction;
try {
recoveryTransaction = await this.recover(recoverParams);
}
catch (e) {
if (e.message.startsWith('Did not find an address with sufficient funds to recover.')) {
lastScanIndex = idx;
continue;
}
throw e;
}
if (isUnsignedSweep) {
consolidationTransactions.push(recoveryTransaction.txRequests[0]);
}
else {
consolidationTransactions.push(recoveryTransaction.transactions[0]);
}
lastScanIndex = idx;
}
if (consolidationTransactions.length === 0) {
throw new Error(`Did not find an address with sufficient funds to recover. Please start the next scan at address index ${lastScanIndex + 1}.`);
}
if (isUnsignedSweep) {
// lastScanIndex will be used to inform user the last address index scanned for available funds (so they can
// appropriately adjust the scan range on the next iteration of consolidation recoveries). In the case of unsigned
// sweep consolidations, this lastScanIndex will be provided in the coinSpecific of the last txn made.
consolidationTransactions[consolidationTransactions.length - 1].transactions[0].unsignedTx.coinSpecific.lastScanIndex = lastScanIndex;
return { txRequests: consolidationTransactions };
}
return { transactions: consolidationTransactions, lastScanIndex };
}
/** inherited doc */
setCoinSpecificFieldsInIntent(intent, params) {
intent.unspents = params.unspents;
}
}
exports.Sui = Sui;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sui.js","sourceRoot":"","sources":["../../src/sui.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseBroadcastTransactionOptions,\n  BaseBroadcastTransactionResult,\n  BaseCoin,\n  BaseTransaction,\n  BitGoBase,\n  EDDSAMethods,\n  EDDSAMethodTypes,\n  Environments,\n  InvalidAddressError,\n  KeyPair,\n  MPCAlgorithm,\n  MPCRecoveryOptions,\n  MPCConsolidationRecoveryOptions,\n  MPCSweepRecoveryOptions,\n  MPCSweepTxs,\n  MPCTx,\n  MPCTxs,\n  MPCUnsignedTx,\n  ParsedTransaction,\n  ParseTransactionOptions as BaseParseTransactionOptions,\n  RecoveryTxRequest,\n  SignedTransaction,\n  SignTransactionOptions,\n  TransactionExplanation,\n  TssVerifyAddressOptions,\n  VerifyTransactionOptions,\n  PopulatedIntent,\n  PrebuildTransactionWithIntentOptions,\n  MultisigType,\n  multisigTypes,\n} from '@bitgo/sdk-core';\nimport { BaseCoin as StaticsBaseCoin, BaseNetwork, coins, SuiCoin } from '@bitgo/statics';\nimport BigNumber from 'bignumber.js';\nimport {\n  KeyPair as SuiKeyPair,\n  TokenTransferTransaction,\n  TransactionBuilder,\n  TransactionBuilderFactory,\n  TransferTransaction,\n} from './lib';\nimport utils from './lib/utils';\nimport * as _ from 'lodash';\nimport { SuiObjectInfo, SuiTransactionType } from './lib/iface';\nimport {\n  DEFAULT_GAS_OVERHEAD,\n  DEFAULT_GAS_PRICE,\n  DEFAULT_SCAN_FACTOR,\n  MAX_GAS_BUDGET,\n  MAX_GAS_OBJECTS,\n  MAX_OBJECT_LIMIT,\n  TOKEN_OBJECT_LIMIT,\n} from './lib/constants';\nimport { getDerivationPath } from '@bitgo/sdk-lib-mpc';\n\nexport interface ExplainTransactionOptions {\n  txHex: string;\n}\n\nexport interface SuiParseTransactionOptions extends BaseParseTransactionOptions {\n  txHex: string;\n}\n\ninterface TransactionOutput {\n  address: string;\n  amount: string;\n}\n\ntype TransactionInput = TransactionOutput;\n\nexport interface SuiParsedTransaction extends ParsedTransaction {\n  // total assets being moved, including fees\n  inputs: TransactionInput[];\n\n  // where assets are moved to\n  outputs: TransactionOutput[];\n\n  fee: BigNumber;\n}\n\nexport type SuiTransactionExplanation = TransactionExplanation;\n\nexport class Sui 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 Sui(bitgo, staticsCoin);\n  }\n\n  /**\n   * Factor between the coin's base unit and its smallest subdivison\n   */\n  public getBaseFactor(): number {\n    return 1e9;\n  }\n\n  public getChain(): string {\n    return 'sui';\n  }\n\n  public getFamily(): string {\n    return 'sui';\n  }\n\n  public getFullName(): string {\n    return 'Sui';\n  }\n\n  getNetwork(): BaseNetwork {\n    return this._staticsCoin.network;\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  getMPCAlgorithm(): MPCAlgorithm {\n    return 'eddsa';\n  }\n\n  allowsAccountConsolidations(): boolean {\n    return true;\n  }\n\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    let totalAmount = new BigNumber(0);\n    const coinConfig = coins.get(this.getChain());\n    const { txPrebuild: txPrebuild, txParams: txParams } = params;\n    const transaction = new TransferTransaction(coinConfig);\n    const rawTx = txPrebuild.txHex;\n    if (!rawTx) {\n      throw new Error('missing required tx prebuild property txHex');\n    }\n\n    transaction.fromRawTransaction(Buffer.from(rawTx, 'hex').toString('base64'));\n    const explainedTx = transaction.explainTransaction();\n\n    if (txParams.recipients && txParams.recipients.length > 0) {\n      const filteredRecipients = txParams.recipients?.map((recipient) => {\n        const filteredRecipient = _.pick(recipient, ['address', 'amount']);\n        filteredRecipient.amount = new BigNumber(filteredRecipient.amount).toFixed();\n        return filteredRecipient;\n      });\n      const filteredOutputs = explainedTx.outputs.map((output) => {\n        const filteredOutput = _.pick(output, ['address', 'amount']);\n        filteredOutput.amount = new BigNumber(filteredOutput.amount).toFixed();\n        return filteredOutput;\n      });\n\n      if (!_.isEqual(filteredOutputs, filteredRecipients)) {\n        throw new Error('Tx outputs does not match with expected txParams recipients');\n      }\n      for (const recipients of txParams.recipients) {\n        totalAmount = totalAmount.plus(recipients.amount);\n      }\n      if (!totalAmount.isEqualTo(explainedTx.outputAmount)) {\n        throw new Error('Tx total amount does not match with expected total amount field');\n      }\n    }\n    return true;\n  }\n\n  async isWalletAddress(params: TssVerifyAddressOptions): Promise<boolean> {\n    const { address: newAddress } = params;\n\n    if (!this.isValidAddress(newAddress)) {\n      throw new InvalidAddressError(`invalid address: ${newAddress}`);\n    }\n    return true;\n  }\n\n  async parseTransaction(params: SuiParseTransactionOptions): Promise<SuiParsedTransaction> {\n    const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });\n\n    if (!transactionExplanation) {\n      throw new Error('Invalid transaction');\n    }\n\n    let fee = new BigNumber(0);\n\n    const suiTransaction = transactionExplanation as SuiTransactionExplanation;\n    if (suiTransaction.outputs.length <= 0) {\n      return {\n        inputs: [],\n        outputs: [],\n        fee,\n      };\n    }\n\n    const senderAddress = suiTransaction.outputs[0].address;\n    if (suiTransaction.fee.fee !== '') {\n      fee = new BigNumber(suiTransaction.fee.fee);\n    }\n\n    // assume 1 sender, who is also the fee payer\n    const inputs = [\n      {\n        address: senderAddress,\n        amount: new BigNumber(suiTransaction.outputAmount).plus(fee).toFixed(),\n      },\n    ];\n\n    const outputs: TransactionOutput[] = suiTransaction.outputs.map((output) => {\n      return {\n        address: output.address,\n        amount: new BigNumber(output.amount).toFixed(),\n      };\n    });\n\n    return {\n      inputs,\n      outputs,\n      fee,\n    };\n  }\n\n  generateKeyPair(seed?: Buffer): KeyPair {\n    const keyPair = seed ? new SuiKeyPair({ seed }) : new SuiKeyPair();\n    const keys = keyPair.getKeys();\n    if (!keys.prv) {\n      throw new Error('Missing prv in key generation.');\n    }\n    return {\n      pub: keys.pub,\n      prv: keys.prv,\n    };\n  }\n\n  isValidPub(_: string): boolean {\n    throw new Error('Method not implemented.');\n  }\n\n  isValidPrv(_: string): boolean {\n    throw new Error('Method not implemented.');\n  }\n\n  isValidAddress(address: string): boolean {\n    return utils.isValidAddress(address);\n  }\n\n  signTransaction(_: SignTransactionOptions): Promise<SignedTransaction> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Explain a Sui transaction\n   * @param params\n   */\n  async explainTransaction(params: ExplainTransactionOptions): Promise<SuiTransactionExplanation> {\n    const factory = this.getBuilder();\n    let rebuiltTransaction: BaseTransaction;\n\n    try {\n      const transactionBuilder = factory.from(Buffer.from(params.txHex, 'hex').toString('base64'));\n      rebuiltTransaction = await transactionBuilder.build();\n    } catch {\n      throw new Error('Invalid transaction');\n    }\n\n    return rebuiltTransaction.explainTransaction();\n  }\n\n  private getBuilder(): TransactionBuilderFactory {\n    return new TransactionBuilderFactory(coins.get(this.getChain()));\n  }\n\n  private getAddressFromPublicKey(derivedPublicKey: string) {\n    // TODO(BG-59016) replace with account lib implementation\n    return utils.getAddressFromPublicKey(derivedPublicKey);\n  }\n\n  /** @inheritDoc */\n  async getSignablePayload(serializedTx: string): Promise<Buffer> {\n    const factory = this.getBuilder();\n    const rebuiltTransaction = await factory.from(serializedTx).build();\n    return rebuiltTransaction.signablePayload;\n  }\n\n  protected getPublicNodeUrl(): string {\n    return Environments[this.bitgo.getEnv()].suiNodeUrl;\n  }\n\n  protected async getBalance(owner: string, coinType?: string): Promise<string> {\n    const url = this.getPublicNodeUrl();\n    return await utils.getBalance(url, owner, coinType);\n  }\n\n  protected async getInputCoins(owner: string, coinType?: string): Promise<SuiObjectInfo[]> {\n    const url = this.getPublicNodeUrl();\n    return await utils.getInputCoins(url, owner, coinType);\n  }\n\n  protected async getFeeEstimate(txHex: string): Promise<BigNumber> {\n    const url = this.getPublicNodeUrl();\n    return await utils.getFeeEstimate(url, txHex);\n  }\n\n  /**\n   * Builds funds recovery transaction(s) without BitGo\n   *\n   * @param {MPCRecoveryOptions} params parameters needed to construct and\n   * (maybe) sign the transaction\n   *\n   * @returns {MPCTx | MPCSweepTxs} array of the serialized transaction hex strings and indices\n   * of the addresses being swept\n   */\n  async recover(params: MPCRecoveryOptions): Promise<MPCTxs | MPCSweepTxs> {\n    if (!params.bitgoKey) {\n      throw new Error('missing bitgoKey');\n    }\n    if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {\n      throw new Error('invalid recoveryDestination');\n    }\n\n    const startIdx = utils.validateNonNegativeNumber(\n      0,\n      'Invalid starting index to scan for addresses',\n      params.startingScanIndex\n    );\n    const numIterations = utils.validateNonNegativeNumber(20, 'Invalid scanning factor', params.scan);\n    const endIdx = startIdx + numIterations;\n    const bitgoKey = params.bitgoKey.replace(/\\s/g, '');\n    const MPC = await EDDSAMethods.getInitializedMpcInstance();\n\n    for (let idx = startIdx; idx < endIdx; idx++) {\n      const derivationPath = (params.seed ? getDerivationPath(params.seed) : 'm') + `/${idx}`;\n      const derivedPublicKey = MPC.deriveUnhardened(bitgoKey, derivationPath).slice(0, 64);\n      const senderAddress = this.getAddressFromPublicKey(derivedPublicKey);\n      let availableBalance = new BigNumber(0);\n      try {\n        availableBalance = new BigNumber(await this.getBalance(senderAddress));\n      } catch (e) {\n        continue;\n      }\n      if (availableBalance.minus(MAX_GAS_BUDGET).toNumber() <= 0) {\n        continue;\n      }\n\n      // check for possible token recovery, recover the token provide by user\n      if (params.tokenContractAddress) {\n        const token = utils.getSuiTokenFromAddress(params.tokenContractAddress!, this.getNetwork()) as SuiCoin;\n        if (!token) {\n          throw new Error(`Sui Token Package ID not supported.`);\n        }\n        const coinType = `${token.packageId}::${token.module}::${token.symbol}`;\n        try {\n          const availableTokenBalance = new BigNumber(await this.getBalance(senderAddress, coinType));\n          if (availableTokenBalance.toNumber() <= 0) {\n            continue;\n          }\n        } catch (e) {\n          continue;\n        }\n        return this.recoverSuiToken(params, token, senderAddress, derivationPath, derivedPublicKey, idx, bitgoKey);\n      }\n\n      let inputCoins = await this.getInputCoins(senderAddress);\n      inputCoins = inputCoins.sort((a, b) => {\n        return b.balance.minus(a.balance).toNumber();\n      });\n      if (inputCoins.length > MAX_OBJECT_LIMIT) {\n        inputCoins = inputCoins.slice(0, MAX_OBJECT_LIMIT);\n      }\n      let netAmount = inputCoins.reduce((acc, obj) => acc.plus(obj.balance), new BigNumber(0));\n      netAmount = netAmount.minus(MAX_GAS_BUDGET);\n\n      const recipients = [\n        {\n          address: params.recoveryDestination,\n          amount: netAmount.toString(),\n        },\n      ];\n\n      // first build the unsigned txn\n      const factory = new TransactionBuilderFactory(coins.get(this.getChain()));\n      const txBuilder = factory\n        .getTransferBuilder()\n        .type(SuiTransactionType.Transfer)\n        .sender(senderAddress)\n        .send(recipients)\n        .gasData({\n          owner: senderAddress,\n          price: DEFAULT_GAS_PRICE,\n          budget: MAX_GAS_BUDGET,\n          payment: inputCoins,\n        });\n\n      const tempTx = (await txBuilder.build()) as TransferTransaction;\n      const feeEstimate = await this.getFeeEstimate(tempTx.toBroadcastFormat());\n      const gasBudget = Math.trunc(feeEstimate.toNumber() * DEFAULT_GAS_OVERHEAD);\n\n      netAmount = netAmount.plus(MAX_GAS_BUDGET).minus(gasBudget);\n      recipients[0].amount = netAmount.toString();\n      txBuilder.send(recipients);\n      txBuilder.gasData({\n        owner: senderAddress,\n        price: DEFAULT_GAS_PRICE,\n        budget: gasBudget,\n        payment: inputCoins,\n      });\n\n      const isUnsignedSweep = !params.userKey && !params.backupKey && !params.walletPassphrase;\n      if (isUnsignedSweep) {\n        return this.buildUnsignedSweepTransaction(txBuilder, senderAddress, bitgoKey, idx, derivationPath);\n      }\n\n      await this.signRecoveryTransaction(txBuilder, params, derivationPath, derivedPublicKey, false);\n      const tx = (await txBuilder.build()) as TransferTransaction;\n      return {\n        transactions: [\n          {\n            scanIndex: idx,\n            recoveryAmount: netAmount.toString(),\n            serializedTx: tx.toBroadcastFormat(),\n            signature: Buffer.from(tx.serializedSig).toString('base64'),\n            coin: this.getChain(),\n          },\n        ],\n        lastScanIndex: idx,\n      };\n    }\n\n    throw new Error(\n      `Did not find an address with sufficient funds to recover. Please start the next scan at address index ${endIdx}. If it is token transaction, please keep sufficient Sui balance in the address for the transaction fee.`\n    );\n  }\n\n  private async recoverSuiToken(\n    params: MPCRecoveryOptions,\n    token: SuiCoin,\n    senderAddress: string,\n    derivationPath: string,\n    derivedPublicKey: string,\n    idx: number,\n    bitgoKey: string\n  ): Promise<MPCTxs | MPCSweepTxs> {\n    const coinType = `${token.packageId}::${token.module}::${token.symbol}`;\n    let tokenObjects = await this.getInputCoins(senderAddress, coinType);\n    tokenObjects = tokenObjects.sort((a, b) => {\n      return b.balance.minus(a.balance).toNumber();\n    });\n    if (tokenObjects.length > TOKEN_OBJECT_LIMIT) {\n      tokenObjects = tokenObjects.slice(0, TOKEN_OBJECT_LIMIT);\n    }\n    const netAmount = tokenObjects.reduce((acc, obj) => acc.plus(obj.balance), new BigNumber(0));\n    const recipients = [\n      {\n        address: params.recoveryDestination,\n        amount: netAmount.toString(),\n      },\n    ];\n\n    const gasAmount = new BigNumber(MAX_GAS_BUDGET);\n    let gasObjects = await this.getInputCoins(senderAddress);\n    gasObjects = utils.selectObjectsInDescOrderOfBalance(gasObjects, gasAmount);\n    if (gasObjects.length >= MAX_GAS_OBJECTS) {\n      gasObjects = gasObjects.slice(0, MAX_GAS_OBJECTS - 1);\n    }\n\n    // first build the unsigned txn\n    const factory = new TransactionBuilderFactory(token);\n    const txBuilder = factory\n      .getTokenTransferBuilder()\n      .type(SuiTransactionType.TokenTransfer)\n      .sender(senderAddress)\n      .send(recipients)\n      .inputObjects(tokenObjects)\n      .gasData({\n        owner: senderAddress,\n        price: DEFAULT_GAS_PRICE,\n        budget: MAX_GAS_BUDGET,\n        payment: gasObjects,\n      });\n\n    const tempTx = (await txBuilder.build()) as TokenTransferTransaction;\n    const feeEstimate = await this.getFeeEstimate(tempTx.toBroadcastFormat());\n    const gasBudget = Math.trunc(feeEstimate.toNumber() * DEFAULT_GAS_OVERHEAD);\n\n    txBuilder.gasData({\n      owner: senderAddress,\n      price: DEFAULT_GAS_PRICE,\n      budget: gasBudget,\n      payment: gasObjects,\n    });\n\n    const isUnsignedSweep = !params.userKey && !params.backupKey && !params.walletPassphrase;\n    if (isUnsignedSweep) {\n      return this.buildUnsignedSweepTransaction(txBuilder, senderAddress, bitgoKey, idx, derivationPath, token);\n    }\n\n    await this.signRecoveryTransaction(txBuilder, params, derivationPath, derivedPublicKey, true);\n    const tx = (await txBuilder.build()) as TokenTransferTransaction;\n    return {\n      transactions: [\n        {\n          scanIndex: idx,\n          recoveryAmount: netAmount.toString(),\n          serializedTx: tx.toBroadcastFormat(),\n          signature: Buffer.from(tx.serializedSig).toString('base64'),\n          coin: token.name,\n        },\n      ],\n      lastScanIndex: idx,\n    };\n  }\n\n  private async buildUnsignedSweepTransaction(\n    txBuilder: TransactionBuilder,\n    senderAddress: string,\n    bitgoKey: string,\n    index: number,\n    derivationPath: string,\n    token?: SuiCoin\n  ): Promise<MPCSweepTxs> {\n    const isTokenTransaction = !!token;\n    const unsignedTransaction = isTokenTransaction\n      ? ((await txBuilder.build()) as TokenTransferTransaction)\n      : ((await txBuilder.build()) as TransferTransaction);\n    const serializedTx = unsignedTransaction.toBroadcastFormat();\n    const serializedTxHex = Buffer.from(serializedTx, 'base64').toString('hex');\n    const parsedTx = await this.parseTransaction({ txHex: serializedTxHex });\n    const walletCoin = isTokenTransaction ? token.name : this.getChain();\n    const output = parsedTx.outputs[0];\n    const inputs = [\n      {\n        address: senderAddress,\n        valueString: output.amount,\n        value: new BigNumber(output.amount),\n      },\n    ];\n    const outputs = [\n      {\n        address: output.address,\n        valueString: output.amount,\n        coinName: walletCoin,\n      },\n    ];\n    const spendAmount = output.amount;\n    const completedParsedTx = {\n      inputs: inputs,\n      outputs: outputs,\n      spendAmount: spendAmount,\n      type: isTokenTransaction ? SuiTransactionType.TokenTransfer : SuiTransactionType.Transfer,\n    };\n    const fee = parsedTx.fee;\n    const feeInfo = { fee: fee.toNumber(), feeString: fee.toString() };\n    const coinSpecific = { commonKeychain: bitgoKey };\n    const transaction: MPCTx = {\n      serializedTx: serializedTxHex,\n      scanIndex: index,\n      coin: walletCoin,\n      signableHex: unsignedTransaction.signablePayload.toString('hex'),\n      derivationPath,\n      parsedTx: completedParsedTx,\n      feeInfo: feeInfo,\n      coinSpecific: coinSpecific,\n    };\n    const unsignedTx: MPCUnsignedTx = { unsignedTx: transaction, signatureShares: [] };\n    const transactions: MPCUnsignedTx[] = [unsignedTx];\n    const txRequest: RecoveryTxRequest = {\n      transactions: transactions,\n      walletCoin: walletCoin,\n    };\n    return { txRequests: [txRequest] };\n  }\n\n  private async signRecoveryTransaction(\n    txBuilder: TransactionBuilder,\n    params: MPCRecoveryOptions,\n    derivationPath: string,\n    derivedPublicKey: string,\n    isTokenTransaction: boolean\n  ) {\n    // TODO(BG-51092): This looks like a common part which can be extracted out too\n    const unsignedTx = isTokenTransaction\n      ? ((await txBuilder.build()) as TokenTransferTransaction)\n      : ((await txBuilder.build()) as TransferTransaction);\n    if (!params.userKey) {\n      throw new Error('missing userKey');\n    }\n    if (!params.backupKey) {\n      throw new Error('missing backupKey');\n    }\n    if (!params.walletPassphrase) {\n      throw new Error('missing wallet passphrase');\n    }\n\n    // Clean up whitespace from entered values\n    const userKey = params.userKey.replace(/\\s/g, '');\n    const backupKey = params.backupKey.replace(/\\s/g, '');\n\n    // Decrypt private keys from KeyCard values\n    let userPrv: string;\n    try {\n      userPrv = this.bitgo.decrypt({\n        input: userKey,\n        password: params.walletPassphrase,\n      });\n    } catch (e) {\n      throw new Error(`Error decrypting user keychain: ${e.message}`);\n    }\n    /** TODO BG-52419 Implement Codec for parsing */\n    const userSigningMaterial = JSON.parse(userPrv) as EDDSAMethodTypes.UserSigningMaterial;\n\n    let backupPrv: string;\n    try {\n      backupPrv = this.bitgo.decrypt({\n        input: backupKey,\n        password: params.walletPassphrase,\n      });\n    } catch (e) {\n      throw new Error(`Error decrypting backup keychain: ${e.message}`);\n    }\n    const backupSigningMaterial = JSON.parse(backupPrv) as EDDSAMethodTypes.BackupSigningMaterial;\n    /* ********************** END ***********************************/\n\n    // add signature\n    const signatureHex = await EDDSAMethods.getTSSSignature(\n      userSigningMaterial,\n      backupSigningMaterial,\n      derivationPath,\n      unsignedTx\n    );\n    txBuilder.addSignature({ pub: derivedPublicKey }, signatureHex);\n  }\n\n  async broadcastTransaction({\n    transactions,\n  }: BaseBroadcastTransactionOptions): Promise<BaseBroadcastTransactionResult> {\n    const txIds: string[] = [];\n    const url = this.getPublicNodeUrl();\n    let digest = '';\n    if (!!transactions) {\n      for (const txn of transactions) {\n        try {\n          digest = await utils.executeTransactionBlock(url, txn.serializedTx, [txn.signature!]);\n        } catch (e) {\n          throw new Error(`Failed to broadcast transaction, error: ${e.message}`);\n        }\n        txIds.push(digest);\n      }\n    }\n    return { txIds };\n  }\n\n  /** inherited doc */\n  async createBroadcastableSweepTransaction(params: MPCSweepRecoveryOptions): Promise<MPCTxs> {\n    const req = params.signatureShares;\n    const broadcastableTransactions: MPCTx[] = [];\n    let lastScanIndex = 0;\n\n    for (let i = 0; i < req.length; i++) {\n      const MPC = await EDDSAMethods.getInitializedMpcInstance();\n      const transaction = req[i].txRequest.transactions[0].unsignedTx;\n      if (!req[i].ovc || !req[i].ovc[0].eddsaSignature) {\n        throw new Error('Missing signature(s)');\n      }\n      const signature = req[i].ovc[0].eddsaSignature;\n      if (!transaction.signableHex) {\n        throw new Error('Missing signable hex');\n      }\n      const messageBuffer = Buffer.from(transaction.signableHex!, 'hex');\n      const result = MPC.verify(messageBuffer, signature);\n      if (!result) {\n        throw new Error('Invalid signature');\n      }\n      const signatureHex = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);\n      const serializedTxBase64 = Buffer.from(transaction.serializedTx, 'hex').toString('base64');\n      const txBuilder = this.getBuilder().from(serializedTxBase64);\n      if (!transaction.coinSpecific?.commonKeychain) {\n        throw new Error('Missing common keychain');\n      }\n      const commonKeychain = transaction.coinSpecific!.commonKeychain! as string;\n      if (!transaction.derivationPath) {\n        throw new Error('Missing derivation path');\n      }\n      const derivationPath = transaction.derivationPath as string;\n      const derivedPublicKey = MPC.deriveUnhardened(commonKeychain, derivationPath).slice(0, 64);\n\n      // add combined signature from ovc\n      txBuilder.addSignature({ pub: derivedPublicKey }, signatureHex);\n      const signedTransaction = (await txBuilder.build()) as TransferTransaction;\n      const serializedTx = signedTransaction.toBroadcastFormat();\n      const outputAmount = signedTransaction.explainTransaction().outputAmount;\n\n      broadcastableTransactions.push({\n        serializedTx: serializedTx,\n        scanIndex: transaction.scanIndex,\n        signature: Buffer.from(signedTransaction.serializedSig).toString('base64'),\n        recoveryAmount: outputAmount.toString(),\n      });\n\n      if (i === req.length - 1 && transaction.coinSpecific!.lastScanIndex) {\n        lastScanIndex = transaction.coinSpecific!.lastScanIndex as number;\n      }\n    }\n\n    return { transactions: broadcastableTransactions, lastScanIndex };\n  }\n\n  /**\n   * Builds native SUI recoveries of receive addresses in batch without BitGo.\n   * Funds will be recovered to base address first. You need to initiate another sweep txn after that.\n   *\n   * @param {MPCConsolidationRecoveryOptions} params - options for consolidation recovery.\n   * @param {string} [params.startingScanIndex] - receive address index to start scanning from. default to 1 (inclusive).\n   * @param {string} [params.endingScanIndex] - receive address index to end scanning at. default to startingScanIndex + 20 (exclusive).\n   */\n  async recoverConsolidations(params: MPCConsolidationRecoveryOptions): Promise<MPCTxs | MPCSweepTxs> {\n    const isUnsignedSweep = !params.userKey && !params.backupKey && !params.walletPassphrase;\n    const startIdx = utils.validateNonNegativeNumber(\n      1,\n      'Invalid starting index to scan for addresses',\n      params.startingScanIndex\n    );\n    const endIdx = utils.validateNonNegativeNumber(\n      startIdx + DEFAULT_SCAN_FACTOR,\n      'Invalid ending index to scan for addresses',\n      params.endingScanIndex\n    );\n\n    if (startIdx < 1 || endIdx <= startIdx || endIdx - startIdx > 10 * DEFAULT_SCAN_FACTOR) {\n      throw new Error(\n        `Invalid starting or ending index to scan for addresses. startingScanIndex: ${startIdx}, endingScanIndex: ${endIdx}.`\n      );\n    }\n\n    const bitgoKey = params.bitgoKey.replace(/\\s/g, '');\n    const MPC = await EDDSAMethods.getInitializedMpcInstance();\n    const derivationPath = (params.seed ? getDerivationPath(params.seed) : 'm') + '/0';\n    const derivedPublicKey = MPC.deriveUnhardened(bitgoKey, derivationPath).slice(0, 64);\n    const baseAddress = this.getAddressFromPublicKey(derivedPublicKey);\n\n    const consolidationTransactions: any[] = [];\n    let lastScanIndex = startIdx;\n    for (let idx = startIdx; idx < endIdx; idx++) {\n      const recoverParams = {\n        userKey: params.userKey,\n        backupKey: params.backupKey,\n        bitgoKey: params.bitgoKey,\n        walletPassphrase: params.walletPassphrase,\n        seed: params.seed,\n        tokenContractAddress: params.tokenContractAddress,\n        recoveryDestination: baseAddress,\n        startingScanIndex: idx,\n        scan: 1,\n      };\n\n      let recoveryTransaction: MPCTxs | MPCSweepTxs;\n      try {\n        recoveryTransaction = await this.recover(recoverParams);\n      } catch (e) {\n        if (e.message.startsWith('Did not find an address with sufficient funds to recover.')) {\n          lastScanIndex = idx;\n          continue;\n        }\n        throw e;\n      }\n\n      if (isUnsignedSweep) {\n        consolidationTransactions.push((recoveryTransaction as MPCSweepTxs).txRequests[0]);\n      } else {\n        consolidationTransactions.push((recoveryTransaction as MPCTxs).transactions[0]);\n      }\n      lastScanIndex = idx;\n    }\n\n    if (consolidationTransactions.length === 0) {\n      throw new Error(\n        `Did not find an address with sufficient funds to recover. Please start the next scan at address index ${\n          lastScanIndex + 1\n        }.`\n      );\n    }\n\n    if (isUnsignedSweep) {\n      // lastScanIndex will be used to inform user the last address index scanned for available funds (so they can\n      // appropriately adjust the scan range on the next iteration of consolidation recoveries). In the case of unsigned\n      // sweep consolidations, this lastScanIndex will be provided in the coinSpecific of the last txn made.\n      consolidationTransactions[\n        consolidationTransactions.length - 1\n      ].transactions[0].unsignedTx.coinSpecific.lastScanIndex = lastScanIndex;\n      return { txRequests: consolidationTransactions };\n    }\n\n    return { transactions: consolidationTransactions, lastScanIndex };\n  }\n\n  /** inherited doc */\n  setCoinSpecificFieldsInIntent(intent: PopulatedIntent, params: PrebuildTransactionWithIntentOptions): void {\n    intent.unspents = params.unspents;\n  }\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!