@kubectl/caminojs
Version:
Camino Platform JS Library
256 lines • 31.2 kB
JavaScript
"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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;GAGG;AACH,sDAAoC;AAgP3B,wBAhPF,gBAAa,CAgPE;AA/OtB,0CAA2C;AAC3C,yCAAyC;AACzC,wCAAuC;AACvC,wCAAuC;AACvC,0DAAsD;AAiP7C,6FAjPA,2BAAY,OAiPA;AAhPrB,wDAAoD;AAiP3C,4FAjPA,yBAAW,OAiPA;AAhPpB,2CAA6C;AAC7C,0CAA2C;AAC3C,yCAAyC;AACzC,6CAAiD;AACjD,4CAA+C;AAC/C,gDAAqD;AACrD,iDAA6C;AA6OpC,uFA7OA,eAAM,OA6OA;AA5Of,gEAAuC;AAmO9B,mBAnOF,kBAAQ,CAmOE;AAlOjB,oDAA2B;AAqOlB,aArOF,YAAE,CAqOE;AApOX,gEAAuC;AAwO9B,mBAxOF,kBAAQ,CAwOE;AAvOjB,4DAAmC;AAwO1B,iBAxOF,gBAAM,CAwOE;AAvOf,4DAAmC;AAmO1B,iBAnOF,gBAAM,CAmOE;AAlOf,kDAAsB;AA+Nb,aA/NF,eAAE,CA+NE;AA9NX,oCAAgC;AA+NvB,uFA/NA,eAAM,OA+NA;AA9Nf,gEAAuC;AACvC,iDAS0B;AAC1B,mCAAgD;AAGhD;;;;;;;;GAQG;AACH,MAAqB,SAAU,SAAQ,gBAAa;IAoDlD;;;;;;;;;;;;;;OAcG;IACH,YACE,IAAY,EACZ,IAAY,EACZ,QAAgB,EAChB,YAAoB,SAAS,EAC7B,WAAmB,SAAS,EAC5B,WAAmB,SAAS,EAC5B,WAAoB,KAAK;QAEzB,KAAK,CAAC,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAA;QA3ExC;;WAEG;QACH,UAAK,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,KAAiB,CAAA;QAEzC;;WAEG;QACH,SAAI,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAe,CAAA;QAEtC;;WAEG;QACH,WAAM,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,MAAgB,CAAA;QAEzC;;WAEG;QACH,WAAM,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,MAAgB,CAAA;QAEzC;;WAEG;QACH,WAAM,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,MAAmB,CAAA;QAE5C;;WAEG;QACH,UAAK,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,KAAiB,CAAA;QAEzC;;WAEG;QACH,SAAI,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAe,CAAA;QAEtC;;WAEG;QACH,YAAO,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,OAAqB,CAAA;QAE/C;;;WAGG;QACH,aAAQ,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,QAAuB,CAAA;QAElD;;WAEG;QACH,WAAM,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,MAAuB,CAAA;QA0DhD,yBAAoB,GAAG,GAA2B,EAAE;YAClD,oCAAoC;YACpC,IAAI,IAAI,CAAC,OAAO;gBAAE,OAAO,IAAI,CAAA;YAC7B,yCAAyC;YACzC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,oBAAa,CAAC,CAAA;YACpC,4BAA4B;YAC5B,IAAI,QAAkC,CAAA;YAEtC,IAAI;gBACF,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC,gBAAgB,EAAE,CAAA;gBACjD,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC,SAAS,CAAA;aACpC;YAAC,OAAO,KAAK,EAAE;gBACd,IAAI,CAAC,SAAS,GAAG,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC,YAAY,EAAE,CAAA;aAClD;YAED,IAAI,CAAC,IAAI,CAAC,OAAO,GAAG,kBAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;gBACtD,OAAO,IAAI,CAAC,UAAU,EAAE,CAAA;YAE1B,IAAI,CAAC,QAAQ,EAAE;gBACb,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAA;aAC1C;YAED,MAAM,MAAM,GAAG,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,SAAS,CAAC,CAAA;YACxE,MAAM,MAAM,GAAG,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,SAAS,CAAC,CAAA;YAExE,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC,QAAQ,EAAE,CAAA;YAEzC,IAAI,CAAC,OAAO,GAAG;gBACb,GAAG,EAAE,QAAQ,CAAC,GAAG;gBACjB,CAAC,EAAE;oBACD,KAAK,EAAE,uBAAW;oBAClB,WAAW,EAAE,QAAQ,CAAC,OAAO;oBAC7B,cAAc,EAAE,QAAQ,CAAC,WAAW;oBACpC,YAAY,EAAE,MAAM,CAAC,IAAI,CAAC;oBAC1B,EAAE,EAAE,wBAAY;oBAChB,aAAa,EAAE,IAAI,CAAC,aAAa;oBACjC,KAAK,EAAE,IAAI,CAAC,KAAK;iBAClB;gBACD,CAAC,EAAE;oBACD,KAAK,EAAE,uBAAW;oBAClB,YAAY,EAAE,8BAAsB;oBACpC,aAAa,EAAE,IAAI,CAAC,aAAa;oBACjC,cAAc,EAAE,IAAI,CAAC,iBAAiB;oBACtC,aAAa,EAAE,IAAI,CAAC,qBAAqB;oBACzC,cAAc,EAAE,QAAQ,CAAC,kBAAkB;oBAC3C,gBAAgB,EAAE,QAAQ,CAAC,gBAAgB;oBAC3C,kBAAkB,EAAE,IAAI,eAAE,CAAC,QAAQ,CAAC,gBAAgB,CAAC;oBACrD,SAAS,EAAE,QAAQ,CAAC,SAAS;oBAC7B,cAAc,EAAE,QAAQ,CAAC,kBAAkB;oBAC3C,gBAAgB,EAAE,QAAQ,CAAC,gBAAgB;oBAC3C,kBAAkB,EAAE,QAAQ,CAAC,iBAAiB;oBAC9C,QAAQ,EAAE,QAAQ,CAAC,iBAAiB;oBACpC,gBAAgB,EAAE,QAAQ,CAAC,gBAAgB;oBAC3C,EAAE,EAAE,wBAAY;oBAChB,KAAK,EAAE,IAAI,CAAC,KAAK;iBAClB;gBACD,CAAC,EAAE;oBACD,KAAK,EAAE,uBAAW;oBAClB,YAAY,EAAE,MAAM,CAAC,IAAI,CAAC;oBAC1B,OAAO,EAAE,KAAK;oBACd,gBAAgB,EAAE,IAAI;oBACtB,QAAQ,EAAE,gBAAI,CAAC,GAAG,CAAC,IAAI,eAAE,CAAC,GAAG,CAAC,CAAC;oBAC/B,WAAW,EAAE,gBAAI,CAAC,GAAG,CAAC,IAAI,eAAE,CAAC,IAAI,CAAC,CAAC;oBACnC,WAAW,EAAE,gBAAI,CAAC,GAAG,CAAC,IAAI,eAAE,CAAC,EAAE,CAAC,CAAC;oBACjC,UAAU,EAAE,CAAC;oBACb,KAAK,EAAE,qBAAS;oBAChB,EAAE,EAAE,wBAAY;iBACjB;aACF,CAAA;YAED,kBAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;YAEtD,OAAO,IAAI,CAAC,UAAU,EAAE,CAAA;QAC1B,CAAC,CAAA,CAAA;QAES,eAAU,GAAG,GAAY,EAAE;YACnC,qDAAqD;YACrD,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,oBAAa,CAAC,CAAA;YAEpC,kCAAkC;YAClC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,YAAM,EAAE,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,CAAA;YACvE,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,YAAM,EAAE,gBAAgB,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,CAAA;YAE5E,OAAO,IAAI,CAAA;QACb,CAAC,CAAA;QAnHC,IAAI,CAAC,QAAQ,EAAE;YACb,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,cAAQ,CAAC,CAAA;YAC9B,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,aAAO,CAAC,CAAA;YAC5B,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,eAAS,CAAC,CAAA;YAChC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,aAAO,CAAC,CAAA;YAC5B,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,cAAQ,CAAC,CAAA;YAC9B,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,iBAAW,CAAC,CAAA;YACpC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,gBAAU,CAAC,CAAA;SACnC;QAED,sBAAsB;QACtB,IAAI,SAAS,IAAI,CAAC,IAAI,CAAC,OAAO,GAAG,kBAAQ,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,EAAE;YAChE,IAAI,CAAC,SAAS,GAAG,SAAS,CAAA;YAC1B,IAAI,CAAC,QAAQ,EAAE;gBACb,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,oBAAa,CAAC,CAAA;gBACpC,IAAI,CAAC,MAAM,CACT,QAAQ,EACR,YAAM,EACN,WAAW,EACX,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,YAAY,CAClD,CAAA;gBACD,IAAI,CAAC,MAAM,CACT,QAAQ,EACR,YAAM,EACN,gBAAgB,EAChB,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,YAAY,CAClD,CAAA;aACF;SACF;IACH,CAAC;CAuFF;AAjMD,4BAiMC;AAEQ,8BAAS;AAalB,sDAAqC;AACrC,oDAAmC;AACnC,kDAAiC;AACjC,mDAAkC;AAClC,kDAAiC;AACjC,wDAAuC;AACvC,sDAAqC;AACrC,oDAAmC;AACnC,4DAA2C;AAC3C,0DAAyC;AACzC,gEAA+C;AAC/C,iDAAgC","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"]}