PHP WebShell
Текущая директория: /opt/BitGoJS/modules/sdk-core/dist/src/account-lib/util
Просмотр файла: crypto.js
"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 () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__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 });
exports.hexToBigInt = exports.convertHexArrToBigIntArr = exports.convertBigIntArrToHexArr = exports.bigIntToHex = void 0;
exports.xpubToUncompressedPub = xpubToUncompressedPub;
exports.xpubToCompressedPub = xpubToCompressedPub;
exports.xprvToRawPrv = xprvToRawPrv;
exports.rawPrvToExtendedKeys = rawPrvToExtendedKeys;
exports.isValidXpub = isValidXpub;
exports.isValidXprv = isValidXprv;
exports.isValidPub = isValidPub;
exports.isValidPrv = isValidPrv;
exports.isValidEd25519Seed = isValidEd25519Seed;
exports.isValidEd25519SecretKey = isValidEd25519SecretKey;
exports.isValidEd25519PublicKey = isValidEd25519PublicKey;
exports.isValidBLSPrivateKey = isValidBLSPrivateKey;
exports.isValidBLSPublicKey = isValidBLSPublicKey;
exports.isValidBLSSignature = isValidBLSSignature;
exports.toHex = toHex;
exports.isBase58 = isBase58;
exports.toUint8Array = toUint8Array;
const utxo_lib_1 = require("@bitgo/utxo-lib");
const hex = __importStar(require("@stablelib/hex"));
const bs58_1 = __importDefault(require("bs58"));
const bls = __importStar(require("noble-bls12-381"));
const strip_hex_prefix_1 = __importDefault(require("strip-hex-prefix"));
const nacl = __importStar(require("tweetnacl"));
/**
* @deprecated - use @bitgo/sdk-lib-mpc instead
*/
var sdk_lib_mpc_1 = require("@bitgo/sdk-lib-mpc");
Object.defineProperty(exports, "bigIntToHex", { enumerable: true, get: function () { return sdk_lib_mpc_1.bigIntToHex; } });
Object.defineProperty(exports, "convertBigIntArrToHexArr", { enumerable: true, get: function () { return sdk_lib_mpc_1.convertBigIntArrToHexArr; } });
Object.defineProperty(exports, "convertHexArrToBigIntArr", { enumerable: true, get: function () { return sdk_lib_mpc_1.convertHexArrToBigIntArr; } });
Object.defineProperty(exports, "hexToBigInt", { enumerable: true, get: function () { return sdk_lib_mpc_1.hexToBigInt; } });
/**
* @param xpub - a base-58 encoded extended public key (BIP32)
* @param compressed flag to determine if return key should be compressed/uncompressed
* @return a compressed or an uncompresseed public key in hexadecimal
*/
function xPubToPub(xpub, compressed) {
if (!isValidXpub(xpub)) {
throw new Error('invalid xpub');
}
return utxo_lib_1.ECPair.fromPublicKey(utxo_lib_1.bip32.fromBase58(xpub, utxo_lib_1.networks.bitcoin).publicKey, {
compressed,
}).publicKey.toString('hex');
}
/**
* @param {string} xpub - a base-58 encoded extended public key (BIP32)
* @returns {string} the uncompressed public key in hexadecimal
*/
function xpubToUncompressedPub(xpub) {
return xPubToPub(xpub, false);
}
/**
* @param {string} xpub - a base-58 encoded extended public key (BIP32)
* @returns {string} the uncompressed public key in hexadecimal
*/
function xpubToCompressedPub(xpub) {
return xPubToPub(xpub, true);
}
/**
* @param {string} xprv - base58-encoded extended private key (BIP32)
* @returns {string} the hex-encoded raw private key
*/
function xprvToRawPrv(xprv) {
if (!isValidXprv(xprv)) {
throw new Error('invalid xprv');
}
const { privateKey } = utxo_lib_1.bip32.fromBase58(xprv, utxo_lib_1.networks.bitcoin);
if (!privateKey) {
throw new Error('invalid xprv');
}
return privateKey.toString('hex');
}
/**
* @param {string} prv - Private key in hex format to get the extended keys for
* @returns {ExtendedKeys} xprv and xpub in string format
*/
function rawPrvToExtendedKeys(prv) {
const hd = utxo_lib_1.bip32.fromPrivateKey(Buffer.from(prv, 'hex'), Buffer.alloc(32));
return {
xprv: hd.toBase58(),
xpub: hd.neutered().toBase58(),
};
}
/**
* Whether the input is a valid BIP32 xpub or not
*
* @param xpub
*/
function isValidXpub(xpub) {
if (xpub.substr(0, 4) !== 'xpub') {
// check for xpub formats we don't support, such as tpub
return false;
}
try {
utxo_lib_1.bip32.fromBase58(xpub, utxo_lib_1.networks.bitcoin);
}
catch (err) {
return false;
}
// if HD generation didn't throw, it is a valid xpub
return true;
}
/**
* Whether the input is a valid BIP32 xprv or not
*
* @param xprv
*/
function isValidXprv(xprv) {
if (xprv.substr(0, 4) !== 'xprv') {
// check for xprv formats we don't support
return false;
}
try {
utxo_lib_1.bip32.fromBase58(xprv, utxo_lib_1.networks.bitcoin);
}
catch (err) {
return false;
}
// if HD generation didn't throw, it is a valid xprv
return true;
}
/**
* Whether the input is a valid secp256k1 public key
*
* @param pub
*/
function isValidPub(pub) {
try {
utxo_lib_1.ECPair.fromPublicKey(Buffer.from(pub, 'hex'));
}
catch (e) {
return false;
}
return true;
}
/**
* Whether the input is a valid secp256k1 private key
*
* @param prv
*/
function isValidPrv(prv) {
try {
utxo_lib_1.ECPair.fromPrivateKey(Buffer.from(prv, 'hex'));
}
catch (e) {
return false;
}
return true;
}
/**
* Whether the input is a valid ed25519 private key
*
* @param {string} prv A hexadecimal private key to validate
* @returns {boolean} Whether the input is a valid public key or not
*/
function isValidEd25519Seed(prv) {
try {
const decodedPrv = toUint8Array(prv);
return decodedPrv.length === nacl.sign.seedLength;
}
catch (e) {
return false;
}
}
/**
* Whether the input is a valid ed25519 private key
*
* @param {string} prv A hexadecimal private key to validate
* @returns {boolean} Whether the input is a valid public key or not
*/
function isValidEd25519SecretKey(prv) {
try {
const decodedPrv = toUint8Array(prv);
return decodedPrv.length === nacl.sign.secretKeyLength;
}
catch (e) {
return false;
}
}
/**
* Whether the input is a valid ed25519 public key
*
* @param {string} pub A hexadecimal public key to validate
* @returns {boolean} Whether the input is a valid public key or not
*/
function isValidEd25519PublicKey(pub) {
try {
const decodedPub = new Uint8Array(Buffer.from(pub, 'hex'));
return decodedPub.length === nacl.sign.publicKeyLength;
}
catch (e) {
return false;
}
}
/**
* Whether the input is a valid BLS private key
*
* @param {string} prv a private key to validate
* @returns {boolean} Whether the input is a valid private key or not
*/
function isValidBLSPrivateKey(prv) {
try {
return bls.Fr.isValid(BigInt('0x' + prv));
}
catch (e) {
return false;
}
}
/**
* Whether input is a valid BLS public key
*
* @param {string} pub the public key to validate
* @returns {boolean} Whether input is a valid public key or not
*/
function isValidBLSPublicKey(pub) {
try {
bls.PointG1.fromCompressedHex((0, strip_hex_prefix_1.default)(pub)).assertValidity();
return true;
}
catch (e) {
return false;
}
}
/**
* Whether input is a valid BLS signature
*
* @param {string} sig the signature to validate
* @returns {boolean} Whether input is a valid signature or not
*/
function isValidBLSSignature(sig) {
try {
bls.PointG2.fromSignature(sig).assertValidity();
return true;
}
catch (e) {
return false;
}
}
/**
* Returns an hex string of the given buffer
*
* @param {Buffer | Uint8Array} buffer - the buffer to be converted to hex
* @returns {string} - the hex value
*/
function toHex(buffer) {
return hex.encode(buffer, true);
}
/**
* Check if base58 decoded string is equale to length
*
* @param {string} value - string to be checked
* @param {number} length - expected decoded length
* @return {boolean} if the string can decoded as base58 and match the expected length
*/
function isBase58(value, length) {
try {
return !!value && bs58_1.default.decode(value).length === length;
}
catch (e) {
return false;
}
}
/**
* Returns a Uint8Array of the given hex string
*
* @param {string} str - the hex string to be converted
* @returns {string} - the Uint8Array value
*/
function toUint8Array(str) {
return hex.decode(str);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"crypto.js","sourceRoot":"","sources":["../../../../src/account-lib/util/crypto.ts"],"names":[],"mappings":"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","sourcesContent":["import { bip32, ECPair, networks } from '@bitgo/utxo-lib';\nimport * as hex from '@stablelib/hex';\nimport bs58 from 'bs58';\nimport * as bls from 'noble-bls12-381';\nimport stripHexPrefix from 'strip-hex-prefix';\nimport * as nacl from 'tweetnacl';\nimport { ExtendedKeys } from '../baseCoin';\n\n/**\n * @deprecated - use @bitgo/sdk-lib-mpc instead\n */\nexport { bigIntToHex, convertBigIntArrToHexArr, convertHexArrToBigIntArr, hexToBigInt } from '@bitgo/sdk-lib-mpc';\n\n/**\n * @param xpub - a base-58 encoded extended public key (BIP32)\n * @param compressed flag to determine if return key should be compressed/uncompressed\n * @return a compressed or an uncompresseed public key in hexadecimal\n */\nfunction xPubToPub(xpub: string, compressed: boolean) {\n  if (!isValidXpub(xpub)) {\n    throw new Error('invalid xpub');\n  }\n  return ECPair.fromPublicKey(bip32.fromBase58(xpub, networks.bitcoin).publicKey, {\n    compressed,\n  }).publicKey.toString('hex');\n}\n\n/**\n * @param {string} xpub - a base-58 encoded extended public key (BIP32)\n * @returns {string} the uncompressed public key in hexadecimal\n */\nexport function xpubToUncompressedPub(xpub: string): string {\n  return xPubToPub(xpub, false);\n}\n\n/**\n * @param {string} xpub - a base-58 encoded extended public key (BIP32)\n * @returns {string} the uncompressed public key in hexadecimal\n */\nexport function xpubToCompressedPub(xpub: string): string {\n  return xPubToPub(xpub, true);\n}\n\n/**\n * @param {string} xprv - base58-encoded extended private key (BIP32)\n * @returns {string} the hex-encoded raw private key\n */\nexport function xprvToRawPrv(xprv: string): string {\n  if (!isValidXprv(xprv)) {\n    throw new Error('invalid xprv');\n  }\n\n  const { privateKey } = bip32.fromBase58(xprv, networks.bitcoin);\n  if (!privateKey) {\n    throw new Error('invalid xprv');\n  }\n  return privateKey.toString('hex');\n}\n\n/**\n * @param {string} prv - Private key in hex format to get the extended keys for\n * @returns {ExtendedKeys} xprv and xpub in string format\n */\nexport function rawPrvToExtendedKeys(prv: string): ExtendedKeys {\n  const hd = bip32.fromPrivateKey(Buffer.from(prv, 'hex'), Buffer.alloc(32));\n  return {\n    xprv: hd.toBase58(),\n    xpub: hd.neutered().toBase58(),\n  };\n}\n\n/**\n * Whether the input is a valid BIP32 xpub or not\n *\n * @param xpub\n */\nexport function isValidXpub(xpub: string): boolean {\n  if (xpub.substr(0, 4) !== 'xpub') {\n    // check for xpub formats we don't support, such as tpub\n    return false;\n  }\n  try {\n    bip32.fromBase58(xpub, networks.bitcoin);\n  } catch (err) {\n    return false;\n  }\n  // if HD generation didn't throw, it is a valid xpub\n  return true;\n}\n\n/**\n * Whether the input is a valid BIP32 xprv or not\n *\n * @param xprv\n */\nexport function isValidXprv(xprv: string): boolean {\n  if (xprv.substr(0, 4) !== 'xprv') {\n    // check for xprv formats we don't support\n    return false;\n  }\n  try {\n    bip32.fromBase58(xprv, networks.bitcoin);\n  } catch (err) {\n    return false;\n  }\n  // if HD generation didn't throw, it is a valid xprv\n  return true;\n}\n\n/**\n * Whether the input is a valid secp256k1 public key\n *\n * @param pub\n */\nexport function isValidPub(pub: string): boolean {\n  try {\n    ECPair.fromPublicKey(Buffer.from(pub, 'hex'));\n  } catch (e) {\n    return false;\n  }\n  return true;\n}\n\n/**\n * Whether the input is a valid secp256k1 private key\n *\n * @param prv\n */\nexport function isValidPrv(prv: string): boolean {\n  try {\n    ECPair.fromPrivateKey(Buffer.from(prv, 'hex'));\n  } catch (e) {\n    return false;\n  }\n  return true;\n}\n\n/**\n * Whether the input is a valid ed25519 private key\n *\n * @param {string} prv A hexadecimal private key to validate\n * @returns {boolean} Whether the input is a valid public key or not\n */\nexport function isValidEd25519Seed(prv: string): boolean {\n  try {\n    const decodedPrv = toUint8Array(prv);\n    return decodedPrv.length === nacl.sign.seedLength;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Whether the input is a valid ed25519 private key\n *\n * @param {string} prv A hexadecimal private key to validate\n * @returns {boolean} Whether the input is a valid public key or not\n */\nexport function isValidEd25519SecretKey(prv: string): boolean {\n  try {\n    const decodedPrv = toUint8Array(prv);\n    return decodedPrv.length === nacl.sign.secretKeyLength;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Whether the input is a valid ed25519 public key\n *\n * @param {string} pub A hexadecimal public key to validate\n * @returns {boolean} Whether the input is a valid public key or not\n */\nexport function isValidEd25519PublicKey(pub: string): boolean {\n  try {\n    const decodedPub = new Uint8Array(Buffer.from(pub, 'hex'));\n    return decodedPub.length === nacl.sign.publicKeyLength;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Whether the input is a valid BLS private key\n *\n * @param {string} prv a private key to validate\n * @returns {boolean} Whether the input is a valid private key or not\n */\nexport function isValidBLSPrivateKey(prv: string): boolean {\n  try {\n    return bls.Fr.isValid(BigInt('0x' + prv));\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Whether input is a valid BLS public key\n *\n * @param {string} pub the public key to validate\n * @returns {boolean} Whether input is a valid public key or not\n */\nexport function isValidBLSPublicKey(pub: string): boolean {\n  try {\n    bls.PointG1.fromCompressedHex(stripHexPrefix(pub)).assertValidity();\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Whether input is a valid BLS signature\n *\n * @param {string} sig the signature to validate\n * @returns {boolean} Whether input is a valid signature or not\n */\nexport function isValidBLSSignature(sig: string): boolean {\n  try {\n    bls.PointG2.fromSignature(sig).assertValidity();\n    return true;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Returns an hex string of the given buffer\n *\n * @param {Buffer | Uint8Array} buffer - the buffer to be converted to hex\n * @returns {string} - the hex value\n */\nexport function toHex(buffer: Buffer | Uint8Array): string {\n  return hex.encode(buffer, true);\n}\n\n/**\n * Check if base58 decoded string is equale to length\n *\n * @param {string} value - string to be checked\n * @param {number} length - expected decoded length\n * @return {boolean} if the string can decoded as base58 and match the expected length\n */\n\nexport function isBase58(value: string, length: number): boolean {\n  try {\n    return !!value && bs58.decode(value).length === length;\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Returns a Uint8Array of the given hex string\n *\n * @param {string} str - the hex string to be converted\n * @returns {string} - the Uint8Array value\n */\nexport function toUint8Array(str: string): Uint8Array {\n  return hex.decode(str);\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!