PHP WebShell
Текущая директория: /usr/lib/node_modules/bitgo/node_modules/avalanche/dist/apis/evm
Просмотр файла: api.js
"use strict";
/**
* @packageDocumentation
* @module API-EVM
*/
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.EVMAPI = void 0;
const buffer_1 = require("buffer/");
const bn_js_1 = __importDefault(require("bn.js"));
const jrpcapi_1 = require("../../common/jrpcapi");
const bintools_1 = __importDefault(require("../../utils/bintools"));
const utxos_1 = require("./utxos");
const keychain_1 = require("./keychain");
const constants_1 = require("../../utils/constants");
const tx_1 = require("./tx");
const constants_2 = require("./constants");
const inputs_1 = require("./inputs");
const outputs_1 = require("./outputs");
const exporttx_1 = require("./exporttx");
const errors_1 = require("../../utils/errors");
const utils_1 = require("../../utils");
/**
* @ignore
*/
const bintools = bintools_1.default.getInstance();
const serialization = utils_1.Serialization.getInstance();
/**
* Class for interacting with a node's EVMAPI
*
* @category RPCAPIs
*
* @remarks This extends the [[JRPCAPI]] class. This class should not be directly called. Instead, use the [[Avalanche.addAPI]] function to register this interface with Avalanche.
*/
class EVMAPI extends jrpcapi_1.JRPCAPI {
/**
* This class should not be instantiated directly.
* Instead use the [[Avalanche.addAPI]] method.
*
* @param core A reference to the Avalanche class
* @param baseURL Defaults to the string "/ext/bc/C/avax" as the path to blockchain's baseURL
* @param blockchainID The Blockchain's ID. Defaults to an empty string: ""
*/
constructor(core, baseURL = "/ext/bc/C/avax", blockchainID = "") {
super(core, baseURL);
/**
* @ignore
*/
this.keychain = new keychain_1.KeyChain("", "");
this.blockchainID = "";
this.blockchainAlias = undefined;
this.AVAXAssetID = undefined;
this.txFee = undefined;
/**
* Gets the alias for the blockchainID if it exists, otherwise returns `undefined`.
*
* @returns The alias for the blockchainID
*/
this.getBlockchainAlias = () => {
if (typeof this.blockchainAlias === "undefined") {
const netID = this.core.getNetworkID();
if (netID in constants_1.Defaults.network &&
this.blockchainID in constants_1.Defaults.network[`${netID}`]) {
this.blockchainAlias =
constants_1.Defaults.network[`${netID}`][this.blockchainID]["alias"];
return this.blockchainAlias;
}
else {
/* istanbul ignore next */
return undefined;
}
}
return this.blockchainAlias;
};
/**
* Sets the alias for the blockchainID.
*
* @param alias The alias for the blockchainID.
*
*/
this.setBlockchainAlias = (alias) => {
this.blockchainAlias = alias;
/* istanbul ignore next */
return undefined;
};
/**
* Gets the blockchainID and returns it.
*
* @returns The blockchainID
*/
this.getBlockchainID = () => this.blockchainID;
/**
* Refresh blockchainID, and if a blockchainID is passed in, use that.
*
* @param Optional. BlockchainID to assign, if none, uses the default based on networkID.
*
* @returns A boolean if the blockchainID was successfully refreshed.
*/
this.refreshBlockchainID = (blockchainID = undefined) => {
const netID = this.core.getNetworkID();
if (typeof blockchainID === "undefined" &&
typeof constants_1.Defaults.network[`${netID}`] !== "undefined") {
this.blockchainID = constants_1.Defaults.network[`${netID}`].C.blockchainID; //default to C-Chain
return true;
}
if (typeof blockchainID === "string") {
this.blockchainID = blockchainID;
return true;
}
return false;
};
/**
* Takes an address string and returns its {@link https://github.com/feross/buffer|Buffer} representation if valid.
*
* @returns A {@link https://github.com/feross/buffer|Buffer} for the address if valid, undefined if not valid.
*/
this.parseAddress = (addr) => {
const alias = this.getBlockchainAlias();
const blockchainID = this.getBlockchainID();
return bintools.parseAddress(addr, blockchainID, alias, constants_2.EVMConstants.ADDRESSLENGTH);
};
this.addressFromBuffer = (address) => {
const chainID = this.getBlockchainAlias()
? this.getBlockchainAlias()
: this.getBlockchainID();
const type = "bech32";
return serialization.bufferToType(address, type, this.core.getHRP(), chainID);
};
/**
* Retrieves an assets name and symbol.
*
* @param assetID Either a {@link https://github.com/feross/buffer|Buffer} or an b58 serialized string for the AssetID or its alias.
*
* @returns Returns a Promise Asset with keys "name", "symbol", "assetID" and "denomination".
*/
this.getAssetDescription = (assetID) => __awaiter(this, void 0, void 0, function* () {
let asset;
if (typeof assetID !== "string") {
asset = bintools.cb58Encode(assetID);
}
else {
asset = assetID;
}
const params = {
assetID: asset
};
const tmpBaseURL = this.getBaseURL();
// set base url to get asset description
this.setBaseURL("/ext/bc/X");
const response = yield this.callMethod("avm.getAssetDescription", params);
// set base url back what it originally was
this.setBaseURL(tmpBaseURL);
return {
name: response.data.result.name,
symbol: response.data.result.symbol,
assetID: bintools.cb58Decode(response.data.result.assetID),
denomination: parseInt(response.data.result.denomination, 10)
};
});
/**
* Fetches the AVAX AssetID and returns it in a Promise.
*
* @param refresh This function caches the response. Refresh = true will bust the cache.
*
* @returns The the provided string representing the AVAX AssetID
*/
this.getAVAXAssetID = (refresh = false) => __awaiter(this, void 0, void 0, function* () {
if (typeof this.AVAXAssetID === "undefined" || refresh) {
const asset = yield this.getAssetDescription(constants_1.PrimaryAssetAlias);
this.AVAXAssetID = asset.assetID;
}
return this.AVAXAssetID;
});
/**
* Overrides the defaults and sets the cache to a specific AVAX AssetID
*
* @param avaxAssetID A cb58 string or Buffer representing the AVAX AssetID
*
* @returns The the provided string representing the AVAX AssetID
*/
this.setAVAXAssetID = (avaxAssetID) => {
if (typeof avaxAssetID === "string") {
avaxAssetID = bintools.cb58Decode(avaxAssetID);
}
this.AVAXAssetID = avaxAssetID;
};
/**
* Gets the default tx fee for this chain.
*
* @returns The default tx fee as a {@link https://github.com/indutny/bn.js/|BN}
*/
this.getDefaultTxFee = () => {
return this.core.getNetworkID() in constants_1.Defaults.network
? new bn_js_1.default(constants_1.Defaults.network[this.core.getNetworkID()]["C"]["txFee"])
: new bn_js_1.default(0);
};
/**
* returns the amount of [assetID] for the given address in the state of the given block number.
* "latest", "pending", and "accepted" meta block numbers are also allowed.
*
* @param hexAddress The hex representation of the address
* @param blockHeight The block height
* @param assetID The asset ID
*
* @returns Returns a Promise object containing the balance
*/
this.getAssetBalance = (hexAddress, blockHeight, assetID) => __awaiter(this, void 0, void 0, function* () {
const params = [hexAddress, blockHeight, assetID];
const method = "eth_getAssetBalance";
const path = "ext/bc/C/rpc";
const response = yield this.callMethod(method, params, path);
return response.data;
});
/**
* Returns the status of a provided atomic transaction ID by calling the node's `getAtomicTxStatus` method.
*
* @param txID The string representation of the transaction ID
*
* @returns Returns a Promise string containing the status retrieved from the node
*/
this.getAtomicTxStatus = (txID) => __awaiter(this, void 0, void 0, function* () {
const params = {
txID
};
const response = yield this.callMethod("avax.getAtomicTxStatus", params);
return response.data.result.status
? response.data.result.status
: response.data.result;
});
/**
* Returns the transaction data of a provided transaction ID by calling the node's `getAtomicTx` method.
*
* @param txID The string representation of the transaction ID
*
* @returns Returns a Promise string containing the bytes retrieved from the node
*/
this.getAtomicTx = (txID) => __awaiter(this, void 0, void 0, function* () {
const params = {
txID
};
const response = yield this.callMethod("avax.getAtomicTx", params);
return response.data.result.tx;
});
/**
* Gets the tx fee for this chain.
*
* @returns The tx fee as a {@link https://github.com/indutny/bn.js/|BN}
*/
this.getTxFee = () => {
if (typeof this.txFee === "undefined") {
this.txFee = this.getDefaultTxFee();
}
return this.txFee;
};
/**
* Send ANT (Avalanche Native Token) assets including AVAX from the C-Chain to an account on the X-Chain.
*
* After calling this method, you must call the X-Chain’s import method to complete the transfer.
*
* @param username The Keystore user that controls the X-Chain account specified in `to`
* @param password The password of the Keystore user
* @param to The account on the X-Chain to send the AVAX to.
* @param amount Amount of asset to export as a {@link https://github.com/indutny/bn.js/|BN}
* @param assetID The asset id which is being sent
*
* @returns String representing the transaction id
*/
this.export = (username, password, to, amount, assetID) => __awaiter(this, void 0, void 0, function* () {
const params = {
to,
amount: amount.toString(10),
username,
password,
assetID
};
const response = yield this.callMethod("avax.export", params);
return response.data.result.txID
? response.data.result.txID
: response.data.result;
});
/**
* Send AVAX from the C-Chain to an account on the X-Chain.
*
* After calling this method, you must call the X-Chain’s importAVAX method to complete the transfer.
*
* @param username The Keystore user that controls the X-Chain account specified in `to`
* @param password The password of the Keystore user
* @param to The account on the X-Chain to send the AVAX to.
* @param amount Amount of AVAX to export as a {@link https://github.com/indutny/bn.js/|BN}
*
* @returns String representing the transaction id
*/
this.exportAVAX = (username, password, to, amount) => __awaiter(this, void 0, void 0, function* () {
const params = {
to,
amount: amount.toString(10),
username,
password
};
const response = yield this.callMethod("avax.exportAVAX", params);
return response.data.result.txID
? response.data.result.txID
: response.data.result;
});
/**
* Retrieves the UTXOs related to the addresses provided from the node's `getUTXOs` method.
*
* @param addresses An array of addresses as cb58 strings or addresses as {@link https://github.com/feross/buffer|Buffer}s
* @param sourceChain A string for the chain to look for the UTXO's. Default is to use this chain, but if exported UTXOs exist
* from other chains, this can used to pull them instead.
* @param limit Optional. Returns at most [limit] addresses. If [limit] == 0 or > [maxUTXOsToFetch], fetches up to [maxUTXOsToFetch].
* @param startIndex Optional. [StartIndex] defines where to start fetching UTXOs (for pagination.)
* UTXOs fetched are from addresses equal to or greater than [StartIndex.Address]
* For address [StartIndex.Address], only UTXOs with IDs greater than [StartIndex.Utxo] will be returned.
*/
this.getUTXOs = (addresses, sourceChain = undefined, limit = 0, startIndex = undefined, encoding = "hex") => __awaiter(this, void 0, void 0, function* () {
if (typeof addresses === "string") {
addresses = [addresses];
}
const params = {
addresses: addresses,
limit,
encoding
};
if (typeof startIndex !== "undefined" && startIndex) {
params.startIndex = startIndex;
}
if (typeof sourceChain !== "undefined") {
params.sourceChain = sourceChain;
}
const response = yield this.callMethod("avax.getUTXOs", params);
const utxos = new utxos_1.UTXOSet();
const data = response.data.result.utxos;
if (data.length > 0 && data[0].substring(0, 2) === "0x") {
const cb58Strs = [];
data.forEach((str) => {
cb58Strs.push(bintools.cb58Encode(new buffer_1.Buffer(str.slice(2), "hex")));
});
utxos.addArray(cb58Strs, false);
}
else {
utxos.addArray(data, false);
}
response.data.result.utxos = utxos;
return response.data.result;
});
/**
* Send ANT (Avalanche Native Token) assets including AVAX from an account on the X-Chain to an address on the C-Chain. This transaction
* must be signed with the key of the account that the asset is sent from and which pays
* the transaction fee.
*
* @param username The Keystore user that controls the account specified in `to`
* @param password The password of the Keystore user
* @param to The address of the account the asset is sent to.
* @param sourceChain The chainID where the funds are coming from. Ex: "X"
*
* @returns Promise for a string for the transaction, which should be sent to the network
* by calling issueTx.
*/
this.import = (username, password, to, sourceChain) => __awaiter(this, void 0, void 0, function* () {
const params = {
to,
sourceChain,
username,
password
};
const response = yield this.callMethod("avax.import", params);
return response.data.result.txID
? response.data.result.txID
: response.data.result;
});
/**
* Send AVAX from an account on the X-Chain to an address on the C-Chain. This transaction
* must be signed with the key of the account that the AVAX is sent from and which pays
* the transaction fee.
*
* @param username The Keystore user that controls the account specified in `to`
* @param password The password of the Keystore user
* @param to The address of the account the AVAX is sent to. This must be the same as the to
* argument in the corresponding call to the X-Chain’s exportAVAX
* @param sourceChain The chainID where the funds are coming from.
*
* @returns Promise for a string for the transaction, which should be sent to the network
* by calling issueTx.
*/
this.importAVAX = (username, password, to, sourceChain) => __awaiter(this, void 0, void 0, function* () {
const params = {
to,
sourceChain,
username,
password
};
const response = yield this.callMethod("avax.importAVAX", params);
return response.data.result.txID
? response.data.result.txID
: response.data.result;
});
/**
* Give a user control over an address by providing the private key that controls the address.
*
* @param username The name of the user to store the private key
* @param password The password that unlocks the user
* @param privateKey A string representing the private key in the vm"s format
*
* @returns The address for the imported private key.
*/
this.importKey = (username, password, privateKey) => __awaiter(this, void 0, void 0, function* () {
const params = {
username,
password,
privateKey
};
const response = yield this.callMethod("avax.importKey", params);
return response.data.result.address
? response.data.result.address
: response.data.result;
});
/**
* Calls the node's issueTx method from the API and returns the resulting transaction ID as a string.
*
* @param tx A string, {@link https://github.com/feross/buffer|Buffer}, or [[Tx]] representing a transaction
*
* @returns A Promise string representing the transaction ID of the posted transaction.
*/
this.issueTx = (tx) => __awaiter(this, void 0, void 0, function* () {
let Transaction = "";
if (typeof tx === "string") {
Transaction = tx;
}
else if (tx instanceof buffer_1.Buffer) {
const txobj = new tx_1.Tx();
txobj.fromBuffer(tx);
Transaction = txobj.toStringHex();
}
else if (tx instanceof tx_1.Tx) {
Transaction = tx.toStringHex();
}
else {
/* istanbul ignore next */
throw new errors_1.TransactionError("Error - avax.issueTx: provided tx is not expected type of string, Buffer, or Tx");
}
const params = {
tx: Transaction.toString(),
encoding: "hex"
};
const response = yield this.callMethod("avax.issueTx", params);
return response.data.result.txID
? response.data.result.txID
: response.data.result;
});
/**
* Exports the private key for an address.
*
* @param username The name of the user with the private key
* @param password The password used to decrypt the private key
* @param address The address whose private key should be exported
*
* @returns Promise with the decrypted private key and private key hex as store in the database
*/
this.exportKey = (username, password, address) => __awaiter(this, void 0, void 0, function* () {
const params = {
username,
password,
address
};
const response = yield this.callMethod("avax.exportKey", params);
return response.data.result;
});
/**
* Helper function which creates an unsigned Import Tx. For more granular control, you may create your own
* [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s).
*
* @param utxoset A set of UTXOs that the transaction is built on
* @param toAddress The address to send the funds
* @param ownerAddresses The addresses being used to import
* @param sourceChain The chainid for where the import is coming from
* @param fromAddresses The addresses being used to send the funds from the UTXOs provided
*
* @returns An unsigned transaction ([[UnsignedTx]]) which contains a [[ImportTx]].
*
* @remarks
* This helper exists because the endpoint API should be the primary point of entry for most functionality.
*/
this.buildImportTx = (utxoset, toAddress, ownerAddresses, sourceChain, fromAddresses, fee = new bn_js_1.default(0)) => __awaiter(this, void 0, void 0, function* () {
const from = this._cleanAddressArray(fromAddresses, "buildImportTx").map((a) => bintools.stringToAddress(a));
let srcChain = undefined;
if (typeof sourceChain === "string") {
// if there is a sourceChain passed in and it's a string then save the string value and cast the original
// variable from a string to a Buffer
srcChain = sourceChain;
sourceChain = bintools.cb58Decode(sourceChain);
}
else if (typeof sourceChain === "undefined" ||
!(sourceChain instanceof buffer_1.Buffer)) {
// if there is no sourceChain passed in or the sourceChain is any data type other than a Buffer then throw an error
throw new errors_1.ChainIdError("Error - EVMAPI.buildImportTx: sourceChain is undefined or invalid sourceChain type.");
}
const utxoResponse = yield this.getUTXOs(ownerAddresses, srcChain, 0, undefined);
const atomicUTXOs = utxoResponse.utxos;
const networkID = this.core.getNetworkID();
const avaxAssetID = constants_1.Defaults.network[`${networkID}`].X.avaxAssetID;
const avaxAssetIDBuf = bintools.cb58Decode(avaxAssetID);
const atomics = atomicUTXOs.getAllUTXOs();
if (atomics.length === 0) {
throw new errors_1.NoAtomicUTXOsError("Error - EVMAPI.buildImportTx: no atomic utxos to import");
}
const builtUnsignedTx = utxoset.buildImportTx(networkID, bintools.cb58Decode(this.blockchainID), toAddress, atomics, sourceChain, fee, avaxAssetIDBuf);
return builtUnsignedTx;
});
/**
* Helper function which creates an unsigned Export Tx. For more granular control, you may create your own
* [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s).
*
* @param amount The amount being exported as a {@link https://github.com/indutny/bn.js/|BN}
* @param assetID The asset id which is being sent
* @param destinationChain The chainid for where the assets will be sent.
* @param toAddresses The addresses to send the funds
* @param fromAddresses The addresses being used to send the funds from the UTXOs provided
* @param changeAddresses The addresses that can spend the change remaining from the spent UTXOs
* @param asOf Optional. The timestamp to verify the transaction against as a {@link https://github.com/indutny/bn.js/|BN}
* @param locktime Optional. The locktime field created in the resulting outputs
* @param threshold Optional. The number of signatures required to spend the funds in the resultant UTXO
*
* @returns An unsigned transaction ([[UnsignedTx]]) which contains an [[ExportTx]].
*/
this.buildExportTx = (amount, assetID, destinationChain, fromAddressHex, fromAddressBech, toAddresses, nonce = 0, locktime = new bn_js_1.default(0), threshold = 1, fee = new bn_js_1.default(0)) => __awaiter(this, void 0, void 0, function* () {
const prefixes = {};
toAddresses.map((address) => {
prefixes[address.split("-")[0]] = true;
});
if (Object.keys(prefixes).length !== 1) {
throw new errors_1.AddressError("Error - EVMAPI.buildExportTx: To addresses must have the same chainID prefix.");
}
if (typeof destinationChain === "undefined") {
throw new errors_1.ChainIdError("Error - EVMAPI.buildExportTx: Destination ChainID is undefined.");
}
else if (typeof destinationChain === "string") {
destinationChain = bintools.cb58Decode(destinationChain);
}
else if (!(destinationChain instanceof buffer_1.Buffer)) {
throw new errors_1.ChainIdError("Error - EVMAPI.buildExportTx: Invalid destinationChain type");
}
if (destinationChain.length !== 32) {
throw new errors_1.ChainIdError("Error - EVMAPI.buildExportTx: Destination ChainID must be 32 bytes in length.");
}
const assetDescription = yield this.getAssetDescription("AVAX");
let evmInputs = [];
if (bintools.cb58Encode(assetDescription.assetID) === assetID) {
const evmInput = new inputs_1.EVMInput(fromAddressHex, amount.add(fee), assetID, nonce);
evmInput.addSignatureIdx(0, bintools.stringToAddress(fromAddressBech));
evmInputs.push(evmInput);
}
else {
// if asset id isn't AVAX asset id then create 2 inputs
// first input will be AVAX and will be for the amount of the fee
// second input will be the ANT
const evmAVAXInput = new inputs_1.EVMInput(fromAddressHex, fee, assetDescription.assetID, nonce);
evmAVAXInput.addSignatureIdx(0, bintools.stringToAddress(fromAddressBech));
evmInputs.push(evmAVAXInput);
const evmANTInput = new inputs_1.EVMInput(fromAddressHex, amount, assetID, nonce);
evmANTInput.addSignatureIdx(0, bintools.stringToAddress(fromAddressBech));
evmInputs.push(evmANTInput);
}
const to = [];
toAddresses.map((address) => {
to.push(bintools.stringToAddress(address));
});
let exportedOuts = [];
const secpTransferOutput = new outputs_1.SECPTransferOutput(amount, to, locktime, threshold);
const transferableOutput = new outputs_1.TransferableOutput(bintools.cb58Decode(assetID), secpTransferOutput);
exportedOuts.push(transferableOutput);
// lexicographically sort ins and outs
evmInputs = evmInputs.sort(inputs_1.EVMInput.comparator());
exportedOuts = exportedOuts.sort(outputs_1.TransferableOutput.comparator());
const exportTx = new exporttx_1.ExportTx(this.core.getNetworkID(), bintools.cb58Decode(this.blockchainID), destinationChain, evmInputs, exportedOuts);
const unsignedTx = new tx_1.UnsignedTx(exportTx);
return unsignedTx;
});
/**
* Gets a reference to the keychain for this class.
*
* @returns The instance of [[KeyChain]] for this class
*/
this.keyChain = () => this.keychain;
/**
*
* @returns new instance of [[KeyChain]]
*/
this.newKeyChain = () => {
// warning, overwrites the old keychain
const alias = this.getBlockchainAlias();
if (alias) {
this.keychain = new keychain_1.KeyChain(this.core.getHRP(), alias);
}
else {
this.keychain = new keychain_1.KeyChain(this.core.getHRP(), this.blockchainID);
}
return this.keychain;
};
/**
* @returns a Promise string containing the base fee for the next block.
*/
this.getBaseFee = () => __awaiter(this, void 0, void 0, function* () {
const params = [];
const method = "eth_baseFee";
const path = "ext/bc/C/rpc";
const response = yield this.callMethod(method, params, path);
return response.data.result;
});
/**
* returns the priority fee needed to be included in a block.
*
* @returns Returns a Promise string containing the priority fee needed to be included in a block.
*/
this.getMaxPriorityFeePerGas = () => __awaiter(this, void 0, void 0, function* () {
const params = [];
const method = "eth_maxPriorityFeePerGas";
const path = "ext/bc/C/rpc";
const response = yield this.callMethod(method, params, path);
return response.data.result;
});
this.blockchainID = blockchainID;
const netID = core.getNetworkID();
if (netID in constants_1.Defaults.network &&
blockchainID in constants_1.Defaults.network[`${netID}`]) {
const alias = constants_1.Defaults.network[`${netID}`][`${blockchainID}`]["alias"];
this.keychain = new keychain_1.KeyChain(this.core.getHRP(), alias);
}
else {
this.keychain = new keychain_1.KeyChain(this.core.getHRP(), blockchainID);
}
}
/**
* @ignore
*/
_cleanAddressArray(addresses, caller) {
const addrs = [];
const chainid = this.getBlockchainAlias()
? this.getBlockchainAlias()
: this.getBlockchainID();
if (addresses && addresses.length > 0) {
addresses.forEach((address) => {
if (typeof address === "string") {
if (typeof this.parseAddress(address) === "undefined") {
/* istanbul ignore next */
throw new errors_1.AddressError("Error - Invalid address format");
}
addrs.push(address);
}
else {
const type = "bech32";
addrs.push(serialization.bufferToType(address, type, this.core.getHRP(), chainid));
}
});
}
return addrs;
}
}
exports.EVMAPI = EVMAPI;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../../src/apis/evm/api.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;;;;;;;;;;;;;AAEH,oCAAgC;AAChC,kDAAsB;AAEtB,kDAA8C;AAE9C,oEAA2C;AAC3C,mCAAuC;AACvC,yCAAqC;AACrC,qDAAmE;AACnE,6BAAqC;AACrC,2CAA0C;AAO1C,qCAAmC;AACnC,uCAAkE;AAClE,yCAAqC;AACrC,+CAK2B;AAC3B,uCAA2D;AAc3D;;GAEG;AACH,MAAM,QAAQ,GAAa,kBAAQ,CAAC,WAAW,EAAE,CAAA;AACjD,MAAM,aAAa,GAAkB,qBAAa,CAAC,WAAW,EAAE,CAAA;AAEhE;;;;;;GAMG;AACH,MAAa,MAAO,SAAQ,iBAAO;IAmyBjC;;;;;;;OAOG;IACH,YACE,IAAmB,EACnB,UAAkB,gBAAgB,EAClC,eAAuB,EAAE;QAEzB,KAAK,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;QA/yBtB;;WAEG;QACO,aAAQ,GAAa,IAAI,mBAAQ,CAAC,EAAE,EAAE,EAAE,CAAC,CAAA;QACzC,iBAAY,GAAW,EAAE,CAAA;QACzB,oBAAe,GAAW,SAAS,CAAA;QACnC,gBAAW,GAAW,SAAS,CAAA;QAC/B,UAAK,GAAO,SAAS,CAAA;QAE/B;;;;WAIG;QACH,uBAAkB,GAAG,GAAW,EAAE;YAChC,IAAI,OAAO,IAAI,CAAC,eAAe,KAAK,WAAW,EAAE;gBAC/C,MAAM,KAAK,GAAW,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAA;gBAC9C,IACE,KAAK,IAAI,oBAAQ,CAAC,OAAO;oBACzB,IAAI,CAAC,YAAY,IAAI,oBAAQ,CAAC,OAAO,CAAC,GAAG,KAAK,EAAE,CAAC,EACjD;oBACA,IAAI,CAAC,eAAe;wBAClB,oBAAQ,CAAC,OAAO,CAAC,GAAG,KAAK,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,CAAA;oBAC1D,OAAO,IAAI,CAAC,eAAe,CAAA;iBAC5B;qBAAM;oBACL,0BAA0B;oBAC1B,OAAO,SAAS,CAAA;iBACjB;aACF;YACD,OAAO,IAAI,CAAC,eAAe,CAAA;QAC7B,CAAC,CAAA;QAED;;;;;WAKG;QACH,uBAAkB,GAAG,CAAC,KAAa,EAAU,EAAE;YAC7C,IAAI,CAAC,eAAe,GAAG,KAAK,CAAA;YAC5B,0BAA0B;YAC1B,OAAO,SAAS,CAAA;QAClB,CAAC,CAAA;QAED;;;;WAIG;QACH,oBAAe,GAAG,GAAW,EAAE,CAAC,IAAI,CAAC,YAAY,CAAA;QAEjD;;;;;;WAMG;QACH,wBAAmB,GAAG,CAAC,eAAuB,SAAS,EAAW,EAAE;YAClE,MAAM,KAAK,GAAW,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAA;YAC9C,IACE,OAAO,YAAY,KAAK,WAAW;gBACnC,OAAO,oBAAQ,CAAC,OAAO,CAAC,GAAG,KAAK,EAAE,CAAC,KAAK,WAAW,EACnD;gBACA,IAAI,CAAC,YAAY,GAAG,oBAAQ,CAAC,OAAO,CAAC,GAAG,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,YAAY,CAAA,CAAC,oBAAoB;gBACpF,OAAO,IAAI,CAAA;aACZ;YAED,IAAI,OAAO,YAAY,KAAK,QAAQ,EAAE;gBACpC,IAAI,CAAC,YAAY,GAAG,YAAY,CAAA;gBAChC,OAAO,IAAI,CAAA;aACZ;YAED,OAAO,KAAK,CAAA;QACd,CAAC,CAAA;QAED;;;;WAIG;QACH,iBAAY,GAAG,CAAC,IAAY,EAAU,EAAE;YACtC,MAAM,KAAK,GAAW,IAAI,CAAC,kBAAkB,EAAE,CAAA;YAC/C,MAAM,YAAY,GAAW,IAAI,CAAC,eAAe,EAAE,CAAA;YACnD,OAAO,QAAQ,CAAC,YAAY,CAC1B,IAAI,EACJ,YAAY,EACZ,KAAK,EACL,wBAAY,CAAC,aAAa,CAC3B,CAAA;QACH,CAAC,CAAA;QAED,sBAAiB,GAAG,CAAC,OAAe,EAAU,EAAE;YAC9C,MAAM,OAAO,GAAW,IAAI,CAAC,kBAAkB,EAAE;gBAC/C,CAAC,CAAC,IAAI,CAAC,kBAAkB,EAAE;gBAC3B,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,CAAA;YAC1B,MAAM,IAAI,GAAmB,QAAQ,CAAA;YACrC,OAAO,aAAa,CAAC,YAAY,CAC/B,OAAO,EACP,IAAI,EACJ,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,EAClB,OAAO,CACR,CAAA;QACH,CAAC,CAAA;QAED;;;;;;WAMG;QACH,wBAAmB,GAAG,CAAO,OAAwB,EAAgB,EAAE;YACrE,IAAI,KAAa,CAAA;YACjB,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE;gBAC/B,KAAK,GAAG,QAAQ,CAAC,UAAU,CAAC,OAAO,CAAC,CAAA;aACrC;iBAAM;gBACL,KAAK,GAAG,OAAO,CAAA;aAChB;YAED,MAAM,MAAM,GAA8B;gBACxC,OAAO,EAAE,KAAK;aACf,CAAA;YAED,MAAM,UAAU,GAAW,IAAI,CAAC,UAAU,EAAE,CAAA;YAE5C,wCAAwC;YACxC,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,CAAA;YAC5B,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,yBAAyB,EACzB,MAAM,CACP,CAAA;YAED,2CAA2C;YAC3C,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAA;YAC3B,OAAO;gBACL,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;gBAC/B,MAAM,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM;gBACnC,OAAO,EAAE,QAAQ,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;gBAC1D,YAAY,EAAE,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,EAAE,CAAC;aAC9D,CAAA;QACH,CAAC,CAAA,CAAA;QAED;;;;;;WAMG;QACH,mBAAc,GAAG,CAAO,UAAmB,KAAK,EAAmB,EAAE;YACnE,IAAI,OAAO,IAAI,CAAC,WAAW,KAAK,WAAW,IAAI,OAAO,EAAE;gBACtD,MAAM,KAAK,GAAU,MAAM,IAAI,CAAC,mBAAmB,CAAC,6BAAiB,CAAC,CAAA;gBACtE,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,OAAO,CAAA;aACjC;YACD,OAAO,IAAI,CAAC,WAAW,CAAA;QACzB,CAAC,CAAA,CAAA;QAED;;;;;;WAMG;QACH,mBAAc,GAAG,CAAC,WAA4B,EAAE,EAAE;YAChD,IAAI,OAAO,WAAW,KAAK,QAAQ,EAAE;gBACnC,WAAW,GAAG,QAAQ,CAAC,UAAU,CAAC,WAAW,CAAC,CAAA;aAC/C;YACD,IAAI,CAAC,WAAW,GAAG,WAAW,CAAA;QAChC,CAAC,CAAA;QAED;;;;WAIG;QACH,oBAAe,GAAG,GAAO,EAAE;YACzB,OAAO,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,oBAAQ,CAAC,OAAO;gBACjD,CAAC,CAAC,IAAI,eAAE,CAAC,oBAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC;gBAClE,CAAC,CAAC,IAAI,eAAE,CAAC,CAAC,CAAC,CAAA;QACf,CAAC,CAAA;QAED;;;;;;;;;WASG;QACH,oBAAe,GAAG,CAChB,UAAkB,EAClB,WAAmB,EACnB,OAAe,EACE,EAAE;YACnB,MAAM,MAAM,GAAa,CAAC,UAAU,EAAE,WAAW,EAAE,OAAO,CAAC,CAAA;YAE3D,MAAM,MAAM,GAAW,qBAAqB,CAAA;YAC5C,MAAM,IAAI,GAAW,cAAc,CAAA;YACnC,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,MAAM,EACN,MAAM,EACN,IAAI,CACL,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAA;QACtB,CAAC,CAAA,CAAA;QAED;;;;;;WAMG;QACH,sBAAiB,GAAG,CAAO,IAAY,EAAmB,EAAE;YAC1D,MAAM,MAAM,GAA4B;gBACtC,IAAI;aACL,CAAA;YAED,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,wBAAwB,EACxB,MAAM,CACP,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM;gBAChC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM;gBAC7B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC1B,CAAC,CAAA,CAAA;QAED;;;;;;WAMG;QACH,gBAAW,GAAG,CAAO,IAAY,EAAmB,EAAE;YACpD,MAAM,MAAM,GAAsB;gBAChC,IAAI;aACL,CAAA;YAED,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,kBAAkB,EAClB,MAAM,CACP,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAA;QAChC,CAAC,CAAA,CAAA;QAED;;;;WAIG;QACH,aAAQ,GAAG,GAAO,EAAE;YAClB,IAAI,OAAO,IAAI,CAAC,KAAK,KAAK,WAAW,EAAE;gBACrC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,eAAe,EAAE,CAAA;aACpC;YACD,OAAO,IAAI,CAAC,KAAK,CAAA;QACnB,CAAC,CAAA;QAED;;;;;;;;;;;;WAYG;QACH,WAAM,GAAG,CACP,QAAgB,EAChB,QAAgB,EAChB,EAAU,EACV,MAAU,EACV,OAAe,EACE,EAAE;YACnB,MAAM,MAAM,GAAiB;gBAC3B,EAAE;gBACF,MAAM,EAAE,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC3B,QAAQ;gBACR,QAAQ;gBACR,OAAO;aACR,CAAA;YACD,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,aAAa,EACb,MAAM,CACP,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;gBAC9B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;gBAC3B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC1B,CAAC,CAAA,CAAA;QAED;;;;;;;;;;;WAWG;QACH,eAAU,GAAG,CACX,QAAgB,EAChB,QAAgB,EAChB,EAAU,EACV,MAAU,EACO,EAAE;YACnB,MAAM,MAAM,GAAqB;gBAC/B,EAAE;gBACF,MAAM,EAAE,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC3B,QAAQ;gBACR,QAAQ;aACT,CAAA;YACD,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,iBAAiB,EACjB,MAAM,CACP,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;gBAC9B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;gBAC3B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC1B,CAAC,CAAA,CAAA;QAED;;;;;;;;;;WAUG;QACH,aAAQ,GAAG,CACT,SAA4B,EAC5B,cAAsB,SAAS,EAC/B,QAAgB,CAAC,EACjB,aAAoB,SAAS,EAC7B,WAAmB,KAAK,EAKvB,EAAE;YACH,IAAI,OAAO,SAAS,KAAK,QAAQ,EAAE;gBACjC,SAAS,GAAG,CAAC,SAAS,CAAC,CAAA;aACxB;YAED,MAAM,MAAM,GAAmB;gBAC7B,SAAS,EAAE,SAAS;gBACpB,KAAK;gBACL,QAAQ;aACT,CAAA;YACD,IAAI,OAAO,UAAU,KAAK,WAAW,IAAI,UAAU,EAAE;gBACnD,MAAM,CAAC,UAAU,GAAG,UAAU,CAAA;aAC/B;YAED,IAAI,OAAO,WAAW,KAAK,WAAW,EAAE;gBACtC,MAAM,CAAC,WAAW,GAAG,WAAW,CAAA;aACjC;YAED,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,eAAe,EACf,MAAM,CACP,CAAA;YACD,MAAM,KAAK,GAAY,IAAI,eAAO,EAAE,CAAA;YACpC,MAAM,IAAI,GAAQ,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAA;YAC5C,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,EAAE;gBACvD,MAAM,QAAQ,GAAa,EAAE,CAAA;gBAC7B,IAAI,CAAC,OAAO,CAAC,CAAC,GAAW,EAAQ,EAAE;oBACjC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,eAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAA;gBACrE,CAAC,CAAC,CAAA;gBAEF,KAAK,CAAC,QAAQ,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAA;aAChC;iBAAM;gBACL,KAAK,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;aAC5B;YACD,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,KAAK,CAAA;YAClC,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC7B,CAAC,CAAA,CAAA;QAED;;;;;;;;;;;;WAYG;QACH,WAAM,GAAG,CACP,QAAgB,EAChB,QAAgB,EAChB,EAAU,EACV,WAAmB,EACF,EAAE;YACnB,MAAM,MAAM,GAAiB;gBAC3B,EAAE;gBACF,WAAW;gBACX,QAAQ;gBACR,QAAQ;aACT,CAAA;YACD,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,aAAa,EACb,MAAM,CACP,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;gBAC9B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;gBAC3B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC1B,CAAC,CAAA,CAAA;QAED;;;;;;;;;;;;;WAaG;QACH,eAAU,GAAG,CACX,QAAgB,EAChB,QAAgB,EAChB,EAAU,EACV,WAAmB,EACF,EAAE;YACnB,MAAM,MAAM,GAAqB;gBAC/B,EAAE;gBACF,WAAW;gBACX,QAAQ;gBACR,QAAQ;aACT,CAAA;YACD,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,iBAAiB,EACjB,MAAM,CACP,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;gBAC9B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;gBAC3B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC1B,CAAC,CAAA,CAAA;QAED;;;;;;;;WAQG;QACH,cAAS,GAAG,CACV,QAAgB,EAChB,QAAgB,EAChB,UAAkB,EACD,EAAE;YACnB,MAAM,MAAM,GAAoB;gBAC9B,QAAQ;gBACR,QAAQ;gBACR,UAAU;aACX,CAAA;YACD,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,gBAAgB,EAChB,MAAM,CACP,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO;gBACjC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO;gBAC9B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC1B,CAAC,CAAA,CAAA;QAED;;;;;;WAMG;QACH,YAAO,GAAG,CAAO,EAAwB,EAAmB,EAAE;YAC5D,IAAI,WAAW,GAAW,EAAE,CAAA;YAC5B,IAAI,OAAO,EAAE,KAAK,QAAQ,EAAE;gBAC1B,WAAW,GAAG,EAAE,CAAA;aACjB;iBAAM,IAAI,EAAE,YAAY,eAAM,EAAE;gBAC/B,MAAM,KAAK,GAAO,IAAI,OAAE,EAAE,CAAA;gBAC1B,KAAK,CAAC,UAAU,CAAC,EAAE,CAAC,CAAA;gBACpB,WAAW,GAAG,KAAK,CAAC,WAAW,EAAE,CAAA;aAClC;iBAAM,IAAI,EAAE,YAAY,OAAE,EAAE;gBAC3B,WAAW,GAAG,EAAE,CAAC,WAAW,EAAE,CAAA;aAC/B;iBAAM;gBACL,0BAA0B;gBAC1B,MAAM,IAAI,yBAAgB,CACxB,iFAAiF,CAClF,CAAA;aACF;YACD,MAAM,MAAM,GAAkB;gBAC5B,EAAE,EAAE,WAAW,CAAC,QAAQ,EAAE;gBAC1B,QAAQ,EAAE,KAAK;aAChB,CAAA;YACD,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,cAAc,EACd,MAAM,CACP,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;gBAC9B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;gBAC3B,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC1B,CAAC,CAAA,CAAA;QAED;;;;;;;;WAQG;QACH,cAAS,GAAG,CACV,QAAgB,EAChB,QAAgB,EAChB,OAAe,EACE,EAAE;YACnB,MAAM,MAAM,GAAoB;gBAC9B,QAAQ;gBACR,QAAQ;gBACR,OAAO;aACR,CAAA;YACD,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,gBAAgB,EAChB,MAAM,CACP,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC7B,CAAC,CAAA,CAAA;QAED;;;;;;;;;;;;;;WAcG;QACH,kBAAa,GAAG,CACd,OAAgB,EAChB,SAAiB,EACjB,cAAwB,EACxB,WAA4B,EAC5B,aAAuB,EACvB,MAAU,IAAI,eAAE,CAAC,CAAC,CAAC,EACE,EAAE;YACvB,MAAM,IAAI,GAAa,IAAI,CAAC,kBAAkB,CAC5C,aAAa,EACb,eAAe,CAChB,CAAC,GAAG,CAAC,CAAC,CAAS,EAAU,EAAE,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAA;YACzD,IAAI,QAAQ,GAAW,SAAS,CAAA;YAEhC,IAAI,OAAO,WAAW,KAAK,QAAQ,EAAE;gBACnC,yGAAyG;gBACzG,qCAAqC;gBACrC,QAAQ,GAAG,WAAW,CAAA;gBACtB,WAAW,GAAG,QAAQ,CAAC,UAAU,CAAC,WAAW,CAAC,CAAA;aAC/C;iBAAM,IACL,OAAO,WAAW,KAAK,WAAW;gBAClC,CAAC,CAAC,WAAW,YAAY,eAAM,CAAC,EAChC;gBACA,mHAAmH;gBACnH,MAAM,IAAI,qBAAY,CACpB,qFAAqF,CACtF,CAAA;aACF;YACD,MAAM,YAAY,GAAiB,MAAM,IAAI,CAAC,QAAQ,CACpD,cAAc,EACd,QAAQ,EACR,CAAC,EACD,SAAS,CACV,CAAA;YACD,MAAM,WAAW,GAAY,YAAY,CAAC,KAAK,CAAA;YAC/C,MAAM,SAAS,GAAW,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAA;YAClD,MAAM,WAAW,GAAW,oBAAQ,CAAC,OAAO,CAAC,GAAG,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,CAAA;YAC1E,MAAM,cAAc,GAAW,QAAQ,CAAC,UAAU,CAAC,WAAW,CAAC,CAAA;YAC/D,MAAM,OAAO,GAAW,WAAW,CAAC,WAAW,EAAE,CAAA;YAEjD,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;gBACxB,MAAM,IAAI,2BAAkB,CAC1B,yDAAyD,CAC1D,CAAA;aACF;YAED,MAAM,eAAe,GAAe,OAAO,CAAC,aAAa,CACvD,SAAS,EACT,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,EACtC,SAAS,EACT,OAAO,EACP,WAAW,EACX,GAAG,EACH,cAAc,CACf,CAAA;YAED,OAAO,eAAe,CAAA;QACxB,CAAC,CAAA,CAAA;QAED;;;;;;;;;;;;;;;WAeG;QACH,kBAAa,GAAG,CACd,MAAU,EACV,OAAwB,EACxB,gBAAiC,EACjC,cAAsB,EACtB,eAAuB,EACvB,WAAqB,EACrB,QAAgB,CAAC,EACjB,WAAe,IAAI,eAAE,CAAC,CAAC,CAAC,EACxB,YAAoB,CAAC,EACrB,MAAU,IAAI,eAAE,CAAC,CAAC,CAAC,EACE,EAAE;YACvB,MAAM,QAAQ,GAAW,EAAE,CAAA;YAC3B,WAAW,CAAC,GAAG,CAAC,CAAC,OAAe,EAAE,EAAE;gBAClC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAA;YACxC,CAAC,CAAC,CAAA;YACF,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;gBACtC,MAAM,IAAI,qBAAY,CACpB,+EAA+E,CAChF,CAAA;aACF;YAED,IAAI,OAAO,gBAAgB,KAAK,WAAW,EAAE;gBAC3C,MAAM,IAAI,qBAAY,CACpB,iEAAiE,CAClE,CAAA;aACF;iBAAM,IAAI,OAAO,gBAAgB,KAAK,QAAQ,EAAE;gBAC/C,gBAAgB,GAAG,QAAQ,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAA;aACzD;iBAAM,IAAI,CAAC,CAAC,gBAAgB,YAAY,eAAM,CAAC,EAAE;gBAChD,MAAM,IAAI,qBAAY,CACpB,6DAA6D,CAC9D,CAAA;aACF;YACD,IAAI,gBAAgB,CAAC,MAAM,KAAK,EAAE,EAAE;gBAClC,MAAM,IAAI,qBAAY,CACpB,+EAA+E,CAChF,CAAA;aACF;YACD,MAAM,gBAAgB,GAAQ,MAAM,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAA;YACpE,IAAI,SAAS,GAAe,EAAE,CAAA;YAC9B,IAAI,QAAQ,CAAC,UAAU,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,OAAO,EAAE;gBAC7D,MAAM,QAAQ,GAAa,IAAI,iBAAQ,CACrC,cAAc,EACd,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,EACf,OAAO,EACP,KAAK,CACN,CAAA;gBACD,QAAQ,CAAC,eAAe,CAAC,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,CAAA;gBACtE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;aACzB;iBAAM;gBACL,uDAAuD;gBACvD,iEAAiE;gBACjE,+BAA+B;gBAC/B,MAAM,YAAY,GAAa,IAAI,iBAAQ,CACzC,cAAc,EACd,GAAG,EACH,gBAAgB,CAAC,OAAO,EACxB,KAAK,CACN,CAAA;gBACD,YAAY,CAAC,eAAe,CAAC,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,CAAA;gBAC1E,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;gBAE5B,MAAM,WAAW,GAAa,IAAI,iBAAQ,CACxC,cAAc,EACd,MAAM,EACN,OAAO,EACP,KAAK,CACN,CAAA;gBACD,WAAW,CAAC,eAAe,CAAC,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,CAAA;gBACzE,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;aAC5B;YAED,MAAM,EAAE,GAAa,EAAE,CAAA;YACvB,WAAW,CAAC,GAAG,CAAC,CAAC,OAAe,EAAQ,EAAE;gBACxC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,CAAA;YAC5C,CAAC,CAAC,CAAA;YAEF,IAAI,YAAY,GAAyB,EAAE,CAAA;YAC3C,MAAM,kBAAkB,GAAuB,IAAI,4BAAkB,CACnE,MAAM,EACN,EAAE,EACF,QAAQ,EACR,SAAS,CACV,CAAA;YACD,MAAM,kBAAkB,GAAuB,IAAI,4BAAkB,CACnE,QAAQ,CAAC,UAAU,CAAC,OAAO,CAAC,EAC5B,kBAAkB,CACnB,CAAA;YACD,YAAY,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAA;YAErC,sCAAsC;YACtC,SAAS,GAAG,SAAS,CAAC,IAAI,CAAC,iBAAQ,CAAC,UAAU,EAAE,CAAC,CAAA;YACjD,YAAY,GAAG,YAAY,CAAC,IAAI,CAAC,4BAAkB,CAAC,UAAU,EAAE,CAAC,CAAA;YAEjE,MAAM,QAAQ,GAAa,IAAI,mBAAQ,CACrC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,EACxB,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,EACtC,gBAAgB,EAChB,SAAS,EACT,YAAY,CACb,CAAA;YAED,MAAM,UAAU,GAAe,IAAI,eAAU,CAAC,QAAQ,CAAC,CAAA;YACvD,OAAO,UAAU,CAAA;QACnB,CAAC,CAAA,CAAA;QAED;;;;WAIG;QACH,aAAQ,GAAG,GAAa,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAA;QAExC;;;WAGG;QACH,gBAAW,GAAG,GAAa,EAAE;YAC3B,uCAAuC;YACvC,MAAM,KAAK,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAA;YACvC,IAAI,KAAK,EAAE;gBACT,IAAI,CAAC,QAAQ,GAAG,IAAI,mBAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,KAAK,CAAC,CAAA;aACxD;iBAAM;gBACL,IAAI,CAAC,QAAQ,GAAG,IAAI,mBAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,CAAA;aACpE;YACD,OAAO,IAAI,CAAC,QAAQ,CAAA;QACtB,CAAC,CAAA;QAiED;;WAEG;QACH,eAAU,GAAG,GAA0B,EAAE;YACvC,MAAM,MAAM,GAAa,EAAE,CAAA;YAC3B,MAAM,MAAM,GAAW,aAAa,CAAA;YACpC,MAAM,IAAI,GAAW,cAAc,CAAA;YACnC,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,MAAM,EACN,MAAM,EACN,IAAI,CACL,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC7B,CAAC,CAAA,CAAA;QAED;;;;WAIG;QACH,4BAAuB,GAAG,GAA0B,EAAE;YACpD,MAAM,MAAM,GAAa,EAAE,CAAA;YAE3B,MAAM,MAAM,GAAW,0BAA0B,CAAA;YACjD,MAAM,IAAI,GAAW,cAAc,CAAA;YACnC,MAAM,QAAQ,GAAwB,MAAM,IAAI,CAAC,UAAU,CACzD,MAAM,EACN,MAAM,EACN,IAAI,CACL,CAAA;YACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAA;QAC7B,CAAC,CAAA,CAAA;QA7CC,IAAI,CAAC,YAAY,GAAG,YAAY,CAAA;QAChC,MAAM,KAAK,GAAW,IAAI,CAAC,YAAY,EAAE,CAAA;QACzC,IACE,KAAK,IAAI,oBAAQ,CAAC,OAAO;YACzB,YAAY,IAAI,oBAAQ,CAAC,OAAO,CAAC,GAAG,KAAK,EAAE,CAAC,EAC5C;YACA,MAAM,KAAK,GACT,oBAAQ,CAAC,OAAO,CAAC,GAAG,KAAK,EAAE,CAAC,CAAC,GAAG,YAAY,EAAE,CAAC,CAAC,OAAO,CAAC,CAAA;YAC1D,IAAI,CAAC,QAAQ,GAAG,IAAI,mBAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,KAAK,CAAC,CAAA;SACxD;aAAM;YACL,IAAI,CAAC,QAAQ,GAAG,IAAI,mBAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,YAAY,CAAC,CAAA;SAC/D;IACH,CAAC;IA7DD;;OAEG;IACO,kBAAkB,CAC1B,SAA8B,EAC9B,MAAc;QAEd,MAAM,KAAK,GAAa,EAAE,CAAA;QAC1B,MAAM,OAAO,GAAW,IAAI,CAAC,kBAAkB,EAAE;YAC/C,CAAC,CAAC,IAAI,CAAC,kBAAkB,EAAE;YAC3B,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,CAAA;QAC1B,IAAI,SAAS,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YACrC,SAAS,CAAC,OAAO,CAAC,CAAC,OAAwB,EAAE,EAAE;gBAC7C,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE;oBAC/B,IAAI,OAAO,IAAI,CAAC,YAAY,CAAC,OAAiB,CAAC,KAAK,WAAW,EAAE;wBAC/D,0BAA0B;wBAC1B,MAAM,IAAI,qBAAY,CAAC,gCAAgC,CAAC,CAAA;qBACzD;oBACD,KAAK,CAAC,IAAI,CAAC,OAAiB,CAAC,CAAA;iBAC9B;qBAAM;oBACL,MAAM,IAAI,GAAmB,QAAQ,CAAA;oBACrC,KAAK,CAAC,IAAI,CACR,aAAa,CAAC,YAAY,CACxB,OAAiB,EACjB,IAAI,EACJ,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,EAClB,OAAO,CACR,CACF,CAAA;iBACF;YACH,CAAC,CAAC,CAAA;SACH;QACD,OAAO,KAAK,CAAA;IACd,CAAC;CA8DF;AA/1BD,wBA+1BC","sourcesContent":["/**\n * @packageDocumentation\n * @module API-EVM\n */\n\nimport { Buffer } from \"buffer/\"\nimport BN from \"bn.js\"\nimport AvalancheCore from \"../../avalanche\"\nimport { JRPCAPI } from \"../../common/jrpcapi\"\nimport { RequestResponseData } from \"../../common/apibase\"\nimport BinTools from \"../../utils/bintools\"\nimport { UTXOSet, UTXO } from \"./utxos\"\nimport { KeyChain } from \"./keychain\"\nimport { Defaults, PrimaryAssetAlias } from \"../../utils/constants\"\nimport { Tx, UnsignedTx } from \"./tx\"\nimport { EVMConstants } from \"./constants\"\nimport {\n  Asset,\n  Index,\n  IssueTxParams,\n  UTXOResponse\n} from \"./../../common/interfaces\"\nimport { EVMInput } from \"./inputs\"\nimport { SECPTransferOutput, TransferableOutput } from \"./outputs\"\nimport { ExportTx } from \"./exporttx\"\nimport {\n  TransactionError,\n  ChainIdError,\n  NoAtomicUTXOsError,\n  AddressError\n} from \"../../utils/errors\"\nimport { Serialization, SerializedType } from \"../../utils\"\nimport {\n  ExportAVAXParams,\n  ExportKeyParams,\n  ExportParams,\n  GetAtomicTxParams,\n  GetAssetDescriptionParams,\n  GetAtomicTxStatusParams,\n  GetUTXOsParams,\n  ImportAVAXParams,\n  ImportKeyParams,\n  ImportParams\n} from \"./interfaces\"\n\n/**\n * @ignore\n */\nconst bintools: BinTools = BinTools.getInstance()\nconst serialization: Serialization = Serialization.getInstance()\n\n/**\n * Class for interacting with a node's EVMAPI\n *\n * @category RPCAPIs\n *\n * @remarks This extends the [[JRPCAPI]] class. This class should not be directly called. Instead, use the [[Avalanche.addAPI]] function to register this interface with Avalanche.\n */\nexport class EVMAPI extends JRPCAPI {\n  /**\n   * @ignore\n   */\n  protected keychain: KeyChain = new KeyChain(\"\", \"\")\n  protected blockchainID: string = \"\"\n  protected blockchainAlias: string = undefined\n  protected AVAXAssetID: Buffer = undefined\n  protected txFee: BN = undefined\n\n  /**\n   * Gets the alias for the blockchainID if it exists, otherwise returns `undefined`.\n   *\n   * @returns The alias for the blockchainID\n   */\n  getBlockchainAlias = (): string => {\n    if (typeof this.blockchainAlias === \"undefined\") {\n      const netID: number = this.core.getNetworkID()\n      if (\n        netID in Defaults.network &&\n        this.blockchainID in Defaults.network[`${netID}`]\n      ) {\n        this.blockchainAlias =\n          Defaults.network[`${netID}`][this.blockchainID][\"alias\"]\n        return this.blockchainAlias\n      } else {\n        /* istanbul ignore next */\n        return undefined\n      }\n    }\n    return this.blockchainAlias\n  }\n\n  /**\n   * Sets the alias for the blockchainID.\n   *\n   * @param alias The alias for the blockchainID.\n   *\n   */\n  setBlockchainAlias = (alias: string): string => {\n    this.blockchainAlias = alias\n    /* istanbul ignore next */\n    return undefined\n  }\n\n  /**\n   * Gets the blockchainID and returns it.\n   *\n   * @returns The blockchainID\n   */\n  getBlockchainID = (): string => this.blockchainID\n\n  /**\n   * Refresh blockchainID, and if a blockchainID is passed in, use that.\n   *\n   * @param Optional. BlockchainID to assign, if none, uses the default based on networkID.\n   *\n   * @returns A boolean if the blockchainID was successfully refreshed.\n   */\n  refreshBlockchainID = (blockchainID: string = undefined): boolean => {\n    const netID: number = this.core.getNetworkID()\n    if (\n      typeof blockchainID === \"undefined\" &&\n      typeof Defaults.network[`${netID}`] !== \"undefined\"\n    ) {\n      this.blockchainID = Defaults.network[`${netID}`].C.blockchainID //default to C-Chain\n      return true\n    }\n\n    if (typeof blockchainID === \"string\") {\n      this.blockchainID = blockchainID\n      return true\n    }\n\n    return false\n  }\n\n  /**\n   * Takes an address string and returns its {@link https://github.com/feross/buffer|Buffer} representation if valid.\n   *\n   * @returns A {@link https://github.com/feross/buffer|Buffer} for the address if valid, undefined if not valid.\n   */\n  parseAddress = (addr: string): Buffer => {\n    const alias: string = this.getBlockchainAlias()\n    const blockchainID: string = this.getBlockchainID()\n    return bintools.parseAddress(\n      addr,\n      blockchainID,\n      alias,\n      EVMConstants.ADDRESSLENGTH\n    )\n  }\n\n  addressFromBuffer = (address: Buffer): string => {\n    const chainID: string = this.getBlockchainAlias()\n      ? this.getBlockchainAlias()\n      : this.getBlockchainID()\n    const type: SerializedType = \"bech32\"\n    return serialization.bufferToType(\n      address,\n      type,\n      this.core.getHRP(),\n      chainID\n    )\n  }\n\n  /**\n   * Retrieves an assets name and symbol.\n   *\n   * @param assetID Either a {@link https://github.com/feross/buffer|Buffer} or an b58 serialized string for the AssetID or its alias.\n   *\n   * @returns Returns a Promise Asset with keys \"name\", \"symbol\", \"assetID\" and \"denomination\".\n   */\n  getAssetDescription = async (assetID: Buffer | string): Promise<any> => {\n    let asset: string\n    if (typeof assetID !== \"string\") {\n      asset = bintools.cb58Encode(assetID)\n    } else {\n      asset = assetID\n    }\n\n    const params: GetAssetDescriptionParams = {\n      assetID: asset\n    }\n\n    const tmpBaseURL: string = this.getBaseURL()\n\n    // set base url to get asset description\n    this.setBaseURL(\"/ext/bc/X\")\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.getAssetDescription\",\n      params\n    )\n\n    // set base url back what it originally was\n    this.setBaseURL(tmpBaseURL)\n    return {\n      name: response.data.result.name,\n      symbol: response.data.result.symbol,\n      assetID: bintools.cb58Decode(response.data.result.assetID),\n      denomination: parseInt(response.data.result.denomination, 10)\n    }\n  }\n\n  /**\n   * Fetches the AVAX AssetID and returns it in a Promise.\n   *\n   * @param refresh This function caches the response. Refresh = true will bust the cache.\n   *\n   * @returns The the provided string representing the AVAX AssetID\n   */\n  getAVAXAssetID = async (refresh: boolean = false): Promise<Buffer> => {\n    if (typeof this.AVAXAssetID === \"undefined\" || refresh) {\n      const asset: Asset = await this.getAssetDescription(PrimaryAssetAlias)\n      this.AVAXAssetID = asset.assetID\n    }\n    return this.AVAXAssetID\n  }\n\n  /**\n   * Overrides the defaults and sets the cache to a specific AVAX AssetID\n   *\n   * @param avaxAssetID A cb58 string or Buffer representing the AVAX AssetID\n   *\n   * @returns The the provided string representing the AVAX AssetID\n   */\n  setAVAXAssetID = (avaxAssetID: string | Buffer) => {\n    if (typeof avaxAssetID === \"string\") {\n      avaxAssetID = bintools.cb58Decode(avaxAssetID)\n    }\n    this.AVAXAssetID = avaxAssetID\n  }\n\n  /**\n   * Gets the default tx fee for this chain.\n   *\n   * @returns The default tx fee as a {@link https://github.com/indutny/bn.js/|BN}\n   */\n  getDefaultTxFee = (): BN => {\n    return this.core.getNetworkID() in Defaults.network\n      ? new BN(Defaults.network[this.core.getNetworkID()][\"C\"][\"txFee\"])\n      : new BN(0)\n  }\n\n  /**\n   * returns the amount of [assetID] for the given address in the state of the given block number.\n   * \"latest\", \"pending\", and \"accepted\" meta block numbers are also allowed.\n   *\n   * @param hexAddress The hex representation of the address\n   * @param blockHeight The block height\n   * @param assetID The asset ID\n   *\n   * @returns Returns a Promise object containing the balance\n   */\n  getAssetBalance = async (\n    hexAddress: string,\n    blockHeight: string,\n    assetID: string\n  ): Promise<object> => {\n    const params: string[] = [hexAddress, blockHeight, assetID]\n\n    const method: string = \"eth_getAssetBalance\"\n    const path: string = \"ext/bc/C/rpc\"\n    const response: RequestResponseData = await this.callMethod(\n      method,\n      params,\n      path\n    )\n    return response.data\n  }\n\n  /**\n   * Returns the status of a provided atomic transaction ID by calling the node's `getAtomicTxStatus` method.\n   *\n   * @param txID The string representation of the transaction ID\n   *\n   * @returns Returns a Promise string containing the status retrieved from the node\n   */\n  getAtomicTxStatus = async (txID: string): Promise<string> => {\n    const params: GetAtomicTxStatusParams = {\n      txID\n    }\n\n    const response: RequestResponseData = await this.callMethod(\n      \"avax.getAtomicTxStatus\",\n      params\n    )\n    return response.data.result.status\n      ? response.data.result.status\n      : response.data.result\n  }\n\n  /**\n   * Returns the transaction data of a provided transaction ID by calling the node's `getAtomicTx` method.\n   *\n   * @param txID The string representation of the transaction ID\n   *\n   * @returns Returns a Promise string containing the bytes retrieved from the node\n   */\n  getAtomicTx = async (txID: string): Promise<string> => {\n    const params: GetAtomicTxParams = {\n      txID\n    }\n\n    const response: RequestResponseData = await this.callMethod(\n      \"avax.getAtomicTx\",\n      params\n    )\n    return response.data.result.tx\n  }\n\n  /**\n   * Gets the tx fee for this chain.\n   *\n   * @returns The tx fee as a {@link https://github.com/indutny/bn.js/|BN}\n   */\n  getTxFee = (): BN => {\n    if (typeof this.txFee === \"undefined\") {\n      this.txFee = this.getDefaultTxFee()\n    }\n    return this.txFee\n  }\n\n  /**\n   * Send ANT (Avalanche Native Token) assets including AVAX from the C-Chain to an account on the X-Chain.\n   *\n   * After calling this method, you must call the X-Chain’s import method to complete the transfer.\n   *\n   * @param username The Keystore user that controls the X-Chain account specified in `to`\n   * @param password The password of the Keystore user\n   * @param to The account on the X-Chain to send the AVAX to.\n   * @param amount Amount of asset to export as a {@link https://github.com/indutny/bn.js/|BN}\n   * @param assetID The asset id which is being sent\n   *\n   * @returns String representing the transaction id\n   */\n  export = async (\n    username: string,\n    password: string,\n    to: string,\n    amount: BN,\n    assetID: string\n  ): Promise<string> => {\n    const params: ExportParams = {\n      to,\n      amount: amount.toString(10),\n      username,\n      password,\n      assetID\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avax.export\",\n      params\n    )\n    return response.data.result.txID\n      ? response.data.result.txID\n      : response.data.result\n  }\n\n  /**\n   * Send AVAX from the C-Chain to an account on the X-Chain.\n   *\n   * After calling this method, you must call the X-Chain’s importAVAX method to complete the transfer.\n   *\n   * @param username The Keystore user that controls the X-Chain account specified in `to`\n   * @param password The password of the Keystore user\n   * @param to The account on the X-Chain to send the AVAX to.\n   * @param amount Amount of AVAX to export as a {@link https://github.com/indutny/bn.js/|BN}\n   *\n   * @returns String representing the transaction id\n   */\n  exportAVAX = async (\n    username: string,\n    password: string,\n    to: string,\n    amount: BN\n  ): Promise<string> => {\n    const params: ExportAVAXParams = {\n      to,\n      amount: amount.toString(10),\n      username,\n      password\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avax.exportAVAX\",\n      params\n    )\n    return response.data.result.txID\n      ? response.data.result.txID\n      : response.data.result\n  }\n\n  /**\n   * Retrieves the UTXOs related to the addresses provided from the node's `getUTXOs` method.\n   *\n   * @param addresses An array of addresses as cb58 strings or addresses as {@link https://github.com/feross/buffer|Buffer}s\n   * @param sourceChain A string for the chain to look for the UTXO's. Default is to use this chain, but if exported UTXOs exist\n   * from other chains, this can used to pull them instead.\n   * @param limit Optional. Returns at most [limit] addresses. If [limit] == 0 or > [maxUTXOsToFetch], fetches up to [maxUTXOsToFetch].\n   * @param startIndex Optional. [StartIndex] defines where to start fetching UTXOs (for pagination.)\n   * UTXOs fetched are from addresses equal to or greater than [StartIndex.Address]\n   * For address [StartIndex.Address], only UTXOs with IDs greater than [StartIndex.Utxo] will be returned.\n   */\n  getUTXOs = async (\n    addresses: string[] | string,\n    sourceChain: string = undefined,\n    limit: number = 0,\n    startIndex: Index = undefined,\n    encoding: string = \"hex\"\n  ): Promise<{\n    numFetched: number\n    utxos\n    endIndex: Index\n  }> => {\n    if (typeof addresses === \"string\") {\n      addresses = [addresses]\n    }\n\n    const params: GetUTXOsParams = {\n      addresses: addresses,\n      limit,\n      encoding\n    }\n    if (typeof startIndex !== \"undefined\" && startIndex) {\n      params.startIndex = startIndex\n    }\n\n    if (typeof sourceChain !== \"undefined\") {\n      params.sourceChain = sourceChain\n    }\n\n    const response: RequestResponseData = await this.callMethod(\n      \"avax.getUTXOs\",\n      params\n    )\n    const utxos: UTXOSet = new UTXOSet()\n    const data: any = response.data.result.utxos\n    if (data.length > 0 && data[0].substring(0, 2) === \"0x\") {\n      const cb58Strs: string[] = []\n      data.forEach((str: string): void => {\n        cb58Strs.push(bintools.cb58Encode(new Buffer(str.slice(2), \"hex\")))\n      })\n\n      utxos.addArray(cb58Strs, false)\n    } else {\n      utxos.addArray(data, false)\n    }\n    response.data.result.utxos = utxos\n    return response.data.result\n  }\n\n  /**\n   * Send ANT (Avalanche Native Token) assets including AVAX from an account on the X-Chain to an address on the C-Chain. This transaction\n   * must be signed with the key of the account that the asset is sent from and which pays\n   * the transaction fee.\n   *\n   * @param username The Keystore user that controls the account specified in `to`\n   * @param password The password of the Keystore user\n   * @param to The address of the account the asset is sent to.\n   * @param sourceChain The chainID where the funds are coming from. Ex: \"X\"\n   *\n   * @returns Promise for a string for the transaction, which should be sent to the network\n   * by calling issueTx.\n   */\n  import = async (\n    username: string,\n    password: string,\n    to: string,\n    sourceChain: string\n  ): Promise<string> => {\n    const params: ImportParams = {\n      to,\n      sourceChain,\n      username,\n      password\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avax.import\",\n      params\n    )\n    return response.data.result.txID\n      ? response.data.result.txID\n      : response.data.result\n  }\n\n  /**\n   * Send AVAX from an account on the X-Chain to an address on the C-Chain. This transaction\n   * must be signed with the key of the account that the AVAX is sent from and which pays\n   * the transaction fee.\n   *\n   * @param username The Keystore user that controls the account specified in `to`\n   * @param password The password of the Keystore user\n   * @param to The address of the account the AVAX is sent to. This must be the same as the to\n   * argument in the corresponding call to the X-Chain’s exportAVAX\n   * @param sourceChain The chainID where the funds are coming from.\n   *\n   * @returns Promise for a string for the transaction, which should be sent to the network\n   * by calling issueTx.\n   */\n  importAVAX = async (\n    username: string,\n    password: string,\n    to: string,\n    sourceChain: string\n  ): Promise<string> => {\n    const params: ImportAVAXParams = {\n      to,\n      sourceChain,\n      username,\n      password\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avax.importAVAX\",\n      params\n    )\n    return response.data.result.txID\n      ? response.data.result.txID\n      : response.data.result\n  }\n\n  /**\n   * Give a user control over an address by providing the private key that controls the address.\n   *\n   * @param username The name of the user to store the private key\n   * @param password The password that unlocks the user\n   * @param privateKey A string representing the private key in the vm\"s format\n   *\n   * @returns The address for the imported private key.\n   */\n  importKey = async (\n    username: string,\n    password: string,\n    privateKey: string\n  ): Promise<string> => {\n    const params: ImportKeyParams = {\n      username,\n      password,\n      privateKey\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avax.importKey\",\n      params\n    )\n    return response.data.result.address\n      ? response.data.result.address\n      : response.data.result\n  }\n\n  /**\n   * Calls the node's issueTx method from the API and returns the resulting transaction ID as a string.\n   *\n   * @param tx A string, {@link https://github.com/feross/buffer|Buffer}, or [[Tx]] representing a transaction\n   *\n   * @returns A Promise string representing the transaction ID of the posted transaction.\n   */\n  issueTx = async (tx: string | Buffer | Tx): Promise<string> => {\n    let Transaction: string = \"\"\n    if (typeof tx === \"string\") {\n      Transaction = tx\n    } else if (tx instanceof Buffer) {\n      const txobj: Tx = new Tx()\n      txobj.fromBuffer(tx)\n      Transaction = txobj.toStringHex()\n    } else if (tx instanceof Tx) {\n      Transaction = tx.toStringHex()\n    } else {\n      /* istanbul ignore next */\n      throw new TransactionError(\n        \"Error - avax.issueTx: provided tx is not expected type of string, Buffer, or Tx\"\n      )\n    }\n    const params: IssueTxParams = {\n      tx: Transaction.toString(),\n      encoding: \"hex\"\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avax.issueTx\",\n      params\n    )\n    return response.data.result.txID\n      ? response.data.result.txID\n      : response.data.result\n  }\n\n  /**\n   * Exports the private key for an address.\n   *\n   * @param username The name of the user with the private key\n   * @param password The password used to decrypt the private key\n   * @param address The address whose private key should be exported\n   *\n   * @returns Promise with the decrypted private key and private key hex as store in the database\n   */\n  exportKey = async (\n    username: string,\n    password: string,\n    address: string\n  ): Promise<object> => {\n    const params: ExportKeyParams = {\n      username,\n      password,\n      address\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avax.exportKey\",\n      params\n    )\n    return response.data.result\n  }\n\n  /**\n   * Helper function which creates an unsigned Import Tx. For more granular control, you may create your own\n   * [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s).\n   *\n   * @param utxoset A set of UTXOs that the transaction is built on\n   * @param toAddress The address to send the funds\n   * @param ownerAddresses The addresses being used to import\n   * @param sourceChain The chainid for where the import is coming from\n   * @param fromAddresses The addresses being used to send the funds from the UTXOs provided\n   *\n   * @returns An unsigned transaction ([[UnsignedTx]]) which contains a [[ImportTx]].\n   *\n   * @remarks\n   * This helper exists because the endpoint API should be the primary point of entry for most functionality.\n   */\n  buildImportTx = async (\n    utxoset: UTXOSet,\n    toAddress: string,\n    ownerAddresses: string[],\n    sourceChain: Buffer | string,\n    fromAddresses: string[],\n    fee: BN = new BN(0)\n  ): Promise<UnsignedTx> => {\n    const from: Buffer[] = this._cleanAddressArray(\n      fromAddresses,\n      \"buildImportTx\"\n    ).map((a: string): Buffer => bintools.stringToAddress(a))\n    let srcChain: string = undefined\n\n    if (typeof sourceChain === \"string\") {\n      // if there is a sourceChain passed in and it's a string then save the string value and cast the original\n      // variable from a string to a Buffer\n      srcChain = sourceChain\n      sourceChain = bintools.cb58Decode(sourceChain)\n    } else if (\n      typeof sourceChain === \"undefined\" ||\n      !(sourceChain instanceof Buffer)\n    ) {\n      // if there is no sourceChain passed in or the sourceChain is any data type other than a Buffer then throw an error\n      throw new ChainIdError(\n        \"Error - EVMAPI.buildImportTx: sourceChain is undefined or invalid sourceChain type.\"\n      )\n    }\n    const utxoResponse: UTXOResponse = await this.getUTXOs(\n      ownerAddresses,\n      srcChain,\n      0,\n      undefined\n    )\n    const atomicUTXOs: UTXOSet = utxoResponse.utxos\n    const networkID: number = this.core.getNetworkID()\n    const avaxAssetID: string = Defaults.network[`${networkID}`].X.avaxAssetID\n    const avaxAssetIDBuf: Buffer = bintools.cb58Decode(avaxAssetID)\n    const atomics: UTXO[] = atomicUTXOs.getAllUTXOs()\n\n    if (atomics.length === 0) {\n      throw new NoAtomicUTXOsError(\n        \"Error - EVMAPI.buildImportTx: no atomic utxos to import\"\n      )\n    }\n\n    const builtUnsignedTx: UnsignedTx = utxoset.buildImportTx(\n      networkID,\n      bintools.cb58Decode(this.blockchainID),\n      toAddress,\n      atomics,\n      sourceChain,\n      fee,\n      avaxAssetIDBuf\n    )\n\n    return builtUnsignedTx\n  }\n\n  /**\n   * Helper function which creates an unsigned Export Tx. For more granular control, you may create your own\n   * [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s).\n   *\n   * @param amount The amount being exported as a {@link https://github.com/indutny/bn.js/|BN}\n   * @param assetID The asset id which is being sent\n   * @param destinationChain The chainid for where the assets will be sent.\n   * @param toAddresses The addresses to send the funds\n   * @param fromAddresses The addresses being used to send the funds from the UTXOs provided\n   * @param changeAddresses The addresses that can spend the change remaining from the spent UTXOs\n   * @param asOf Optional. The timestamp to verify the transaction against as a {@link https://github.com/indutny/bn.js/|BN}\n   * @param locktime Optional. The locktime field created in the resulting outputs\n   * @param threshold Optional. The number of signatures required to spend the funds in the resultant UTXO\n   *\n   * @returns An unsigned transaction ([[UnsignedTx]]) which contains an [[ExportTx]].\n   */\n  buildExportTx = async (\n    amount: BN,\n    assetID: Buffer | string,\n    destinationChain: Buffer | string,\n    fromAddressHex: string,\n    fromAddressBech: string,\n    toAddresses: string[],\n    nonce: number = 0,\n    locktime: BN = new BN(0),\n    threshold: number = 1,\n    fee: BN = new BN(0)\n  ): Promise<UnsignedTx> => {\n    const prefixes: object = {}\n    toAddresses.map((address: string) => {\n      prefixes[address.split(\"-\")[0]] = true\n    })\n    if (Object.keys(prefixes).length !== 1) {\n      throw new AddressError(\n        \"Error - EVMAPI.buildExportTx: To addresses must have the same chainID prefix.\"\n      )\n    }\n\n    if (typeof destinationChain === \"undefined\") {\n      throw new ChainIdError(\n        \"Error - EVMAPI.buildExportTx: Destination ChainID is undefined.\"\n      )\n    } else if (typeof destinationChain === \"string\") {\n      destinationChain = bintools.cb58Decode(destinationChain)\n    } else if (!(destinationChain instanceof Buffer)) {\n      throw new ChainIdError(\n        \"Error - EVMAPI.buildExportTx: Invalid destinationChain type\"\n      )\n    }\n    if (destinationChain.length !== 32) {\n      throw new ChainIdError(\n        \"Error - EVMAPI.buildExportTx: Destination ChainID must be 32 bytes in length.\"\n      )\n    }\n    const assetDescription: any = await this.getAssetDescription(\"AVAX\")\n    let evmInputs: EVMInput[] = []\n    if (bintools.cb58Encode(assetDescription.assetID) === assetID) {\n      const evmInput: EVMInput = new EVMInput(\n        fromAddressHex,\n        amount.add(fee),\n        assetID,\n        nonce\n      )\n      evmInput.addSignatureIdx(0, bintools.stringToAddress(fromAddressBech))\n      evmInputs.push(evmInput)\n    } else {\n      // if asset id isn't AVAX asset id then create 2 inputs\n      // first input will be AVAX and will be for the amount of the fee\n      // second input will be the ANT\n      const evmAVAXInput: EVMInput = new EVMInput(\n        fromAddressHex,\n        fee,\n        assetDescription.assetID,\n        nonce\n      )\n      evmAVAXInput.addSignatureIdx(0, bintools.stringToAddress(fromAddressBech))\n      evmInputs.push(evmAVAXInput)\n\n      const evmANTInput: EVMInput = new EVMInput(\n        fromAddressHex,\n        amount,\n        assetID,\n        nonce\n      )\n      evmANTInput.addSignatureIdx(0, bintools.stringToAddress(fromAddressBech))\n      evmInputs.push(evmANTInput)\n    }\n\n    const to: Buffer[] = []\n    toAddresses.map((address: string): void => {\n      to.push(bintools.stringToAddress(address))\n    })\n\n    let exportedOuts: TransferableOutput[] = []\n    const secpTransferOutput: SECPTransferOutput = new SECPTransferOutput(\n      amount,\n      to,\n      locktime,\n      threshold\n    )\n    const transferableOutput: TransferableOutput = new TransferableOutput(\n      bintools.cb58Decode(assetID),\n      secpTransferOutput\n    )\n    exportedOuts.push(transferableOutput)\n\n    // lexicographically sort ins and outs\n    evmInputs = evmInputs.sort(EVMInput.comparator())\n    exportedOuts = exportedOuts.sort(TransferableOutput.comparator())\n\n    const exportTx: ExportTx = new ExportTx(\n      this.core.getNetworkID(),\n      bintools.cb58Decode(this.blockchainID),\n      destinationChain,\n      evmInputs,\n      exportedOuts\n    )\n\n    const unsignedTx: UnsignedTx = new UnsignedTx(exportTx)\n    return unsignedTx\n  }\n\n  /**\n   * Gets a reference to the keychain for this class.\n   *\n   * @returns The instance of [[KeyChain]] for this class\n   */\n  keyChain = (): KeyChain => this.keychain\n\n  /**\n   *\n   * @returns new instance of [[KeyChain]]\n   */\n  newKeyChain = (): KeyChain => {\n    // warning, overwrites the old keychain\n    const alias = this.getBlockchainAlias()\n    if (alias) {\n      this.keychain = new KeyChain(this.core.getHRP(), alias)\n    } else {\n      this.keychain = new KeyChain(this.core.getHRP(), this.blockchainID)\n    }\n    return this.keychain\n  }\n\n  /**\n   * @ignore\n   */\n  protected _cleanAddressArray(\n    addresses: string[] | Buffer[],\n    caller: string\n  ): string[] {\n    const addrs: string[] = []\n    const chainid: string = this.getBlockchainAlias()\n      ? this.getBlockchainAlias()\n      : this.getBlockchainID()\n    if (addresses && addresses.length > 0) {\n      addresses.forEach((address: string | Buffer) => {\n        if (typeof address === \"string\") {\n          if (typeof this.parseAddress(address as string) === \"undefined\") {\n            /* istanbul ignore next */\n            throw new AddressError(\"Error - Invalid address format\")\n          }\n          addrs.push(address as string)\n        } else {\n          const type: SerializedType = \"bech32\"\n          addrs.push(\n            serialization.bufferToType(\n              address as Buffer,\n              type,\n              this.core.getHRP(),\n              chainid\n            )\n          )\n        }\n      })\n    }\n    return addrs\n  }\n\n  /**\n   * This class should not be instantiated directly.\n   * Instead use the [[Avalanche.addAPI]] method.\n   *\n   * @param core A reference to the Avalanche class\n   * @param baseURL Defaults to the string \"/ext/bc/C/avax\" as the path to blockchain's baseURL\n   * @param blockchainID The Blockchain's ID. Defaults to an empty string: \"\"\n   */\n  constructor(\n    core: AvalancheCore,\n    baseURL: string = \"/ext/bc/C/avax\",\n    blockchainID: string = \"\"\n  ) {\n    super(core, baseURL)\n    this.blockchainID = blockchainID\n    const netID: number = core.getNetworkID()\n    if (\n      netID in Defaults.network &&\n      blockchainID in Defaults.network[`${netID}`]\n    ) {\n      const alias: string =\n        Defaults.network[`${netID}`][`${blockchainID}`][\"alias\"]\n      this.keychain = new KeyChain(this.core.getHRP(), alias)\n    } else {\n      this.keychain = new KeyChain(this.core.getHRP(), blockchainID)\n    }\n  }\n\n  /**\n   * @returns a Promise string containing the base fee for the next block.\n   */\n  getBaseFee = async (): Promise<string> => {\n    const params: string[] = []\n    const method: string = \"eth_baseFee\"\n    const path: string = \"ext/bc/C/rpc\"\n    const response: RequestResponseData = await this.callMethod(\n      method,\n      params,\n      path\n    )\n    return response.data.result\n  }\n\n  /**\n   * returns the priority fee needed to be included in a block.\n   *\n   * @returns Returns a Promise string containing the priority fee needed to be included in a block.\n   */\n  getMaxPriorityFeePerGas = async (): Promise<string> => {\n    const params: string[] = []\n\n    const method: string = \"eth_maxPriorityFeePerGas\"\n    const path: string = \"ext/bc/C/rpc\"\n    const response: RequestResponseData = await this.callMethod(\n      method,\n      params,\n      path\n    )\n    return response.data.result\n  }\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!