Browse Source

TxBuilder: remove impossible/untestable assertions

hk-custom-address
Daniel Cousens 10 years ago
parent
commit
fd2311bda4
  1. 31
      src/transaction_builder.js

31
src/transaction_builder.js

@ -205,6 +205,9 @@ TransactionBuilder.prototype.addOutput = function(scriptPubKey, value) {
TransactionBuilder.prototype.build = function() { return this.__build(false) } TransactionBuilder.prototype.build = function() { return this.__build(false) }
TransactionBuilder.prototype.buildIncomplete = function() { return this.__build(true) } TransactionBuilder.prototype.buildIncomplete = function() { return this.__build(true) }
var canSignTypes = { 'pubkeyhash': true, 'multisig': true, 'pubkey': true }
TransactionBuilder.prototype.__build = function(allowIncomplete) { TransactionBuilder.prototype.__build = function(allowIncomplete) {
if (!allowIncomplete) { if (!allowIncomplete) {
assert(this.tx.ins.length > 0, 'Transaction has no inputs') assert(this.tx.ins.length > 0, 'Transaction has no inputs')
@ -215,24 +218,22 @@ TransactionBuilder.prototype.__build = function(allowIncomplete) {
// Create script signatures from signature meta-data // Create script signatures from signature meta-data
this.inputs.forEach(function(input, index) { this.inputs.forEach(function(input, index) {
var scriptType = input.scriptType
var scriptSig
if (!allowIncomplete) { if (!allowIncomplete) {
assert(input.initialized, 'Transaction is not complete') assert(input.initialized, 'Transaction is not complete')
assert(scriptType in canSignTypes, scriptType + ' not supported')
assert(input.signatures, 'Transaction is missing signatures')
} }
var scriptSig switch (scriptType) {
switch (input.scriptType) {
case 'pubkeyhash': case 'pubkeyhash':
assert(input.signatures, 'Transaction is missing signatures')
assert.equal(input.signatures.length, 1, 'Transaction is missing signatures')
var pkhSignature = input.signatures[0].toScriptSignature(input.hashType) var pkhSignature = input.signatures[0].toScriptSignature(input.hashType)
scriptSig = scripts.pubKeyHashInput(pkhSignature, input.pubKeys[0]) scriptSig = scripts.pubKeyHashInput(pkhSignature, input.pubKeys[0])
break break
case 'multisig': case 'multisig':
assert(input.signatures, 'Transaction is missing signatures')
// Array.prototype.map is sparse-compatible // Array.prototype.map is sparse-compatible
var msSignatures = input.signatures.map(function(signature) { var msSignatures = input.signatures.map(function(signature) {
return signature.toScriptSignature(input.hashType) return signature.toScriptSignature(input.hashType)
@ -250,20 +251,13 @@ TransactionBuilder.prototype.__build = function(allowIncomplete) {
break break
case 'pubkey': case 'pubkey':
assert(input.signatures, 'Transaction is missing signatures')
assert.equal(input.signatures.length, 1, 'Transaction is missing signatures')
var pkSignature = input.signatures[0].toScriptSignature(input.hashType) var pkSignature = input.signatures[0].toScriptSignature(input.hashType)
scriptSig = scripts.pubKeyInput(pkSignature) scriptSig = scripts.pubKeyInput(pkSignature)
break break
default:
if (allowIncomplete) return
assert(false, input.scriptType + ' not supported')
} }
if (input.redeemScript) { // if we built a scriptSig, wrap as scriptHash if necessary
if (scriptSig && input.prevOutType === 'scripthash') {
scriptSig = scripts.scriptHashInput(scriptSig, input.redeemScript) scriptSig = scripts.scriptHashInput(scriptSig, input.redeemScript)
} }
@ -273,8 +267,6 @@ TransactionBuilder.prototype.__build = function(allowIncomplete) {
return tx return tx
} }
var canSignTypes = { 'pubkeyhash': true, 'multisig': true, 'pubkey': true }
TransactionBuilder.prototype.sign = function(index, privKey, redeemScript, hashType) { TransactionBuilder.prototype.sign = function(index, privKey, redeemScript, hashType) {
assert(index in this.inputs, 'No input at index: ' + index) assert(index in this.inputs, 'No input at index: ' + index)
hashType = hashType || Transaction.SIGHASH_ALL hashType = hashType || Transaction.SIGHASH_ALL
@ -342,6 +334,7 @@ TransactionBuilder.prototype.sign = function(index, privKey, redeemScript, hashT
} else { } else {
assert.notEqual(input.prevOutType, 'scripthash', 'PrevOutScript is P2SH, missing redeemScript') assert.notEqual(input.prevOutType, 'scripthash', 'PrevOutScript is P2SH, missing redeemScript')
// if nothing known, assume pubKeyHash
if (!input.scriptType) { if (!input.scriptType) {
input.prevOutScript = privKey.pub.getAddress().toOutputScript() input.prevOutScript = privKey.pub.getAddress().toOutputScript()
input.prevOutType = 'pubkeyhash' input.prevOutType = 'pubkeyhash'

Loading…
Cancel
Save