From 4ef2c19d71fde6ecfa7beb85000458790dbf826c Mon Sep 17 00:00:00 2001 From: Daniel Cousens Date: Thu, 5 Feb 2015 14:45:12 +1100 Subject: [PATCH] TxBuilder: defer mutation further, but still catch non-standards --- src/transaction_builder.js | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/src/transaction_builder.js b/src/transaction_builder.js index 14c3451..e1ede83 100644 --- a/src/transaction_builder.js +++ b/src/transaction_builder.js @@ -273,10 +273,11 @@ TransactionBuilder.prototype.sign = function(index, privKey, redeemScript, hashT assert.equal(input.hashType, hashType, 'Inconsistent hashType') } - var initialized = input.prevOutScript && + var initialized = input.hashType && + input.prevOutScript && input.prevOutType && - input.hashType && input.pubKeys && + input.scriptType && input.signatures // are we already initialized? @@ -331,12 +332,17 @@ TransactionBuilder.prototype.sign = function(index, privKey, redeemScript, hashT } else { assert.notEqual(input.prevOutType, 'scripthash', 'PrevOutScript is P2SH, missing redeemScript') - // if nothing known, assume pubKeyHash - if (!input.scriptType) { + // can we sign this? + if (input.scriptType) { + assert(input.pubKeys, input.scriptType + ' not supported') + + // we know nothin' Jon Snow, assume pubKeyHash + } else { input.prevOutScript = privKey.pub.getAddress().toOutputScript() input.prevOutType = 'pubkeyhash' input.pubKeys = [privKey.pub] input.scriptType = input.prevOutType + } } @@ -344,9 +350,6 @@ TransactionBuilder.prototype.sign = function(index, privKey, redeemScript, hashT input.signatures = input.signatures || [] } - // do we know how to sign this? - assert(input.scriptType in canSignTypes, input.scriptType + ' not supported') - // enforce in order signing of public keys assert(input.pubKeys.some(function(pubKey, i) { if (!privKey.pub.Q.equals(pubKey.Q)) return false