PHP WebShell

Текущая директория: /usr/lib/node_modules/bitgo/node_modules/avalanche/dist/apis/avm

Просмотр файла: api.js

"use strict";
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.AVMAPI = void 0;
/**
 * @packageDocumentation
 * @module API-AVM
 */
const bn_js_1 = __importDefault(require("bn.js"));
const buffer_1 = require("buffer/");
const bintools_1 = __importDefault(require("../../utils/bintools"));
const utxos_1 = require("./utxos");
const constants_1 = require("./constants");
const keychain_1 = require("./keychain");
const tx_1 = require("./tx");
const payload_1 = require("../../utils/payload");
const helperfunctions_1 = require("../../utils/helperfunctions");
const jrpcapi_1 = require("../../common/jrpcapi");
const constants_2 = require("../../utils/constants");
const output_1 = require("../../common/output");
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 endpoint that is using the AVM.
 *
 * @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 AVMAPI extends jrpcapi_1.JRPCAPI {
    /**
     * This class should not be instantiated directly. Instead use the [[Avalanche.addAP`${I}`]] method.
     *
     * @param core A reference to the Avalanche class
     * @param baseURL Defaults to the string "/ext/bc/X" as the path to blockchain's baseURL
     * @param blockchainID The Blockchain"s ID. Defaults to an empty string: ""
     */
    constructor(core, baseURL = "/ext/bc/X", blockchainID = "") {
        super(core, baseURL);
        /**
         * @ignore
         */
        this.keychain = new keychain_1.KeyChain("", "");
        this.blockchainID = "";
        this.blockchainAlias = undefined;
        this.AVAXAssetID = undefined;
        this.txFee = undefined;
        this.creationTxFee = undefined;
        this.mintTxFee = 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_2.Defaults.network &&
                    this.blockchainID in constants_2.Defaults.network[`${netid}`]) {
                    this.blockchainAlias =
                        constants_2.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 The blockchainID
         */
        this.refreshBlockchainID = (blockchainID = undefined) => {
            const netid = this.core.getNetworkID();
            if (typeof blockchainID === "undefined" &&
                typeof constants_2.Defaults.network[`${netid}`] !== "undefined") {
                this.blockchainID = constants_2.Defaults.network[`${netid}`].X.blockchainID; //default to X-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_1.AVMConstants.ADDRESSLENGTH);
        };
        this.addressFromBuffer = (address) => {
            const chainID = this.getBlockchainAlias()
                ? this.getBlockchainAlias()
                : this.getBlockchainID();
            const type = "bech32";
            const hrp = this.core.getHRP();
            return serialization.bufferToType(address, type, hrp, chainID);
        };
        /**
         * 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_2.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_2.Defaults.network
                ? new bn_js_1.default(constants_2.Defaults.network[this.core.getNetworkID()]["X"]["txFee"])
                : new bn_js_1.default(0);
        };
        /**
         * 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;
        };
        /**
         * Sets the tx fee for this chain.
         *
         * @param fee The tx fee amount to set as {@link https://github.com/indutny/bn.js/|BN}
         */
        this.setTxFee = (fee) => {
            this.txFee = fee;
        };
        /**
         * Gets the default creation fee for this chain.
         *
         * @returns The default creation fee as a {@link https://github.com/indutny/bn.js/|BN}
         */
        this.getDefaultCreationTxFee = () => {
            return this.core.getNetworkID() in constants_2.Defaults.network
                ? new bn_js_1.default(constants_2.Defaults.network[this.core.getNetworkID()]["X"]["creationTxFee"])
                : new bn_js_1.default(0);
        };
        /**
         * Gets the default mint fee for this chain.
         *
         * @returns The default mint fee as a {@link https://github.com/indutny/bn.js/|BN}
         */
        this.getDefaultMintTxFee = () => {
            return this.core.getNetworkID() in constants_2.Defaults.network
                ? new bn_js_1.default(constants_2.Defaults.network[this.core.getNetworkID()]["X"]["mintTxFee"])
                : new bn_js_1.default(0);
        };
        /**
         * Gets the mint fee for this chain.
         *
         * @returns The mint fee as a {@link https://github.com/indutny/bn.js/|BN}
         */
        this.getMintTxFee = () => {
            if (typeof this.mintTxFee === "undefined") {
                this.mintTxFee = this.getDefaultMintTxFee();
            }
            return this.mintTxFee;
        };
        /**
         * Gets the creation fee for this chain.
         *
         * @returns The creation fee as a {@link https://github.com/indutny/bn.js/|BN}
         */
        this.getCreationTxFee = () => {
            if (typeof this.creationTxFee === "undefined") {
                this.creationTxFee = this.getDefaultCreationTxFee();
            }
            return this.creationTxFee;
        };
        /**
         * Sets the mint fee for this chain.
         *
         * @param fee The mint fee amount to set as {@link https://github.com/indutny/bn.js/|BN}
         */
        this.setMintTxFee = (fee) => {
            this.mintTxFee = fee;
        };
        /**
         * Sets the creation fee for this chain.
         *
         * @param fee The creation fee amount to set as {@link https://github.com/indutny/bn.js/|BN}
         */
        this.setCreationTxFee = (fee) => {
            this.creationTxFee = fee;
        };
        /**
         * Gets a reference to the keychain for this class.
         *
         * @returns The instance of [[KeyChain]] for this class
         */
        this.keyChain = () => this.keychain;
        /**
         * @ignore
         */
        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;
        };
        /**
         * Helper function which determines if a tx is a goose egg transaction.
         *
         * @param utx An UnsignedTx
         *
         * @returns boolean true if passes goose egg test and false if fails.
         *
         * @remarks
         * A "Goose Egg Transaction" is when the fee far exceeds a reasonable amount
         */
        this.checkGooseEgg = (utx, outTotal = new bn_js_1.default(0)) => __awaiter(this, void 0, void 0, function* () {
            const avaxAssetID = yield this.getAVAXAssetID();
            const outputTotal = outTotal.gt(new bn_js_1.default(0))
                ? outTotal
                : utx.getOutputTotal(avaxAssetID);
            const fee = utx.getBurn(avaxAssetID);
            if (fee.lte(constants_2.ONEAVAX.mul(new bn_js_1.default(10))) || fee.lte(outputTotal)) {
                return true;
            }
            else {
                return false;
            }
        });
        /**
         * Gets the balance of a particular asset on a blockchain.
         *
         * @param address The address to pull the asset balance from
         * @param assetID The assetID to pull the balance from
         * @param includePartial If includePartial=false, returns only the balance held solely
         *
         * @returns Promise with the balance of the assetID as a {@link https://github.com/indutny/bn.js/|BN} on the provided address for the blockchain.
         */
        this.getBalance = (address, assetID, includePartial = false) => __awaiter(this, void 0, void 0, function* () {
            if (typeof this.parseAddress(address) === "undefined") {
                /* istanbul ignore next */
                throw new errors_1.AddressError("Error - AVMAPI.getBalance: Invalid address format");
            }
            const params = {
                address,
                assetID,
                includePartial
            };
            const response = yield this.callMethod("avm.getBalance", params);
            return response.data.result;
        });
        /**
         * Creates an address (and associated private keys) on a user on a blockchain.
         *
         * @param username Name of the user to create the address under
         * @param password Password to unlock the user and encrypt the private key
         *
         * @returns Promise for a string representing the address created by the vm.
         */
        this.createAddress = (username, password) => __awaiter(this, void 0, void 0, function* () {
            const params = {
                username,
                password
            };
            const response = yield this.callMethod("avm.createAddress", params);
            return response.data.result.address;
        });
        /**
         * Create a new fixed-cap, fungible asset. A quantity of it is created at initialization and there no more is ever created.
         *
         * @param username The user paying the transaction fee (in $AVAX) for asset creation
         * @param password The password for the user paying the transaction fee (in $AVAX) for asset creation
         * @param name The human-readable name for the asset
         * @param symbol Optional. The shorthand symbol for the asset. Between 0 and 4 characters
         * @param denomination Optional. Determines how balances of this asset are displayed by user interfaces. Default is 0
         * @param initialHolders An array of objects containing the field "address" and "amount" to establish the genesis values for the new asset
         *
         * ```js
         * Example initialHolders:
         * [
         *   {
         *     "address": "X-avax1kj06lhgx84h39snsljcey3tpc046ze68mek3g5",
         *     "amount": 10000
         *   },
         *   {
         *     "address": "X-avax1am4w6hfrvmh3akduzkjthrtgtqafalce6an8cr",
         *     "amount": 50000
         *   }
         * ]
         * ```
         *
         * @returns Returns a Promise string containing the base 58 string representation of the ID of the newly created asset.
         */
        this.createFixedCapAsset = (username, password, name, symbol, denomination, initialHolders) => __awaiter(this, void 0, void 0, function* () {
            const params = {
                name,
                symbol,
                denomination,
                username,
                password,
                initialHolders
            };
            const response = yield this.callMethod("avm.createFixedCapAsset", params);
            return response.data.result.assetID;
        });
        /**
         * Create a new variable-cap, fungible asset. No units of the asset exist at initialization. Minters can mint units of this asset using createMintTx, signMintTx and sendMintTx.
         *
         * @param username The user paying the transaction fee (in $AVAX) for asset creation
         * @param password The password for the user paying the transaction fee (in $AVAX) for asset creation
         * @param name The human-readable name for the asset
         * @param symbol Optional. The shorthand symbol for the asset -- between 0 and 4 characters
         * @param denomination Optional. Determines how balances of this asset are displayed by user interfaces. Default is 0
         * @param minterSets is a list where each element specifies that threshold of the addresses in minters may together mint more of the asset by signing a minting transaction
         *
         * ```js
         * Example minterSets:
         * [
         *    {
         *      "minters":[
         *        "X-avax1am4w6hfrvmh3akduzkjthrtgtqafalce6an8cr"
         *      ],
         *      "threshold": 1
         *     },
         *     {
         *      "minters": [
         *        "X-avax1am4w6hfrvmh3akduzkjthrtgtqafalce6an8cr",
         *        "X-avax1kj06lhgx84h39snsljcey3tpc046ze68mek3g5",
         *        "X-avax1yell3e4nln0m39cfpdhgqprsd87jkh4qnakklx"
         *      ],
         *      "threshold": 2
         *     }
         * ]
         * ```
         *
         * @returns Returns a Promise string containing the base 58 string representation of the ID of the newly created asset.
         */
        this.createVariableCapAsset = (username, password, name, symbol, denomination, minterSets) => __awaiter(this, void 0, void 0, function* () {
            const params = {
                name,
                symbol,
                denomination,
                username,
                password,
                minterSets
            };
            const response = yield this.callMethod("avm.createVariableCapAsset", params);
            return response.data.result.assetID;
        });
        /**
         * Creates a family of NFT Asset. No units of the asset exist at initialization. Minters can mint units of this asset using createMintTx, signMintTx and sendMintTx.
         *
         * @param username The user paying the transaction fee (in $AVAX) for asset creation
         * @param password The password for the user paying the transaction fee (in $AVAX) for asset creation
         * @param from Optional. An array of addresses managed by the node's keystore for this blockchain which will fund this transaction
         * @param changeAddr Optional. An address to send the change
         * @param name The human-readable name for the asset
         * @param symbol Optional. The shorthand symbol for the asset -- between 0 and 4 characters
         * @param minterSets is a list where each element specifies that threshold of the addresses in minters may together mint more of the asset by signing a minting transaction
         *
         * @returns Returns a Promise string containing the base 58 string representation of the ID of the newly created asset.
         */
        this.createNFTAsset = (username, password, from = undefined, changeAddr, name, symbol, minterSet) => __awaiter(this, void 0, void 0, function* () {
            const params = {
                username,
                password,
                name,
                symbol,
                minterSet
            };
            const caller = "createNFTAsset";
            from = this._cleanAddressArray(from, caller);
            if (typeof from !== "undefined") {
                params["from"] = from;
            }
            if (typeof changeAddr !== "undefined") {
                if (typeof this.parseAddress(changeAddr) === "undefined") {
                    /* istanbul ignore next */
                    throw new errors_1.AddressError("Error - AVMAPI.createNFTAsset: Invalid address format");
                }
                params["changeAddr"] = changeAddr;
            }
            const response = yield this.callMethod("avm.createNFTAsset", params);
            return response.data.result.assetID;
        });
        /**
         * Create an unsigned transaction to mint more of an asset.
         *
         * @param amount The units of the asset to mint
         * @param assetID The ID of the asset to mint
         * @param to The address to assign the units of the minted asset
         * @param minters Addresses of the minters responsible for signing the transaction
         *
         * @returns Returns a Promise string containing the base 58 string representation of the unsigned transaction.
         */
        this.mint = (username, password, amount, assetID, to, minters) => __awaiter(this, void 0, void 0, function* () {
            let asset;
            let amnt;
            if (typeof assetID !== "string") {
                asset = bintools.cb58Encode(assetID);
            }
            else {
                asset = assetID;
            }
            if (typeof amount === "number") {
                amnt = new bn_js_1.default(amount);
            }
            else {
                amnt = amount;
            }
            const params = {
                username: username,
                password: password,
                amount: amnt,
                assetID: asset,
                to,
                minters
            };
            const response = yield this.callMethod("avm.mint", params);
            return response.data.result.txID;
        });
        /**
         * Mint non-fungible tokens which were created with AVMAPI.createNFTAsset
         *
         * @param username The user paying the transaction fee (in $AVAX) for asset creation
         * @param password The password for the user paying the transaction fee (in $AVAX) for asset creation
         * @param from Optional. An array of addresses managed by the node's keystore for this blockchain which will fund this transaction
         * @param changeAddr Optional. An address to send the change
         * @param assetID The asset id which is being sent
         * @param to Address on X-Chain of the account to which this NFT is being sent
         * @param encoding Optional.  is the encoding format to use for the payload argument. Can be either "cb58" or "hex". Defaults to "hex".
         *
         * @returns ID of the transaction
         */
        this.mintNFT = (username, password, from = undefined, changeAddr = undefined, payload, assetID, to, encoding = "hex") => __awaiter(this, void 0, void 0, function* () {
            let asset;
            if (typeof this.parseAddress(to) === "undefined") {
                /* istanbul ignore next */
                throw new errors_1.AddressError("Error - AVMAPI.mintNFT: Invalid address format");
            }
            if (typeof assetID !== "string") {
                asset = bintools.cb58Encode(assetID);
            }
            else {
                asset = assetID;
            }
            const params = {
                username,
                password,
                assetID: asset,
                payload,
                to,
                encoding
            };
            const caller = "mintNFT";
            from = this._cleanAddressArray(from, caller);
            if (typeof from !== "undefined") {
                params["from"] = from;
            }
            if (typeof changeAddr !== "undefined") {
                if (typeof this.parseAddress(changeAddr) === "undefined") {
                    /* istanbul ignore next */
                    throw new errors_1.AddressError("Error - AVMAPI.mintNFT: Invalid address format");
                }
                params["changeAddr"] = changeAddr;
            }
            const response = yield this.callMethod("avm.mintNFT", params);
            return response.data.result.txID;
        });
        /**
         * Send NFT from one account to another on X-Chain
         *
         * @param username The user paying the transaction fee (in $AVAX) for asset creation
         * @param password The password for the user paying the transaction fee (in $AVAX) for asset creation
         * @param from Optional. An array of addresses managed by the node's keystore for this blockchain which will fund this transaction
         * @param changeAddr Optional. An address to send the change
         * @param assetID The asset id which is being sent
         * @param groupID The group this NFT is issued to.
         * @param to Address on X-Chain of the account to which this NFT is being sent
         *
         * @returns ID of the transaction
         */
        this.sendNFT = (username, password, from = undefined, changeAddr = undefined, assetID, groupID, to) => __awaiter(this, void 0, void 0, function* () {
            let asset;
            if (typeof this.parseAddress(to) === "undefined") {
                /* istanbul ignore next */
                throw new errors_1.AddressError("Error - AVMAPI.sendNFT: Invalid address format");
            }
            if (typeof assetID !== "string") {
                asset = bintools.cb58Encode(assetID);
            }
            else {
                asset = assetID;
            }
            const params = {
                username,
                password,
                assetID: asset,
                groupID,
                to
            };
            const caller = "sendNFT";
            from = this._cleanAddressArray(from, caller);
            if (typeof from !== "undefined") {
                params["from"] = from;
            }
            if (typeof changeAddr !== "undefined") {
                if (typeof this.parseAddress(changeAddr) === "undefined") {
                    /* istanbul ignore next */
                    throw new errors_1.AddressError("Error - AVMAPI.sendNFT: Invalid address format");
                }
                params["changeAddr"] = changeAddr;
            }
            const response = yield this.callMethod("avm.sendNFT", params);
            return response.data.result.txID;
        });
        /**
         * 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 as store in the database
         */
        this.exportKey = (username, password, address) => __awaiter(this, void 0, void 0, function* () {
            if (typeof this.parseAddress(address) === "undefined") {
                /* istanbul ignore next */
                throw new errors_1.AddressError("Error - AVMAPI.exportKey: Invalid address format");
            }
            const params = {
                username,
                password,
                address
            };
            const response = yield this.callMethod("avm.exportKey", params);
            return response.data.result.privateKey;
        });
        /**
         * Imports a private key into the node's keystore under an user and for a blockchain.
         *
         * @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("avm.importKey", params);
            return response.data.result.address;
        });
        /**
         * Send ANT (Avalanche Native Token) assets including AVAX from the X-Chain to an account on the P-Chain or C-Chain.
         *
         * After calling this method, you must call the P-Chain's `import` or the C-Chain’s `import` method to complete the transfer.
         *
         * @param username The Keystore user that controls the P-Chain or C-Chain account specified in `to`
         * @param password The password of the Keystore user
         * @param to The account on the P-Chain or C-Chain to send the asset 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 = {
                username,
                password,
                to,
                amount: amount,
                assetID
            };
            const response = yield this.callMethod("avm.export", params);
            return response.data.result.txID;
        });
        /**
         * Send ANT (Avalanche Native Token) assets including AVAX from an account on the P-Chain or C-Chain to an address on the X-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: "C"
         *
         * @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 = {
                username,
                password,
                to,
                sourceChain
            };
            const response = yield this.callMethod("avm.import", params);
            return response.data.result.txID;
        });
        /**
         * Lists all the addresses under a user.
         *
         * @param username The user to list addresses
         * @param password The password of the user to list the addresses
         *
         * @returns Promise of an array of address strings in the format specified by the blockchain.
         */
        this.listAddresses = (username, password) => __awaiter(this, void 0, void 0, function* () {
            const params = {
                username,
                password
            };
            const response = yield this.callMethod("avm.listAddresses", params);
            return response.data.result.addresses;
        });
        /**
         * Retrieves all assets for an address on a server and their associated balances.
         *
         * @param address The address to get a list of assets
         *
         * @returns Promise of an object mapping assetID strings with {@link https://github.com/indutny/bn.js/|BN} balance for the address on the blockchain.
         */
        this.getAllBalances = (address) => __awaiter(this, void 0, void 0, function* () {
            if (typeof this.parseAddress(address) === "undefined") {
                /* istanbul ignore next */
                throw new errors_1.AddressError("Error - AVMAPI.getAllBalances: Invalid address format");
            }
            const params = {
                address
            };
            const response = yield this.callMethod("avm.getAllBalances", params);
            return response.data.result.balances;
        });
        /**
         * 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 object with keys "name" and "symbol".
         */
        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 response = yield this.callMethod("avm.getAssetDescription", params);
            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)
            };
        });
        /**
         * Returns the transaction data of a provided transaction ID by calling the node's `getTx` method.
         *
         * @param txID The string representation of the transaction ID
         * @param encoding sets the format of the returned transaction. Can be, "cb58", "hex" or "json". Defaults to "cb58".
         *
         * @returns Returns a Promise string or object containing the bytes retrieved from the node
         */
        this.getTx = (txID, encoding = "hex") => __awaiter(this, void 0, void 0, function* () {
            const params = {
                txID,
                encoding
            };
            const response = yield this.callMethod("avm.getTx", params);
            return response.data.result.tx;
        });
        /**
         * Returns the status of a provided transaction ID by calling the node's `getTxStatus` method.
         *
         * @param txID The string representation of the transaction ID
         *
         * @returns Returns a Promise string containing the status retrieved from the node
         */
        this.getTxStatus = (txID) => __awaiter(this, void 0, void 0, function* () {
            const params = {
                txID
            };
            const response = yield this.callMethod("avm.getTxStatus", params);
            return response.data.result.status;
        });
        /**
         * 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.
         * @param persistOpts Options available to persist these UTXOs in local storage
         *
         * @remarks
         * persistOpts is optional and must be of type [[PersistanceOptions]]
         *
         */
        this.getUTXOs = (addresses, sourceChain = undefined, limit = 0, startIndex = undefined, persistOpts = 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("avm.getUTXOs", params);
            const utxos = new utxos_1.UTXOSet();
            let data = response.data.result.utxos;
            if (persistOpts && typeof persistOpts === "object") {
                if (this.db.has(persistOpts.getName())) {
                    const selfArray = this.db.get(persistOpts.getName());
                    if (Array.isArray(selfArray)) {
                        utxos.addArray(data);
                        const utxoSet = new utxos_1.UTXOSet();
                        utxoSet.addArray(selfArray);
                        utxoSet.mergeByRule(utxos, persistOpts.getMergeRule());
                        data = utxoSet.getAllUTXOStrings();
                    }
                }
                this.db.set(persistOpts.getName(), data, persistOpts.getOverwrite());
            }
            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;
        });
        /**
         * Helper function which creates an unsigned transaction. For more granular control, you may create your own
         * [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s, and [[TransferOperation]]s).
         *
         * @param utxoset A set of UTXOs that the transaction is built on
         * @param amount The amount of AssetID to be spent in its smallest denomination, represented as {@link https://github.com/indutny/bn.js/|BN}.
         * @param assetID The assetID of the value being 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 memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes
         * @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 a [[BaseTx]].
         *
         * @remarks
         * This helper exists because the endpoint API should be the primary point of entry for most functionality.
         */
        this.buildBaseTx = (utxoset, amount, assetID = undefined, toAddresses, fromAddresses, changeAddresses, memo = undefined, asOf = (0, helperfunctions_1.UnixNow)(), locktime = new bn_js_1.default(0), threshold = 1) => __awaiter(this, void 0, void 0, function* () {
            const caller = "buildBaseTx";
            const to = this._cleanAddressArray(toAddresses, caller).map((a) => bintools.stringToAddress(a));
            const from = this._cleanAddressArray(fromAddresses, caller).map((a) => bintools.stringToAddress(a));
            const change = this._cleanAddressArray(changeAddresses, caller).map((a) => bintools.stringToAddress(a));
            if (typeof assetID === "string") {
                assetID = bintools.cb58Decode(assetID);
            }
            if (memo instanceof payload_1.PayloadBase) {
                memo = memo.getPayload();
            }
            const networkID = this.core.getNetworkID();
            const blockchainIDBuf = bintools.cb58Decode(this.blockchainID);
            const fee = this.getTxFee();
            const feeAssetID = yield this.getAVAXAssetID();
            const builtUnsignedTx = utxoset.buildBaseTx(networkID, blockchainIDBuf, amount, assetID, to, from, change, fee, feeAssetID, memo, asOf, locktime, threshold);
            if (!(yield this.checkGooseEgg(builtUnsignedTx))) {
                /* istanbul ignore next */
                throw new errors_1.GooseEggCheckError("Error - AVMAPI.buildBaseTx:Failed Goose Egg Check");
            }
            return builtUnsignedTx;
        });
        /**
         * Helper function which creates an unsigned NFT Transfer. For more granular control, you may create your own
         * [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s, and [[TransferOperation]]s).
         *
         * @param utxoset  A set of UTXOs that the transaction is built on
         * @param toAddresses The addresses to send the NFT
         * @param fromAddresses The addresses being used to send the NFT from the utxoID provided
         * @param changeAddresses The addresses that can spend the change remaining from the spent UTXOs
         * @param utxoid A base58 utxoID or an array of base58 utxoIDs for the nfts this transaction is sending
         * @param memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes
         * @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 a [[NFTTransferTx]].
         *
         * @remarks
         * This helper exists because the endpoint API should be the primary point of entry for most functionality.
         */
        this.buildNFTTransferTx = (utxoset, toAddresses, fromAddresses, changeAddresses, utxoid, memo = undefined, asOf = (0, helperfunctions_1.UnixNow)(), locktime = new bn_js_1.default(0), threshold = 1) => __awaiter(this, void 0, void 0, function* () {
            const caller = "buildNFTTransferTx";
            const to = this._cleanAddressArray(toAddresses, caller).map((a) => bintools.stringToAddress(a));
            const from = this._cleanAddressArray(fromAddresses, caller).map((a) => bintools.stringToAddress(a));
            const change = this._cleanAddressArray(changeAddresses, caller).map((a) => bintools.stringToAddress(a));
            if (memo instanceof payload_1.PayloadBase) {
                memo = memo.getPayload();
            }
            const avaxAssetID = yield this.getAVAXAssetID();
            let utxoidArray = [];
            if (typeof utxoid === "string") {
                utxoidArray = [utxoid];
            }
            else if (Array.isArray(utxoid)) {
                utxoidArray = utxoid;
            }
            const builtUnsignedTx = utxoset.buildNFTTransferTx(this.core.getNetworkID(), bintools.cb58Decode(this.blockchainID), to, from, change, utxoidArray, this.getTxFee(), avaxAssetID, memo, asOf, locktime, threshold);
            if (!(yield this.checkGooseEgg(builtUnsignedTx))) {
                /* istanbul ignore next */
                throw new errors_1.GooseEggCheckError("Error - AVMAPI.buildNFTTransferTx:Failed Goose Egg Check");
            }
            return builtUnsignedTx;
        });
        /**
         * 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, and [[TransferOperation]]s).
         *
         * @param utxoset  A set of UTXOs that the transaction is built on
         * @param ownerAddresses The addresses being used to import
         * @param sourceChain The chainid for where the import is coming from
         * @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 memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes
         * @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 a [[ImportTx]].
         *
         * @remarks
         * This helper exists because the endpoint API should be the primary point of entry for most functionality.
         */
        this.buildImportTx = (utxoset, ownerAddresses, sourceChain, toAddresses, fromAddresses, changeAddresses = undefined, memo = undefined, asOf = (0, helperfunctions_1.UnixNow)(), locktime = new bn_js_1.default(0), threshold = 1) => __awaiter(this, void 0, void 0, function* () {
            const caller = "buildImportTx";
            const to = this._cleanAddressArray(toAddresses, caller).map((a) => bintools.stringToAddress(a));
            const from = this._cleanAddressArray(fromAddresses, caller).map((a) => bintools.stringToAddress(a));
            const change = this._cleanAddressArray(changeAddresses, caller).map((a) => bintools.stringToAddress(a));
            let srcChain = undefined;
            if (typeof sourceChain === "undefined") {
                throw new errors_1.ChainIdError("Error - AVMAPI.buildImportTx: Source ChainID is undefined.");
            }
            else if (typeof sourceChain === "string") {
                srcChain = sourceChain;
                sourceChain = bintools.cb58Decode(sourceChain);
            }
            else if (!(sourceChain instanceof buffer_1.Buffer)) {
                throw new errors_1.ChainIdError("Error - AVMAPI.buildImportTx: Invalid destinationChain type: " +
                    typeof sourceChain);
            }
            const atomicUTXOs = (yield this.getUTXOs(ownerAddresses, srcChain, 0, undefined)).utxos;
            const avaxAssetID = yield this.getAVAXAssetID();
            const atomics = atomicUTXOs.getAllUTXOs();
            if (atomics.length === 0) {
                throw new errors_1.NoAtomicUTXOsError("Error - AVMAPI.buildImportTx: No atomic UTXOs to import from " +
                    srcChain +
                    " using addresses: " +
                    ownerAddresses.join(", "));
            }
            if (memo instanceof payload_1.PayloadBase) {
                memo = memo.getPayload();
            }
            const builtUnsignedTx = utxoset.buildImportTx(this.core.getNetworkID(), bintools.cb58Decode(this.blockchainID), to, from, change, atomics, sourceChain, this.getTxFee(), avaxAssetID, memo, asOf, locktime, threshold);
            if (!(yield this.checkGooseEgg(builtUnsignedTx))) {
                /* istanbul ignore next */
                throw new errors_1.GooseEggCheckError("Error - AVMAPI.buildImportTx:Failed Goose Egg Check");
            }
            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, and [[TransferOperation]]s).
         *
         * @param utxoset A set of UTXOs that the transaction is built on
         * @param amount The amount being exported as a {@link https://github.com/indutny/bn.js/|BN}
         * @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 memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes
         * @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
         * @param assetID Optional. The assetID of the asset to send. Defaults to AVAX assetID.
         * Regardless of the asset which you"re exporting, all fees are paid in AVAX.
         *
         * @returns An unsigned transaction ([[UnsignedTx]]) which contains an [[ExportTx]].
         */
        this.buildExportTx = (utxoset, amount, destinationChain, toAddresses, fromAddresses, changeAddresses = undefined, memo = undefined, asOf = (0, helperfunctions_1.UnixNow)(), locktime = new bn_js_1.default(0), threshold = 1, assetID = undefined) => __awaiter(this, void 0, void 0, function* () {
            const prefixes = {};
            toAddresses.map((a) => {
                prefixes[a.split("-")[0]] = true;
            });
            if (Object.keys(prefixes).length !== 1) {
                throw new errors_1.AddressError("Error - AVMAPI.buildExportTx: To addresses must have the same chainID prefix.");
            }
            if (typeof destinationChain === "undefined") {
                throw new errors_1.ChainIdError("Error - AVMAPI.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 - AVMAPI.buildExportTx: Invalid destinationChain type: " +
                    typeof destinationChain);
            }
            if (destinationChain.length !== 32) {
                throw new errors_1.ChainIdError("Error - AVMAPI.buildExportTx: Destination ChainID must be 32 bytes in length.");
            }
            const to = [];
            toAddresses.map((a) => {
                to.push(bintools.stringToAddress(a));
            });
            const caller = "buildExportTx";
            const from = this._cleanAddressArray(fromAddresses, caller).map((a) => bintools.stringToAddress(a));
            const change = this._cleanAddressArray(changeAddresses, caller).map((a) => bintools.stringToAddress(a));
            if (memo instanceof payload_1.PayloadBase) {
                memo = memo.getPayload();
            }
            const avaxAssetID = yield this.getAVAXAssetID();
            if (typeof assetID === "undefined") {
                assetID = bintools.cb58Encode(avaxAssetID);
            }
            const networkID = this.core.getNetworkID();
            const blockchainID = bintools.cb58Decode(this.blockchainID);
            const assetIDBuf = bintools.cb58Decode(assetID);
            const fee = this.getTxFee();
            const builtUnsignedTx = utxoset.buildExportTx(networkID, blockchainID, amount, assetIDBuf, to, from, change, destinationChain, fee, avaxAssetID, memo, asOf, locktime, threshold);
            if (!(yield this.checkGooseEgg(builtUnsignedTx))) {
                /* istanbul ignore next */
                throw new errors_1.GooseEggCheckError("Error - AVMAPI.buildExportTx:Failed Goose Egg Check");
            }
            return builtUnsignedTx;
        });
        /**
         * Creates an unsigned transaction. For more granular control, you may create your own
         * [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s, and [[TransferOperation]]s).
         *
         * @param utxoset A set of UTXOs that the transaction is built on
         * @param fromAddresses The addresses being used to send the funds from the UTXOs {@link https://github.com/feross/buffer|Buffer}
         * @param changeAddresses The addresses that can spend the change remaining from the spent UTXOs
         * @param initialState The [[InitialStates]] that represent the intial state of a created asset
         * @param name String for the descriptive name of the asset
         * @param symbol String for the ticker symbol of the asset
         * @param denomination Number for the denomination which is 10^D. D must be >= 0 and <= 32. Ex: $1 AVAX = 10^9 $nAVAX
         * @param mintOutputs Optional. Array of [[SECPMintOutput]]s to be included in the transaction. These outputs can be spent to mint more tokens.
         * @param memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes
         * @param asOf Optional. The timestamp to verify the transaction against as a {@link https://github.com/indutny/bn.js/|BN}
         *
         * @returns An unsigned transaction ([[UnsignedTx]]) which contains a [[CreateAssetTx]].
         *
         */
        this.buildCreateAssetTx = (utxoset, fromAddresses, changeAddresses, initialStates, name, symbol, denomination, mintOutputs = undefined, memo = undefined, asOf = (0, helperfunctions_1.UnixNow)()) => __awaiter(this, void 0, void 0, function* () {
            const caller = "buildCreateAssetTx";
            const from = this._cleanAddressArray(fromAddresses, caller).map((a) => bintools.stringToAddress(a));
            const change = this._cleanAddressArray(changeAddresses, caller).map((a) => bintools.stringToAddress(a));
            if (memo instanceof payload_1.PayloadBase) {
                memo = memo.getPayload();
            }
            if (symbol.length > constants_1.AVMConstants.SYMBOLMAXLEN) {
                throw new errors_1.SymbolError("Error - AVMAPI.buildCreateAssetTx: Symbols may not exceed length of " +
                    constants_1.AVMConstants.SYMBOLMAXLEN);
            }
            if (name.length > constants_1.AVMConstants.ASSETNAMELEN) {
                throw new errors_1.NameError("Error - AVMAPI.buildCreateAssetTx: Names may not exceed length of " +
                    constants_1.AVMConstants.ASSETNAMELEN);
            }
            const networkID = this.core.getNetworkID();
            const blockchainID = bintools.cb58Decode(this.blockchainID);
            const avaxAssetID = yield this.getAVAXAssetID();
            const fee = this.getDefaultCreationTxFee();
            const builtUnsignedTx = utxoset.buildCreateAssetTx(networkID, blockchainID, from, change, initialStates, name, symbol, denomination, mintOutputs, fee, avaxAssetID, memo, asOf);
            if (!(yield this.checkGooseEgg(builtUnsignedTx, fee))) {
                /* istanbul ignore next */
                throw new errors_1.GooseEggCheckError("Error - AVMAPI.buildCreateAssetTx:Failed Goose Egg Check");
            }
            return builtUnsignedTx;
        });
        this.buildSECPMintTx = (utxoset, mintOwner, transferOwner, fromAddresses, changeAddresses, mintUTXOID, memo = undefined, asOf = (0, helperfunctions_1.UnixNow)()) => __awaiter(this, void 0, void 0, function* () {
            const caller = "buildSECPMintTx";
            const from = this._cleanAddressArray(fromAddresses, caller).map((a) => bintools.stringToAddress(a));
            const change = this._cleanAddressArray(changeAddresses, caller).map((a) => bintools.stringToAddress(a));
            if (memo instanceof payload_1.PayloadBase) {
                memo = memo.getPayload();
            }
            const networkID = this.core.getNetworkID();
            const blockchainID = bintools.cb58Decode(this.blockchainID);
            const avaxAssetID = yield this.getAVAXAssetID();
            const fee = this.getMintTxFee();
            const builtUnsignedTx = utxoset.buildSECPMintTx(networkID, blockchainID, mintOwner, transferOwner, from, change, mintUTXOID, fee, avaxAssetID, memo, asOf);
            if (!(yield this.checkGooseEgg(builtUnsignedTx))) {
                /* istanbul ignore next */
                throw new errors_1.GooseEggCheckError("Error - AVMAPI.buildSECPMintTx:Failed Goose Egg Check");
            }
            return builtUnsignedTx;
        });
        /**
         * Creates an unsigned transaction. For more granular control, you may create your own
         * [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s, and [[TransferOperation]]s).
         *
         * @param utxoset A set of UTXOs that the transaction is built on
         * @param fromAddresses The addresses being used to send the funds from the UTXOs {@link https://github.com/feross/buffer|Buffer}
         * @param changeAddresses The addresses that can spend the change remaining from the spent UTXOs
         * @param minterSets is a list where each element specifies that threshold of the addresses in minters may together mint more of the asset by signing a minting transaction
         * @param name String for the descriptive name of the asset
         * @param symbol String for the ticker symbol of the asset
         * @param memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes
         * @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 mint output
         *
         * ```js
         * Example minterSets:
         * [
         *      {
         *          "minters":[
         *              "X-avax1ghstjukrtw8935lryqtnh643xe9a94u3tc75c7"
         *          ],
         *          "threshold": 1
         *      },
         *      {
         *          "minters": [
         *              "X-avax1yell3e4nln0m39cfpdhgqprsd87jkh4qnakklx",
         *              "X-avax1k4nr26c80jaquzm9369j5a4shmwcjn0vmemcjz",
         *              "X-avax1ztkzsrjnkn0cek5ryvhqswdtcg23nhge3nnr5e"
         *          ],
         *          "threshold": 2
         *      }
         * ]
         * ```
         *
         * @returns An unsigned transaction ([[UnsignedTx]]) which contains a [[CreateAssetTx]].
         *
         */
        this.buildCreateNFTAssetTx = (utxoset, fromAddresses, changeAddresses, minterSets, name, symbol, memo = undefined, asOf = (0, helperfunctions_1.UnixNow)(), locktime = new bn_js_1.default(0)) => __awaiter(this, void 0, void 0, function* () {
            const caller = "buildCreateNFTAssetTx";
            const from = this._cleanAddressArray(fromAddresses, caller).map((a) => bintools.stringToAddress(a));
            const change = this._cleanAddressArray(changeAddresses, caller).map((a) => bintools.stringToAddress(a));
            if (memo instanceof payload_1.PayloadBase) {
                memo = memo.getPayload();
            }
            if (name.length > constants_1.AVMConstants.ASSETNAMELEN) {
                /* istanbul ignore next */
                throw new errors_1.NameError("Error - AVMAPI.buildCreateNFTAssetTx: Names may not exceed length of " +
                    constants_1.AVMConstants.ASSETNAMELEN);
            }
            if (symbol.length > constants_1.AVMConstants.SYMBOLMAXLEN) {
                /* istanbul ignore next */
                throw new errors_1.SymbolError("Error - AVMAPI.buildCreateNFTAssetTx: Symbols may not exceed length of " +
                    constants_1.AVMConstants.SYMBOLMAXLEN);
            }
            const networkID = this.core.getNetworkID();
            const blockchainID = bintools.cb58Decode(this.blockchainID);
            const creationTxFee = this.getCreationTxFee();
            const avaxAssetID = yield this.getAVAXAssetID();
            const builtUnsignedTx = utxoset.buildCreateNFTAssetTx(networkID, blockchainID, from, change, minterSets, name, symbol, creationTxFee, avaxAssetID, memo, asOf, locktime);
            if (!(yield this.checkGooseEgg(builtUnsignedTx, creationTxFee))) {
                /* istanbul ignore next */
                throw new errors_1.GooseEggCheckError("Error - AVMAPI.buildCreateNFTAssetTx:Failed Goose Egg Check");
            }
            return builtUnsignedTx;
        });
        /**
         * Creates an unsigned transaction. For more granular control, you may create your own
         * [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s, and [[TransferOperation]]s).
         *
         * @param utxoset  A set of UTXOs that the transaction is built on
         * @param owners Either a single or an array of [[OutputOwners]] to send the nft output
         * @param fromAddresses The addresses being used to send the NFT from the utxoID provided
         * @param changeAddresses The addresses that can spend the change remaining from the spent UTXOs
         * @param utxoid A base58 utxoID or an array of base58 utxoIDs for the nft mint output this transaction is sending
         * @param groupID Optional. The group this NFT is issued to.
         * @param payload Optional. Data for NFT Payload as either a [[PayloadBase]] or a {@link https://github.com/feross/buffer|Buffer}
         * @param memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes
         * @param asOf Optional. The timestamp to verify the transaction against as a {@link https://github.com/indutny/bn.js/|BN}
         *
         * @returns An unsigned transaction ([[UnsignedTx]]) which contains an [[OperationTx]].
         *
         */
        this.buildCreateNFTMintTx = (utxoset, owners, fromAddresses, changeAddresses, utxoid, groupID = 0, payload = undefined, memo = undefined, asOf = (0, helperfunctions_1.UnixNow)()) => __awaiter(this, void 0, void 0, function* () {
            const caller = "buildCreateNFTMintTx";
            const from = this._cleanAddressArray(fromAddresses, caller).map((a) => bintools.stringToAddress(a));
            const change = this._cleanAddressArray(changeAddresses, caller).map((a) => bintools.stringToAddress(a));
            if (memo instanceof payload_1.PayloadBase) {
                memo = memo.getPayload();
            }
            if (payload instanceof payload_1.PayloadBase) {
                payload = payload.getPayload();
            }
            if (typeof utxoid === "string") {
                utxoid = [utxoid];
            }
            const avaxAssetID = yield this.getAVAXAssetID();
            if (owners instanceof output_1.OutputOwners) {
                owners = [owners];
            }
            const networkID = this.core.getNetworkID();
            const blockchainID = bintools.cb58Decode(this.blockchainID);
            const txFee = this.getTxFee();
            const builtUnsignedTx = utxoset.buildCreateNFTMintTx(networkID, blockchainID, owners, from, change, utxoid, groupID, payload, txFee, avaxAssetID, memo, asOf);
            if (!(yield this.checkGooseEgg(builtUnsignedTx))) {
                /* istanbul ignore next */
                throw new errors_1.GooseEggCheckError("Error - AVMAPI.buildCreateNFTMintTx:Failed Goose Egg Check");
            }
            return builtUnsignedTx;
        });
        /**
         * Helper function which takes an unsigned transaction and signs it, returning the resulting [[Tx]].
         *
         * @param utx The unsigned transaction of type [[UnsignedTx]]
         *
         * @returns A signed transaction of type [[Tx]]
         */
        this.signTx = (utx) => utx.sign(this.keychain);
        /**
         * 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 - AVMAPI.issueTx: provided tx is not expected type of string, Buffer, or Tx");
            }
            const params = {
                tx: Transaction.toString(),
                encoding: "hex"
            };
            const response = yield this.callMethod("avm.issueTx", params);
            return response.data.result.txID;
        });
        /**
         * Calls the node's getAddressTxs method from the API and returns transactions corresponding to the provided address and assetID
         *
         * @param address The address for which we're fetching related transactions.
         * @param cursor Page number or offset.
         * @param pageSize  Number of items to return per page. Optional. Defaults to 1024. If [pageSize] == 0 or [pageSize] > [maxPageSize], then it fetches at max [maxPageSize] transactions
         * @param assetID Only return transactions that changed the balance of this asset. Must be an ID or an alias for an asset.
         *
         * @returns A promise object representing the array of transaction IDs and page offset
         */
        this.getAddressTxs = (address, cursor, pageSize, assetID) => __awaiter(this, void 0, void 0, function* () {
            let asset;
            let pageSizeNum;
            if (typeof assetID !== "string") {
                asset = bintools.cb58Encode(assetID);
            }
            else {
                asset = assetID;
            }
            if (typeof pageSize !== "number") {
                pageSizeNum = 0;
            }
            else {
                pageSizeNum = pageSize;
            }
            const params = {
                address,
                cursor,
                pageSize: pageSizeNum,
                assetID: asset
            };
            const response = yield this.callMethod("avm.getAddressTxs", params);
            return response.data.result;
        });
        /**
         * Sends an amount of assetID to the specified address from a list of owned of addresses.
         *
         * @param username The user that owns the private keys associated with the `from` addresses
         * @param password The password unlocking the user
         * @param assetID The assetID of the asset to send
         * @param amount The amount of the asset to be sent
         * @param to The address of the recipient
         * @param from Optional. An array of addresses managed by the node's keystore for this blockchain which will fund this transaction
         * @param changeAddr Optional. An address to send the change
         * @param memo Optional. CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes
         *
         * @returns Promise for the string representing the transaction's ID.
         */
        this.send = (username, password, assetID, amount, to, from = undefined, changeAddr = undefined, memo = undefined) => __awaiter(this, void 0, void 0, function* () {
            let asset;
            let amnt;
            if (typeof this.parseAddress(to) === "undefined") {
                /* istanbul ignore next */
                throw new errors_1.AddressError("Error - AVMAPI.send: Invalid address format");
            }
            if (typeof assetID !== "string") {
                asset = bintools.cb58Encode(assetID);
            }
            else {
                asset = assetID;
            }
            if (typeof amount === "number") {
                amnt = new bn_js_1.default(amount);
            }
            else {
                amnt = amount;
            }
            const params = {
                username: username,
                password: password,
                assetID: asset,
                amount: amnt.toString(10),
                to: to
            };
            const caller = "send";
            from = this._cleanAddressArray(from, caller);
            if (typeof from !== "undefined") {
                params["from"] = from;
            }
            if (typeof changeAddr !== "undefined") {
                if (typeof this.parseAddress(changeAddr) === "undefined") {
                    /* istanbul ignore next */
                    throw new errors_1.AddressError("Error - AVMAPI.send: Invalid address format");
                }
                params["changeAddr"] = changeAddr;
            }
            if (typeof memo !== "undefined") {
                if (typeof memo !== "string") {
                    params["memo"] = bintools.cb58Encode(memo);
                }
                else {
                    params["memo"] = memo;
                }
            }
            const response = yield this.callMethod("avm.send", params);
            return response.data.result;
        });
        /**
         * Sends an amount of assetID to an array of specified addresses from a list of owned of addresses.
         *
         * @param username The user that owns the private keys associated with the `from` addresses
         * @param password The password unlocking the user
         * @param sendOutputs The array of SendOutputs. A SendOutput is an object literal which contains an assetID, amount, and to.
         * @param from Optional. An array of addresses managed by the node's keystore for this blockchain which will fund this transaction
         * @param changeAddr Optional. An address to send the change
         * @param memo Optional. CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes
         *
         * @returns Promise for the string representing the transaction"s ID.
         */
        this.sendMultiple = (username, password, sendOutputs, from = undefined, changeAddr = undefined, memo = undefined) => __awaiter(this, void 0, void 0, function* () {
            let asset;
            let amnt;
            const sOutputs = [];
            sendOutputs.forEach((output) => {
                if (typeof this.parseAddress(output.to) === "undefined") {
                    /* istanbul ignore next */
                    throw new errors_1.AddressError("Error - AVMAPI.sendMultiple: Invalid address format");
                }
                if (typeof output.assetID !== "string") {
                    asset = bintools.cb58Encode(output.assetID);
                }
                else {
                    asset = output.assetID;
                }
                if (typeof output.amount === "number") {
                    amnt = new bn_js_1.default(output.amount);
                }
                else {
                    amnt = output.amount;
                }
                sOutputs.push({
                    to: output.to,
                    assetID: asset,
                    amount: amnt.toString(10)
                });
            });
            const params = {
                username: username,
                password: password,
                outputs: sOutputs
            };
            const caller = "send";
            from = this._cleanAddressArray(from, caller);
            if (typeof from !== "undefined") {
                params.from = from;
            }
            if (typeof changeAddr !== "undefined") {
                if (typeof this.parseAddress(changeAddr) === "undefined") {
                    /* istanbul ignore next */
                    throw new errors_1.AddressError("Error - AVMAPI.send: Invalid address format");
                }
                params.changeAddr = changeAddr;
            }
            if (typeof memo !== "undefined") {
                if (typeof memo !== "string") {
                    params.memo = bintools.cb58Encode(memo);
                }
                else {
                    params.memo = memo;
                }
            }
            const response = yield this.callMethod("avm.sendMultiple", params);
            return response.data.result;
        });
        /**
         * Given a JSON representation of this Virtual Machine’s genesis state, create the byte representation of that state.
         *
         * @param genesisData The blockchain's genesis data object
         *
         * @returns Promise of a string of bytes
         */
        this.buildGenesis = (genesisData) => __awaiter(this, void 0, void 0, function* () {
            const params = {
                genesisData
            };
            const response = yield this.callMethod("avm.buildGenesis", params);
            return response.data.result.bytes;
        });
        this.blockchainID = blockchainID;
        const netID = core.getNetworkID();
        if (netID in constants_2.Defaults.network &&
            blockchainID in constants_2.Defaults.network[`${netID}`]) {
            const alias = constants_2.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) {
            for (let i = 0; i < addresses.length; i++) {
                if (typeof addresses[`${i}`] === "string") {
                    if (typeof this.parseAddress(addresses[`${i}`]) ===
                        "undefined") {
                        /* istanbul ignore next */
                        throw new errors_1.AddressError("Error - AVMAPI.${caller}: Invalid address format");
                    }
                    addrs.push(addresses[`${i}`]);
                }
                else {
                    const type = "bech32";
                    addrs.push(serialization.bufferToType(addresses[`${i}`], type, this.core.getHRP(), chainID));
                }
            }
        }
        return addrs;
    }
}
exports.AVMAPI = AVMAPI;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../../src/apis/avm/api.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @packageDocumentation\n * @module API-AVM\n */\nimport BN from \"bn.js\"\nimport { Buffer } from \"buffer/\"\nimport AvalancheCore from \"../../avalanche\"\nimport BinTools from \"../../utils/bintools\"\nimport { UTXO, UTXOSet } from \"./utxos\"\nimport { AVMConstants } from \"./constants\"\nimport { KeyChain } from \"./keychain\"\nimport { Tx, UnsignedTx } from \"./tx\"\nimport { PayloadBase } from \"../../utils/payload\"\nimport { SECPMintOutput } from \"./outputs\"\nimport { InitialStates } from \"./initialstates\"\nimport { UnixNow } from \"../../utils/helperfunctions\"\nimport { JRPCAPI } from \"../../common/jrpcapi\"\nimport { RequestResponseData } from \"../../common/apibase\"\nimport { Defaults, PrimaryAssetAlias, ONEAVAX } from \"../../utils/constants\"\nimport { MinterSet } from \"./minterset\"\nimport { PersistanceOptions } from \"../../utils/persistenceoptions\"\nimport { OutputOwners } from \"../../common/output\"\nimport { SECPTransferOutput } from \"./outputs\"\nimport {\n  AddressError,\n  GooseEggCheckError,\n  ChainIdError,\n  NoAtomicUTXOsError,\n  SymbolError,\n  NameError,\n  TransactionError\n} from \"../../utils/errors\"\nimport { Serialization, SerializedType } from \"../../utils\"\nimport {\n  BuildGenesisParams,\n  CreateAddressParams,\n  CreateFixedCapAssetParams,\n  CreateVariableCapAssetParams,\n  ExportParams,\n  ExportKeyParams,\n  GetAllBalancesParams,\n  GetAssetDescriptionParams,\n  GetAVAXAssetIDParams,\n  GetBalanceParams,\n  GetTxParams,\n  GetTxStatusParams,\n  GetUTXOsParams,\n  ImportParams,\n  ImportKeyParams,\n  ListAddressesParams,\n  MintParams,\n  SendMultipleParams,\n  SOutputsParams,\n  GetUTXOsResponse,\n  GetAssetDescriptionResponse,\n  GetBalanceResponse,\n  SendParams,\n  SendResponse,\n  SendMultipleResponse,\n  GetAddressTxsParams,\n  GetAddressTxsResponse,\n  CreateNFTAssetParams,\n  SendNFTParams,\n  MintNFTParams,\n  IMinterSet\n} from \"./interfaces\"\nimport { IssueTxParams } from \"../../common\"\n\n/**\n * @ignore\n */\nconst bintools: BinTools = BinTools.getInstance()\nconst serialization: Serialization = Serialization.getInstance()\n\n/**\n * Class for interacting with a node endpoint that is using the AVM.\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 AVMAPI 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  protected creationTxFee: BN = undefined\n  protected mintTxFee: 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): undefined => {\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 The blockchainID\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}`].X.blockchainID //default to X-Chain\n      return true\n    }\n    if (typeof blockchainID === \"string\") {\n      this.blockchainID = blockchainID\n      return true\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      AVMConstants.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    const hrp: string = this.core.getHRP()\n    return serialization.bufferToType(address, type, hrp, chainID)\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: GetAVAXAssetIDParams = await this.getAssetDescription(\n        PrimaryAssetAlias\n      )\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()][\"X\"][\"txFee\"])\n      : new BN(0)\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   * Sets the tx fee for this chain.\n   *\n   * @param fee The tx fee amount to set as {@link https://github.com/indutny/bn.js/|BN}\n   */\n  setTxFee = (fee: BN): void => {\n    this.txFee = fee\n  }\n\n  /**\n   * Gets the default creation fee for this chain.\n   *\n   * @returns The default creation fee as a {@link https://github.com/indutny/bn.js/|BN}\n   */\n  getDefaultCreationTxFee = (): BN => {\n    return this.core.getNetworkID() in Defaults.network\n      ? new BN(Defaults.network[this.core.getNetworkID()][\"X\"][\"creationTxFee\"])\n      : new BN(0)\n  }\n\n  /**\n   * Gets the default mint fee for this chain.\n   *\n   * @returns The default mint fee as a {@link https://github.com/indutny/bn.js/|BN}\n   */\n  getDefaultMintTxFee = (): BN => {\n    return this.core.getNetworkID() in Defaults.network\n      ? new BN(Defaults.network[this.core.getNetworkID()][\"X\"][\"mintTxFee\"])\n      : new BN(0)\n  }\n\n  /**\n   * Gets the mint fee for this chain.\n   *\n   * @returns The mint fee as a {@link https://github.com/indutny/bn.js/|BN}\n   */\n  getMintTxFee = (): BN => {\n    if (typeof this.mintTxFee === \"undefined\") {\n      this.mintTxFee = this.getDefaultMintTxFee()\n    }\n    return this.mintTxFee\n  }\n\n  /**\n   * Gets the creation fee for this chain.\n   *\n   * @returns The creation fee as a {@link https://github.com/indutny/bn.js/|BN}\n   */\n  getCreationTxFee = (): BN => {\n    if (typeof this.creationTxFee === \"undefined\") {\n      this.creationTxFee = this.getDefaultCreationTxFee()\n    }\n    return this.creationTxFee\n  }\n\n  /**\n   * Sets the mint fee for this chain.\n   *\n   * @param fee The mint fee amount to set as {@link https://github.com/indutny/bn.js/|BN}\n   */\n  setMintTxFee = (fee: BN): void => {\n    this.mintTxFee = fee\n  }\n\n  /**\n   * Sets the creation fee for this chain.\n   *\n   * @param fee The creation fee amount to set as {@link https://github.com/indutny/bn.js/|BN}\n   */\n  setCreationTxFee = (fee: BN): void => {\n    this.creationTxFee = fee\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   * @ignore\n   */\n  newKeyChain = (): KeyChain => {\n    // warning, overwrites the old keychain\n    const alias: string = 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   * Helper function which determines if a tx is a goose egg transaction.\n   *\n   * @param utx An UnsignedTx\n   *\n   * @returns boolean true if passes goose egg test and false if fails.\n   *\n   * @remarks\n   * A \"Goose Egg Transaction\" is when the fee far exceeds a reasonable amount\n   */\n  checkGooseEgg = async (\n    utx: UnsignedTx,\n    outTotal: BN = new BN(0)\n  ): Promise<boolean> => {\n    const avaxAssetID: Buffer = await this.getAVAXAssetID()\n    const outputTotal: BN = outTotal.gt(new BN(0))\n      ? outTotal\n      : utx.getOutputTotal(avaxAssetID)\n    const fee: BN = utx.getBurn(avaxAssetID)\n    if (fee.lte(ONEAVAX.mul(new BN(10))) || fee.lte(outputTotal)) {\n      return true\n    } else {\n      return false\n    }\n  }\n\n  /**\n   * Gets the balance of a particular asset on a blockchain.\n   *\n   * @param address The address to pull the asset balance from\n   * @param assetID The assetID to pull the balance from\n   * @param includePartial If includePartial=false, returns only the balance held solely\n   *\n   * @returns Promise with the balance of the assetID as a {@link https://github.com/indutny/bn.js/|BN} on the provided address for the blockchain.\n   */\n  getBalance = async (\n    address: string,\n    assetID: string,\n    includePartial: boolean = false\n  ): Promise<GetBalanceResponse> => {\n    if (typeof this.parseAddress(address) === \"undefined\") {\n      /* istanbul ignore next */\n      throw new AddressError(\n        \"Error - AVMAPI.getBalance: Invalid address format\"\n      )\n    }\n    const params: GetBalanceParams = {\n      address,\n      assetID,\n      includePartial\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.getBalance\",\n      params\n    )\n    return response.data.result\n  }\n\n  /**\n   * Creates an address (and associated private keys) on a user on a blockchain.\n   *\n   * @param username Name of the user to create the address under\n   * @param password Password to unlock the user and encrypt the private key\n   *\n   * @returns Promise for a string representing the address created by the vm.\n   */\n  createAddress = async (\n    username: string,\n    password: string\n  ): Promise<string> => {\n    const params: CreateAddressParams = {\n      username,\n      password\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.createAddress\",\n      params\n    )\n    return response.data.result.address\n  }\n\n  /**\n   * Create a new fixed-cap, fungible asset. A quantity of it is created at initialization and there no more is ever created.\n   *\n   * @param username The user paying the transaction fee (in $AVAX) for asset creation\n   * @param password The password for the user paying the transaction fee (in $AVAX) for asset creation\n   * @param name The human-readable name for the asset\n   * @param symbol Optional. The shorthand symbol for the asset. Between 0 and 4 characters\n   * @param denomination Optional. Determines how balances of this asset are displayed by user interfaces. Default is 0\n   * @param initialHolders An array of objects containing the field \"address\" and \"amount\" to establish the genesis values for the new asset\n   *\n   * ```js\n   * Example initialHolders:\n   * [\n   *   {\n   *     \"address\": \"X-avax1kj06lhgx84h39snsljcey3tpc046ze68mek3g5\",\n   *     \"amount\": 10000\n   *   },\n   *   {\n   *     \"address\": \"X-avax1am4w6hfrvmh3akduzkjthrtgtqafalce6an8cr\",\n   *     \"amount\": 50000\n   *   }\n   * ]\n   * ```\n   *\n   * @returns Returns a Promise string containing the base 58 string representation of the ID of the newly created asset.\n   */\n  createFixedCapAsset = async (\n    username: string,\n    password: string,\n    name: string,\n    symbol: string,\n    denomination: number,\n    initialHolders: object[]\n  ): Promise<string> => {\n    const params: CreateFixedCapAssetParams = {\n      name,\n      symbol,\n      denomination,\n      username,\n      password,\n      initialHolders\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.createFixedCapAsset\",\n      params\n    )\n    return response.data.result.assetID\n  }\n\n  /**\n   * Create a new variable-cap, fungible asset. No units of the asset exist at initialization. Minters can mint units of this asset using createMintTx, signMintTx and sendMintTx.\n   *\n   * @param username The user paying the transaction fee (in $AVAX) for asset creation\n   * @param password The password for the user paying the transaction fee (in $AVAX) for asset creation\n   * @param name The human-readable name for the asset\n   * @param symbol Optional. The shorthand symbol for the asset -- between 0 and 4 characters\n   * @param denomination Optional. Determines how balances of this asset are displayed by user interfaces. Default is 0\n   * @param minterSets is a list where each element specifies that threshold of the addresses in minters may together mint more of the asset by signing a minting transaction\n   *\n   * ```js\n   * Example minterSets:\n   * [\n   *    {\n   *      \"minters\":[\n   *        \"X-avax1am4w6hfrvmh3akduzkjthrtgtqafalce6an8cr\"\n   *      ],\n   *      \"threshold\": 1\n   *     },\n   *     {\n   *      \"minters\": [\n   *        \"X-avax1am4w6hfrvmh3akduzkjthrtgtqafalce6an8cr\",\n   *        \"X-avax1kj06lhgx84h39snsljcey3tpc046ze68mek3g5\",\n   *        \"X-avax1yell3e4nln0m39cfpdhgqprsd87jkh4qnakklx\"\n   *      ],\n   *      \"threshold\": 2\n   *     }\n   * ]\n   * ```\n   *\n   * @returns Returns a Promise string containing the base 58 string representation of the ID of the newly created asset.\n   */\n  createVariableCapAsset = async (\n    username: string,\n    password: string,\n    name: string,\n    symbol: string,\n    denomination: number,\n    minterSets: object[]\n  ): Promise<string> => {\n    const params: CreateVariableCapAssetParams = {\n      name,\n      symbol,\n      denomination,\n      username,\n      password,\n      minterSets\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.createVariableCapAsset\",\n      params\n    )\n    return response.data.result.assetID\n  }\n\n  /**\n   * Creates a family of NFT Asset. No units of the asset exist at initialization. Minters can mint units of this asset using createMintTx, signMintTx and sendMintTx.\n   *\n   * @param username The user paying the transaction fee (in $AVAX) for asset creation\n   * @param password The password for the user paying the transaction fee (in $AVAX) for asset creation\n   * @param from Optional. An array of addresses managed by the node's keystore for this blockchain which will fund this transaction\n   * @param changeAddr Optional. An address to send the change\n   * @param name The human-readable name for the asset\n   * @param symbol Optional. The shorthand symbol for the asset -- between 0 and 4 characters\n   * @param minterSets is a list where each element specifies that threshold of the addresses in minters may together mint more of the asset by signing a minting transaction\n   *\n   * @returns Returns a Promise string containing the base 58 string representation of the ID of the newly created asset.\n   */\n  createNFTAsset = async (\n    username: string,\n    password: string,\n    from: string[] | Buffer[] = undefined,\n    changeAddr: string,\n    name: string,\n    symbol: string,\n    minterSet: IMinterSet\n  ): Promise<string> => {\n    const params: CreateNFTAssetParams = {\n      username,\n      password,\n      name,\n      symbol,\n      minterSet\n    }\n\n    const caller: string = \"createNFTAsset\"\n    from = this._cleanAddressArray(from, caller)\n    if (typeof from !== \"undefined\") {\n      params[\"from\"] = from\n    }\n\n    if (typeof changeAddr !== \"undefined\") {\n      if (typeof this.parseAddress(changeAddr) === \"undefined\") {\n        /* istanbul ignore next */\n        throw new AddressError(\n          \"Error - AVMAPI.createNFTAsset: Invalid address format\"\n        )\n      }\n      params[\"changeAddr\"] = changeAddr\n    }\n\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.createNFTAsset\",\n      params\n    )\n    return response.data.result.assetID\n  }\n\n  /**\n   * Create an unsigned transaction to mint more of an asset.\n   *\n   * @param amount The units of the asset to mint\n   * @param assetID The ID of the asset to mint\n   * @param to The address to assign the units of the minted asset\n   * @param minters Addresses of the minters responsible for signing the transaction\n   *\n   * @returns Returns a Promise string containing the base 58 string representation of the unsigned transaction.\n   */\n  mint = async (\n    username: string,\n    password: string,\n    amount: number | BN,\n    assetID: Buffer | string,\n    to: string,\n    minters: string[]\n  ): Promise<string> => {\n    let asset: string\n    let amnt: BN\n    if (typeof assetID !== \"string\") {\n      asset = bintools.cb58Encode(assetID)\n    } else {\n      asset = assetID\n    }\n    if (typeof amount === \"number\") {\n      amnt = new BN(amount)\n    } else {\n      amnt = amount\n    }\n    const params: MintParams = {\n      username: username,\n      password: password,\n      amount: amnt,\n      assetID: asset,\n      to,\n      minters\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.mint\",\n      params\n    )\n    return response.data.result.txID\n  }\n\n  /**\n   * Mint non-fungible tokens which were created with AVMAPI.createNFTAsset\n   *\n   * @param username The user paying the transaction fee (in $AVAX) for asset creation\n   * @param password The password for the user paying the transaction fee (in $AVAX) for asset creation\n   * @param from Optional. An array of addresses managed by the node's keystore for this blockchain which will fund this transaction\n   * @param changeAddr Optional. An address to send the change\n   * @param assetID The asset id which is being sent\n   * @param to Address on X-Chain of the account to which this NFT is being sent\n   * @param encoding Optional.  is the encoding format to use for the payload argument. Can be either \"cb58\" or \"hex\". Defaults to \"hex\".\n   *\n   * @returns ID of the transaction\n   */\n  mintNFT = async (\n    username: string,\n    password: string,\n    from: string[] | Buffer[] = undefined,\n    changeAddr: string = undefined,\n    payload: string,\n    assetID: string | Buffer,\n    to: string,\n    encoding: string = \"hex\"\n  ): Promise<string> => {\n    let asset: string\n\n    if (typeof this.parseAddress(to) === \"undefined\") {\n      /* istanbul ignore next */\n      throw new AddressError(\"Error - AVMAPI.mintNFT: Invalid address format\")\n    }\n\n    if (typeof assetID !== \"string\") {\n      asset = bintools.cb58Encode(assetID)\n    } else {\n      asset = assetID\n    }\n\n    const params: MintNFTParams = {\n      username,\n      password,\n      assetID: asset,\n      payload,\n      to,\n      encoding\n    }\n\n    const caller: string = \"mintNFT\"\n    from = this._cleanAddressArray(from, caller)\n    if (typeof from !== \"undefined\") {\n      params[\"from\"] = from\n    }\n\n    if (typeof changeAddr !== \"undefined\") {\n      if (typeof this.parseAddress(changeAddr) === \"undefined\") {\n        /* istanbul ignore next */\n        throw new AddressError(\"Error - AVMAPI.mintNFT: Invalid address format\")\n      }\n      params[\"changeAddr\"] = changeAddr\n    }\n\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.mintNFT\",\n      params\n    )\n    return response.data.result.txID\n  }\n\n  /**\n   * Send NFT from one account to another on X-Chain\n   *\n   * @param username The user paying the transaction fee (in $AVAX) for asset creation\n   * @param password The password for the user paying the transaction fee (in $AVAX) for asset creation\n   * @param from Optional. An array of addresses managed by the node's keystore for this blockchain which will fund this transaction\n   * @param changeAddr Optional. An address to send the change\n   * @param assetID The asset id which is being sent\n   * @param groupID The group this NFT is issued to.\n   * @param to Address on X-Chain of the account to which this NFT is being sent\n   *\n   * @returns ID of the transaction\n   */\n  sendNFT = async (\n    username: string,\n    password: string,\n    from: string[] | Buffer[] = undefined,\n    changeAddr: string = undefined,\n    assetID: string | Buffer,\n    groupID: number,\n    to: string\n  ): Promise<string> => {\n    let asset: string\n\n    if (typeof this.parseAddress(to) === \"undefined\") {\n      /* istanbul ignore next */\n      throw new AddressError(\"Error - AVMAPI.sendNFT: Invalid address format\")\n    }\n\n    if (typeof assetID !== \"string\") {\n      asset = bintools.cb58Encode(assetID)\n    } else {\n      asset = assetID\n    }\n\n    const params: SendNFTParams = {\n      username,\n      password,\n      assetID: asset,\n      groupID,\n      to\n    }\n\n    const caller: string = \"sendNFT\"\n    from = this._cleanAddressArray(from, caller)\n    if (typeof from !== \"undefined\") {\n      params[\"from\"] = from\n    }\n\n    if (typeof changeAddr !== \"undefined\") {\n      if (typeof this.parseAddress(changeAddr) === \"undefined\") {\n        /* istanbul ignore next */\n        throw new AddressError(\"Error - AVMAPI.sendNFT: Invalid address format\")\n      }\n      params[\"changeAddr\"] = changeAddr\n    }\n\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.sendNFT\",\n      params\n    )\n    return response.data.result.txID\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 as store in the database\n   */\n  exportKey = async (\n    username: string,\n    password: string,\n    address: string\n  ): Promise<string> => {\n    if (typeof this.parseAddress(address) === \"undefined\") {\n      /* istanbul ignore next */\n      throw new AddressError(\"Error - AVMAPI.exportKey: Invalid address format\")\n    }\n    const params: ExportKeyParams = {\n      username,\n      password,\n      address\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.exportKey\",\n      params\n    )\n    return response.data.result.privateKey\n  }\n\n  /**\n   * Imports a private key into the node's keystore under an user and for a blockchain.\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      \"avm.importKey\",\n      params\n    )\n    return response.data.result.address\n  }\n\n  /**\n   * Send ANT (Avalanche Native Token) assets including AVAX from the X-Chain to an account on the P-Chain or C-Chain.\n   *\n   * After calling this method, you must call the P-Chain's `import` or the C-Chain’s `import` method to complete the transfer.\n   *\n   * @param username The Keystore user that controls the P-Chain or C-Chain account specified in `to`\n   * @param password The password of the Keystore user\n   * @param to The account on the P-Chain or C-Chain to send the asset 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      username,\n      password,\n      to,\n      amount: amount,\n      assetID\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.export\",\n      params\n    )\n    return response.data.result.txID\n  }\n\n  /**\n   * Send ANT (Avalanche Native Token) assets including AVAX from an account on the P-Chain or C-Chain to an address on the X-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: \"C\"\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      username,\n      password,\n      to,\n      sourceChain\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.import\",\n      params\n    )\n    return response.data.result.txID\n  }\n\n  /**\n   * Lists all the addresses under a user.\n   *\n   * @param username The user to list addresses\n   * @param password The password of the user to list the addresses\n   *\n   * @returns Promise of an array of address strings in the format specified by the blockchain.\n   */\n  listAddresses = async (\n    username: string,\n    password: string\n  ): Promise<string[]> => {\n    const params: ListAddressesParams = {\n      username,\n      password\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.listAddresses\",\n      params\n    )\n    return response.data.result.addresses\n  }\n\n  /**\n   * Retrieves all assets for an address on a server and their associated balances.\n   *\n   * @param address The address to get a list of assets\n   *\n   * @returns Promise of an object mapping assetID strings with {@link https://github.com/indutny/bn.js/|BN} balance for the address on the blockchain.\n   */\n  getAllBalances = async (address: string): Promise<object[]> => {\n    if (typeof this.parseAddress(address) === \"undefined\") {\n      /* istanbul ignore next */\n      throw new AddressError(\n        \"Error - AVMAPI.getAllBalances: Invalid address format\"\n      )\n    }\n    const params: GetAllBalancesParams = {\n      address\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.getAllBalances\",\n      params\n    )\n    return response.data.result.balances\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 object with keys \"name\" and \"symbol\".\n   */\n  getAssetDescription = async (\n    assetID: Buffer | string\n  ): Promise<GetAssetDescriptionResponse> => {\n    let asset: string\n    if (typeof assetID !== \"string\") {\n      asset = bintools.cb58Encode(assetID)\n    } else {\n      asset = assetID\n    }\n    const params: GetAssetDescriptionParams = {\n      assetID: asset\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.getAssetDescription\",\n      params\n    )\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   * Returns the transaction data of a provided transaction ID by calling the node's `getTx` method.\n   *\n   * @param txID The string representation of the transaction ID\n   * @param encoding sets the format of the returned transaction. Can be, \"cb58\", \"hex\" or \"json\". Defaults to \"cb58\".\n   *\n   * @returns Returns a Promise string or object containing the bytes retrieved from the node\n   */\n  getTx = async (\n    txID: string,\n    encoding: string = \"hex\"\n  ): Promise<string | object> => {\n    const params: GetTxParams = {\n      txID,\n      encoding\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.getTx\",\n      params\n    )\n    return response.data.result.tx\n  }\n\n  /**\n   * Returns the status of a provided transaction ID by calling the node's `getTxStatus` 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  getTxStatus = async (txID: string): Promise<string> => {\n    const params: GetTxStatusParams = {\n      txID\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.getTxStatus\",\n      params\n    )\n    return response.data.result.status\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 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   * @param persistOpts Options available to persist these UTXOs in local storage\n   *\n   * @remarks\n   * persistOpts is optional and must be of type [[PersistanceOptions]]\n   *\n   */\n  getUTXOs = async (\n    addresses: string[] | string,\n    sourceChain: string = undefined,\n    limit: number = 0,\n    startIndex: { address: string; utxo: string } = undefined,\n    persistOpts: PersistanceOptions = undefined,\n    encoding: string = \"hex\"\n  ): Promise<GetUTXOsResponse> => {\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      \"avm.getUTXOs\",\n      params\n    )\n    const utxos: UTXOSet = new UTXOSet()\n    let data = response.data.result.utxos\n    if (persistOpts && typeof persistOpts === \"object\") {\n      if (this.db.has(persistOpts.getName())) {\n        const selfArray: string[] = this.db.get(persistOpts.getName())\n        if (Array.isArray(selfArray)) {\n          utxos.addArray(data)\n          const utxoSet: UTXOSet = new UTXOSet()\n          utxoSet.addArray(selfArray)\n          utxoSet.mergeByRule(utxos, persistOpts.getMergeRule())\n          data = utxoSet.getAllUTXOStrings()\n        }\n      }\n      this.db.set(persistOpts.getName(), data, persistOpts.getOverwrite())\n    }\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   * Helper function which creates an unsigned transaction. For more granular control, you may create your own\n   * [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s, and [[TransferOperation]]s).\n   *\n   * @param utxoset A set of UTXOs that the transaction is built on\n   * @param amount The amount of AssetID to be spent in its smallest denomination, represented as {@link https://github.com/indutny/bn.js/|BN}.\n   * @param assetID The assetID of the value being 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 memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes\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 a [[BaseTx]].\n   *\n   * @remarks\n   * This helper exists because the endpoint API should be the primary point of entry for most functionality.\n   */\n  buildBaseTx = async (\n    utxoset: UTXOSet,\n    amount: BN,\n    assetID: Buffer | string = undefined,\n    toAddresses: string[],\n    fromAddresses: string[],\n    changeAddresses: string[],\n    memo: PayloadBase | Buffer = undefined,\n    asOf: BN = UnixNow(),\n    locktime: BN = new BN(0),\n    threshold: number = 1\n  ): Promise<UnsignedTx> => {\n    const caller: string = \"buildBaseTx\"\n    const to: Buffer[] = this._cleanAddressArray(toAddresses, caller).map(\n      (a: string): Buffer => bintools.stringToAddress(a)\n    )\n    const from: Buffer[] = this._cleanAddressArray(fromAddresses, caller).map(\n      (a: string): Buffer => bintools.stringToAddress(a)\n    )\n    const change: Buffer[] = this._cleanAddressArray(\n      changeAddresses,\n      caller\n    ).map((a: string): Buffer => bintools.stringToAddress(a))\n\n    if (typeof assetID === \"string\") {\n      assetID = bintools.cb58Decode(assetID)\n    }\n\n    if (memo instanceof PayloadBase) {\n      memo = memo.getPayload()\n    }\n\n    const networkID: number = this.core.getNetworkID()\n    const blockchainIDBuf: Buffer = bintools.cb58Decode(this.blockchainID)\n    const fee: BN = this.getTxFee()\n    const feeAssetID: Buffer = await this.getAVAXAssetID()\n    const builtUnsignedTx: UnsignedTx = utxoset.buildBaseTx(\n      networkID,\n      blockchainIDBuf,\n      amount,\n      assetID,\n      to,\n      from,\n      change,\n      fee,\n      feeAssetID,\n      memo,\n      asOf,\n      locktime,\n      threshold\n    )\n\n    if (!(await this.checkGooseEgg(builtUnsignedTx))) {\n      /* istanbul ignore next */\n      throw new GooseEggCheckError(\n        \"Error - AVMAPI.buildBaseTx:Failed Goose Egg Check\"\n      )\n    }\n\n    return builtUnsignedTx\n  }\n\n  /**\n   * Helper function which creates an unsigned NFT Transfer. For more granular control, you may create your own\n   * [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s, and [[TransferOperation]]s).\n   *\n   * @param utxoset  A set of UTXOs that the transaction is built on\n   * @param toAddresses The addresses to send the NFT\n   * @param fromAddresses The addresses being used to send the NFT from the utxoID provided\n   * @param changeAddresses The addresses that can spend the change remaining from the spent UTXOs\n   * @param utxoid A base58 utxoID or an array of base58 utxoIDs for the nfts this transaction is sending\n   * @param memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes\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 a [[NFTTransferTx]].\n   *\n   * @remarks\n   * This helper exists because the endpoint API should be the primary point of entry for most functionality.\n   */\n  buildNFTTransferTx = async (\n    utxoset: UTXOSet,\n    toAddresses: string[],\n    fromAddresses: string[],\n    changeAddresses: string[],\n    utxoid: string | string[],\n    memo: PayloadBase | Buffer = undefined,\n    asOf: BN = UnixNow(),\n    locktime: BN = new BN(0),\n    threshold: number = 1\n  ): Promise<UnsignedTx> => {\n    const caller: string = \"buildNFTTransferTx\"\n    const to: Buffer[] = this._cleanAddressArray(toAddresses, caller).map(\n      (a: string): Buffer => bintools.stringToAddress(a)\n    )\n    const from: Buffer[] = this._cleanAddressArray(fromAddresses, caller).map(\n      (a: string): Buffer => bintools.stringToAddress(a)\n    )\n    const change: Buffer[] = this._cleanAddressArray(\n      changeAddresses,\n      caller\n    ).map((a: string): Buffer => bintools.stringToAddress(a))\n\n    if (memo instanceof PayloadBase) {\n      memo = memo.getPayload()\n    }\n    const avaxAssetID: Buffer = await this.getAVAXAssetID()\n\n    let utxoidArray: string[] = []\n    if (typeof utxoid === \"string\") {\n      utxoidArray = [utxoid]\n    } else if (Array.isArray(utxoid)) {\n      utxoidArray = utxoid\n    }\n\n    const builtUnsignedTx: UnsignedTx = utxoset.buildNFTTransferTx(\n      this.core.getNetworkID(),\n      bintools.cb58Decode(this.blockchainID),\n      to,\n      from,\n      change,\n      utxoidArray,\n      this.getTxFee(),\n      avaxAssetID,\n      memo,\n      asOf,\n      locktime,\n      threshold\n    )\n\n    if (!(await this.checkGooseEgg(builtUnsignedTx))) {\n      /* istanbul ignore next */\n      throw new GooseEggCheckError(\n        \"Error - AVMAPI.buildNFTTransferTx:Failed Goose Egg Check\"\n      )\n    }\n\n    return builtUnsignedTx\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, and [[TransferOperation]]s).\n   *\n   * @param utxoset  A set of UTXOs that the transaction is built on\n   * @param ownerAddresses The addresses being used to import\n   * @param sourceChain The chainid for where the import is coming from\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 memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes\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 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    ownerAddresses: string[],\n    sourceChain: Buffer | string,\n    toAddresses: string[],\n    fromAddresses: string[],\n    changeAddresses: string[] = undefined,\n    memo: PayloadBase | Buffer = undefined,\n    asOf: BN = UnixNow(),\n    locktime: BN = new BN(0),\n    threshold: number = 1\n  ): Promise<UnsignedTx> => {\n    const caller: string = \"buildImportTx\"\n    const to: Buffer[] = this._cleanAddressArray(toAddresses, caller).map(\n      (a: string): Buffer => bintools.stringToAddress(a)\n    )\n    const from: Buffer[] = this._cleanAddressArray(fromAddresses, caller).map(\n      (a: string): Buffer => bintools.stringToAddress(a)\n    )\n    const change: Buffer[] = this._cleanAddressArray(\n      changeAddresses,\n      caller\n    ).map((a: string): Buffer => bintools.stringToAddress(a))\n\n    let srcChain: string = undefined\n\n    if (typeof sourceChain === \"undefined\") {\n      throw new ChainIdError(\n        \"Error - AVMAPI.buildImportTx: Source ChainID is undefined.\"\n      )\n    } else if (typeof sourceChain === \"string\") {\n      srcChain = sourceChain\n      sourceChain = bintools.cb58Decode(sourceChain)\n    } else if (!(sourceChain instanceof Buffer)) {\n      throw new ChainIdError(\n        \"Error - AVMAPI.buildImportTx: Invalid destinationChain type: \" +\n          typeof sourceChain\n      )\n    }\n\n    const atomicUTXOs: UTXOSet = (\n      await this.getUTXOs(ownerAddresses, srcChain, 0, undefined)\n    ).utxos\n    const avaxAssetID: Buffer = await this.getAVAXAssetID()\n    const atomics: UTXO[] = atomicUTXOs.getAllUTXOs()\n\n    if (atomics.length === 0) {\n      throw new NoAtomicUTXOsError(\n        \"Error - AVMAPI.buildImportTx: No atomic UTXOs to import from \" +\n          srcChain +\n          \" using addresses: \" +\n          ownerAddresses.join(\", \")\n      )\n    }\n\n    if (memo instanceof PayloadBase) {\n      memo = memo.getPayload()\n    }\n\n    const builtUnsignedTx: UnsignedTx = utxoset.buildImportTx(\n      this.core.getNetworkID(),\n      bintools.cb58Decode(this.blockchainID),\n      to,\n      from,\n      change,\n      atomics,\n      sourceChain,\n      this.getTxFee(),\n      avaxAssetID,\n      memo,\n      asOf,\n      locktime,\n      threshold\n    )\n\n    if (!(await this.checkGooseEgg(builtUnsignedTx))) {\n      /* istanbul ignore next */\n      throw new GooseEggCheckError(\n        \"Error - AVMAPI.buildImportTx:Failed Goose Egg Check\"\n      )\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, and [[TransferOperation]]s).\n   *\n   * @param utxoset A set of UTXOs that the transaction is built on\n   * @param amount The amount being exported as a {@link https://github.com/indutny/bn.js/|BN}\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 memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes\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   * @param assetID Optional. The assetID of the asset to send. Defaults to AVAX assetID.\n   * Regardless of the asset which you\"re exporting, all fees are paid in AVAX.\n   *\n   * @returns An unsigned transaction ([[UnsignedTx]]) which contains an [[ExportTx]].\n   */\n  buildExportTx = async (\n    utxoset: UTXOSet,\n    amount: BN,\n    destinationChain: Buffer | string,\n    toAddresses: string[],\n    fromAddresses: string[],\n    changeAddresses: string[] = undefined,\n    memo: PayloadBase | Buffer = undefined,\n    asOf: BN = UnixNow(),\n    locktime: BN = new BN(0),\n    threshold: number = 1,\n    assetID: string = undefined\n  ): Promise<UnsignedTx> => {\n    const prefixes: object = {}\n    toAddresses.map((a: string): void => {\n      prefixes[a.split(\"-\")[0]] = true\n    })\n    if (Object.keys(prefixes).length !== 1) {\n      throw new AddressError(\n        \"Error - AVMAPI.buildExportTx: To addresses must have the same chainID prefix.\"\n      )\n    }\n\n    if (typeof destinationChain === \"undefined\") {\n      throw new ChainIdError(\n        \"Error - AVMAPI.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 - AVMAPI.buildExportTx: Invalid destinationChain type: \" +\n          typeof destinationChain\n      )\n    }\n    if (destinationChain.length !== 32) {\n      throw new ChainIdError(\n        \"Error - AVMAPI.buildExportTx: Destination ChainID must be 32 bytes in length.\"\n      )\n    }\n\n    const to: Buffer[] = []\n    toAddresses.map((a: string): void => {\n      to.push(bintools.stringToAddress(a))\n    })\n\n    const caller: string = \"buildExportTx\"\n    const from: Buffer[] = this._cleanAddressArray(fromAddresses, caller).map(\n      (a: string): Buffer => bintools.stringToAddress(a)\n    )\n\n    const change: Buffer[] = this._cleanAddressArray(\n      changeAddresses,\n      caller\n    ).map((a: string): Buffer => bintools.stringToAddress(a))\n\n    if (memo instanceof PayloadBase) {\n      memo = memo.getPayload()\n    }\n\n    const avaxAssetID: Buffer = await this.getAVAXAssetID()\n    if (typeof assetID === \"undefined\") {\n      assetID = bintools.cb58Encode(avaxAssetID)\n    }\n\n    const networkID: number = this.core.getNetworkID()\n    const blockchainID: Buffer = bintools.cb58Decode(this.blockchainID)\n    const assetIDBuf: Buffer = bintools.cb58Decode(assetID)\n    const fee: BN = this.getTxFee()\n    const builtUnsignedTx: UnsignedTx = utxoset.buildExportTx(\n      networkID,\n      blockchainID,\n      amount,\n      assetIDBuf,\n      to,\n      from,\n      change,\n      destinationChain,\n      fee,\n      avaxAssetID,\n      memo,\n      asOf,\n      locktime,\n      threshold\n    )\n\n    if (!(await this.checkGooseEgg(builtUnsignedTx))) {\n      /* istanbul ignore next */\n      throw new GooseEggCheckError(\n        \"Error - AVMAPI.buildExportTx:Failed Goose Egg Check\"\n      )\n    }\n\n    return builtUnsignedTx\n  }\n\n  /**\n   * Creates an unsigned transaction. For more granular control, you may create your own\n   * [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s, and [[TransferOperation]]s).\n   *\n   * @param utxoset A set of UTXOs that the transaction is built on\n   * @param fromAddresses The addresses being used to send the funds from the UTXOs {@link https://github.com/feross/buffer|Buffer}\n   * @param changeAddresses The addresses that can spend the change remaining from the spent UTXOs\n   * @param initialState The [[InitialStates]] that represent the intial state of a created asset\n   * @param name String for the descriptive name of the asset\n   * @param symbol String for the ticker symbol of the asset\n   * @param denomination Number for the denomination which is 10^D. D must be >= 0 and <= 32. Ex: $1 AVAX = 10^9 $nAVAX\n   * @param mintOutputs Optional. Array of [[SECPMintOutput]]s to be included in the transaction. These outputs can be spent to mint more tokens.\n   * @param memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes\n   * @param asOf Optional. The timestamp to verify the transaction against as a {@link https://github.com/indutny/bn.js/|BN}\n   *\n   * @returns An unsigned transaction ([[UnsignedTx]]) which contains a [[CreateAssetTx]].\n   *\n   */\n  buildCreateAssetTx = async (\n    utxoset: UTXOSet,\n    fromAddresses: string[],\n    changeAddresses: string[],\n    initialStates: InitialStates,\n    name: string,\n    symbol: string,\n    denomination: number,\n    mintOutputs: SECPMintOutput[] = undefined,\n    memo: PayloadBase | Buffer = undefined,\n    asOf: BN = UnixNow()\n  ): Promise<UnsignedTx> => {\n    const caller: string = \"buildCreateAssetTx\"\n    const from: Buffer[] = this._cleanAddressArray(fromAddresses, caller).map(\n      (a: string): Buffer => bintools.stringToAddress(a)\n    )\n    const change: Buffer[] = this._cleanAddressArray(\n      changeAddresses,\n      caller\n    ).map((a: string): Buffer => bintools.stringToAddress(a))\n\n    if (memo instanceof PayloadBase) {\n      memo = memo.getPayload()\n    }\n\n    if (symbol.length > AVMConstants.SYMBOLMAXLEN) {\n      throw new SymbolError(\n        \"Error - AVMAPI.buildCreateAssetTx: Symbols may not exceed length of \" +\n          AVMConstants.SYMBOLMAXLEN\n      )\n    }\n    if (name.length > AVMConstants.ASSETNAMELEN) {\n      throw new NameError(\n        \"Error - AVMAPI.buildCreateAssetTx: Names may not exceed length of \" +\n          AVMConstants.ASSETNAMELEN\n      )\n    }\n\n    const networkID: number = this.core.getNetworkID()\n    const blockchainID: Buffer = bintools.cb58Decode(this.blockchainID)\n    const avaxAssetID: Buffer = await this.getAVAXAssetID()\n    const fee: BN = this.getDefaultCreationTxFee()\n    const builtUnsignedTx: UnsignedTx = utxoset.buildCreateAssetTx(\n      networkID,\n      blockchainID,\n      from,\n      change,\n      initialStates,\n      name,\n      symbol,\n      denomination,\n      mintOutputs,\n      fee,\n      avaxAssetID,\n      memo,\n      asOf\n    )\n\n    if (!(await this.checkGooseEgg(builtUnsignedTx, fee))) {\n      /* istanbul ignore next */\n      throw new GooseEggCheckError(\n        \"Error - AVMAPI.buildCreateAssetTx:Failed Goose Egg Check\"\n      )\n    }\n\n    return builtUnsignedTx\n  }\n\n  buildSECPMintTx = async (\n    utxoset: UTXOSet,\n    mintOwner: SECPMintOutput,\n    transferOwner: SECPTransferOutput,\n    fromAddresses: string[],\n    changeAddresses: string[],\n    mintUTXOID: string,\n    memo: PayloadBase | Buffer = undefined,\n    asOf: BN = UnixNow()\n  ): Promise<any> => {\n    const caller: string = \"buildSECPMintTx\"\n    const from: Buffer[] = this._cleanAddressArray(fromAddresses, caller).map(\n      (a: string): Buffer => bintools.stringToAddress(a)\n    )\n    const change: Buffer[] = this._cleanAddressArray(\n      changeAddresses,\n      caller\n    ).map((a: string): Buffer => bintools.stringToAddress(a))\n\n    if (memo instanceof PayloadBase) {\n      memo = memo.getPayload()\n    }\n\n    const networkID: number = this.core.getNetworkID()\n    const blockchainID: Buffer = bintools.cb58Decode(this.blockchainID)\n    const avaxAssetID: Buffer = await this.getAVAXAssetID()\n    const fee: BN = this.getMintTxFee()\n    const builtUnsignedTx: UnsignedTx = utxoset.buildSECPMintTx(\n      networkID,\n      blockchainID,\n      mintOwner,\n      transferOwner,\n      from,\n      change,\n      mintUTXOID,\n      fee,\n      avaxAssetID,\n      memo,\n      asOf\n    )\n    if (!(await this.checkGooseEgg(builtUnsignedTx))) {\n      /* istanbul ignore next */\n      throw new GooseEggCheckError(\n        \"Error - AVMAPI.buildSECPMintTx:Failed Goose Egg Check\"\n      )\n    }\n    return builtUnsignedTx\n  }\n\n  /**\n   * Creates an unsigned transaction. For more granular control, you may create your own\n   * [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s, and [[TransferOperation]]s).\n   *\n   * @param utxoset A set of UTXOs that the transaction is built on\n   * @param fromAddresses The addresses being used to send the funds from the UTXOs {@link https://github.com/feross/buffer|Buffer}\n   * @param changeAddresses The addresses that can spend the change remaining from the spent UTXOs\n   * @param minterSets is a list where each element specifies that threshold of the addresses in minters may together mint more of the asset by signing a minting transaction\n   * @param name String for the descriptive name of the asset\n   * @param symbol String for the ticker symbol of the asset\n   * @param memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes\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 mint output\n   *\n   * ```js\n   * Example minterSets:\n   * [\n   *      {\n   *          \"minters\":[\n   *              \"X-avax1ghstjukrtw8935lryqtnh643xe9a94u3tc75c7\"\n   *          ],\n   *          \"threshold\": 1\n   *      },\n   *      {\n   *          \"minters\": [\n   *              \"X-avax1yell3e4nln0m39cfpdhgqprsd87jkh4qnakklx\",\n   *              \"X-avax1k4nr26c80jaquzm9369j5a4shmwcjn0vmemcjz\",\n   *              \"X-avax1ztkzsrjnkn0cek5ryvhqswdtcg23nhge3nnr5e\"\n   *          ],\n   *          \"threshold\": 2\n   *      }\n   * ]\n   * ```\n   *\n   * @returns An unsigned transaction ([[UnsignedTx]]) which contains a [[CreateAssetTx]].\n   *\n   */\n  buildCreateNFTAssetTx = async (\n    utxoset: UTXOSet,\n    fromAddresses: string[],\n    changeAddresses: string[],\n    minterSets: MinterSet[],\n    name: string,\n    symbol: string,\n    memo: PayloadBase | Buffer = undefined,\n    asOf: BN = UnixNow(),\n    locktime: BN = new BN(0)\n  ): Promise<UnsignedTx> => {\n    const caller: string = \"buildCreateNFTAssetTx\"\n    const from: Buffer[] = this._cleanAddressArray(fromAddresses, caller).map(\n      (a: string): Buffer => bintools.stringToAddress(a)\n    )\n    const change: Buffer[] = this._cleanAddressArray(\n      changeAddresses,\n      caller\n    ).map((a: string): Buffer => bintools.stringToAddress(a))\n\n    if (memo instanceof PayloadBase) {\n      memo = memo.getPayload()\n    }\n\n    if (name.length > AVMConstants.ASSETNAMELEN) {\n      /* istanbul ignore next */\n      throw new NameError(\n        \"Error - AVMAPI.buildCreateNFTAssetTx: Names may not exceed length of \" +\n          AVMConstants.ASSETNAMELEN\n      )\n    }\n    if (symbol.length > AVMConstants.SYMBOLMAXLEN) {\n      /* istanbul ignore next */\n      throw new SymbolError(\n        \"Error - AVMAPI.buildCreateNFTAssetTx: Symbols may not exceed length of \" +\n          AVMConstants.SYMBOLMAXLEN\n      )\n    }\n    const networkID: number = this.core.getNetworkID()\n    const blockchainID: Buffer = bintools.cb58Decode(this.blockchainID)\n    const creationTxFee: BN = this.getCreationTxFee()\n    const avaxAssetID: Buffer = await this.getAVAXAssetID()\n    const builtUnsignedTx: UnsignedTx = utxoset.buildCreateNFTAssetTx(\n      networkID,\n      blockchainID,\n      from,\n      change,\n      minterSets,\n      name,\n      symbol,\n      creationTxFee,\n      avaxAssetID,\n      memo,\n      asOf,\n      locktime\n    )\n    if (!(await this.checkGooseEgg(builtUnsignedTx, creationTxFee))) {\n      /* istanbul ignore next */\n      throw new GooseEggCheckError(\n        \"Error - AVMAPI.buildCreateNFTAssetTx:Failed Goose Egg Check\"\n      )\n    }\n    return builtUnsignedTx\n  }\n\n  /**\n   * Creates an unsigned transaction. For more granular control, you may create your own\n   * [[UnsignedTx]] manually (with their corresponding [[TransferableInput]]s, [[TransferableOutput]]s, and [[TransferOperation]]s).\n   *\n   * @param utxoset  A set of UTXOs that the transaction is built on\n   * @param owners Either a single or an array of [[OutputOwners]] to send the nft output\n   * @param fromAddresses The addresses being used to send the NFT from the utxoID provided\n   * @param changeAddresses The addresses that can spend the change remaining from the spent UTXOs\n   * @param utxoid A base58 utxoID or an array of base58 utxoIDs for the nft mint output this transaction is sending\n   * @param groupID Optional. The group this NFT is issued to.\n   * @param payload Optional. Data for NFT Payload as either a [[PayloadBase]] or a {@link https://github.com/feross/buffer|Buffer}\n   * @param memo Optional CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes\n   * @param asOf Optional. The timestamp to verify the transaction against as a {@link https://github.com/indutny/bn.js/|BN}\n   *\n   * @returns An unsigned transaction ([[UnsignedTx]]) which contains an [[OperationTx]].\n   *\n   */\n  buildCreateNFTMintTx = async (\n    utxoset: UTXOSet,\n    owners: OutputOwners[] | OutputOwners,\n    fromAddresses: string[],\n    changeAddresses: string[],\n    utxoid: string | string[],\n    groupID: number = 0,\n    payload: PayloadBase | Buffer = undefined,\n    memo: PayloadBase | Buffer = undefined,\n    asOf: BN = UnixNow()\n  ): Promise<any> => {\n    const caller: string = \"buildCreateNFTMintTx\"\n    const from: Buffer[] = this._cleanAddressArray(fromAddresses, caller).map(\n      (a: string): Buffer => bintools.stringToAddress(a)\n    )\n    const change: Buffer[] = this._cleanAddressArray(\n      changeAddresses,\n      caller\n    ).map((a: string): Buffer => bintools.stringToAddress(a))\n\n    if (memo instanceof PayloadBase) {\n      memo = memo.getPayload()\n    }\n\n    if (payload instanceof PayloadBase) {\n      payload = payload.getPayload()\n    }\n\n    if (typeof utxoid === \"string\") {\n      utxoid = [utxoid]\n    }\n\n    const avaxAssetID: Buffer = await this.getAVAXAssetID()\n\n    if (owners instanceof OutputOwners) {\n      owners = [owners]\n    }\n\n    const networkID: number = this.core.getNetworkID()\n    const blockchainID: Buffer = bintools.cb58Decode(this.blockchainID)\n    const txFee: BN = this.getTxFee()\n    const builtUnsignedTx: UnsignedTx = utxoset.buildCreateNFTMintTx(\n      networkID,\n      blockchainID,\n      owners,\n      from,\n      change,\n      utxoid,\n      groupID,\n      payload,\n      txFee,\n      avaxAssetID,\n      memo,\n      asOf\n    )\n    if (!(await this.checkGooseEgg(builtUnsignedTx))) {\n      /* istanbul ignore next */\n      throw new GooseEggCheckError(\n        \"Error - AVMAPI.buildCreateNFTMintTx:Failed Goose Egg Check\"\n      )\n    }\n    return builtUnsignedTx\n  }\n\n  /**\n   * Helper function which takes an unsigned transaction and signs it, returning the resulting [[Tx]].\n   *\n   * @param utx The unsigned transaction of type [[UnsignedTx]]\n   *\n   * @returns A signed transaction of type [[Tx]]\n   */\n  signTx = (utx: UnsignedTx): Tx => utx.sign(this.keychain)\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 = \"\"\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 - AVMAPI.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      \"avm.issueTx\",\n      params\n    )\n    return response.data.result.txID\n  }\n\n  /**\n   * Calls the node's getAddressTxs method from the API and returns transactions corresponding to the provided address and assetID\n   *\n   * @param address The address for which we're fetching related transactions.\n   * @param cursor Page number or offset.\n   * @param pageSize  Number of items to return per page. Optional. Defaults to 1024. If [pageSize] == 0 or [pageSize] > [maxPageSize], then it fetches at max [maxPageSize] transactions\n   * @param assetID Only return transactions that changed the balance of this asset. Must be an ID or an alias for an asset.\n   *\n   * @returns A promise object representing the array of transaction IDs and page offset\n   */\n  getAddressTxs = async (\n    address: string,\n    cursor: number,\n    pageSize: number | undefined,\n    assetID: string | Buffer\n  ): Promise<GetAddressTxsResponse> => {\n    let asset: string\n    let pageSizeNum: number\n\n    if (typeof assetID !== \"string\") {\n      asset = bintools.cb58Encode(assetID)\n    } else {\n      asset = assetID\n    }\n\n    if (typeof pageSize !== \"number\") {\n      pageSizeNum = 0\n    } else {\n      pageSizeNum = pageSize\n    }\n\n    const params: GetAddressTxsParams = {\n      address,\n      cursor,\n      pageSize: pageSizeNum,\n      assetID: asset\n    }\n\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.getAddressTxs\",\n      params\n    )\n    return response.data.result\n  }\n\n  /**\n   * Sends an amount of assetID to the specified address from a list of owned of addresses.\n   *\n   * @param username The user that owns the private keys associated with the `from` addresses\n   * @param password The password unlocking the user\n   * @param assetID The assetID of the asset to send\n   * @param amount The amount of the asset to be sent\n   * @param to The address of the recipient\n   * @param from Optional. An array of addresses managed by the node's keystore for this blockchain which will fund this transaction\n   * @param changeAddr Optional. An address to send the change\n   * @param memo Optional. CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes\n   *\n   * @returns Promise for the string representing the transaction's ID.\n   */\n  send = async (\n    username: string,\n    password: string,\n    assetID: string | Buffer,\n    amount: number | BN,\n    to: string,\n    from: string[] | Buffer[] = undefined,\n    changeAddr: string = undefined,\n    memo: string | Buffer = undefined\n  ): Promise<SendResponse> => {\n    let asset: string\n    let amnt: BN\n\n    if (typeof this.parseAddress(to) === \"undefined\") {\n      /* istanbul ignore next */\n      throw new AddressError(\"Error - AVMAPI.send: Invalid address format\")\n    }\n\n    if (typeof assetID !== \"string\") {\n      asset = bintools.cb58Encode(assetID)\n    } else {\n      asset = assetID\n    }\n    if (typeof amount === \"number\") {\n      amnt = new BN(amount)\n    } else {\n      amnt = amount\n    }\n\n    const params: SendParams = {\n      username: username,\n      password: password,\n      assetID: asset,\n      amount: amnt.toString(10),\n      to: to\n    }\n\n    const caller: string = \"send\"\n    from = this._cleanAddressArray(from, caller)\n    if (typeof from !== \"undefined\") {\n      params[\"from\"] = from\n    }\n\n    if (typeof changeAddr !== \"undefined\") {\n      if (typeof this.parseAddress(changeAddr) === \"undefined\") {\n        /* istanbul ignore next */\n        throw new AddressError(\"Error - AVMAPI.send: Invalid address format\")\n      }\n      params[\"changeAddr\"] = changeAddr\n    }\n\n    if (typeof memo !== \"undefined\") {\n      if (typeof memo !== \"string\") {\n        params[\"memo\"] = bintools.cb58Encode(memo)\n      } else {\n        params[\"memo\"] = memo\n      }\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.send\",\n      params\n    )\n    return response.data.result\n  }\n\n  /**\n   * Sends an amount of assetID to an array of specified addresses from a list of owned of addresses.\n   *\n   * @param username The user that owns the private keys associated with the `from` addresses\n   * @param password The password unlocking the user\n   * @param sendOutputs The array of SendOutputs. A SendOutput is an object literal which contains an assetID, amount, and to.\n   * @param from Optional. An array of addresses managed by the node's keystore for this blockchain which will fund this transaction\n   * @param changeAddr Optional. An address to send the change\n   * @param memo Optional. CB58 Buffer or String which contains arbitrary bytes, up to 256 bytes\n   *\n   * @returns Promise for the string representing the transaction\"s ID.\n   */\n  sendMultiple = async (\n    username: string,\n    password: string,\n    sendOutputs: {\n      assetID: string | Buffer\n      amount: number | BN\n      to: string\n    }[],\n    from: string[] | Buffer[] = undefined,\n    changeAddr: string = undefined,\n    memo: string | Buffer = undefined\n  ): Promise<SendMultipleResponse> => {\n    let asset: string\n    let amnt: BN\n    const sOutputs: SOutputsParams[] = []\n\n    sendOutputs.forEach(\n      (output: {\n        assetID: string | Buffer\n        amount: number | BN\n        to: string\n      }) => {\n        if (typeof this.parseAddress(output.to) === \"undefined\") {\n          /* istanbul ignore next */\n          throw new AddressError(\n            \"Error - AVMAPI.sendMultiple: Invalid address format\"\n          )\n        }\n        if (typeof output.assetID !== \"string\") {\n          asset = bintools.cb58Encode(output.assetID)\n        } else {\n          asset = output.assetID\n        }\n        if (typeof output.amount === \"number\") {\n          amnt = new BN(output.amount)\n        } else {\n          amnt = output.amount\n        }\n        sOutputs.push({\n          to: output.to,\n          assetID: asset,\n          amount: amnt.toString(10)\n        })\n      }\n    )\n\n    const params: SendMultipleParams = {\n      username: username,\n      password: password,\n      outputs: sOutputs\n    }\n\n    const caller: string = \"send\"\n    from = this._cleanAddressArray(from, caller)\n    if (typeof from !== \"undefined\") {\n      params.from = from\n    }\n\n    if (typeof changeAddr !== \"undefined\") {\n      if (typeof this.parseAddress(changeAddr) === \"undefined\") {\n        /* istanbul ignore next */\n        throw new AddressError(\"Error - AVMAPI.send: Invalid address format\")\n      }\n      params.changeAddr = changeAddr\n    }\n\n    if (typeof memo !== \"undefined\") {\n      if (typeof memo !== \"string\") {\n        params.memo = bintools.cb58Encode(memo)\n      } else {\n        params.memo = memo\n      }\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.sendMultiple\",\n      params\n    )\n    return response.data.result\n  }\n\n  /**\n   * Given a JSON representation of this Virtual Machine’s genesis state, create the byte representation of that state.\n   *\n   * @param genesisData The blockchain's genesis data object\n   *\n   * @returns Promise of a string of bytes\n   */\n  buildGenesis = async (genesisData: object): Promise<string> => {\n    const params: BuildGenesisParams = {\n      genesisData\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"avm.buildGenesis\",\n      params\n    )\n    return response.data.result.bytes\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      for (let i: number = 0; i < addresses.length; i++) {\n        if (typeof addresses[`${i}`] === \"string\") {\n          if (\n            typeof this.parseAddress(addresses[`${i}`] as string) ===\n            \"undefined\"\n          ) {\n            /* istanbul ignore next */\n            throw new AddressError(\n              \"Error - AVMAPI.${caller}: Invalid address format\"\n            )\n          }\n          addrs.push(addresses[`${i}`] as string)\n        } else {\n          const type: SerializedType = \"bech32\"\n          addrs.push(\n            serialization.bufferToType(\n              addresses[`${i}`] 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. Instead use the [[Avalanche.addAP`${I}`]] method.\n   *\n   * @param core A reference to the Avalanche class\n   * @param baseURL Defaults to the string \"/ext/bc/X\" 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/X\",\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"]}

Выполнить команду


Для локальной разработки. Не используйте в интернете!