From 30d0f7be6e6bd45fed7195ddf31187438b02227a Mon Sep 17 00:00:00 2001 From: benthecarman Date: Mon, 4 Feb 2019 21:26:43 -0600 Subject: [PATCH] rpc: Fix for segfault if combinepsbt called with empty inputs --- src/rpc/rawtransaction.cpp | 3 +++ test/functional/rpc_psbt.py | 3 +++ 2 files changed, 6 insertions(+) diff --git a/src/rpc/rawtransaction.cpp b/src/rpc/rawtransaction.cpp index ac2e0ff4ee1..5a057cdb113 100644 --- a/src/rpc/rawtransaction.cpp +++ b/src/rpc/rawtransaction.cpp @@ -1514,6 +1514,9 @@ UniValue combinepsbt(const JSONRPCRequest& request) // Unserialize the transactions std::vector psbtxs; UniValue txs = request.params[0].get_array(); + if (txs.empty()) { + throw JSONRPCError(RPC_INVALID_PARAMETER, "Parameter 'txs' cannot be empty"); + } for (unsigned int i = 0; i < txs.size(); ++i) { PartiallySignedTransaction psbtx; std::string error; diff --git a/test/functional/rpc_psbt.py b/test/functional/rpc_psbt.py index 1e10280e603..a82a5d0208f 100755 --- a/test/functional/rpc_psbt.py +++ b/test/functional/rpc_psbt.py @@ -269,6 +269,9 @@ class PSBTTest(BitcoinTestFramework): combined = self.nodes[2].combinepsbt(combiner['combine']) assert_equal(combined, combiner['result']) + # Empty combiner test + assert_raises_rpc_error(-8, "Parameter 'txs' cannot be empty", self.nodes[0].combinepsbt, []) + # Finalizer test for finalizer in finalizers: finalized = self.nodes[2].finalizepsbt(finalizer['finalize'], False)['psbt']