@kubectl/caminojs
Version:
Camino Platform JS Library
148 lines • 17.8 kB
JavaScript
"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),
createAssetTxFee: new bn_js_1.default(response.data.result.createAssetTxFee, 10),
createSubnetTxFee: new bn_js_1.default(response.data.result.createSubnetTxFee, 10),
createBlockchainTxFee: new bn_js_1.default(response.data.result.createBlockchainTxFee, 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 \"../../camino\"\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      createAssetTxFee: new BN(response.data.result.createAssetTxFee, 10),\n      createSubnetTxFee: new BN(response.data.result.createSubnetTxFee, 10),\n      createBlockchainTxFee: new BN(\n        response.data.result.createBlockchainTxFee,\n        10\n      )\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"]}