mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-02-09 10:43:19 -05:00
rpc: Disallow gettxoutsetinfo queries for a specific block with use_index=false
by returning an RPC error where previously a NonFatalError would be thrown.
This commit is contained in:
parent
1da1c0dd66
commit
27c8056885
1 changed files with 5 additions and 1 deletions
|
@ -845,7 +845,7 @@ static RPCHelpMan gettxoutsetinfo()
|
||||||
"Note this call may take some time if you are not using coinstatsindex.\n",
|
"Note this call may take some time if you are not using coinstatsindex.\n",
|
||||||
{
|
{
|
||||||
{"hash_type", RPCArg::Type::STR, RPCArg::Default{"hash_serialized_2"}, "Which UTXO set hash should be calculated. Options: 'hash_serialized_2' (the legacy algorithm), 'muhash', 'none'."},
|
{"hash_type", RPCArg::Type::STR, RPCArg::Default{"hash_serialized_2"}, "Which UTXO set hash should be calculated. Options: 'hash_serialized_2' (the legacy algorithm), 'muhash', 'none'."},
|
||||||
{"hash_or_height", RPCArg::Type::NUM, RPCArg::Optional::OMITTED_NAMED_ARG, "The block hash or height of the target height (only available with coinstatsindex).", "", {"", "string or numeric"}},
|
{"hash_or_height", RPCArg::Type::NUM, RPCArg::DefaultHint{"the current best block"}, "The block hash or height of the target height (only available with coinstatsindex).", "", {"", "string or numeric"}},
|
||||||
{"use_index", RPCArg::Type::BOOL, RPCArg::Default{true}, "Use coinstatsindex, if available."},
|
{"use_index", RPCArg::Type::BOOL, RPCArg::Default{true}, "Use coinstatsindex, if available."},
|
||||||
},
|
},
|
||||||
RPCResult{
|
RPCResult{
|
||||||
|
@ -881,6 +881,7 @@ static RPCHelpMan gettxoutsetinfo()
|
||||||
HelpExampleCli("gettxoutsetinfo", R"("none")") +
|
HelpExampleCli("gettxoutsetinfo", R"("none")") +
|
||||||
HelpExampleCli("gettxoutsetinfo", R"("none" 1000)") +
|
HelpExampleCli("gettxoutsetinfo", R"("none" 1000)") +
|
||||||
HelpExampleCli("gettxoutsetinfo", R"("none" '"00000000c937983704a73af28acdec37b049d214adbda81d7e2a3dd146f6ed09"')") +
|
HelpExampleCli("gettxoutsetinfo", R"("none" '"00000000c937983704a73af28acdec37b049d214adbda81d7e2a3dd146f6ed09"')") +
|
||||||
|
HelpExampleCli("-named gettxoutsetinfo", R"(hash_type='muhash' use_index='false')") +
|
||||||
HelpExampleRpc("gettxoutsetinfo", "") +
|
HelpExampleRpc("gettxoutsetinfo", "") +
|
||||||
HelpExampleRpc("gettxoutsetinfo", R"("none")") +
|
HelpExampleRpc("gettxoutsetinfo", R"("none")") +
|
||||||
HelpExampleRpc("gettxoutsetinfo", R"("none", 1000)") +
|
HelpExampleRpc("gettxoutsetinfo", R"("none", 1000)") +
|
||||||
|
@ -917,6 +918,9 @@ static RPCHelpMan gettxoutsetinfo()
|
||||||
throw JSONRPCError(RPC_INVALID_PARAMETER, "hash_serialized_2 hash type cannot be queried for a specific block");
|
throw JSONRPCError(RPC_INVALID_PARAMETER, "hash_serialized_2 hash type cannot be queried for a specific block");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!index_requested) {
|
||||||
|
throw JSONRPCError(RPC_INVALID_PARAMETER, "Cannot set use_index to false when querying for a specific block");
|
||||||
|
}
|
||||||
pindex = ParseHashOrHeight(request.params[1], chainman);
|
pindex = ParseHashOrHeight(request.params[1], chainman);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue