PHP WebShell
Текущая директория: /opt/BitGoJS/node_modules/bip322-js/dist
Просмотр файла: BIP322.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 (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;
};
Object.defineProperty(exports, "__esModule", { value: true });
// Import dependencies
const fast_sha256_1 = require("fast-sha256");
const bitcoin = __importStar(require("bitcoinjs-lib"));
/**
* Class that handles BIP-322 related operations.
* Reference: https://github.com/LegReq/bip0322-signatures/blob/master/BIP0322_signing.ipynb
*/
class BIP322 {
/**
* Compute the message hash as specified in the BIP-322.
* The standard is specified in BIP-340 as:
* The function hashtag(x) where tag is a UTF-8 encoded tag name and x is a byte array returns the 32-byte hash SHA256(SHA256(tag) || SHA256(tag) || x).
* @param message Message to be hashed
* @returns Hashed message
*/
static hashMessage(message) {
// Compute the message hash - SHA256(SHA256(tag) || SHA256(tag) || message)
const tagHasher = new fast_sha256_1.Hash();
tagHasher.update(this.TAG);
const tagHash = tagHasher.digest();
const messageHasher = new fast_sha256_1.Hash();
messageHasher.update(tagHash);
messageHasher.update(tagHash);
messageHasher.update(Buffer.from(message));
const messageHash = messageHasher.digest();
return messageHash;
}
/**
* Build a to_spend transaction using simple signature in accordance to the BIP-322.
* @param message Message to be signed using BIP-322
* @param scriptPublicKey The script public key for the signing wallet
* @returns Bitcoin transaction that correspond to the to_spend transaction
*/
static buildToSpendTx(message, scriptPublicKey) {
// Create PSBT object for constructing the transaction
const psbt = new bitcoin.Psbt();
// Set default value for nVersion and nLockTime
psbt.setVersion(0); // nVersion = 0
psbt.setLocktime(0); // nLockTime = 0
// Compute the message hash - SHA256(SHA256(tag) || SHA256(tag) || message)
const messageHash = this.hashMessage(message);
// Construct the scriptSig - OP_0 PUSH32[ message_hash ]
const scriptSigPartOne = new Uint8Array([0x00, 0x20]); // OP_0 PUSH32
const scriptSig = new Uint8Array(scriptSigPartOne.length + messageHash.length);
scriptSig.set(scriptSigPartOne);
scriptSig.set(messageHash, scriptSigPartOne.length);
// Set the input
psbt.addInput({
hash: '0'.repeat(64), // vin[0].prevout.hash = 0000...000
index: 0xFFFFFFFF, // vin[0].prevout.n = 0xFFFFFFFF
sequence: 0, // vin[0].nSequence = 0
finalScriptSig: Buffer.from(scriptSig), // vin[0].scriptSig = OP_0 PUSH32[ message_hash ]
witnessScript: Buffer.from([]) // vin[0].scriptWitness = []
});
// Set the output
psbt.addOutput({
value: 0, // vout[0].nValue = 0
script: scriptPublicKey // vout[0].scriptPubKey = message_challenge
});
// Return transaction
return psbt.extractTransaction();
}
/**
* Build a to_sign transaction using simple signature in accordance to the BIP-322.
* @param toSpendTxId Transaction ID of the to_spend transaction as constructed by buildToSpendTx
* @param witnessScript The script public key for the signing wallet, or the redeemScript for P2SH-P2WPKH address
* @param isRedeemScript Set to true if the provided witnessScript is a redeemScript for P2SH-P2WPKH address, default to false
* @param tapInternalKey Used to set the taproot internal public key of a taproot signing address when provided, default to undefined
* @returns Ready-to-be-signed bitcoinjs.Psbt transaction
*/
static buildToSignTx(toSpendTxId, witnessScript, isRedeemScript = false, tapInternalKey = undefined) {
// Create PSBT object for constructing the transaction
const psbt = new bitcoin.Psbt();
// Set default value for nVersion and nLockTime
psbt.setVersion(0); // nVersion = 0
psbt.setLocktime(0); // nLockTime = 0
// Set the input
psbt.addInput({
hash: toSpendTxId, // vin[0].prevout.hash = to_spend.txid
index: 0, // vin[0].prevout.n = 0
sequence: 0, // vin[0].nSequence = 0
witnessUtxo: {
script: witnessScript,
value: 0
}
});
// Set redeemScript as witnessScript if isRedeemScript
if (isRedeemScript) {
psbt.updateInput(0, {
redeemScript: witnessScript
});
}
// Set tapInternalKey if provided
if (tapInternalKey) {
psbt.updateInput(0, {
tapInternalKey: tapInternalKey
});
}
// Set the output
psbt.addOutput({
value: 0, // vout[0].nValue = 0
script: Buffer.from([0x6a]) // vout[0].scriptPubKey = OP_RETURN
});
return psbt;
}
/**
* Encode witness stack in a signed BIP-322 PSBT into its base-64 encoded format.
* @param signedPsbt Signed PSBT
* @returns Base-64 encoded witness data
*/
static encodeWitness(signedPsbt) {
// Obtain the signed witness data
const witness = signedPsbt.data.inputs[0].finalScriptWitness;
// Check if the witness data is present
if (witness) {
// Return the base-64 encoded witness stack
return witness.toString('base64');
}
else {
throw new Error('Cannot encode empty witness stack.');
}
}
}
// BIP322 message tag
BIP322.TAG = Buffer.from("BIP0322-signed-message");
exports.default = BIP322;
//# sourceMappingURL=BIP322.js.mapВыполнить команду
Для локальной разработки. Не используйте в интернете!