|
@ -489,27 +489,12 @@ describe('TransactionBuilder', function () { |
|
|
input.signs.forEach(function (sign) { |
|
|
input.signs.forEach(function (sign) { |
|
|
// rebuild the transaction each-time after the first
|
|
|
// rebuild the transaction each-time after the first
|
|
|
if (tx) { |
|
|
if (tx) { |
|
|
// do we filter OP_0's beforehand?
|
|
|
// manually override the scriptSig?
|
|
|
if (sign.filterOP_0) { |
|
|
if (sign.scriptSigBefore) { |
|
|
const scriptSig = tx.ins[i].script |
|
|
tx.ins[i].script = bscript.fromASM(sign.scriptSigBefore) |
|
|
|
|
|
|
|
|
// ignore OP_0 on the front, ignore redeemScript
|
|
|
|
|
|
const signatures = bscript.decompile(scriptSig) |
|
|
|
|
|
.slice(1, -1) |
|
|
|
|
|
.filter(x => x !== ops.OP_0) |
|
|
|
|
|
|
|
|
|
|
|
// rebuild/replace the scriptSig without them
|
|
|
|
|
|
const replacement = payments.p2sh({ |
|
|
|
|
|
redeem: payments.p2ms({ |
|
|
|
|
|
output: redeemScript, |
|
|
|
|
|
signatures |
|
|
|
|
|
}, { allowIncomplete: true }) |
|
|
|
|
|
}).input |
|
|
|
|
|
assert.strictEqual(bscript.toASM(replacement), sign.scriptSigFiltered) |
|
|
|
|
|
|
|
|
|
|
|
tx.ins[i].script = replacement |
|
|
|
|
|
} |
|
|
} |
|
|
// now import it
|
|
|
|
|
|
|
|
|
// rebuild
|
|
|
txb = TransactionBuilder.fromTransaction(tx, network) |
|
|
txb = TransactionBuilder.fromTransaction(tx, network) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -518,6 +503,7 @@ describe('TransactionBuilder', function () { |
|
|
|
|
|
|
|
|
// update the tx
|
|
|
// update the tx
|
|
|
tx = txb.buildIncomplete() |
|
|
tx = txb.buildIncomplete() |
|
|
|
|
|
|
|
|
// now verify the serialized scriptSig is as expected
|
|
|
// now verify the serialized scriptSig is as expected
|
|
|
assert.strictEqual(bscript.toASM(tx.ins[i].script), sign.scriptSig) |
|
|
assert.strictEqual(bscript.toASM(tx.ins[i].script), sign.scriptSig) |
|
|
}) |
|
|
}) |
|
|