UNPKG

bitcore-lib-doge

Version:

A pure and powerful JavaScript Dogecoin library.

155 lines (135 loc) 4.93 kB
'use strict'; var inherits = require('inherits'); var $ = require('../../util/preconditions'); var BufferUtil = require('../../util/buffer'); var Hash = require('../../crypto/hash'); var Input = require('./input'); var Output = require('../output'); var Sighash = require('../sighash'); var SighashWitness = require('../sighashwitness'); var BufferWriter = require('../../encoding/bufferwriter'); var BufferUtil = require('../../util/buffer'); var Script = require('../../script'); var Signature = require('../../crypto/signature'); var TransactionSignature = require('../signature'); /** * Represents a special kind of input of PayToPublicKeyHash kind. * @constructor */ function PublicKeyHashInput() { Input.apply(this, arguments); } inherits(PublicKeyHashInput, Input); PublicKeyHashInput.prototype.getRedeemScript = function(publicKey) { if (!this.redeemScript) { var redeemScript = Script.buildWitnessV0Out(publicKey); if (Script.buildScriptHashOut(redeemScript).equals(this.output.script)) { var scriptSig = new Script(); scriptSig.add(redeemScript.toBuffer()); this.setScript(scriptSig); this.redeemScript = redeemScript; } } return this.redeemScript; }; PublicKeyHashInput.prototype.getScriptCode = function(publicKey) { var writer = new BufferWriter(); var script; if (this.output.script.isScriptHashOut()) { script = this.getRedeemScript(publicKey); } else { script = this.output.script; } var scriptBuffer = Script.buildPublicKeyHashOut(script.toAddress()).toBuffer(); writer.writeVarintNum(scriptBuffer.length); writer.write(scriptBuffer); return writer.toBuffer(); }; PublicKeyHashInput.prototype.getSighash = function(transaction, privateKey, index, sigtype) { var scriptCode = this.getScriptCode(privateKey); var satoshisBuffer = this.getSatoshisBuffer(); return SighashWitness.sighash(transaction, sigtype, index, scriptCode, satoshisBuffer); }; /* jshint maxparams: 5 */ /** * @param {Transaction} transaction - the transaction to be signed * @param {PrivateKey} privateKey - the private key with which to sign the transaction * @param {number} index - the index of the input in the transaction input vector * @param {number=} sigtype - the type of signature, defaults to Signature.SIGHASH_ALL * @param {Buffer=} hashData - the precalculated hash of the public key associated with the privateKey provided * @return {Array} of objects that can be */ PublicKeyHashInput.prototype.getSignatures = function(transaction, privateKey, index, sigtype, hashData) { $.checkState(this.output instanceof Output); hashData = hashData || Hash.sha256ripemd160(privateKey.publicKey.toBuffer()); sigtype = sigtype || Signature.SIGHASH_ALL; var script; if (this.output.script.isScriptHashOut()) { script = this.getRedeemScript(privateKey.publicKey); } else { script = this.output.script; } if (script && BufferUtil.equals(hashData, script.getPublicKeyHash())) { return [new TransactionSignature({ publicKey: privateKey.publicKey, prevTxId: this.prevTxId, outputIndex: this.outputIndex, inputIndex: index, signature: Sighash.sign(transaction, privateKey, sigtype, index, this.output.script), sigtype: sigtype })]; } return []; }; /* jshint maxparams: 3 */ /** * Add the provided signature * * @param {Object} signature * @param {PublicKey} signature.publicKey * @param {Signature} signature.signature * @param {number=} signature.sigtype * @return {PublicKeyHashInput} this, for chaining */ PublicKeyHashInput.prototype.addSignature = function(transaction, signature) { $.checkState(this.isValidSignature(transaction, signature), 'Signature is invalid'); this.setScript(Script.buildPublicKeyHashIn( signature.publicKey, signature.signature.toDER(), signature.sigtype )); return this; }; /** * Clear the input's signature * @return {PublicKeyHashInput} this, for chaining */ PublicKeyHashInput.prototype.clearSignatures = function() { this.setScript(Script.empty()); this.setWitnesses([]); return this; }; /** * Query whether the input is signed * @return {boolean} */ PublicKeyHashInput.prototype.isFullySigned = function() { return this.script.isPublicKeyHashIn() || this.hasWitnesses(); }; PublicKeyHashInput.prototype.isValidSignature = function(transaction, signature) { // FIXME: Refactor signature so this is not necessary signature.signature.nhashtype = signature.sigtype; return Sighash.verify( transaction, signature.signature, signature.publicKey, signature.inputIndex, this.output.script ); }; PublicKeyHashInput.SCRIPT_MAX_SIZE = 73 + 34; // sigsize (1 + 72) + pubkey (1 + 33) PublicKeyHashInput.prototype._estimateSize = function() { // 1 byte for script size return this._getBaseSize() + 1 + PublicKeyHashInput.SCRIPT_MAX_SIZE; }; module.exports = PublicKeyHashInput;