Browse Source

Merge pull request #942 from bitcoinjs/stackme

enforce decodeStack receives a stack array
hk-custom-address
Daniel Cousens 7 years ago
committed by GitHub
parent
commit
42407e2c41
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 1
      src/templates/multisig/input.js
  2. 1
      src/templates/pubkey/input.js
  3. 1
      src/templates/pubkeyhash/input.js
  4. 1
      src/templates/scripthash/input.js
  5. 1
      src/templates/witnesspubkeyhash/input.js
  6. 9
      src/templates/witnessscripthash/input.js
  7. 8
      test/transaction_builder.js

1
src/templates/multisig/input.js

@ -53,6 +53,7 @@ function encode (signatures, scriptPubKey) {
} }
function decodeStack (stack, allowIncomplete) { function decodeStack (stack, allowIncomplete) {
typeforce(typeforce.Array, stack)
typeforce(check, stack, allowIncomplete) typeforce(check, stack, allowIncomplete)
return stack.slice(1) return stack.slice(1)
} }

1
src/templates/pubkey/input.js

@ -21,6 +21,7 @@ function encode (signature) {
} }
function decodeStack (stack) { function decodeStack (stack) {
typeforce(typeforce.Array, stack)
typeforce(check, stack) typeforce(check, stack)
return stack[0] return stack[0]
} }

1
src/templates/pubkeyhash/input.js

@ -29,6 +29,7 @@ function encode (signature, pubKey) {
} }
function decodeStack (stack) { function decodeStack (stack) {
typeforce(typeforce.Array, stack)
typeforce(check, stack) typeforce(check, stack)
return { return {

1
src/templates/scripthash/input.js

@ -59,6 +59,7 @@ function encode (redeemScriptSig, redeemScript) {
} }
function decodeStack (stack) { function decodeStack (stack) {
typeforce(typeforce.Array, stack)
typeforce(check, stack) typeforce(check, stack)
return { return {

1
src/templates/witnesspubkeyhash/input.js

@ -29,6 +29,7 @@ function encodeStack (signature, pubKey) {
} }
function decodeStack (stack) { function decodeStack (stack) {
typeforce(typeforce.Array, stack)
typeforce(check, stack) typeforce(check, stack)
return { return {

9
src/templates/witnessscripthash/input.js

@ -48,11 +48,12 @@ function encodeStack (witnessData, witnessScript) {
return [].concat(witnessData, witnessScript) return [].concat(witnessData, witnessScript)
} }
function decodeStack (chunks) { function decodeStack (stack) {
typeforce(check, chunks) typeforce(typeforce.Array, stack)
typeforce(check, stack)
return { return {
witnessData: chunks.slice(0, -1), witnessData: stack.slice(0, -1),
witnessScript: chunks[chunks.length - 1] witnessScript: stack[stack.length - 1]
} }
} }

8
test/transaction_builder.js

@ -500,10 +500,10 @@ describe('TransactionBuilder', function () {
'194a565cd6aa4cc38b8eaffa343402201c5b4b61d73fa38e49c1ee68cc0e6dfd2f5dae453dd86eb142e87a' + '194a565cd6aa4cc38b8eaffa343402201c5b4b61d73fa38e49c1ee68cc0e6dfd2f5dae453dd86eb142e87a' +
'0bafb1bc8401210283409659355b6d1cc3c32decd5d561abaac86c37a353b52895a5e6c196d6f44800000000' '0bafb1bc8401210283409659355b6d1cc3c32decd5d561abaac86c37a353b52895a5e6c196d6f44800000000'
var txb = TransactionBuilder.fromTransaction(Transaction.fromHex(rawtx)) var txb = TransactionBuilder.fromTransaction(Transaction.fromHex(rawtx))
txb.inputs[0].value = 81530 txb.inputs[0].value = 241530
txb.inputs[1].value = 81530 txb.inputs[1].value = 241530
txb.inputs[2].value = 88920 txb.inputs[2].value = 248920
txb.inputs[3].value = 88920 txb.inputs[3].value = 248920
assert.throws(function () { assert.throws(function () {
txb.build() txb.build()

Loading…
Cancel
Save