@kubectl/caminojs
Version:
Camino Platform JS Library
392 lines • 44.9 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 __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
/**
* @packageDocumentation
* @module Utils-BinTools
*/
const bn_js_1 = __importDefault(require("bn.js"));
const buffer_1 = require("buffer/");
const create_hash_1 = __importDefault(require("create-hash"));
const bech32 = __importStar(require("bech32"));
const base58_1 = require("./base58");
const errors_1 = require("../utils/errors");
const ethers_1 = require("ethers");
/**
* A class containing tools useful in interacting with binary data cross-platform using
* nodejs & javascript.
*
* This class should never be instantiated directly. Instead,
* invoke the "BinTools.getInstance()" static * function to grab the singleton
* instance of the tools.
*
* Everything in this library uses
* the {@link https://github.com/feross/buffer|feross's Buffer class}.
*
* ```js
* const bintools: BinTools = BinTools.getInstance();
* const b58str: = bintools.bufferToB58(Buffer.from("Wubalubadubdub!"));
* ```
*/
class BinTools {
constructor() {
/**
* Returns true if meets requirements to parse as an address as Bech32 on X-Chain or P-Chain, otherwise false
* @param address the string to verify is address
*/
this.isPrimaryBechAddress = (address) => {
const parts = address.trim().split("-");
if (parts.length !== 2) {
return false;
}
try {
bech32.bech32.fromWords(bech32.bech32.decode(parts[1]).words);
}
catch (err) {
return false;
}
return true;
};
/**
* Produces a string from a {@link https://github.com/feross/buffer|Buffer}
* representing a string. ONLY USED IN TRANSACTION FORMATTING, ASSUMED LENGTH IS PREPENDED.
*
* @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to a string
*/
this.bufferToString = (buff) => this.copyFrom(buff, 2).toString("utf8");
/**
* Produces a {@link https://github.com/feross/buffer|Buffer} from a string. ONLY USED IN TRANSACTION FORMATTING, LENGTH IS PREPENDED.
*
* @param str The string to convert to a {@link https://github.com/feross/buffer|Buffer}
*/
this.stringToBuffer = (str) => {
const buff = buffer_1.Buffer.alloc(2 + str.length);
buff.writeUInt16BE(str.length, 0);
buff.write(str, 2, str.length, "utf8");
return buff;
};
/**
* Makes a copy (no reference) of a {@link https://github.com/feross/buffer|Buffer}
* over provided indecies.
*
* @param buff The {@link https://github.com/feross/buffer|Buffer} to copy
* @param start The index to start the copy
* @param end The index to end the copy
*/
this.copyFrom = (buff, start = 0, end = undefined) => {
if (end === undefined) {
end = buff.length;
}
return buffer_1.Buffer.from(Uint8Array.prototype.slice.call(buff.slice(start, end)));
};
/**
* Takes a {@link https://github.com/feross/buffer|Buffer} and returns a base-58 string of
* the {@link https://github.com/feross/buffer|Buffer}.
*
* @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to base-58
*/
this.bufferToB58 = (buff) => this.b58.encode(buff);
/**
* Takes a base-58 string and returns a {@link https://github.com/feross/buffer|Buffer}.
*
* @param b58str The base-58 string to convert
* to a {@link https://github.com/feross/buffer|Buffer}
*/
this.b58ToBuffer = (b58str) => this.b58.decode(b58str);
/**
* Takes a {@link https://github.com/feross/buffer|Buffer} and returns an ArrayBuffer.
*
* @param buff The {@link https://github.com/feross/buffer|Buffer} to
* convert to an ArrayBuffer
*/
this.fromBufferToArrayBuffer = (buff) => {
const ab = new ArrayBuffer(buff.length);
const view = new Uint8Array(ab);
for (let i = 0; i < buff.length; ++i) {
view[`${i}`] = buff[`${i}`];
}
return view;
};
/**
* Takes an ArrayBuffer and converts it to a {@link https://github.com/feross/buffer|Buffer}.
*
* @param ab The ArrayBuffer to convert to a {@link https://github.com/feross/buffer|Buffer}
*/
this.fromArrayBufferToBuffer = (ab) => {
const buf = buffer_1.Buffer.alloc(ab.byteLength);
for (let i = 0; i < ab.byteLength; ++i) {
buf[`${i}`] = ab[`${i}`];
}
return buf;
};
/**
* Takes a {@link https://github.com/feross/buffer|Buffer} and converts it
* to a {@link https://github.com/indutny/bn.js/|BN}.
*
* @param buff The {@link https://github.com/feross/buffer|Buffer} to convert
* to a {@link https://github.com/indutny/bn.js/|BN}
*/
this.fromBufferToBN = (buff) => {
if (typeof buff === "undefined") {
return undefined;
}
return new bn_js_1.default(buff.toString("hex"), 16, "be");
};
/**
* Takes a {@link https://github.com/indutny/bn.js/|BN} and converts it
* to a {@link https://github.com/feross/buffer|Buffer}.
*
* @param bn The {@link https://github.com/indutny/bn.js/|BN} to convert
* to a {@link https://github.com/feross/buffer|Buffer}
* @param length The zero-padded length of the {@link https://github.com/feross/buffer|Buffer}
*/
this.fromBNToBuffer = (bn, length) => {
if (typeof bn === "undefined") {
return undefined;
}
const newarr = bn.toArray("be");
/**
* CKC: Still unsure why bn.toArray with a "be" and a length do not work right. Bug?
*/
if (length) {
// bn toArray with the length parameter doesn't work correctly, need this.
const x = length - newarr.length;
for (let i = 0; i < x; i++) {
newarr.unshift(0);
}
}
return buffer_1.Buffer.from(newarr);
};
/**
* Takes a {@link https://github.com/feross/buffer|Buffer} and adds a checksum, returning
* a {@link https://github.com/feross/buffer|Buffer} with the 4-byte checksum appended.
*
* @param buff The {@link https://github.com/feross/buffer|Buffer} to append a checksum
*/
this.addChecksum = (buff) => {
const hashslice = buffer_1.Buffer.from((0, create_hash_1.default)("sha256").update(buff).digest().slice(28));
return buffer_1.Buffer.concat([buff, hashslice]);
};
/**
* Takes a {@link https://github.com/feross/buffer|Buffer} with an appended 4-byte checksum
* and returns true if the checksum is valid, otherwise false.
*
* @param b The {@link https://github.com/feross/buffer|Buffer} to validate the checksum
*/
this.validateChecksum = (buff) => {
const checkslice = buff.slice(buff.length - 4);
const hashslice = buffer_1.Buffer.from((0, create_hash_1.default)("sha256")
.update(buff.slice(0, buff.length - 4))
.digest()
.slice(28));
return checkslice.toString("hex") === hashslice.toString("hex");
};
/**
* Takes a {@link https://github.com/feross/buffer|Buffer} and returns a base-58 string with
* checksum as per the cb58 standard.
*
* @param bytes A {@link https://github.com/feross/buffer|Buffer} to serialize
*
* @returns A serialized base-58 string of the Buffer.
*/
this.cb58Encode = (bytes) => {
const x = this.addChecksum(bytes);
return this.bufferToB58(x);
};
/**
* Takes a cb58 serialized {@link https://github.com/feross/buffer|Buffer} or base-58 string
* and returns a {@link https://github.com/feross/buffer|Buffer} of the original data. Throws on error.
*
* @param bytes A cb58 serialized {@link https://github.com/feross/buffer|Buffer} or base-58 string
*/
this.cb58Decode = (bytes) => {
if (typeof bytes === "string") {
bytes = this.b58ToBuffer(bytes);
}
if (this.validateChecksum(bytes)) {
return this.copyFrom(bytes, 0, bytes.length - 4);
}
throw new errors_1.ChecksumError("Error - BinTools.cb58Decode: invalid checksum");
};
this.cb58DecodeWithChecksum = (bytes) => {
if (typeof bytes === "string") {
bytes = this.b58ToBuffer(bytes);
}
if (this.validateChecksum(bytes)) {
return `0x${this.copyFrom(bytes, 0, bytes.length).toString("hex")}`;
}
throw new errors_1.ChecksumError("Error - BinTools.cb58Decode: invalid checksum");
};
this.addressToString = (hrp, chainid, bytes) => `${chainid}-${bech32.bech32.encode(hrp, bech32.bech32.toWords(bytes))}`;
this.stringToAddress = (address, hrp) => {
if (address.substring(0, 2) === "0x") {
// ETH-style address
if (ethers_1.utils.isAddress(address)) {
return buffer_1.Buffer.from(address.substring(2), "hex");
}
else {
throw new errors_1.HexError("Error - Invalid address");
}
}
// Bech32 addresses
const parts = address.trim().split("-");
if (parts.length < 2) {
throw new errors_1.Bech32Error("Error - Valid address should include -");
}
if (parts[0].length < 1) {
throw new errors_1.Bech32Error("Error - Valid address must have prefix before -");
}
const split = parts[1].lastIndexOf("1");
if (split < 0) {
throw new errors_1.Bech32Error("Error - Valid address must include separator (1)");
}
const humanReadablePart = parts[1].slice(0, split);
if (humanReadablePart.length < 1) {
throw new errors_1.Bech32Error("Error - HRP should be at least 1 character");
}
if (humanReadablePart !== "avax" &&
humanReadablePart !== "fuji" &&
humanReadablePart != "local" &&
humanReadablePart != "columbus" &&
humanReadablePart != "camino" &&
humanReadablePart != "custom" &&
humanReadablePart != hrp) {
throw new errors_1.Bech32Error("Error - Invalid HRP");
}
return buffer_1.Buffer.from(bech32.bech32.fromWords(bech32.bech32.decode(parts[1]).words));
};
/**
* Takes an address and returns its {@link https://github.com/feross/buffer|Buffer}
* representation if valid. A more strict version of stringToAddress.
*
* @param addr A string representation of the address
* @param blockchainID A cb58 encoded string representation of the blockchainID
* @param alias A chainID alias, if any, that the address can also parse from.
* @param addrlen VMs can use any addressing scheme that they like, so this is the appropriate number of address bytes. Default 20.
*
* @returns A {@link https://github.com/feross/buffer|Buffer} for the address if valid,
* undefined if not valid.
*/
this.parseAddress = (addr, blockchainID, alias = undefined, addrlen = 20) => {
const abc = addr.split("-");
if (abc.length === 2 &&
((alias && abc[0] === alias) || (blockchainID && abc[0] === blockchainID))) {
const addrbuff = this.stringToAddress(addr);
if ((addrlen && addrbuff.length === addrlen) || !addrlen) {
return addrbuff;
}
}
return undefined;
};
this.b58 = base58_1.Base58.getInstance();
}
/**
* Retrieves the BinTools singleton.
*/
static getInstance() {
if (!BinTools.instance) {
BinTools.instance = new BinTools();
}
return BinTools.instance;
}
/**
* Returns true if base64, otherwise false
* @param str the string to verify is Base64
*/
isBase64(str) {
if (str === "" || str.trim() === "") {
return false;
}
try {
let b64 = buffer_1.Buffer.from(str, "base64");
return b64.toString("base64") === str;
}
catch (err) {
return false;
}
}
/**
* Returns true if cb58, otherwise false
* @param cb58 the string to verify is cb58
*/
isCB58(cb58) {
return this.isBase58(cb58);
}
/**
* Returns true if base58, otherwise false
* @param base58 the string to verify is base58
*/
isBase58(base58) {
if (base58 === "" || base58.trim() === "") {
return false;
}
try {
return this.b58.encode(this.b58.decode(base58)) === base58;
}
catch (err) {
return false;
}
}
/**
* Returns true if hexidecimal, otherwise false
* @param hex the string to verify is hexidecimal
*/
isHex(hex) {
if (hex === "" || hex.trim() === "") {
return false;
}
const startsWith0x = hex.startsWith("0x");
const matchResult = startsWith0x
? hex.slice(2).match(/[0-9A-Fa-f]/g)
: hex.match(/[0-9A-Fa-f]/g);
if ((startsWith0x && hex.length - 2 == matchResult.length) ||
hex.length == matchResult.length) {
return true;
}
else {
return false;
}
}
/**
* Returns true if decimal, otherwise false
* @param str the string to verify is hexidecimal
*/
isDecimal(str) {
if (str === "" || str.trim() === "") {
return false;
}
try {
return new bn_js_1.default(str, 10).toString(10) === str.trim();
}
catch (err) {
return false;
}
}
}
exports.default = BinTools;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bintools.js","sourceRoot":"","sources":["../../../src/utils/bintools.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @packageDocumentation\n * @module Utils-BinTools\n */\nimport BN from \"bn.js\"\nimport { Buffer } from \"buffer/\"\nimport createHash from \"create-hash\"\nimport * as bech32 from \"bech32\"\nimport { Base58 } from \"./base58\"\nimport { Bech32Error, ChecksumError, HexError } from \"../utils/errors\"\nimport { utils } from \"ethers\"\n\n/**\n * A class containing tools useful in interacting with binary data cross-platform using\n * nodejs & javascript.\n *\n * This class should never be instantiated directly. Instead,\n * invoke the \"BinTools.getInstance()\" static * function to grab the singleton\n * instance of the tools.\n *\n * Everything in this library uses\n * the {@link https://github.com/feross/buffer|feross's Buffer class}.\n *\n * ```js\n * const bintools: BinTools = BinTools.getInstance();\n * const b58str:  = bintools.bufferToB58(Buffer.from(\"Wubalubadubdub!\"));\n * ```\n */\nexport default class BinTools {\n  private static instance: BinTools\n\n  private constructor() {\n    this.b58 = Base58.getInstance()\n  }\n\n  private b58: Base58\n\n  /**\n   * Retrieves the BinTools singleton.\n   */\n  static getInstance(): BinTools {\n    if (!BinTools.instance) {\n      BinTools.instance = new BinTools()\n    }\n    return BinTools.instance\n  }\n\n  /**\n   * Returns true if base64, otherwise false\n   * @param str the string to verify is Base64\n   */\n  isBase64(str: string) {\n    if (str === \"\" || str.trim() === \"\") {\n      return false\n    }\n    try {\n      let b64: Buffer = Buffer.from(str, \"base64\")\n      return b64.toString(\"base64\") === str\n    } catch (err) {\n      return false\n    }\n  }\n\n  /**\n   * Returns true if cb58, otherwise false\n   * @param cb58 the string to verify is cb58\n   */\n  isCB58(cb58: string): boolean {\n    return this.isBase58(cb58)\n  }\n\n  /**\n   * Returns true if base58, otherwise false\n   * @param base58 the string to verify is base58\n   */\n  isBase58(base58: string): boolean {\n    if (base58 === \"\" || base58.trim() === \"\") {\n      return false\n    }\n    try {\n      return this.b58.encode(this.b58.decode(base58)) === base58\n    } catch (err) {\n      return false\n    }\n  }\n\n  /**\n   * Returns true if hexidecimal, otherwise false\n   * @param hex the string to verify is hexidecimal\n   */\n  isHex(hex: string): boolean {\n    if (hex === \"\" || hex.trim() === \"\") {\n      return false\n    }\n    const startsWith0x = hex.startsWith(\"0x\")\n    const matchResult = startsWith0x\n      ? hex.slice(2).match(/[0-9A-Fa-f]/g)\n      : hex.match(/[0-9A-Fa-f]/g)\n    if (\n      (startsWith0x && hex.length - 2 == matchResult.length) ||\n      hex.length == matchResult.length\n    ) {\n      return true\n    } else {\n      return false\n    }\n  }\n\n  /**\n   * Returns true if decimal, otherwise false\n   * @param str the string to verify is hexidecimal\n   */\n  isDecimal(str: string) {\n    if (str === \"\" || str.trim() === \"\") {\n      return false\n    }\n    try {\n      return new BN(str, 10).toString(10) === str.trim()\n    } catch (err) {\n      return false\n    }\n  }\n\n  /**\n   * Returns true if meets requirements to parse as an address as Bech32 on X-Chain or P-Chain, otherwise false\n   * @param address the string to verify is address\n   */\n  isPrimaryBechAddress = (address: string): boolean => {\n    const parts: string[] = address.trim().split(\"-\")\n    if (parts.length !== 2) {\n      return false\n    }\n    try {\n      bech32.bech32.fromWords(bech32.bech32.decode(parts[1]).words)\n    } catch (err) {\n      return false\n    }\n    return true\n  }\n\n  /**\n   * Produces a string from a {@link https://github.com/feross/buffer|Buffer}\n   * representing a string. ONLY USED IN TRANSACTION FORMATTING, ASSUMED LENGTH IS PREPENDED.\n   *\n   * @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to a string\n   */\n  bufferToString = (buff: Buffer): string =>\n    this.copyFrom(buff, 2).toString(\"utf8\")\n\n  /**\n   * Produces a {@link https://github.com/feross/buffer|Buffer} from a string. ONLY USED IN TRANSACTION FORMATTING, LENGTH IS PREPENDED.\n   *\n   * @param str The string to convert to a {@link https://github.com/feross/buffer|Buffer}\n   */\n  stringToBuffer = (str: string): Buffer => {\n    const buff: Buffer = Buffer.alloc(2 + str.length)\n    buff.writeUInt16BE(str.length, 0)\n    buff.write(str, 2, str.length, \"utf8\")\n    return buff\n  }\n\n  /**\n   * Makes a copy (no reference) of a {@link https://github.com/feross/buffer|Buffer}\n   * over provided indecies.\n   *\n   * @param buff The {@link https://github.com/feross/buffer|Buffer} to copy\n   * @param start The index to start the copy\n   * @param end The index to end the copy\n   */\n  copyFrom = (\n    buff: Buffer,\n    start: number = 0,\n    end: number = undefined\n  ): Buffer => {\n    if (end === undefined) {\n      end = buff.length\n    }\n    return Buffer.from(Uint8Array.prototype.slice.call(buff.slice(start, end)))\n  }\n\n  /**\n   * Takes a {@link https://github.com/feross/buffer|Buffer} and returns a base-58 string of\n   * the {@link https://github.com/feross/buffer|Buffer}.\n   *\n   * @param buff The {@link https://github.com/feross/buffer|Buffer} to convert to base-58\n   */\n  bufferToB58 = (buff: Buffer): string => this.b58.encode(buff)\n\n  /**\n   * Takes a base-58 string and returns a {@link https://github.com/feross/buffer|Buffer}.\n   *\n   * @param b58str The base-58 string to convert\n   * to a {@link https://github.com/feross/buffer|Buffer}\n   */\n  b58ToBuffer = (b58str: string): Buffer => this.b58.decode(b58str)\n\n  /**\n   * Takes a {@link https://github.com/feross/buffer|Buffer} and returns an ArrayBuffer.\n   *\n   * @param buff The {@link https://github.com/feross/buffer|Buffer} to\n   * convert to an ArrayBuffer\n   */\n  fromBufferToArrayBuffer = (buff: Buffer): ArrayBuffer => {\n    const ab = new ArrayBuffer(buff.length)\n    const view = new Uint8Array(ab)\n    for (let i: number = 0; i < buff.length; ++i) {\n      view[`${i}`] = buff[`${i}`]\n    }\n    return view\n  }\n\n  /**\n   * Takes an ArrayBuffer and converts it to a {@link https://github.com/feross/buffer|Buffer}.\n   *\n   * @param ab The ArrayBuffer to convert to a {@link https://github.com/feross/buffer|Buffer}\n   */\n  fromArrayBufferToBuffer = (ab: ArrayBuffer): Buffer => {\n    const buf = Buffer.alloc(ab.byteLength)\n    for (let i: number = 0; i < ab.byteLength; ++i) {\n      buf[`${i}`] = ab[`${i}`]\n    }\n    return buf\n  }\n\n  /**\n   * Takes a {@link https://github.com/feross/buffer|Buffer} and converts it\n   * to a {@link https://github.com/indutny/bn.js/|BN}.\n   *\n   * @param buff The {@link https://github.com/feross/buffer|Buffer} to convert\n   * to a {@link https://github.com/indutny/bn.js/|BN}\n   */\n  fromBufferToBN = (buff: Buffer): BN => {\n    if (typeof buff === \"undefined\") {\n      return undefined\n    }\n    return new BN(buff.toString(\"hex\"), 16, \"be\")\n  }\n  /**\n   * Takes a {@link https://github.com/indutny/bn.js/|BN} and converts it\n   * to a {@link https://github.com/feross/buffer|Buffer}.\n   *\n   * @param bn The {@link https://github.com/indutny/bn.js/|BN} to convert\n   * to a {@link https://github.com/feross/buffer|Buffer}\n   * @param length The zero-padded length of the {@link https://github.com/feross/buffer|Buffer}\n   */\n  fromBNToBuffer = (bn: BN, length?: number): Buffer => {\n    if (typeof bn === \"undefined\") {\n      return undefined\n    }\n    const newarr = bn.toArray(\"be\")\n    /**\n     * CKC: Still unsure why bn.toArray with a \"be\" and a length do not work right. Bug?\n     */\n    if (length) {\n      // bn toArray with the length parameter doesn't work correctly, need this.\n      const x = length - newarr.length\n      for (let i: number = 0; i < x; i++) {\n        newarr.unshift(0)\n      }\n    }\n    return Buffer.from(newarr)\n  }\n\n  /**\n   * Takes a {@link https://github.com/feross/buffer|Buffer} and adds a checksum, returning\n   * a {@link https://github.com/feross/buffer|Buffer} with the 4-byte checksum appended.\n   *\n   * @param buff The {@link https://github.com/feross/buffer|Buffer} to append a checksum\n   */\n  addChecksum = (buff: Buffer): Buffer => {\n    const hashslice: Buffer = Buffer.from(\n      createHash(\"sha256\").update(buff).digest().slice(28)\n    )\n    return Buffer.concat([buff, hashslice])\n  }\n\n  /**\n   * Takes a {@link https://github.com/feross/buffer|Buffer} with an appended 4-byte checksum\n   * and returns true if the checksum is valid, otherwise false.\n   *\n   * @param b The {@link https://github.com/feross/buffer|Buffer} to validate the checksum\n   */\n  validateChecksum = (buff: Buffer): boolean => {\n    const checkslice: Buffer = buff.slice(buff.length - 4)\n    const hashslice: Buffer = Buffer.from(\n      createHash(\"sha256\")\n        .update(buff.slice(0, buff.length - 4))\n        .digest()\n        .slice(28)\n    )\n    return checkslice.toString(\"hex\") === hashslice.toString(\"hex\")\n  }\n\n  /**\n   * Takes a {@link https://github.com/feross/buffer|Buffer} and returns a base-58 string with\n   * checksum as per the cb58 standard.\n   *\n   * @param bytes A {@link https://github.com/feross/buffer|Buffer} to serialize\n   *\n   * @returns A serialized base-58 string of the Buffer.\n   */\n  cb58Encode = (bytes: Buffer): string => {\n    const x: Buffer = this.addChecksum(bytes)\n    return this.bufferToB58(x)\n  }\n\n  /**\n   * Takes a cb58 serialized {@link https://github.com/feross/buffer|Buffer} or base-58 string\n   * and returns a {@link https://github.com/feross/buffer|Buffer} of the original data. Throws on error.\n   *\n   * @param bytes A cb58 serialized {@link https://github.com/feross/buffer|Buffer} or base-58 string\n   */\n  cb58Decode = (bytes: Buffer | string): Buffer => {\n    if (typeof bytes === \"string\") {\n      bytes = this.b58ToBuffer(bytes)\n    }\n    if (this.validateChecksum(bytes)) {\n      return this.copyFrom(bytes, 0, bytes.length - 4)\n    }\n    throw new ChecksumError(\"Error - BinTools.cb58Decode: invalid checksum\")\n  }\n\n  cb58DecodeWithChecksum = (bytes: Buffer | string): string => {\n    if (typeof bytes === \"string\") {\n      bytes = this.b58ToBuffer(bytes)\n    }\n    if (this.validateChecksum(bytes)) {\n      return `0x${this.copyFrom(bytes, 0, bytes.length).toString(\"hex\")}`\n    }\n    throw new ChecksumError(\"Error - BinTools.cb58Decode: invalid checksum\")\n  }\n\n  addressToString = (hrp: string, chainid: string, bytes: Buffer): string =>\n    `${chainid}-${bech32.bech32.encode(hrp, bech32.bech32.toWords(bytes))}`\n\n  stringToAddress = (address: string, hrp?: string): Buffer => {\n    if (address.substring(0, 2) === \"0x\") {\n      // ETH-style address\n      if (utils.isAddress(address)) {\n        return Buffer.from(address.substring(2), \"hex\")\n      } else {\n        throw new HexError(\"Error - Invalid address\")\n      }\n    }\n    // Bech32 addresses\n    const parts: string[] = address.trim().split(\"-\")\n\n    if (parts.length < 2) {\n      throw new Bech32Error(\"Error - Valid address should include -\")\n    }\n\n    if (parts[0].length < 1) {\n      throw new Bech32Error(\"Error - Valid address must have prefix before -\")\n    }\n\n    const split: number = parts[1].lastIndexOf(\"1\")\n    if (split < 0) {\n      throw new Bech32Error(\"Error - Valid address must include separator (1)\")\n    }\n\n    const humanReadablePart: string = parts[1].slice(0, split)\n    if (humanReadablePart.length < 1) {\n      throw new Bech32Error(\"Error - HRP should be at least 1 character\")\n    }\n\n    if (\n      humanReadablePart !== \"avax\" &&\n      humanReadablePart !== \"fuji\" &&\n      humanReadablePart != \"local\" &&\n      humanReadablePart != \"columbus\" &&\n      humanReadablePart != \"camino\" &&\n      humanReadablePart != \"custom\" &&\n      humanReadablePart != hrp\n    ) {\n      throw new Bech32Error(\"Error - Invalid HRP\")\n    }\n\n    return Buffer.from(\n      bech32.bech32.fromWords(bech32.bech32.decode(parts[1]).words)\n    )\n  }\n\n  /**\n   * Takes an address and returns its {@link https://github.com/feross/buffer|Buffer}\n   * representation if valid. A more strict version of stringToAddress.\n   *\n   * @param addr A string representation of the address\n   * @param blockchainID A cb58 encoded string representation of the blockchainID\n   * @param alias A chainID alias, if any, that the address can also parse from.\n   * @param addrlen VMs can use any addressing scheme that they like, so this is the appropriate number of address bytes. Default 20.\n   *\n   * @returns A {@link https://github.com/feross/buffer|Buffer} for the address if valid,\n   * undefined if not valid.\n   */\n  parseAddress = (\n    addr: string,\n    blockchainID: string,\n    alias: string = undefined,\n    addrlen: number = 20\n  ): Buffer => {\n    const abc: string[] = addr.split(\"-\")\n    if (\n      abc.length === 2 &&\n      ((alias && abc[0] === alias) || (blockchainID && abc[0] === blockchainID))\n    ) {\n      const addrbuff = this.stringToAddress(addr)\n      if ((addrlen && addrbuff.length === addrlen) || !addrlen) {\n        return addrbuff\n      }\n    }\n    return undefined\n  }\n}\n"]}