PHP WebShell
Текущая директория: /usr/lib/node_modules/bitgo/node_modules/@bitgo/abstract-cosmos/dist/src
Просмотр файла: cosmosCoin.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.CosmosCoin = void 0;
const sdk_core_1 = require("@bitgo/sdk-core");
const secp256k1_1 = require("@bitgo/secp256k1");
const bignumber_js_1 = require("bignumber.js");
const buffer_1 = require("buffer");
const crypto_1 = require("crypto");
const _ = __importStar(require("lodash"));
const querystring = __importStar(require("querystring"));
const request = __importStar(require("superagent"));
const url = __importStar(require("url"));
const constants_1 = require("./lib/constants");
const utils_1 = __importDefault(require("./lib/utils"));
const sdk_lib_mpc_1 = require("@bitgo/sdk-lib-mpc");
class CosmosCoin 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 CosmosCoin(bitgo, staticsCoin);
}
/**
* Creates an instance of TransactionBuilderFactory for the coin specific sdk
*/
getBuilder() {
throw new Error('Method not implemented.');
}
/** @inheritDoc **/
getBaseFactor() {
throw new Error('Method not implemented');
}
/** @inheritDoc **/
getChain() {
return this._staticsCoin.name;
}
/** @inheritDoc **/
getFamily() {
return this._staticsCoin.family;
}
/** @inheritDoc **/
getFullName() {
return this._staticsCoin.fullName;
}
/** @inheritDoc */
supportsTss() {
return true;
}
/** inherited doc */
getDefaultMultisigType() {
return sdk_core_1.multisigTypes.tss;
}
/** @inheritDoc **/
getMPCAlgorithm() {
return 'ecdsa';
}
/** @inheritDoc **/
isValidPub(pub) {
return utils_1.default.isValidPublicKey(pub);
}
/** @inheritDoc **/
isValidPrv(prv) {
return utils_1.default.isValidPrivateKey(prv);
}
isValidAddress(address) {
throw new Error('Method not implemented.');
}
/**
* Builds a funds recovery transaction without BitGo
* @param {RecoveryOptions} params parameters needed to construct and
* (maybe) sign the transaction
*
* @returns {CosmosLikeCoinRecoveryOutput} the serialized transaction hex string and index
* of the address being swept
*/
async recover(params) {
const isUnsignedSweep = this.isUnsignedSweep(params);
this.validateRecoveryParams(params, isUnsignedSweep);
const { senderAddress, publicKey, keyShares } = await this.getSenderDetails(params, isUnsignedSweep);
const [chainId, accountDetails, balances] = await Promise.all([
this.getChainId(),
this.getAccountDetails(senderAddress),
this.getAccountBalance(senderAddress),
]);
const { actualBalance, remainingBalances } = this.processBalances(balances);
const messages = this.buildTransactionMessages(senderAddress, params.recoveryDestination, actualBalance, remainingBalances);
return this.buildAndSignTransaction({
messages,
chainId,
accountDetails,
publicKey: publicKey || '',
isUnsignedSweep,
keyShares,
});
}
/**
* Validates the recovery parameters
*/
validateRecoveryParams(params, isUnsignedSweep) {
if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {
throw new Error('invalid recoveryDestination');
}
if (!isUnsignedSweep) {
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');
}
}
/**
* Checks if this is an unsigned sweep operation
*/
isUnsignedSweep(params) {
return !params.userKey && !params.backupKey && !params.walletPassphrase;
}
/**
* Gets sender details including address, public key and key shares
*/
async getSenderDetails(params, isUnsignedSweep) {
const MPC = new sdk_core_1.Ecdsa();
if (isUnsignedSweep) {
return {
senderAddress: params.rootAddress,
publicKey: MPC.deriveUnhardened(params.bitgoKey || '', constants_1.ROOT_PATH).slice(0, 66),
};
}
const keyShares = await this.getKeyShares(params);
const publicKey = MPC.deriveUnhardened(keyShares.commonKeyChain, constants_1.ROOT_PATH).slice(0, 66);
return {
senderAddress: this.getAddressFromPublicKey(publicKey),
publicKey,
keyShares,
};
}
/**
* Gets key shares from recovery parameters
*/
async getKeyShares(params) {
if (!params.userKey || !params.backupKey || !params.walletPassphrase) {
throw new Error('Missing required key parameters');
}
const userKey = params.userKey.replace(/\s/g, '');
const backupKey = params.backupKey.replace(/\s/g, '');
const walletPassphrase = params.walletPassphrase;
if (!userKey || !backupKey) {
throw new Error('Invalid key format');
}
return await sdk_core_1.ECDSAUtils.getMpcV2RecoveryKeyShares(userKey, backupKey, walletPassphrase);
}
/**
* Processes account balances and validates sufficient funds
*/
processBalances(balances) {
if (!balances?.length) {
throw new Error('No balance found on account');
}
const denomination = this.getDenomination();
if (!denomination) {
throw new Error('Invalid denomination');
}
let nativeBalance = new bignumber_js_1.BigNumber(0);
const remainingBalances = [];
const gasAmountDetails = this.getGasAmountDetails();
if (!gasAmountDetails?.gasAmount) {
throw new Error('Invalid gas amount');
}
const gasAmount = new bignumber_js_1.BigNumber(gasAmountDetails.gasAmount);
balances.forEach((balance) => {
if (!balance.amount) {
throw new Error('Invalid balance amount');
}
if (balance.denom === denomination) {
nativeBalance = new bignumber_js_1.BigNumber(balance.amount);
}
else {
remainingBalances.push(balance);
}
});
const actualBalance = nativeBalance.minus(gasAmount);
if (actualBalance.isLessThanOrEqualTo(0)) {
throw new Error('Did not have enough funds to recover');
}
return { nativeBalance, remainingBalances, actualBalance };
}
/**
* Builds transaction messages for all balances
*/
buildTransactionMessages(senderAddress, recoveryDestination, actualBalance, remainingBalances) {
const nativeSendMessage = {
fromAddress: senderAddress,
toAddress: recoveryDestination,
amount: [
{
denom: this.getDenomination(),
amount: actualBalance.toFixed(),
},
],
};
const otherTokenMessages = remainingBalances.map((balance) => ({
fromAddress: senderAddress,
toAddress: recoveryDestination,
amount: [balance],
}));
return [...otherTokenMessages, nativeSendMessage];
}
/**
* Builds and signs the transaction
*/
async buildAndSignTransaction(params) {
if (!params.chainId) {
throw new Error('Invalid chain ID');
}
const [accountNumber, sequenceNo] = params.accountDetails;
if (!accountNumber || !sequenceNo) {
throw new Error('Invalid account details');
}
const denomination = this.getDenomination();
const gasAmountDetails = this.getGasAmountDetails();
if (!denomination || !gasAmountDetails?.gasAmount || !gasAmountDetails?.gasLimit) {
throw new Error('Invalid gas configuration');
}
const gasBudget = {
amount: [
{
denom: denomination,
amount: gasAmountDetails.gasAmount,
},
],
gasLimit: gasAmountDetails.gasLimit,
};
const txnBuilder = this.getBuilder()
.getTransferBuilder()
.messages(params.messages)
.gasBudget(gasBudget)
.sequence(Number(sequenceNo))
.accountNumber(Number(accountNumber))
.chainId(params.chainId)
.publicKey(params.publicKey);
const unsignedTransaction = (await txnBuilder.build());
if (!unsignedTransaction) {
throw new Error('Failed to build unsigned transaction');
}
if (params.isUnsignedSweep) {
return {
signableHex: unsignedTransaction.signablePayload.toString('hex'),
};
}
return this.signTransactionWithMpc(unsignedTransaction, txnBuilder, params.keyShares, params.publicKey);
}
/**
* Signs the transaction with MPC
*/
/**
* Signs the transaction using MPC (Multi-Party Computation)
* @param unsignedTransaction The unsigned transaction to sign
* @param txnBuilder The transaction builder instance
* @param keyShares The key shares for MPC signing
* @param publicKey The public key for verification
* @returns The signed transaction output
* @throws Error if validation fails or signing process encounters an error
*/
async signTransactionWithMpc(unsignedTransaction, txnBuilder, keyShares, publicKey) {
// Validate inputs
if (!unsignedTransaction?.signablePayload) {
throw new Error('Invalid unsigned transaction');
}
if (!keyShares?.userKeyShare || !keyShares?.backupKeyShare || !keyShares?.commonKeyChain) {
throw new Error('Invalid key shares');
}
if (!publicKey) {
throw new Error('Invalid public key');
}
try {
const MPC = new sdk_core_1.Ecdsa();
const message = unsignedTransaction.signablePayload;
// Get hash function and compute message hash
const hashFunction = utils_1.default.getHashFunction() || (0, crypto_1.createHash)('sha256');
if (!hashFunction) {
throw new Error('Failed to get hash function');
}
const messageHash = hashFunction.update(message).digest();
// Sign the transaction
const signature = await sdk_core_1.ECDSAUtils.signRecoveryMpcV2(messageHash, keyShares.userKeyShare, keyShares.backupKeyShare, keyShares.commonKeyChain);
// Verify the signature
const signableHex = unsignedTransaction.signablePayload.toString('hex');
const signableBuffer = buffer_1.Buffer.from(signableHex, 'hex');
MPC.verify(signableBuffer, signature, this.getHashFunction());
// Get cosmos key pair and validate
const cosmosKeyPair = this.getKeyPair(publicKey);
if (!cosmosKeyPair) {
throw new Error('Invalid cosmos key pair');
}
// Add signature to transaction
txnBuilder.addSignature({ pub: cosmosKeyPair.getKeys().pub }, buffer_1.Buffer.from(signature.r + signature.s, 'hex'));
// Build final transaction
const signedTransaction = await txnBuilder.build();
if (!signedTransaction) {
throw new Error('Failed to build signed transaction');
}
return {
serializedTx: signedTransaction.toBroadcastFormat(),
};
}
catch (error) {
throw new Error(`Failed to sign transaction: ${error.message}`);
}
}
/**
* Builds a redelegate transaction
* @param {RecoveryOptions} params parameters needed to construct and
* (maybe) sign the transaction
*
* @returns {CosmosLikeCoinRecoveryOutput} the serialized transaction hex string
*/
async redelegate(params) {
if (!params.validatorSrcAddress || !this.isValidAddress(params.validatorSrcAddress)) {
throw new Error('invalid validatorSrcAddress');
}
if (!params.validatorDstAddress || !this.isValidAddress(params.validatorDstAddress)) {
throw new Error('invalid validatorDstAddress');
}
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');
}
if (!params.amountToRedelegate) {
throw new Error('missing amountToRedelegate');
}
const userKey = params.userKey.replace(/\s/g, '');
const backupKey = params.backupKey.replace(/\s/g, '');
const { userKeyShare, backupKeyShare, commonKeyChain } = await sdk_core_1.ECDSAUtils.getMpcV2RecoveryKeyShares(userKey, backupKey, params.walletPassphrase); // baseAddress is not extracted
const MPC = new sdk_core_1.Ecdsa();
const chainId = await this.getChainId();
const publicKey = MPC.deriveUnhardened(commonKeyChain, constants_1.ROOT_PATH).slice(0, 66);
const senderAddress = this.getAddressFromPublicKey(publicKey);
const [accountNumber, sequenceNo] = await this.getAccountDetails(senderAddress);
const gasBudget = {
amount: [{ denom: this.getDenomination(), amount: this.getGasAmountDetails().gasAmount }],
gasLimit: this.getGasAmountDetails().gasLimit,
};
const amount = {
denom: this.getDenomination(),
amount: new bignumber_js_1.BigNumber(params.amountToRedelegate).toFixed(),
};
const sendMessage = [
{
delegatorAddress: senderAddress,
validatorSrcAddress: params.validatorSrcAddress,
validatorDstAddress: params.validatorDstAddress,
amount: amount,
},
];
const txnBuilder = this.getBuilder().getStakingRedelegateBuilder();
txnBuilder
.messages(sendMessage)
.gasBudget(gasBudget)
.publicKey(publicKey)
.sequence(Number(sequenceNo))
.accountNumber(Number(accountNumber))
.chainId(chainId);
const unsignedTransaction = (await txnBuilder.build());
let serializedTx = unsignedTransaction.toBroadcastFormat();
const signableHex = unsignedTransaction.signablePayload.toString('hex');
const message = unsignedTransaction.signablePayload;
const messageHash = (utils_1.default.getHashFunction() || (0, crypto_1.createHash)('sha256')).update(message).digest();
const signature = await sdk_core_1.ECDSAUtils.signRecoveryMpcV2(messageHash, userKeyShare, backupKeyShare, commonKeyChain);
const signableBuffer = buffer_1.Buffer.from(signableHex, 'hex');
MPC.verify(signableBuffer, signature, this.getHashFunction());
const cosmosKeyPair = this.getKeyPair(publicKey);
txnBuilder.addSignature({ pub: cosmosKeyPair.getKeys().pub }, buffer_1.Buffer.from(signature.r + signature.s, 'hex'));
const signedTransaction = await txnBuilder.build();
serializedTx = signedTransaction.toBroadcastFormat();
return { serializedTx: serializedTx };
}
/** @inheritDoc **/
async verifyTransaction(params) {
let totalAmount = new bignumber_js_1.BigNumber(0);
const { txPrebuild, txParams } = params;
const rawTx = txPrebuild.txHex;
if (!rawTx) {
throw new Error('missing required tx prebuild property txHex');
}
const transaction = await this.getBuilder().from(rawTx).build();
const explainedTx = transaction.explainTransaction();
if (txParams.recipients && txParams.recipients.length > 0) {
const filteredRecipients = txParams.recipients?.map((recipient) => _.pick(recipient, ['address', 'amount']));
const filteredOutputs = explainedTx.outputs.map((output) => _.pick(output, ['address', 'amount']));
if (!_.isEqual(filteredOutputs, filteredRecipients)) {
throw new Error('Tx outputs does not match with expected txParams recipients');
}
// WithdrawDelegatorRewards and ContractCall transaction don't have amount
if (transaction.type !== sdk_core_1.TransactionType.StakingWithdraw && transaction.type !== sdk_core_1.TransactionType.ContractCall) {
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;
}
/** @inheritDoc **/
async explainTransaction(options) {
if (!options.txHex) {
throw new Error('missing required txHex parameter');
}
try {
const transactionBuilder = this.getBuilder().from(options.txHex);
const transaction = await transactionBuilder.build();
return transaction.explainTransaction();
}
catch (e) {
throw new Error('Invalid transaction: ' + e.message);
}
}
/**
* Sign a transaction with a single private key
* @param params parameters in the form of { txPrebuild: {txHex}, prv }
* @returns signed transaction in the form of { txHex }
*/
async signTransaction(params) {
const txHex = params?.txPrebuild?.txHex;
const privateKey = params?.prv;
if (!txHex) {
throw new sdk_core_1.SigningError('missing required txPrebuild parameter: params.txPrebuild.txHex');
}
if (!privateKey) {
throw new sdk_core_1.SigningError('missing required prv parameter: params.prv');
}
const txBuilder = this.getBuilder().from(params.txPrebuild.txHex);
txBuilder.sign({ key: params.prv });
const transaction = await txBuilder.build();
if (!transaction) {
throw new sdk_core_1.SigningError('Failed to build signed transaction');
}
const serializedTx = transaction.toBroadcastFormat();
return {
txHex: serializedTx,
};
}
/** @inheritDoc **/
async parseTransaction(params) {
const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });
if (!transactionExplanation) {
throw new Error('Invalid transaction');
}
if (transactionExplanation.outputs.length <= 0) {
return {
inputs: [],
outputs: [],
};
}
const senderAddress = transactionExplanation.outputs[0].address;
const feeAmount = new bignumber_js_1.BigNumber(transactionExplanation.fee.fee === '' ? '0' : transactionExplanation.fee.fee);
const inputs = [
{
address: senderAddress,
amount: new bignumber_js_1.BigNumber(transactionExplanation.outputAmount).plus(feeAmount).toFixed(),
},
];
const outputs = transactionExplanation.outputs.map((output) => {
return {
address: output.address,
amount: new bignumber_js_1.BigNumber(output.amount).toFixed(),
};
});
return {
inputs,
outputs,
};
}
/**
* Get the public node url from the Environments constant we have defined
*/
getPublicNodeUrl() {
throw new Error('Method not implemented.');
}
/**
* Get account number from public node
*/
async getAccountFromNode(senderAddress) {
const nodeUrl = this.getPublicNodeUrl();
const getAccountPath = '/cosmos/auth/v1beta1/accounts/';
const fullEndpoint = nodeUrl + getAccountPath + senderAddress;
try {
return await request.get(fullEndpoint).send();
}
catch (e) {
console.debug(e);
}
throw new Error(`Unable to call endpoint ${getAccountPath + senderAddress} from node: ${nodeUrl}`);
}
/**
* Get balance from public node
*/
async getBalanceFromNode(senderAddress) {
const nodeUrl = this.getPublicNodeUrl();
const getBalancePath = '/cosmos/bank/v1beta1/balances/';
const fullEndpoint = nodeUrl + getBalancePath + senderAddress;
try {
return await request.get(fullEndpoint).send();
}
catch (e) {
console.debug(e);
}
throw new Error(`Unable to call endpoint ${getBalancePath + senderAddress} from node: ${nodeUrl}`);
}
/**
* Get chain id from public node
*/
async getChainIdFromNode() {
const nodeUrl = this.getPublicNodeUrl();
const getLatestBlockPath = '/cosmos/base/tendermint/v1beta1/blocks/latest';
const fullEndpoint = nodeUrl + getLatestBlockPath;
try {
return await request.get(fullEndpoint).send();
}
catch (e) {
console.debug(e);
}
throw new Error(`Unable to call endpoint ${getLatestBlockPath} from node: ${nodeUrl}`);
}
/**
* Helper to fetch account balance
*/
async getAccountBalance(senderAddress) {
const response = await this.getBalanceFromNode(senderAddress);
if (response.status !== 200) {
throw new Error('Account not found');
}
return response.body.balances;
}
/**
* Helper to fetch chainId
*/
async getChainId() {
const response = await this.getChainIdFromNode();
if (response.status !== 200) {
throw new Error('Account not found');
}
return response.body.block.header.chain_id;
}
/**
* Helper to fetch account number
*/
async getAccountDetails(senderAddress) {
const response = await this.getAccountFromNode(senderAddress);
if (response.status !== 200) {
throw new Error('Account not found');
}
return [response.body.account.account_number, response.body.account.sequence];
}
/** @inheritDoc **/
generateKeyPair(seed) {
if (!seed) {
// An extended private key has both a normal 256 bit private key and a 256
// bit chain code, both of which must be random. 512 bits is therefore the
// maximum entropy and gives us maximum security against cracking.
seed = (0, crypto_1.randomBytes)(512 / 8);
}
const extendedKey = secp256k1_1.bip32.fromSeed(seed);
return {
pub: extendedKey.neutered().toBase58(),
prv: extendedKey.toBase58(),
};
}
/**
* Retrieves the address from a public key.
* @param {string} pubKey - The public key.
* @returns {string} The corresponding address.
*/
getAddressFromPublicKey(pubKey) {
throw new Error('Method not implemented');
}
/** @inheritDoc **/
async isWalletAddress(params) {
const addressDetails = this.getAddressDetails(params.address);
if (!this.isValidAddress(addressDetails.address)) {
throw new sdk_core_1.InvalidAddressError(`invalid address: ${addressDetails.address}`);
}
const rootAddress = params.coinSpecific.rootAddress;
if (addressDetails.address !== rootAddress) {
throw new sdk_core_1.UnexpectedAddressError(`address validation failure: ${addressDetails.address} vs ${rootAddress}`);
}
return true;
}
/** @inheritDoc **/
getHashFunction() {
return utils_1.default.getHashFunction();
}
/**
* Process address into address and memo id
*
* @param address the address
* @returns object containing address and memo id
*/
getAddressDetails(address) {
const destinationDetails = url.parse(address);
const destinationAddress = destinationDetails.pathname || '';
// address doesn't have a memo id
if (destinationDetails.pathname === address) {
return {
address: address,
memoId: undefined,
};
}
if (!destinationDetails.query) {
throw new sdk_core_1.InvalidAddressError(`invalid address: ${address}`);
}
const queryDetails = querystring.parse(destinationDetails.query);
if (!queryDetails.memoId) {
// if there are more properties, the query details need to contain the memo id property
throw new sdk_core_1.InvalidAddressError(`invalid address: ${address}`);
}
if (Array.isArray(queryDetails.memoId)) {
throw new sdk_core_1.InvalidAddressError(`memoId may only be given at most once, but found ${queryDetails.memoId.length} instances in address ${address}`);
}
if (Array.isArray(queryDetails.memoId) && queryDetails.memoId.length !== 1) {
// valid addresses can only contain one memo id
throw new sdk_core_1.InvalidAddressError(`invalid address '${address}', must contain exactly one memoId`);
}
const [memoId] = _.castArray(queryDetails.memoId) || undefined;
if (!this.isValidMemoId(memoId)) {
throw new sdk_core_1.InvalidMemoIdError(`invalid address: '${address}', memoId is not valid`);
}
return {
address: destinationAddress,
memoId,
};
}
/**
* Return boolean indicating whether a memo id is valid
*
* @param memoId memo id
* @returns true if memo id is valid
*/
isValidMemoId(memoId) {
return utils_1.default.isValidMemoId(memoId);
}
/**
* Helper method to return the respective coin's base unit
*/
getDenomination() {
throw new Error('Method not implemented');
}
/**
* Helper method to fetch gas amount details for respective coin
*/
getGasAmountDetails() {
throw new Error('Method not implemented');
}
/**
* Helper method to get key pair for individual coin
* @param publicKey
*/
getKeyPair(publicKey) {
throw new Error('Method not implemented');
}
/** @inheritDoc **/
auditDecryptedKey({ multiSigType, publicKey, prv }) {
if (multiSigType !== 'tss') {
throw new Error('Unsupported multiSigType');
}
else {
(0, sdk_lib_mpc_1.auditEcdsaPrivateKey)(prv, publicKey);
}
}
}
exports.CosmosCoin = CosmosCoin;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cosmosCoin.js","sourceRoot":"","sources":["../../src/cosmosCoin.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AuditDecryptedKeyParams,\n  BaseCoin,\n  BaseTransaction,\n  BitGoBase,\n  Ecdsa,\n  ECDSAUtils,\n  ExplanationResult,\n  InvalidAddressError,\n  InvalidMemoIdError,\n  KeyPair,\n  MPCAlgorithm,\n  MultisigType,\n  multisigTypes,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SigningError,\n  SignTransactionOptions,\n  TransactionType,\n  UnexpectedAddressError,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n} from '@bitgo/sdk-core';\nimport { BaseCoin as StaticsBaseCoin, CoinFamily } from '@bitgo/statics';\nimport { bip32 } from '@bitgo/secp256k1';\nimport { Coin } from '@cosmjs/stargate';\nimport { BigNumber } from 'bignumber.js';\nimport { Buffer } from 'buffer';\nimport { createHash, Hash, randomBytes } from 'crypto';\nimport * as _ from 'lodash';\nimport * as querystring from 'querystring';\nimport * as request from 'superagent';\nimport * as url from 'url';\nimport {\n  CosmosKeyPair,\n  CosmosLikeCoinRecoveryOutput,\n  CosmosTransaction,\n  FeeData,\n  GasAmountDetails,\n  RecoveryOptions,\n  RedelegateMessage,\n  SendMessage,\n  CosmosTransactionBuilder,\n  KeyShares,\n  TransactionBuildParams,\n  BalanceResult,\n} from './lib';\nimport { ROOT_PATH } from './lib/constants';\nimport utils from './lib/utils';\nimport { auditEcdsaPrivateKey } from '@bitgo/sdk-lib-mpc';\n\n/**\n * Cosmos accounts support memo Id based addresses\n */\ninterface AddressDetails {\n  address: string;\n  memoId?: string | undefined;\n}\n\n/**\n * Cosmos accounts support memo Id based addresses\n */\ninterface CosmosCoinSpecific {\n  rootAddress: string;\n}\n\nexport class CosmosCoin<CustomMessage = never> 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 CosmosCoin(bitgo, staticsCoin);\n  }\n\n  /**\n   * Creates an instance of TransactionBuilderFactory for the coin specific sdk\n   */\n  getBuilder(): any {\n    throw new Error('Method not implemented.');\n  }\n\n  /** @inheritDoc **/\n  getBaseFactor(): string | number {\n    throw new Error('Method not implemented');\n  }\n\n  /** @inheritDoc **/\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n\n  /** @inheritDoc **/\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  /** @inheritDoc **/\n  getFullName(): string {\n    return this._staticsCoin.fullName;\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  isValidPub(pub: string): boolean {\n    return utils.isValidPublicKey(pub);\n  }\n\n  /** @inheritDoc **/\n  isValidPrv(prv: string): boolean {\n    return utils.isValidPrivateKey(prv);\n  }\n\n  isValidAddress(address: string): boolean {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Builds a funds recovery transaction without BitGo\n   * @param {RecoveryOptions} params parameters needed to construct and\n   * (maybe) sign the transaction\n   *\n   * @returns {CosmosLikeCoinRecoveryOutput} the serialized transaction hex string and index\n   * of the address being swept\n   */\n  async recover(params: RecoveryOptions): Promise<CosmosLikeCoinRecoveryOutput> {\n    const isUnsignedSweep = this.isUnsignedSweep(params);\n    this.validateRecoveryParams(params, isUnsignedSweep);\n\n    const { senderAddress, publicKey, keyShares } = await this.getSenderDetails(params, isUnsignedSweep);\n\n    const [chainId, accountDetails, balances] = await Promise.all([\n      this.getChainId(),\n      this.getAccountDetails(senderAddress),\n      this.getAccountBalance(senderAddress),\n    ]);\n\n    const { actualBalance, remainingBalances } = this.processBalances(balances);\n    const messages = this.buildTransactionMessages(\n      senderAddress,\n      params.recoveryDestination,\n      actualBalance,\n      remainingBalances\n    );\n\n    return this.buildAndSignTransaction({\n      messages,\n      chainId,\n      accountDetails,\n      publicKey: publicKey || '',\n      isUnsignedSweep,\n      keyShares,\n    });\n  }\n\n  /**\n   * Validates the recovery parameters\n   */\n  private validateRecoveryParams(params: RecoveryOptions, isUnsignedSweep: boolean): void {\n    if (!params.recoveryDestination || !this.isValidAddress(params.recoveryDestination)) {\n      throw new Error('invalid recoveryDestination');\n    }\n\n    if (!isUnsignedSweep) {\n      if (!params.userKey) throw new Error('missing userKey');\n      if (!params.backupKey) throw new Error('missing backupKey');\n      if (!params.walletPassphrase) throw new Error('missing wallet passphrase');\n    }\n  }\n\n  /**\n   * Checks if this is an unsigned sweep operation\n   */\n  private isUnsignedSweep(params: RecoveryOptions): boolean {\n    return !params.userKey && !params.backupKey && !params.walletPassphrase;\n  }\n\n  /**\n   * Gets sender details including address, public key and key shares\n   */\n  private async getSenderDetails(\n    params: RecoveryOptions,\n    isUnsignedSweep: boolean\n  ): Promise<{\n    senderAddress: string;\n    publicKey?: string;\n    keyShares?: KeyShares;\n  }> {\n    const MPC = new Ecdsa();\n\n    if (isUnsignedSweep) {\n      return {\n        senderAddress: params.rootAddress as string,\n        publicKey: MPC.deriveUnhardened(params.bitgoKey || '', ROOT_PATH).slice(0, 66),\n      };\n    }\n\n    const keyShares = await this.getKeyShares(params);\n    const publicKey = MPC.deriveUnhardened(keyShares.commonKeyChain, ROOT_PATH).slice(0, 66);\n\n    return {\n      senderAddress: this.getAddressFromPublicKey(publicKey),\n      publicKey,\n      keyShares,\n    };\n  }\n\n  /**\n   * Gets key shares from recovery parameters\n   */\n  private async getKeyShares(params: RecoveryOptions): Promise<KeyShares> {\n    if (!params.userKey || !params.backupKey || !params.walletPassphrase) {\n      throw new Error('Missing required key parameters');\n    }\n\n    const userKey = params.userKey.replace(/\\s/g, '');\n    const backupKey = params.backupKey.replace(/\\s/g, '');\n    const walletPassphrase = params.walletPassphrase;\n\n    if (!userKey || !backupKey) {\n      throw new Error('Invalid key format');\n    }\n\n    return await ECDSAUtils.getMpcV2RecoveryKeyShares(userKey, backupKey, walletPassphrase);\n  }\n\n  /**\n   * Processes account balances and validates sufficient funds\n   */\n  private processBalances(balances: Coin[]): BalanceResult {\n    if (!balances?.length) {\n      throw new Error('No balance found on account');\n    }\n\n    const denomination = this.getDenomination();\n    if (!denomination) {\n      throw new Error('Invalid denomination');\n    }\n\n    let nativeBalance = new BigNumber(0);\n    const remainingBalances: Coin[] = [];\n\n    const gasAmountDetails = this.getGasAmountDetails();\n    if (!gasAmountDetails?.gasAmount) {\n      throw new Error('Invalid gas amount');\n    }\n\n    const gasAmount = new BigNumber(gasAmountDetails.gasAmount);\n    balances.forEach((balance) => {\n      if (!balance.amount) {\n        throw new Error('Invalid balance amount');\n      }\n\n      if (balance.denom === denomination) {\n        nativeBalance = new BigNumber(balance.amount);\n      } else {\n        remainingBalances.push(balance);\n      }\n    });\n\n    const actualBalance = nativeBalance.minus(gasAmount);\n    if (actualBalance.isLessThanOrEqualTo(0)) {\n      throw new Error('Did not have enough funds to recover');\n    }\n\n    return { nativeBalance, remainingBalances, actualBalance };\n  }\n\n  /**\n   * Builds transaction messages for all balances\n   */\n  private buildTransactionMessages(\n    senderAddress: string,\n    recoveryDestination: string,\n    actualBalance: BigNumber,\n    remainingBalances: Coin[]\n  ): SendMessage[] {\n    const nativeSendMessage: SendMessage = {\n      fromAddress: senderAddress,\n      toAddress: recoveryDestination,\n      amount: [\n        {\n          denom: this.getDenomination(),\n          amount: actualBalance.toFixed(),\n        },\n      ],\n    };\n\n    const otherTokenMessages = remainingBalances.map((balance) => ({\n      fromAddress: senderAddress,\n      toAddress: recoveryDestination,\n      amount: [balance],\n    }));\n\n    return [...otherTokenMessages, nativeSendMessage];\n  }\n\n  /**\n   * Builds and signs the transaction\n   */\n  private async buildAndSignTransaction(params: TransactionBuildParams): Promise<CosmosLikeCoinRecoveryOutput> {\n    if (!params.chainId) {\n      throw new Error('Invalid chain ID');\n    }\n\n    const [accountNumber, sequenceNo] = params.accountDetails;\n    if (!accountNumber || !sequenceNo) {\n      throw new Error('Invalid account details');\n    }\n\n    const denomination = this.getDenomination();\n    const gasAmountDetails = this.getGasAmountDetails();\n    if (!denomination || !gasAmountDetails?.gasAmount || !gasAmountDetails?.gasLimit) {\n      throw new Error('Invalid gas configuration');\n    }\n\n    const gasBudget: FeeData = {\n      amount: [\n        {\n          denom: denomination,\n          amount: gasAmountDetails.gasAmount,\n        },\n      ],\n      gasLimit: gasAmountDetails.gasLimit,\n    };\n\n    const txnBuilder = this.getBuilder()\n      .getTransferBuilder()\n      .messages(params.messages)\n      .gasBudget(gasBudget)\n      .sequence(Number(sequenceNo))\n      .accountNumber(Number(accountNumber))\n      .chainId(params.chainId)\n      .publicKey(params.publicKey);\n\n    const unsignedTransaction = (await txnBuilder.build()) as CosmosTransaction<CustomMessage>;\n    if (!unsignedTransaction) {\n      throw new Error('Failed to build unsigned transaction');\n    }\n\n    if (params.isUnsignedSweep) {\n      return {\n        signableHex: unsignedTransaction.signablePayload.toString('hex'),\n      };\n    }\n\n    return this.signTransactionWithMpc(unsignedTransaction, txnBuilder, params.keyShares!, params.publicKey);\n  }\n\n  /**\n   * Signs the transaction with MPC\n   */\n  /**\n   * Signs the transaction using MPC (Multi-Party Computation)\n   * @param unsignedTransaction The unsigned transaction to sign\n   * @param txnBuilder The transaction builder instance\n   * @param keyShares The key shares for MPC signing\n   * @param publicKey The public key for verification\n   * @returns The signed transaction output\n   * @throws Error if validation fails or signing process encounters an error\n   */\n  protected async signTransactionWithMpc(\n    unsignedTransaction: CosmosTransaction<CustomMessage>,\n    txnBuilder: CosmosTransactionBuilder,\n    keyShares: KeyShares,\n    publicKey: string\n  ): Promise<CosmosLikeCoinRecoveryOutput> {\n    // Validate inputs\n    if (!unsignedTransaction?.signablePayload) {\n      throw new Error('Invalid unsigned transaction');\n    }\n\n    if (!keyShares?.userKeyShare || !keyShares?.backupKeyShare || !keyShares?.commonKeyChain) {\n      throw new Error('Invalid key shares');\n    }\n\n    if (!publicKey) {\n      throw new Error('Invalid public key');\n    }\n\n    try {\n      const MPC = new Ecdsa();\n      const message = unsignedTransaction.signablePayload;\n\n      // Get hash function and compute message hash\n      const hashFunction = utils.getHashFunction() || createHash('sha256');\n      if (!hashFunction) {\n        throw new Error('Failed to get hash function');\n      }\n      const messageHash = hashFunction.update(message).digest();\n\n      // Sign the transaction\n      const signature = await ECDSAUtils.signRecoveryMpcV2(\n        messageHash,\n        keyShares.userKeyShare,\n        keyShares.backupKeyShare,\n        keyShares.commonKeyChain\n      );\n\n      // Verify the signature\n      const signableHex = unsignedTransaction.signablePayload.toString('hex');\n      const signableBuffer = Buffer.from(signableHex, 'hex');\n      MPC.verify(signableBuffer, signature, this.getHashFunction());\n\n      // Get cosmos key pair and validate\n      const cosmosKeyPair = this.getKeyPair(publicKey);\n      if (!cosmosKeyPair) {\n        throw new Error('Invalid cosmos key pair');\n      }\n\n      // Add signature to transaction\n      txnBuilder.addSignature({ pub: cosmosKeyPair.getKeys().pub }, Buffer.from(signature.r + signature.s, 'hex'));\n\n      // Build final transaction\n      const signedTransaction = await txnBuilder.build();\n      if (!signedTransaction) {\n        throw new Error('Failed to build signed transaction');\n      }\n\n      return {\n        serializedTx: signedTransaction.toBroadcastFormat(),\n      };\n    } catch (error) {\n      throw new Error(`Failed to sign transaction: ${error.message}`);\n    }\n  }\n\n  /**\n   * Builds a redelegate transaction\n   * @param {RecoveryOptions} params parameters needed to construct and\n   * (maybe) sign the transaction\n   *\n   * @returns {CosmosLikeCoinRecoveryOutput} the serialized transaction hex string\n   */\n  async redelegate(\n    params: RecoveryOptions & {\n      validatorSrcAddress: string;\n      validatorDstAddress: string;\n      amountToRedelegate: string;\n    }\n  ): Promise<CosmosLikeCoinRecoveryOutput> {\n    if (!params.validatorSrcAddress || !this.isValidAddress(params.validatorSrcAddress)) {\n      throw new Error('invalid validatorSrcAddress');\n    }\n\n    if (!params.validatorDstAddress || !this.isValidAddress(params.validatorDstAddress)) {\n      throw new Error('invalid validatorDstAddress');\n    }\n\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    if (!params.amountToRedelegate) {\n      throw new Error('missing amountToRedelegate');\n    }\n\n    const userKey = params.userKey.replace(/\\s/g, '');\n    const backupKey = params.backupKey.replace(/\\s/g, '');\n\n    const { userKeyShare, backupKeyShare, commonKeyChain } = await ECDSAUtils.getMpcV2RecoveryKeyShares(\n      userKey,\n      backupKey,\n      params.walletPassphrase\n    ); // baseAddress is not extracted\n\n    const MPC = new Ecdsa();\n    const chainId = await this.getChainId();\n    const publicKey = MPC.deriveUnhardened(commonKeyChain, ROOT_PATH).slice(0, 66);\n    const senderAddress = this.getAddressFromPublicKey(publicKey);\n\n    const [accountNumber, sequenceNo] = await this.getAccountDetails(senderAddress);\n    const gasBudget: FeeData = {\n      amount: [{ denom: this.getDenomination(), amount: this.getGasAmountDetails().gasAmount }],\n      gasLimit: this.getGasAmountDetails().gasLimit,\n    };\n\n    const amount: Coin = {\n      denom: this.getDenomination(),\n      amount: new BigNumber(params.amountToRedelegate).toFixed(),\n    };\n\n    const sendMessage: RedelegateMessage[] = [\n      {\n        delegatorAddress: senderAddress,\n        validatorSrcAddress: params.validatorSrcAddress,\n        validatorDstAddress: params.validatorDstAddress,\n        amount: amount,\n      },\n    ];\n\n    const txnBuilder = this.getBuilder().getStakingRedelegateBuilder();\n    txnBuilder\n      .messages(sendMessage)\n      .gasBudget(gasBudget)\n      .publicKey(publicKey)\n      .sequence(Number(sequenceNo))\n      .accountNumber(Number(accountNumber))\n      .chainId(chainId);\n\n    const unsignedTransaction = (await txnBuilder.build()) as CosmosTransaction<CustomMessage>;\n    let serializedTx = unsignedTransaction.toBroadcastFormat();\n    const signableHex = unsignedTransaction.signablePayload.toString('hex');\n    const message = unsignedTransaction.signablePayload;\n    const messageHash = (utils.getHashFunction() || createHash('sha256')).update(message).digest();\n    const signature = await ECDSAUtils.signRecoveryMpcV2(messageHash, userKeyShare, backupKeyShare, commonKeyChain);\n    const signableBuffer = Buffer.from(signableHex, 'hex');\n    MPC.verify(signableBuffer, signature, this.getHashFunction());\n    const cosmosKeyPair = this.getKeyPair(publicKey);\n    txnBuilder.addSignature({ pub: cosmosKeyPair.getKeys().pub }, Buffer.from(signature.r + signature.s, 'hex'));\n    const signedTransaction = await txnBuilder.build();\n    serializedTx = signedTransaction.toBroadcastFormat();\n\n    return { serializedTx: serializedTx };\n  }\n\n  /** @inheritDoc **/\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    let totalAmount = new BigNumber(0);\n    const { txPrebuild, txParams } = params;\n    const rawTx = txPrebuild.txHex;\n    if (!rawTx) {\n      throw new Error('missing required tx prebuild property txHex');\n    }\n    const transaction = await this.getBuilder().from(rawTx).build();\n    const explainedTx = transaction.explainTransaction();\n    if (txParams.recipients && txParams.recipients.length > 0) {\n      const filteredRecipients = txParams.recipients?.map((recipient) => _.pick(recipient, ['address', 'amount']));\n      const filteredOutputs = explainedTx.outputs.map((output) => _.pick(output, ['address', 'amount']));\n\n      if (!_.isEqual(filteredOutputs, filteredRecipients)) {\n        throw new Error('Tx outputs does not match with expected txParams recipients');\n      }\n      // WithdrawDelegatorRewards and ContractCall transaction don't have amount\n      if (transaction.type !== TransactionType.StakingWithdraw && transaction.type !== TransactionType.ContractCall) {\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    }\n    return true;\n  }\n\n  /** @inheritDoc **/\n  async explainTransaction(options: { txHex: string }): Promise<ExplanationResult> {\n    if (!options.txHex) {\n      throw new Error('missing required txHex parameter');\n    }\n    try {\n      const transactionBuilder = this.getBuilder().from(options.txHex);\n      const transaction = await transactionBuilder.build();\n      return transaction.explainTransaction();\n    } catch (e) {\n      throw new Error('Invalid transaction: ' + e.message);\n    }\n  }\n\n  /**\n   * Sign a transaction with a single private key\n   * @param params parameters in the form of { txPrebuild: {txHex}, prv }\n   * @returns signed transaction in the form of { txHex }\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 txBuilder = this.getBuilder().from(params.txPrebuild.txHex);\n    txBuilder.sign({ key: params.prv });\n    const transaction: BaseTransaction = await txBuilder.build();\n    if (!transaction) {\n      throw new SigningError('Failed to build signed transaction');\n    }\n    const serializedTx = transaction.toBroadcastFormat();\n    return {\n      txHex: serializedTx,\n    };\n  }\n\n  /** @inheritDoc **/\n  async parseTransaction(params: ParseTransactionOptions & { txHex: string }): Promise<ParsedTransaction> {\n    const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });\n    if (!transactionExplanation) {\n      throw new Error('Invalid transaction');\n    }\n\n    if (transactionExplanation.outputs.length <= 0) {\n      return {\n        inputs: [],\n        outputs: [],\n      };\n    }\n    const senderAddress = transactionExplanation.outputs[0].address;\n    const feeAmount = new BigNumber(transactionExplanation.fee.fee === '' ? '0' : transactionExplanation.fee.fee);\n    const inputs = [\n      {\n        address: senderAddress,\n        amount: new BigNumber(transactionExplanation.outputAmount).plus(feeAmount).toFixed(),\n      },\n    ];\n    const outputs = transactionExplanation.outputs.map((output) => {\n      return {\n        address: output.address,\n        amount: new BigNumber(output.amount).toFixed(),\n      };\n    });\n    return {\n      inputs,\n      outputs,\n    };\n  }\n\n  /**\n   * Get the public node url from the Environments constant we have defined\n   */\n  protected getPublicNodeUrl(): string {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Get account number from public node\n   */\n  protected async getAccountFromNode(senderAddress: string): Promise<request.Response> {\n    const nodeUrl = this.getPublicNodeUrl();\n    const getAccountPath = '/cosmos/auth/v1beta1/accounts/';\n    const fullEndpoint = nodeUrl + getAccountPath + senderAddress;\n    try {\n      return await request.get(fullEndpoint).send();\n    } catch (e) {\n      console.debug(e);\n    }\n    throw new Error(`Unable to call endpoint ${getAccountPath + senderAddress} from node: ${nodeUrl}`);\n  }\n\n  /**\n   * Get balance from public node\n   */\n  protected async getBalanceFromNode(senderAddress: string): Promise<request.Response> {\n    const nodeUrl = this.getPublicNodeUrl();\n    const getBalancePath = '/cosmos/bank/v1beta1/balances/';\n    const fullEndpoint = nodeUrl + getBalancePath + senderAddress;\n    try {\n      return await request.get(fullEndpoint).send();\n    } catch (e) {\n      console.debug(e);\n    }\n    throw new Error(`Unable to call endpoint ${getBalancePath + senderAddress} from node: ${nodeUrl}`);\n  }\n\n  /**\n   * Get chain id from public node\n   */\n  protected async getChainIdFromNode(): Promise<request.Response> {\n    const nodeUrl = this.getPublicNodeUrl();\n    const getLatestBlockPath = '/cosmos/base/tendermint/v1beta1/blocks/latest';\n    const fullEndpoint = nodeUrl + getLatestBlockPath;\n    try {\n      return await request.get(fullEndpoint).send();\n    } catch (e) {\n      console.debug(e);\n    }\n    throw new Error(`Unable to call endpoint ${getLatestBlockPath} from node: ${nodeUrl}`);\n  }\n\n  /**\n   * Helper to fetch account balance\n   */\n  protected async getAccountBalance(senderAddress: string): Promise<Coin[]> {\n    const response = await this.getBalanceFromNode(senderAddress);\n    if (response.status !== 200) {\n      throw new Error('Account not found');\n    }\n    return response.body.balances;\n  }\n\n  /**\n   * Helper to fetch chainId\n   */\n  protected async getChainId(): Promise<string> {\n    const response = await this.getChainIdFromNode();\n    if (response.status !== 200) {\n      throw new Error('Account not found');\n    }\n    return response.body.block.header.chain_id;\n  }\n\n  /**\n   * Helper to fetch account number\n   */\n  protected async getAccountDetails(senderAddress: string): Promise<string[]> {\n    const response = await this.getAccountFromNode(senderAddress);\n    if (response.status !== 200) {\n      throw new Error('Account not found');\n    }\n    return [response.body.account.account_number, response.body.account.sequence];\n  }\n\n  /** @inheritDoc **/\n  generateKeyPair(seed?: Buffer): KeyPair {\n    if (!seed) {\n      // An extended private key has both a normal 256 bit private key and a 256\n      // bit chain code, both of which must be random. 512 bits is therefore the\n      // maximum entropy and gives us maximum security against cracking.\n      seed = randomBytes(512 / 8);\n    }\n    const extendedKey = bip32.fromSeed(seed);\n    return {\n      pub: extendedKey.neutered().toBase58(),\n      prv: extendedKey.toBase58(),\n    };\n  }\n\n  /**\n   * Retrieves the address from a public key.\n   * @param {string} pubKey - The public key.\n   * @returns {string} The corresponding address.\n   */\n  getAddressFromPublicKey(pubKey: string): string {\n    throw new Error('Method not implemented');\n  }\n\n  /** @inheritDoc **/\n  async isWalletAddress(params: VerifyAddressOptions): Promise<boolean> {\n    const addressDetails = this.getAddressDetails(params.address);\n\n    if (!this.isValidAddress(addressDetails.address)) {\n      throw new InvalidAddressError(`invalid address: ${addressDetails.address}`);\n    }\n    const rootAddress = (params.coinSpecific as CosmosCoinSpecific).rootAddress;\n    if (addressDetails.address !== rootAddress) {\n      throw new UnexpectedAddressError(`address validation failure: ${addressDetails.address} vs ${rootAddress}`);\n    }\n    return true;\n  }\n\n  /** @inheritDoc **/\n  getHashFunction(): Hash {\n    return utils.getHashFunction();\n  }\n\n  /**\n   * Process address into address and memo id\n   *\n   * @param address the address\n   * @returns object containing address and memo id\n   */\n  getAddressDetails(address: string): AddressDetails {\n    const destinationDetails = url.parse(address);\n    const destinationAddress = destinationDetails.pathname || '';\n\n    // address doesn't have a memo id\n    if (destinationDetails.pathname === address) {\n      return {\n        address: address,\n        memoId: undefined,\n      };\n    }\n\n    if (!destinationDetails.query) {\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n\n    const queryDetails = querystring.parse(destinationDetails.query);\n    if (!queryDetails.memoId) {\n      // if there are more properties, the query details need to contain the memo id property\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n\n    if (Array.isArray(queryDetails.memoId)) {\n      throw new InvalidAddressError(\n        `memoId may only be given at most once, but found ${queryDetails.memoId.length} instances in address ${address}`\n      );\n    }\n\n    if (Array.isArray(queryDetails.memoId) && queryDetails.memoId.length !== 1) {\n      // valid addresses can only contain one memo id\n      throw new InvalidAddressError(`invalid address '${address}', must contain exactly one memoId`);\n    }\n\n    const [memoId] = _.castArray(queryDetails.memoId) || undefined;\n    if (!this.isValidMemoId(memoId)) {\n      throw new InvalidMemoIdError(`invalid address: '${address}', memoId is not valid`);\n    }\n\n    return {\n      address: destinationAddress,\n      memoId,\n    };\n  }\n\n  /**\n   * Return boolean indicating whether a memo id is valid\n   *\n   * @param memoId memo id\n   * @returns true if memo id is valid\n   */\n  isValidMemoId(memoId: string): boolean {\n    return utils.isValidMemoId(memoId);\n  }\n\n  /**\n   * Helper method to return the respective coin's base unit\n   */\n  getDenomination(): string {\n    throw new Error('Method not implemented');\n  }\n\n  /**\n   * Helper method to fetch gas amount details for respective coin\n   */\n  getGasAmountDetails(): GasAmountDetails {\n    throw new Error('Method not implemented');\n  }\n\n  /**\n   * Helper method to get key pair for individual coin\n   * @param publicKey\n   */\n  getKeyPair(publicKey: string): CosmosKeyPair {\n    throw new Error('Method not implemented');\n  }\n\n  /** @inheritDoc **/\n  auditDecryptedKey({ multiSigType, publicKey, prv }: AuditDecryptedKeyParams) {\n    if (multiSigType !== 'tss') {\n      throw new Error('Unsupported multiSigType');\n    } else {\n      auditEcdsaPrivateKey(prv as string, publicKey as string);\n    }\n  }\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!