PHP WebShell

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

Просмотр файла: 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.InfoAPI = void 0;
const jrpcapi_1 = require("../../common/jrpcapi");
const bn_js_1 = __importDefault(require("bn.js"));
/**
 * Class for interacting with a node's InfoAPI.
 *
 * @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 InfoAPI extends jrpcapi_1.JRPCAPI {
    /**
     * This class should not be instantiated directly. Instead use the [[Avalanche.addAPI]] method.
     *
     * @param core A reference to the Avalanche class
     * @param baseURL Defaults to the string "/ext/info" as the path to rpc's baseURL
     */
    constructor(core, baseURL = "/ext/info") {
        super(core, baseURL);
        /**
         * Fetches the blockchainID from the node for a given alias.
         *
         * @param alias The blockchain alias to get the blockchainID
         *
         * @returns Returns a Promise string containing the base 58 string representation of the blockchainID.
         */
        this.getBlockchainID = (alias) => __awaiter(this, void 0, void 0, function* () {
            const params = {
                alias
            };
            const response = yield this.callMethod("info.getBlockchainID", params);
            return response.data.result.blockchainID;
        });
        /**
         * Fetches the IP address from the node.
         *
         * @returns Returns a Promise string of the node IP address.
         */
        this.getNodeIP = () => __awaiter(this, void 0, void 0, function* () {
            const response = yield this.callMethod("info.getBlockchainID");
            return response.data.result.ip;
        });
        /**
         * Fetches the networkID from the node.
         *
         * @returns Returns a Promise number of the networkID.
         */
        this.getNetworkID = () => __awaiter(this, void 0, void 0, function* () {
            const response = yield this.callMethod("info.getNetworkID");
            return response.data.result.networkID;
        });
        /**
         * Fetches the network name this node is running on
         *
         * @returns Returns a Promise string containing the network name.
         */
        this.getNetworkName = () => __awaiter(this, void 0, void 0, function* () {
            const response = yield this.callMethod("info.getNetworkName");
            return response.data.result.networkName;
        });
        /**
         * Fetches the nodeID from the node.
         *
         * @returns Returns a Promise string of the nodeID.
         */
        this.getNodeID = () => __awaiter(this, void 0, void 0, function* () {
            const response = yield this.callMethod("info.getNodeID");
            return response.data.result.nodeID;
        });
        /**
         * Fetches the version of Gecko this node is running
         *
         * @returns Returns a Promise string containing the version of Gecko.
         */
        this.getNodeVersion = () => __awaiter(this, void 0, void 0, function* () {
            const response = yield this.callMethod("info.getNodeVersion");
            return response.data.result.version;
        });
        /**
         * Fetches the transaction fee from the node.
         *
         * @returns Returns a Promise object of the transaction fee in nAVAX.
         */
        this.getTxFee = () => __awaiter(this, void 0, void 0, function* () {
            const response = yield this.callMethod("info.getTxFee");
            return {
                txFee: new bn_js_1.default(response.data.result.txFee, 10),
                creationTxFee: new bn_js_1.default(response.data.result.creationTxFee, 10)
            };
        });
        /**
         * Check whether a given chain is done bootstrapping
         * @param chain The ID or alias of a chain.
         *
         * @returns Returns a Promise boolean of whether the chain has completed bootstrapping.
         */
        this.isBootstrapped = (chain) => __awaiter(this, void 0, void 0, function* () {
            const params = {
                chain
            };
            const response = yield this.callMethod("info.isBootstrapped", params);
            return response.data.result.isBootstrapped;
        });
        /**
         * Returns the peers connected to the node.
         * @param nodeIDs an optional parameter to specify what nodeID's descriptions should be returned.
         * If this parameter is left empty, descriptions for all active connections will be returned.
         * If the node is not connected to a specified nodeID, it will be omitted from the response.
         *
         * @returns Promise for the list of connected peers in PeersResponse format.
         */
        this.peers = (nodeIDs = []) => __awaiter(this, void 0, void 0, function* () {
            const params = {
                nodeIDs
            };
            const response = yield this.callMethod("info.peers", params);
            return response.data.result.peers;
        });
        /**
         * Returns the network's observed uptime of this node.
         *
         * @returns Returns a Promise UptimeResponse which contains rewardingStakePercentage and weightedAveragePercentage.
         */
        this.uptime = () => __awaiter(this, void 0, void 0, function* () {
            const response = yield this.callMethod("info.uptime");
            return response.data.result;
        });
    }
}
exports.InfoAPI = InfoAPI;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["../../../../src/apis/info/api.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @packageDocumentation\n * @module API-Info\n */\nimport AvalancheCore from \"../../avalanche\"\nimport { JRPCAPI } from \"../../common/jrpcapi\"\nimport { RequestResponseData } from \"../../common/apibase\"\nimport BN from \"bn.js\"\nimport {\n  GetBlockchainIDParams,\n  GetTxFeeResponse,\n  IsBootstrappedParams,\n  PeersParams,\n  PeersResponse,\n  UptimeResponse\n} from \"./interfaces\"\n\n/**\n * Class for interacting with a node's InfoAPI.\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 InfoAPI extends JRPCAPI {\n  /**\n   * Fetches the blockchainID from the node for a given alias.\n   *\n   * @param alias The blockchain alias to get the blockchainID\n   *\n   * @returns Returns a Promise string containing the base 58 string representation of the blockchainID.\n   */\n  getBlockchainID = async (alias: string): Promise<string> => {\n    const params: GetBlockchainIDParams = {\n      alias\n    }\n\n    const response: RequestResponseData = await this.callMethod(\n      \"info.getBlockchainID\",\n      params\n    )\n    return response.data.result.blockchainID\n  }\n\n  /**\n   * Fetches the IP address from the node.\n   *\n   * @returns Returns a Promise string of the node IP address.\n   */\n  getNodeIP = async (): Promise<string> => {\n    const response: RequestResponseData = await this.callMethod(\n      \"info.getBlockchainID\"\n    )\n    return response.data.result.ip\n  }\n\n  /**\n   * Fetches the networkID from the node.\n   *\n   * @returns Returns a Promise number of the networkID.\n   */\n  getNetworkID = async (): Promise<number> => {\n    const response: RequestResponseData = await this.callMethod(\n      \"info.getNetworkID\"\n    )\n    return response.data.result.networkID\n  }\n\n  /**\n   * Fetches the network name this node is running on\n   *\n   * @returns Returns a Promise string containing the network name.\n   */\n  getNetworkName = async (): Promise<string> => {\n    const response: RequestResponseData = await this.callMethod(\n      \"info.getNetworkName\"\n    )\n    return response.data.result.networkName\n  }\n\n  /**\n   * Fetches the nodeID from the node.\n   *\n   * @returns Returns a Promise string of the nodeID.\n   */\n  getNodeID = async (): Promise<string> => {\n    const response: RequestResponseData = await this.callMethod(\n      \"info.getNodeID\"\n    )\n    return response.data.result.nodeID\n  }\n\n  /**\n   * Fetches the version of Gecko this node is running\n   *\n   * @returns Returns a Promise string containing the version of Gecko.\n   */\n  getNodeVersion = async (): Promise<string> => {\n    const response: RequestResponseData = await this.callMethod(\n      \"info.getNodeVersion\"\n    )\n    return response.data.result.version\n  }\n\n  /**\n   * Fetches the transaction fee from the node.\n   *\n   * @returns Returns a Promise object of the transaction fee in nAVAX.\n   */\n  getTxFee = async (): Promise<GetTxFeeResponse> => {\n    const response: RequestResponseData = await this.callMethod(\"info.getTxFee\")\n    return {\n      txFee: new BN(response.data.result.txFee, 10),\n      creationTxFee: new BN(response.data.result.creationTxFee, 10)\n    }\n  }\n\n  /**\n   * Check whether a given chain is done bootstrapping\n   * @param chain The ID or alias of a chain.\n   *\n   * @returns Returns a Promise boolean of whether the chain has completed bootstrapping.\n   */\n  isBootstrapped = async (chain: string): Promise<boolean> => {\n    const params: IsBootstrappedParams = {\n      chain\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"info.isBootstrapped\",\n      params\n    )\n    return response.data.result.isBootstrapped\n  }\n\n  /**\n   * Returns the peers connected to the node.\n   * @param nodeIDs an optional parameter to specify what nodeID's descriptions should be returned.\n   * If this parameter is left empty, descriptions for all active connections will be returned.\n   * If the node is not connected to a specified nodeID, it will be omitted from the response.\n   *\n   * @returns Promise for the list of connected peers in PeersResponse format.\n   */\n  peers = async (nodeIDs: string[] = []): Promise<PeersResponse[]> => {\n    const params: PeersParams = {\n      nodeIDs\n    }\n    const response: RequestResponseData = await this.callMethod(\n      \"info.peers\",\n      params\n    )\n    return response.data.result.peers\n  }\n\n  /**\n   * Returns the network's observed uptime of this node.\n   *\n   * @returns Returns a Promise UptimeResponse which contains rewardingStakePercentage and weightedAveragePercentage.\n   */\n  uptime = async (): Promise<UptimeResponse> => {\n    const response: RequestResponseData = await this.callMethod(\"info.uptime\")\n    return response.data.result\n  }\n\n  /**\n   * This class should not be instantiated directly. Instead use the [[Avalanche.addAPI]] method.\n   *\n   * @param core A reference to the Avalanche class\n   * @param baseURL Defaults to the string \"/ext/info\" as the path to rpc's baseURL\n   */\n  constructor(core: AvalancheCore, baseURL: string = \"/ext/info\") {\n    super(core, baseURL)\n  }\n}\n"]}

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


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