UNPKG

@kubectl/caminojs

Version:
256 lines 31.2 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; 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.utils = exports.platformvm = exports.metrics = exports.keystore = exports.info = exports.index = exports.health = exports.evm = exports.common = exports.avm = exports.auth = exports.admin = exports.Socket = exports.PubSub = exports.Mnemonic = exports.GenesisData = exports.GenesisAsset = exports.HDNode = exports.DB = exports.Buffer = exports.BN = exports.BinTools = exports.AvalancheCore = exports.Avalanche = void 0; /** * @packageDocumentation * @module Avalanche */ const camino_1 = __importDefault(require("./camino")); exports.AvalancheCore = camino_1.default; const api_1 = require("./apis/admin/api"); const api_2 = require("./apis/auth/api"); const api_3 = require("./apis/avm/api"); const api_4 = require("./apis/evm/api"); const genesisasset_1 = require("./apis/avm/genesisasset"); Object.defineProperty(exports, "GenesisAsset", { enumerable: true, get: function () { return genesisasset_1.GenesisAsset; } }); const genesisdata_1 = require("./apis/avm/genesisdata"); Object.defineProperty(exports, "GenesisData", { enumerable: true, get: function () { return genesisdata_1.GenesisData; } }); const api_5 = require("./apis/health/api"); const api_6 = require("./apis/index/api"); const api_7 = require("./apis/info/api"); const api_8 = require("./apis/keystore/api"); const api_9 = require("./apis/metrics/api"); const api_10 = require("./apis/platformvm/api"); const socket_1 = require("./apis/socket/socket"); Object.defineProperty(exports, "Socket", { enumerable: true, get: function () { return socket_1.Socket; } }); const bintools_1 = __importDefault(require("./utils/bintools")); exports.BinTools = bintools_1.default; const db_1 = __importDefault(require("./utils/db")); exports.DB = db_1.default; const mnemonic_1 = __importDefault(require("./utils/mnemonic")); exports.Mnemonic = mnemonic_1.default; const pubsub_1 = __importDefault(require("./utils/pubsub")); exports.PubSub = pubsub_1.default; const hdnode_1 = __importDefault(require("./utils/hdnode")); exports.HDNode = hdnode_1.default; const bn_js_1 = __importDefault(require("bn.js")); exports.BN = bn_js_1.default; const buffer_1 = require("buffer/"); Object.defineProperty(exports, "Buffer", { enumerable: true, get: function () { return buffer_1.Buffer; } }); const networks_1 = __importDefault(require("./utils/networks")); const constants_1 = require("./utils/constants"); const utils_1 = require("./utils"); /** * CaminoJS is middleware for interacting with Camino node RPC APIs. * * Example usage: * ```js * const avalanche: Avalanche = new Avalanche("127.0.0.1", 9650, "https") * ``` * */ class Avalanche extends camino_1.default { /** * Creates a new Avalanche instance. Sets the address and port of the main Avalanche Client. * * @param host The hostname to resolve to reach the Avalanche Client RPC APIs * @param port The port to resolve to reach the Avalanche Client RPC APIs * @param protocol The protocol string to use before a "://" in a request, * ex: "http", "https", "git", "ws", etc. Defaults to http * @param networkID Sets the NetworkID of the class. Default [[DefaultNetworkID]] * @param XChainID Sets the blockchainID for the AVM. Will try to auto-detect, * otherwise default "2eNy1mUFdmaxXNj1eQHUe7Np4gju9sJsEtWQ4MX3ToiNKuADed" * @param CChainID Sets the blockchainID for the EVM. Will try to auto-detect, * otherwise default "2CA6j5zYzasynPsFeNoqWkmTCt3VScMvXUZHbfDJ8k3oGzAPtU" * @param hrp The human-readable part of the bech32 addresses * @param skipinit Skips creating the APIs. Defaults to false */ constructor(host, port, protocol, networkID = undefined, XChainID = undefined, CChainID = undefined, skipinit = false) { super(host, port, protocol, networkID); /** * Returns a reference to the Admin RPC. */ this.Admin = () => this.apis.admin; /** * Returns a reference to the Auth RPC. */ this.Auth = () => this.apis.auth; /** * Returns a reference to the EVMAPI RPC pointed at the C-Chain. */ this.CChain = () => this.apis.cchain; /** * Returns a reference to the AVM RPC pointed at the X-Chain. */ this.XChain = () => this.apis.xchain; /** * Returns a reference to the Health RPC for a node. */ this.Health = () => this.apis.health; /** * Returns a reference to the Index RPC for a node. */ this.Index = () => this.apis.index; /** * Returns a reference to the Info RPC for a node. */ this.Info = () => this.apis.info; /** * Returns a reference to the Metrics RPC. */ this.Metrics = () => this.apis.metrics; /** * Returns a reference to the Keystore RPC for a node. We label it "NodeKeys" to reduce * confusion about what it's accessing. */ this.NodeKeys = () => this.apis.keystore; /** * Returns a reference to the PlatformVM RPC pointed at the P-Chain. */ this.PChain = () => this.apis.pchain; this.fetchNetworkSettings = () => __awaiter(this, void 0, void 0, function* () { // Nothing to do if network is known if (this.network) return true; // We need this be able to make next call this.addAPI("pchain", api_10.PlatformVMAPI); //Get platform configuration let response; try { response = yield this.PChain().getConfiguration(); this.networkID = response.networkID; } catch (error) { this.networkID = yield this.Info().getNetworkID(); } if ((this.network = networks_1.default.getNetwork(this.networkID))) return this.refreshAPI(); if (!response) { throw new Error("Configuration required"); } const xchain = response.blockchains.find((b) => b["name"] === "X-Chain"); const cchain = response.blockchains.find((b) => b["name"] === "C-Chain"); const fees = yield this.Info().getTxFee(); this.network = { hrp: response.hrp, X: { alias: constants_1.XChainAlias, avaxAssetID: response.assetID, avaxAssetAlias: response.assetSymbol, blockchainID: xchain["id"], vm: constants_1.XChainVMName, creationTxFee: fees.creationTxFee, txFee: fees.txFee }, P: { alias: constants_1.PChainAlias, blockchainID: utils_1.DefaultPlatformChainID, creationTxFee: fees.creationTxFee, createSubnetTx: fees.createSubnetTxFee, createChainTx: fees.createBlockchainTxFee, maxConsumption: response.maxConsumptionRate, maxStakeDuration: response.maxStakeDuration, maxStakingDuration: new bn_js_1.default(response.maxStakeDuration), maxSupply: response.supplyCap, minConsumption: response.minConsumptionRate, minDelegationFee: response.minDelegationFee, minDelegationStake: response.minDelegatorStake, minStake: response.minValidatorStake, minStakeDuration: response.minStakeDuration, vm: constants_1.PChainVMName, txFee: fees.txFee }, C: { alias: constants_1.CChainAlias, blockchainID: cchain["id"], chainID: 43112, costPerSignature: 1000, gasPrice: constants_1.GWEI.mul(new bn_js_1.default(225)), maxGasPrice: constants_1.GWEI.mul(new bn_js_1.default(1000)), minGasPrice: constants_1.GWEI.mul(new bn_js_1.default(25)), txBytesGas: 1, txFee: constants_1.MILLIAVAX, vm: constants_1.CChainVMName } }; networks_1.default.registerNetwork(this.networkID, this.network); return this.refreshAPI(); }); this.refreshAPI = () => { // Re-apply pchain which creates the correct keychain this.addAPI("pchain", api_10.PlatformVMAPI); // Finally register x and c chains this.addAPI("xchain", api_3.AVMAPI, "/ext/bc/X", this.network.X.blockchainID); this.addAPI("cchain", api_4.EVMAPI, "/ext/bc/C/avax", this.network.C.blockchainID); return true; }; if (!skipinit) { this.addAPI("admin", api_1.AdminAPI); this.addAPI("auth", api_2.AuthAPI); this.addAPI("health", api_5.HealthAPI); this.addAPI("info", api_7.InfoAPI); this.addAPI("index", api_6.IndexAPI); this.addAPI("keystore", api_8.KeystoreAPI); this.addAPI("metrics", api_9.MetricsAPI); } // Static initializing if (networkID && (this.network = networks_1.default.getNetwork(networkID))) { this.networkID = networkID; if (!skipinit) { this.addAPI("pchain", api_10.PlatformVMAPI); this.addAPI("xchain", api_3.AVMAPI, "/ext/bc/X", XChainID ? XChainID : this.network.X.blockchainID); this.addAPI("cchain", api_4.EVMAPI, "/ext/bc/C/avax", CChainID ? CChainID : this.network.C.blockchainID); } } } } exports.default = Avalanche; exports.Avalanche = Avalanche; exports.admin = __importStar(require("./apis/admin")); exports.auth = __importStar(require("./apis/auth")); exports.avm = __importStar(require("./apis/avm")); exports.common = __importStar(require("./common")); exports.evm = __importStar(require("./apis/evm")); exports.health = __importStar(require("./apis/health")); exports.index = __importStar(require("./apis/index")); exports.info = __importStar(require("./apis/info")); exports.keystore = __importStar(require("./apis/keystore")); exports.metrics = __importStar(require("./apis/metrics")); exports.platformvm = __importStar(require("./apis/platformvm")); exports.utils = __importStar(require("./utils")); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @packageDocumentation\n * @module Avalanche\n */\nimport AvalancheCore from \"./camino\"\nimport { AdminAPI } from \"./apis/admin/api\"\nimport { AuthAPI } from \"./apis/auth/api\"\nimport { AVMAPI } from \"./apis/avm/api\"\nimport { EVMAPI } from \"./apis/evm/api\"\nimport { GenesisAsset } from \"./apis/avm/genesisasset\"\nimport { GenesisData } from \"./apis/avm/genesisdata\"\nimport { HealthAPI } from \"./apis/health/api\"\nimport { IndexAPI } from \"./apis/index/api\"\nimport { InfoAPI } from \"./apis/info/api\"\nimport { KeystoreAPI } from \"./apis/keystore/api\"\nimport { MetricsAPI } from \"./apis/metrics/api\"\nimport { PlatformVMAPI } from \"./apis/platformvm/api\"\nimport { Socket } from \"./apis/socket/socket\"\nimport BinTools from \"./utils/bintools\"\nimport DB from \"./utils/db\"\nimport Mnemonic from \"./utils/mnemonic\"\nimport PubSub from \"./utils/pubsub\"\nimport HDNode from \"./utils/hdnode\"\nimport BN from \"bn.js\"\nimport { Buffer } from \"buffer/\"\nimport networks from \"./utils/networks\"\nimport {\n  CChainAlias,\n  CChainVMName,\n  GWEI,\n  MILLIAVAX,\n  PChainAlias,\n  PChainVMName,\n  XChainAlias,\n  XChainVMName\n} from \"./utils/constants\"\nimport { DefaultPlatformChainID } from \"./utils\"\nimport { GetConfigurationResponse } from \"./apis/platformvm/interfaces\"\n\n/**\n * CaminoJS is middleware for interacting with Camino node RPC APIs.\n *\n * Example usage:\n * ```js\n * const avalanche: Avalanche = new Avalanche(\"127.0.0.1\", 9650, \"https\")\n * ```\n *\n */\nexport default class Avalanche extends AvalancheCore {\n  /**\n   * Returns a reference to the Admin RPC.\n   */\n  Admin = () => this.apis.admin as AdminAPI\n\n  /**\n   * Returns a reference to the Auth RPC.\n   */\n  Auth = () => this.apis.auth as AuthAPI\n\n  /**\n   * Returns a reference to the EVMAPI RPC pointed at the C-Chain.\n   */\n  CChain = () => this.apis.cchain as EVMAPI\n\n  /**\n   * Returns a reference to the AVM RPC pointed at the X-Chain.\n   */\n  XChain = () => this.apis.xchain as AVMAPI\n\n  /**\n   * Returns a reference to the Health RPC for a node.\n   */\n  Health = () => this.apis.health as HealthAPI\n\n  /**\n   * Returns a reference to the Index RPC for a node.\n   */\n  Index = () => this.apis.index as IndexAPI\n\n  /**\n   * Returns a reference to the Info RPC for a node.\n   */\n  Info = () => this.apis.info as InfoAPI\n\n  /**\n   * Returns a reference to the Metrics RPC.\n   */\n  Metrics = () => this.apis.metrics as MetricsAPI\n\n  /**\n   * Returns a reference to the Keystore RPC for a node. We label it \"NodeKeys\" to reduce\n   * confusion about what it's accessing.\n   */\n  NodeKeys = () => this.apis.keystore as KeystoreAPI\n\n  /**\n   * Returns a reference to the PlatformVM RPC pointed at the P-Chain.\n   */\n  PChain = () => this.apis.pchain as PlatformVMAPI\n\n  /**\n   * Creates a new Avalanche instance. Sets the address and port of the main Avalanche Client.\n   *\n   * @param host The hostname to resolve to reach the Avalanche Client RPC APIs\n   * @param port The port to resolve to reach the Avalanche Client RPC APIs\n   * @param protocol The protocol string to use before a \"://\" in a request,\n   * ex: \"http\", \"https\", \"git\", \"ws\", etc. Defaults to http\n   * @param networkID Sets the NetworkID of the class. Default [[DefaultNetworkID]]\n   * @param XChainID Sets the blockchainID for the AVM. Will try to auto-detect,\n   * otherwise default \"2eNy1mUFdmaxXNj1eQHUe7Np4gju9sJsEtWQ4MX3ToiNKuADed\"\n   * @param CChainID Sets the blockchainID for the EVM. Will try to auto-detect,\n   * otherwise default \"2CA6j5zYzasynPsFeNoqWkmTCt3VScMvXUZHbfDJ8k3oGzAPtU\"\n   * @param hrp The human-readable part of the bech32 addresses\n   * @param skipinit Skips creating the APIs. Defaults to false\n   */\n  constructor(\n    host: string,\n    port: number,\n    protocol: string,\n    networkID: number = undefined,\n    XChainID: string = undefined,\n    CChainID: string = undefined,\n    skipinit: boolean = false\n  ) {\n    super(host, port, protocol, networkID)\n    if (!skipinit) {\n      this.addAPI(\"admin\", AdminAPI)\n      this.addAPI(\"auth\", AuthAPI)\n      this.addAPI(\"health\", HealthAPI)\n      this.addAPI(\"info\", InfoAPI)\n      this.addAPI(\"index\", IndexAPI)\n      this.addAPI(\"keystore\", KeystoreAPI)\n      this.addAPI(\"metrics\", MetricsAPI)\n    }\n\n    // Static initializing\n    if (networkID && (this.network = networks.getNetwork(networkID))) {\n      this.networkID = networkID\n      if (!skipinit) {\n        this.addAPI(\"pchain\", PlatformVMAPI)\n        this.addAPI(\n          \"xchain\",\n          AVMAPI,\n          \"/ext/bc/X\",\n          XChainID ? XChainID : this.network.X.blockchainID\n        )\n        this.addAPI(\n          \"cchain\",\n          EVMAPI,\n          \"/ext/bc/C/avax\",\n          CChainID ? CChainID : this.network.C.blockchainID\n        )\n      }\n    }\n  }\n\n  fetchNetworkSettings = async (): Promise<boolean> => {\n    // Nothing to do if network is known\n    if (this.network) return true\n    // We need this be able to make next call\n    this.addAPI(\"pchain\", PlatformVMAPI)\n    //Get platform configuration\n    let response: GetConfigurationResponse\n\n    try {\n      response = await this.PChain().getConfiguration()\n      this.networkID = response.networkID\n    } catch (error) {\n      this.networkID = await this.Info().getNetworkID()\n    }\n\n    if ((this.network = networks.getNetwork(this.networkID)))\n      return this.refreshAPI()\n\n    if (!response) {\n      throw new Error(\"Configuration required\")\n    }\n\n    const xchain = response.blockchains.find((b) => b[\"name\"] === \"X-Chain\")\n    const cchain = response.blockchains.find((b) => b[\"name\"] === \"C-Chain\")\n\n    const fees = await this.Info().getTxFee()\n\n    this.network = {\n      hrp: response.hrp,\n      X: {\n        alias: XChainAlias,\n        avaxAssetID: response.assetID,\n        avaxAssetAlias: response.assetSymbol,\n        blockchainID: xchain[\"id\"],\n        vm: XChainVMName,\n        creationTxFee: fees.creationTxFee,\n        txFee: fees.txFee\n      },\n      P: {\n        alias: PChainAlias,\n        blockchainID: DefaultPlatformChainID,\n        creationTxFee: fees.creationTxFee,\n        createSubnetTx: fees.createSubnetTxFee,\n        createChainTx: fees.createBlockchainTxFee,\n        maxConsumption: response.maxConsumptionRate,\n        maxStakeDuration: response.maxStakeDuration,\n        maxStakingDuration: new BN(response.maxStakeDuration),\n        maxSupply: response.supplyCap,\n        minConsumption: response.minConsumptionRate,\n        minDelegationFee: response.minDelegationFee,\n        minDelegationStake: response.minDelegatorStake,\n        minStake: response.minValidatorStake,\n        minStakeDuration: response.minStakeDuration,\n        vm: PChainVMName,\n        txFee: fees.txFee\n      },\n      C: {\n        alias: CChainAlias,\n        blockchainID: cchain[\"id\"],\n        chainID: 43112,\n        costPerSignature: 1000,\n        gasPrice: GWEI.mul(new BN(225)),\n        maxGasPrice: GWEI.mul(new BN(1000)),\n        minGasPrice: GWEI.mul(new BN(25)),\n        txBytesGas: 1,\n        txFee: MILLIAVAX,\n        vm: CChainVMName\n      }\n    }\n\n    networks.registerNetwork(this.networkID, this.network)\n\n    return this.refreshAPI()\n  }\n\n  protected refreshAPI = (): boolean => {\n    // Re-apply pchain which creates the correct keychain\n    this.addAPI(\"pchain\", PlatformVMAPI)\n\n    // Finally register x and c chains\n    this.addAPI(\"xchain\", AVMAPI, \"/ext/bc/X\", this.network.X.blockchainID)\n    this.addAPI(\"cchain\", EVMAPI, \"/ext/bc/C/avax\", this.network.C.blockchainID)\n\n    return true\n  }\n}\n\nexport { Avalanche }\nexport { AvalancheCore }\nexport { BinTools }\nexport { BN }\nexport { Buffer }\nexport { DB }\nexport { HDNode }\nexport { GenesisAsset }\nexport { GenesisData }\nexport { Mnemonic }\nexport { PubSub }\nexport { Socket }\n\nexport * as admin from \"./apis/admin\"\nexport * as auth from \"./apis/auth\"\nexport * as avm from \"./apis/avm\"\nexport * as common from \"./common\"\nexport * as evm from \"./apis/evm\"\nexport * as health from \"./apis/health\"\nexport * as index from \"./apis/index\"\nexport * as info from \"./apis/info\"\nexport * as keystore from \"./apis/keystore\"\nexport * as metrics from \"./apis/metrics\"\nexport * as platformvm from \"./apis/platformvm\"\nexport * as utils from \"./utils\"\n"]}