From b24dc44770e3b1cb545904ad1ee3d95f38fbb146 Mon Sep 17 00:00:00 2001 From: Thomas Kerin Date: Thu, 29 Dec 2016 18:23:15 +0100 Subject: [PATCH] P2WSH working, now for tests --- src/templates/multisig/input.js | 2 +- src/transaction_builder.js | 17 +++++++++-------- 2 files changed, 10 insertions(+), 9 deletions(-) diff --git a/src/templates/multisig/input.js b/src/templates/multisig/input.js index d3e230c..c91ab7e 100644 --- a/src/templates/multisig/input.js +++ b/src/templates/multisig/input.js @@ -36,7 +36,7 @@ function encodeStack (signatures, scriptPubKey) { } } - return [].concat(OPS.OP_0, signatures) + return [].concat(new Buffer(0), signatures) } function encode (signatures, scriptPubKey) { diff --git a/src/transaction_builder.js b/src/transaction_builder.js index 3186ec4..dc0cddb 100644 --- a/src/transaction_builder.js +++ b/src/transaction_builder.js @@ -194,7 +194,7 @@ function checkP2WSHInput (input, witnessScriptHash) { } } -function prepareInput (input, kpPubKey, redeemScript, witnessScript) { +function prepareInput (input, kpPubKey, redeemScript, witnessValue, witnessScript) { var expanded var prevOutType var prevOutScript @@ -204,13 +204,15 @@ function prepareInput (input, kpPubKey, redeemScript, witnessScript) { var redeemScriptHash var witness = false + var p2wsh = false var witnessType var witnessScriptHash if (redeemScript && witnessScript) { redeemScriptHash = bcrypto.hash160(redeemScript) - witnessScriptHash = bcrypto.hash256(witnessScript) + witnessScriptHash = bcrypto.sha256(witnessScript) checkP2shInput(input, redeemScriptHash) + if (!redeemScript.equals(bscript.witnessScriptHash.output.encode(witnessScriptHash))) throw new Error('Witness script inconsistent with redeem script') expanded = expandOutput(witnessScript, undefined, kpPubKey) @@ -218,7 +220,7 @@ function prepareInput (input, kpPubKey, redeemScript, witnessScript) { prevOutType = bscript.types.P2SH prevOutScript = bscript.scriptHash.output.encode(redeemScriptHash) - p2sh = witness = true + p2sh = witness = p2wsh = true p2shType = bscript.types.P2WSH witnessType = expanded.scriptType } else if (redeemScript) { @@ -241,7 +243,7 @@ function prepareInput (input, kpPubKey, redeemScript, witnessScript) { prevOutType = bscript.types.P2WSH prevOutScript = bscript.witnessScriptHash.output.encode(witnessScriptHash) - witness = true + witness = p2wsh = true witnessType = expanded.scriptType } else if (input.prevOutType) { // embedded scripts are not possible without a redeemScript @@ -268,7 +270,7 @@ function prepareInput (input, kpPubKey, redeemScript, witnessScript) { input.redeemScriptType = p2shType } - if (witness && witnessType === bscript.types.P2WSH) { + if (p2wsh) { input.witnessScript = witnessScript input.witnessScriptType = witnessType } @@ -516,7 +518,6 @@ TransactionBuilder.prototype.__build = function (allowIncomplete) { } var tx = this.tx.clone() - // Create script signatures from inputs this.inputs.forEach(function (input, i) { var scriptType = input.redeemScriptType || input.prevOutType @@ -553,7 +554,7 @@ function canSign (input) { input.witness !== undefined } -TransactionBuilder.prototype.sign = function (vin, keyPair, redeemScript, hashType, witnessValue) { +TransactionBuilder.prototype.sign = function (vin, keyPair, redeemScript, hashType, witnessValue, witnessScript) { if (keyPair.network !== this.network) throw new Error('Inconsistent network') if (!this.inputs[vin]) throw new Error('No input at index: ' + vin) hashType = hashType || Transaction.SIGHASH_ALL @@ -569,7 +570,7 @@ TransactionBuilder.prototype.sign = function (vin, keyPair, redeemScript, hashTy var kpPubKey = keyPair.getPublicKeyBuffer() if (!canSign(input)) { - prepareInput(input, kpPubKey, redeemScript, witnessValue) + prepareInput(input, kpPubKey, redeemScript, witnessValue, witnessScript) if (!canSign(input)) throw Error(input.prevOutType + ' not supported') }