UNPKG

@hdwallet/core

Version:

A complete Hierarchical Deterministic (HD) Wallet generator for 200+ cryptocurrencies, built with TypeScript.

49 lines 1.9 kB
"use strict"; // SPDX-License-Identifier: MIT Object.defineProperty(exports, "__esModule", { value: true }); exports.InjectiveAddress = void 0; const ethereum_1 = require("./ethereum"); const bech32_1 = require("../libs/bech32"); const eccs_1 = require("../eccs"); const cryptocurrencies_1 = require("../cryptocurrencies"); const utils_1 = require("../utils"); const address_1 = require("./address"); const exceptions_1 = require("../exceptions"); class InjectiveAddress extends address_1.Address { static hrp = cryptocurrencies_1.Injective.NETWORKS.MAINNET.HRP; static getName() { return 'Injective'; } static encode(publicKey, options = { hrp: this.hrp }) { const pk = (0, eccs_1.validateAndGetPublicKey)(publicKey, eccs_1.SLIP10Secp256k1PublicKey); const ethEncoded = ethereum_1.EthereumAddress.encode(pk, { skipChecksumEncode: true }); const rawBytes = (0, utils_1.getBytes)(ethEncoded.slice(2)); // remove "0x" const hrp = options.hrp ?? this.hrp; const encoded = (0, bech32_1.bech32Encode)(hrp, rawBytes); if (!encoded) { throw new exceptions_1.AddressError('Failed to encode Bech32 Injective address'); } return encoded; } static decode(address, options = { hrp: this.hrp }) { const hrp = options.hrp ?? this.hrp; const [gotHrp, data] = (0, bech32_1.bech32Decode)(hrp, address); if (!gotHrp || !data) { throw new exceptions_1.AddressError('Failed to decode Bech32 Injective address'); } if (data.length !== 20) { throw new exceptions_1.AddressError('Invalid length', { expected: 20, got: data.length }); } return (0, utils_1.bytesToString)(data); } } exports.InjectiveAddress = InjectiveAddress; //# sourceMappingURL=injective.js.map