mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-24 18:23:26 -03:00
rpc, psbt: Require sighashes match for descriptorprocesspsbt
This commit is contained in:
parent
123b3ec1f6
commit
416eb3683b
2 changed files with 20 additions and 2 deletions
|
@ -235,8 +235,10 @@ PartiallySignedTransaction ProcessPSBT(const std::string& psbt_string, const std
|
||||||
// Note that SignPSBTInput does a lot more than just constructing ECDSA signatures.
|
// Note that SignPSBTInput does a lot more than just constructing ECDSA signatures.
|
||||||
// We only actually care about those if our signing provider doesn't hide private
|
// We only actually care about those if our signing provider doesn't hide private
|
||||||
// information, as is the case with `descriptorprocesspsbt`
|
// information, as is the case with `descriptorprocesspsbt`
|
||||||
// As such, we ignore the return value as any errors just mean that we do not have enough information.
|
// Only error for mismatching sighash types as it is critical that the sighash to sign with matches the PSBT's
|
||||||
SignPSBTInput(provider, psbtx, /*index=*/i, &txdata, sighash_type, /*out_sigdata=*/nullptr, finalize);
|
if (SignPSBTInput(provider, psbtx, /*index=*/i, &txdata, sighash_type, /*out_sigdata=*/nullptr, finalize) == common::PSBTError::SIGHASH_MISMATCH) {
|
||||||
|
throw JSONRPCPSBTError(common::PSBTError::SIGHASH_MISMATCH);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update script/keypath information using descriptor data.
|
// Update script/keypath information using descriptor data.
|
||||||
|
|
|
@ -241,6 +241,22 @@ class PSBTTest(BitcoinTestFramework):
|
||||||
proc = wallet.walletprocesspsbt(psbt, True, "ALL|ANYONECANPAY")
|
proc = wallet.walletprocesspsbt(psbt, True, "ALL|ANYONECANPAY")
|
||||||
assert_equal(proc["complete"], True)
|
assert_equal(proc["complete"], True)
|
||||||
|
|
||||||
|
# Repeat with descriptorprocesspsbt
|
||||||
|
# Mismatching sighash type fails
|
||||||
|
assert_raises_rpc_error(-22, "Specified sighash value does not match value stored in PSBT", self.nodes[0].descriptorprocesspsbt, psbt, descs, "DEFAULT")
|
||||||
|
assert_raises_rpc_error(-22, "Specified sighash value does not match value stored in PSBT", self.nodes[0].descriptorprocesspsbt, psbt, descs, "ALL")
|
||||||
|
assert_raises_rpc_error(-22, "Specified sighash value does not match value stored in PSBT", self.nodes[0].descriptorprocesspsbt, psbt, descs, "NONE")
|
||||||
|
assert_raises_rpc_error(-22, "Specified sighash value does not match value stored in PSBT", self.nodes[0].descriptorprocesspsbt, psbt, descs, "SINGLE")
|
||||||
|
assert_raises_rpc_error(-22, "Specified sighash value does not match value stored in PSBT", self.nodes[0].descriptorprocesspsbt, psbt, descs, "NONE|ANYONECANPAY")
|
||||||
|
assert_raises_rpc_error(-22, "Specified sighash value does not match value stored in PSBT", self.nodes[0].descriptorprocesspsbt, psbt, descs, "SINGLE|ANYONECANPAY")
|
||||||
|
|
||||||
|
# No sighash type specified fails
|
||||||
|
assert_raises_rpc_error(-22, "Specified sighash value does not match value stored in PSBT", self.nodes[0].descriptorprocesspsbt, psbt, descs)
|
||||||
|
|
||||||
|
# Matching sighash type succeeds
|
||||||
|
proc = self.nodes[0].descriptorprocesspsbt(psbt, descs, "ALL|ANYONECANPAY")
|
||||||
|
assert_equal(proc["complete"], True)
|
||||||
|
|
||||||
wallet.unloadwallet()
|
wallet.unloadwallet()
|
||||||
|
|
||||||
def test_sighash_adding(self):
|
def test_sighash_adding(self):
|
||||||
|
|
Loading…
Add table
Reference in a new issue