PHP WebShell
Текущая директория: /opt/BitGoJS/modules/sdk-coin-trx/dist/src/lib
Просмотр файла: keyPair.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;
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
exports.KeyPair = void 0;
const secp256k1_1 = require("@bitgo/secp256k1");
const crypto_1 = require("crypto");
const sdk_core_1 = require("@bitgo/sdk-core");
const Utils = __importStar(require("./utils"));
const DEFAULT_SEED_SIZE_BYTES = 16;
/**
* Tron keys and address management.
*/
class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
/**
* Public constructor. By default, creates a key pair with a random master seed.
*
* @param {KeyPairOptions} source Either a master seed, a private key (extended or raw), or a public key
* (extended, compressed, or uncompressed)
*/
constructor(source) {
super(source);
if (!source) {
const seed = (0, crypto_1.randomBytes)(DEFAULT_SEED_SIZE_BYTES);
this.hdNode = secp256k1_1.bip32.fromSeed(seed);
}
else if ((0, sdk_core_1.isSeed)(source)) {
this.hdNode = secp256k1_1.bip32.fromSeed(source.seed);
}
else if ((0, sdk_core_1.isPrivateKey)(source)) {
super.recordKeysFromPrivateKey(source.prv);
}
else if ((0, sdk_core_1.isPublicKey)(source)) {
super.recordKeysFromPublicKey(source.pub);
}
else {
throw new Error('Invalid key pair options');
}
if (this.hdNode) {
this.keyPair = sdk_core_1.Secp256k1ExtendedKeyPair.toKeyPair(this.hdNode);
}
}
/**
* Tron default keys format is raw private and uncompressed public key
*
* @returns {DefaultKeys} The keys in the protocol default key format
*/
getKeys() {
return {
pub: this.getPublicKey({ compressed: false }).toString('hex').toUpperCase(),
prv: this.getPrivateKey()?.toString('hex').toUpperCase(),
};
}
/**
* Get a public address in the specified format, or in base58 if none is provided.
*
* @param {AddressFormat} format The address specified format
* @returns {string} The public address in the specified format
*/
getAddress(format) {
const { pub } = this.getKeys();
// These are custom Tron methods. They can probably be replaced with other methods or libraries
const addressBytes = Utils.getRawAddressFromPubKey(Buffer.from(pub, 'hex'));
if (!format || format === sdk_core_1.AddressFormat.base58) {
// Default address are in hex
return Utils.getBase58AddressFromByteArray(addressBytes);
}
else if (format === sdk_core_1.AddressFormat.hex) {
return Utils.getHexAddressFromByteArray(addressBytes);
}
throw new Error('Unsupported address format');
}
/**
* Generates a signature for an arbitrary string with the current private key using keccak256
* hashing algorithm. Throws if there is no private key.
*
* @param {string} message to produce a signature for
* @returns {Buffer} The signature as a buffer
*/
signMessage(message) {
const messageToSign = Buffer.from(message).toString('hex');
const { prv } = this.getKeys();
if (!prv) {
throw new Error('Missing private key');
}
const signature = Utils.signString(messageToSign, prv, true).replace(/^0x/, '');
return Buffer.from(signature, 'hex');
}
/**
* Verifies a message signature using the current public key.
*
* @param {string} message signed
* @param {Buffer} signature to verify
* @returns {boolean} True if the message was signed with the current key pair
*/
verifySignature(message, signature) {
const messageToVerify = Buffer.from(message).toString('hex');
const address = this.getAddress(sdk_core_1.AddressFormat.base58);
return Utils.verifySignature(messageToVerify, address, signature.toString('hex'), true);
}
}
exports.KeyPair = KeyPair;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../src/lib/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import { bip32 } from '@bitgo/secp256k1';\nimport { randomBytes } from 'crypto';\nimport {\n  AddressFormat,\n  DefaultKeys,\n  isPrivateKey,\n  isPublicKey,\n  isSeed,\n  KeyPairOptions,\n  Secp256k1ExtendedKeyPair,\n} from '@bitgo/sdk-core';\nimport * as Utils from './utils';\n\nconst DEFAULT_SEED_SIZE_BYTES = 16;\n\n/**\n * Tron keys and address management.\n */\nexport class KeyPair extends Secp256k1ExtendedKeyPair {\n  /**\n   * Public constructor. By default, creates a key pair with a random master seed.\n   *\n   * @param {KeyPairOptions} source Either a master seed, a private key (extended or raw), or a public key\n   *     (extended, compressed, or uncompressed)\n   */\n  constructor(source?: KeyPairOptions) {\n    super(source);\n    if (!source) {\n      const seed = randomBytes(DEFAULT_SEED_SIZE_BYTES);\n      this.hdNode = bip32.fromSeed(seed);\n    } else if (isSeed(source)) {\n      this.hdNode = bip32.fromSeed(source.seed);\n    } else if (isPrivateKey(source)) {\n      super.recordKeysFromPrivateKey(source.prv);\n    } else if (isPublicKey(source)) {\n      super.recordKeysFromPublicKey(source.pub);\n    } else {\n      throw new Error('Invalid key pair options');\n    }\n\n    if (this.hdNode) {\n      this.keyPair = Secp256k1ExtendedKeyPair.toKeyPair(this.hdNode);\n    }\n  }\n\n  /**\n   * Tron default keys format is raw private and uncompressed public key\n   *\n   * @returns {DefaultKeys} The keys in the protocol default key format\n   */\n  getKeys(): DefaultKeys {\n    return {\n      pub: this.getPublicKey({ compressed: false }).toString('hex').toUpperCase(),\n      prv: this.getPrivateKey()?.toString('hex').toUpperCase(),\n    };\n  }\n\n  /**\n   * Get a public address in the specified format, or in base58 if none is provided.\n   *\n   * @param {AddressFormat} format The address specified format\n   * @returns {string} The public address in the specified format\n   */\n  getAddress(format?: AddressFormat): string {\n    const { pub } = this.getKeys();\n    // These are custom Tron methods. They can probably be replaced with other methods or libraries\n    const addressBytes = Utils.getRawAddressFromPubKey(Buffer.from(pub, 'hex'));\n\n    if (!format || format === AddressFormat.base58) {\n      // Default address are in hex\n      return Utils.getBase58AddressFromByteArray(addressBytes);\n    } else if (format === AddressFormat.hex) {\n      return Utils.getHexAddressFromByteArray(addressBytes);\n    }\n    throw new Error('Unsupported address format');\n  }\n\n  /**\n   * Generates a signature for an arbitrary string with the current private key using keccak256\n   * hashing algorithm. Throws if there is no private key.\n   *\n   * @param {string} message to produce a signature for\n   * @returns {Buffer} The signature as a buffer\n   */\n  signMessage(message: string): Buffer {\n    const messageToSign = Buffer.from(message).toString('hex');\n    const { prv } = this.getKeys();\n    if (!prv) {\n      throw new Error('Missing private key');\n    }\n    const signature = Utils.signString(messageToSign, prv, true).replace(/^0x/, '');\n    return Buffer.from(signature, 'hex');\n  }\n\n  /**\n   * Verifies a message signature using the current public key.\n   *\n   * @param {string} message signed\n   * @param {Buffer} signature to verify\n   * @returns {boolean} True if the message was signed with the current key pair\n   */\n  verifySignature(message: string, signature: Buffer): boolean {\n    const messageToVerify = Buffer.from(message).toString('hex');\n    const address = this.getAddress(AddressFormat.base58);\n    return Utils.verifySignature(messageToVerify, address, signature.toString('hex'), true);\n  }\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!