PHP WebShell
Текущая директория: /opt/BitGoJS/modules/sdk-core/dist/src/account-lib/baseCoin
Просмотр файла: ed25519KeyPair.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.Ed25519KeyPair = void 0;
const nacl = __importStar(require("tweetnacl"));
const crypto_1 = require("../util/crypto");
const ed25519KeyDeriver_1 = require("../util/ed25519KeyDeriver");
const iface_1 = require("./iface");
const DEFAULT_SEED_SIZE_BYTES = 32;
class Ed25519KeyPair {
/**
* Public constructor. By default, creates a key pair with a random master seed.
*
* @param {KeyPairOptions} source Either a master seed, a private key, or a public key
*/
constructor(source) {
let naclKeyPair;
if (!source) {
const seed = nacl.randomBytes(DEFAULT_SEED_SIZE_BYTES);
naclKeyPair = nacl.sign.keyPair.fromSeed(seed);
this.setKeyPair(naclKeyPair);
}
else if ((0, iface_1.isSeed)(source)) {
naclKeyPair = nacl.sign.keyPair.fromSeed(source.seed);
this.setKeyPair(naclKeyPair);
}
else if ((0, iface_1.isPrivateKey)(source)) {
this.recordKeysFromPrivateKey(source.prv);
}
else if ((0, iface_1.isPublicKey)(source)) {
this.recordKeysFromPublicKey(source.pub);
}
else {
throw new Error('Invalid key pair options');
}
}
getKeyPair(naclKeyPair) {
return {
prv: (0, crypto_1.toHex)(naclKeyPair.secretKey.slice(0, 32)),
pub: (0, crypto_1.toHex)(naclKeyPair.publicKey),
};
}
setKeyPair(naclKeyPair) {
this.keyPair = this.getKeyPair(naclKeyPair);
}
/** @inheritdoc */
recordKeysFromPrivateKey(prv) {
if ((0, crypto_1.isValidEd25519Seed)(prv)) {
const decodedPrv = (0, crypto_1.toUint8Array)(prv);
const naclKeyPair = nacl.sign.keyPair.fromSeed(decodedPrv);
this.setKeyPair(naclKeyPair);
}
else if ((0, crypto_1.isValidEd25519SecretKey)(prv)) {
const decodedPrv = (0, crypto_1.toUint8Array)(prv);
const naclKeyPair = nacl.sign.keyPair.fromSecretKey(decodedPrv);
this.setKeyPair(naclKeyPair);
}
else {
this.keyPair = this.recordKeysFromPrivateKeyInProtocolFormat(prv);
}
}
/** @inheritdoc */
recordKeysFromPublicKey(pub) {
if ((0, crypto_1.isValidEd25519PublicKey)(pub)) {
this.keyPair = { pub };
}
else {
this.keyPair = this.recordKeysFromPublicKeyInProtocolFormat(pub);
}
}
/**
* Generates a signature for an arbitrary string with the current private key using the ed25519 public-key signature
* system.
*
* @param {string} message to produce a signature for
* @returns {Uint8Array} The signature produced for the message
* @throws if there is no private key
*/
signMessage(message) {
const messageToSign = (0, crypto_1.toUint8Array)(Buffer.from(message).toString('hex'));
const prv = this.keyPair?.prv;
if (!prv) {
throw new Error('Missing private key');
}
return nacl.sign.detached(messageToSign, nacl.sign.keyPair.fromSeed((0, crypto_1.toUint8Array)(prv)).secretKey);
}
/**
* Verifies a message signature using the current public key.
*
* @param {string} message signed
* @param {Uint8Array} signature to verify
* @returns {boolean} True if the message was signed with the current key pair
*/
verifySignature(message, signature) {
let messageToVerify;
if (typeof message === 'string') {
messageToVerify = (0, crypto_1.toUint8Array)(Buffer.from(message).toString('hex'));
}
else {
messageToVerify = message;
}
if (!this.keyPair?.pub) {
return false;
}
const publicKey = (0, crypto_1.toUint8Array)(this.keyPair.pub);
return nacl.sign.detached.verify(messageToVerify, signature, publicKey);
}
/**
* Derives a hardened child key pair using this key pair's secret key
* as the seed.
*
* @param path derivation path
* @deprecated
*/
deriveHardened(path) {
if (!this.keyPair?.prv) {
throw new Error('need private key to derive hardened keypair');
}
const seed = ed25519KeyDeriver_1.Ed25519KeyDeriver.derivePath(path, this.keyPair.prv).key;
const derivedKeyPair = nacl.sign.keyPair.fromSeed(seed);
return this.getKeyPair(derivedKeyPair);
}
}
exports.Ed25519KeyPair = Ed25519KeyPair;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ed25519KeyPair.js","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/ed25519KeyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import * as nacl from 'tweetnacl';\nimport {\n  isValidEd25519PublicKey,\n  isValidEd25519SecretKey,\n  isValidEd25519Seed,\n  toHex,\n  toUint8Array,\n} from '../util/crypto';\nimport { Ed25519KeyDeriver } from '../util/ed25519KeyDeriver';\nimport { BaseKeyPair } from './baseKeyPair';\nimport { AddressFormat, DotAddressFormat } from './enum';\nimport { isPrivateKey, isPublicKey, isSeed, DefaultKeys, KeyPairOptions } from './iface';\n\nconst DEFAULT_SEED_SIZE_BYTES = 32;\n\nexport abstract class Ed25519KeyPair implements BaseKeyPair {\n  protected keyPair: DefaultKeys;\n  protected source?: KeyPairOptions;\n\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, or a public key\n   */\n  protected constructor(source?: KeyPairOptions) {\n    let naclKeyPair;\n    if (!source) {\n      const seed = nacl.randomBytes(DEFAULT_SEED_SIZE_BYTES);\n      naclKeyPair = nacl.sign.keyPair.fromSeed(seed);\n      this.setKeyPair(naclKeyPair);\n    } else if (isSeed(source)) {\n      naclKeyPair = nacl.sign.keyPair.fromSeed(source.seed);\n      this.setKeyPair(naclKeyPair);\n    } else if (isPrivateKey(source)) {\n      this.recordKeysFromPrivateKey(source.prv);\n    } else if (isPublicKey(source)) {\n      this.recordKeysFromPublicKey(source.pub);\n    } else {\n      throw new Error('Invalid key pair options');\n    }\n  }\n\n  private getKeyPair(naclKeyPair: nacl.SignKeyPair): DefaultKeys {\n    return {\n      prv: toHex(naclKeyPair.secretKey.slice(0, 32)),\n      pub: toHex(naclKeyPair.publicKey),\n    };\n  }\n\n  private setKeyPair(naclKeyPair: nacl.SignKeyPair): void {\n    this.keyPair = this.getKeyPair(naclKeyPair);\n  }\n\n  /** @inheritdoc */\n  recordKeysFromPrivateKey(prv: string): void {\n    if (isValidEd25519Seed(prv)) {\n      const decodedPrv = toUint8Array(prv);\n      const naclKeyPair = nacl.sign.keyPair.fromSeed(decodedPrv);\n      this.setKeyPair(naclKeyPair);\n    } else if (isValidEd25519SecretKey(prv)) {\n      const decodedPrv = toUint8Array(prv);\n      const naclKeyPair = nacl.sign.keyPair.fromSecretKey(decodedPrv);\n      this.setKeyPair(naclKeyPair);\n    } else {\n      this.keyPair = this.recordKeysFromPrivateKeyInProtocolFormat(prv);\n    }\n  }\n\n  /** @inheritdoc */\n  recordKeysFromPublicKey(pub: string): void {\n    if (isValidEd25519PublicKey(pub)) {\n      this.keyPair = { pub };\n    } else {\n      this.keyPair = this.recordKeysFromPublicKeyInProtocolFormat(pub);\n    }\n  }\n\n  abstract recordKeysFromPrivateKeyInProtocolFormat(prv: string): DefaultKeys;\n\n  abstract recordKeysFromPublicKeyInProtocolFormat(pub: string): DefaultKeys;\n\n  /** @inheritdoc */\n  abstract getAddress(format?: AddressFormat | DotAddressFormat): string;\n\n  /** @inheritdoc */\n  abstract getKeys(): any;\n\n  /**\n   * Generates a signature for an arbitrary string with the current private key using the ed25519 public-key signature\n   * system.\n   *\n   * @param {string} message to produce a signature for\n   * @returns {Uint8Array} The signature produced for the message\n   * @throws if there is no private key\n   */\n  signMessage(message: string): Uint8Array {\n    const messageToSign = toUint8Array(Buffer.from(message).toString('hex'));\n    const prv = this.keyPair?.prv;\n    if (!prv) {\n      throw new Error('Missing private key');\n    }\n    return nacl.sign.detached(messageToSign, nacl.sign.keyPair.fromSeed(toUint8Array(prv)).secretKey);\n  }\n\n  /**\n   * Verifies a message signature using the current public key.\n   *\n   * @param {string} message signed\n   * @param {Uint8Array} signature to verify\n   * @returns {boolean} True if the message was signed with the current key pair\n   */\n  verifySignature(message: Uint8Array | string, signature: Uint8Array): boolean {\n    let messageToVerify;\n    if (typeof message === 'string') {\n      messageToVerify = toUint8Array(Buffer.from(message).toString('hex'));\n    } else {\n      messageToVerify = message;\n    }\n    if (!this.keyPair?.pub) {\n      return false;\n    }\n    const publicKey = toUint8Array(this.keyPair.pub);\n    return nacl.sign.detached.verify(messageToVerify, signature, publicKey);\n  }\n\n  /**\n   * Derives a hardened child key pair using this key pair's secret key\n   * as the seed.\n   *\n   * @param path derivation path\n   * @deprecated\n   */\n  deriveHardened(path: string): DefaultKeys {\n    if (!this.keyPair?.prv) {\n      throw new Error('need private key to derive hardened keypair');\n    }\n\n    const seed = Ed25519KeyDeriver.derivePath(path, this.keyPair.prv).key;\n    const derivedKeyPair = nacl.sign.keyPair.fromSeed(seed);\n\n    return this.getKeyPair(derivedKeyPair);\n  }\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!