mirror of
https://github.com/kvazar-network/kevacoin.git
synced 2025-01-11 15:48:05 +00:00
Merge #8704: [RPC] Transaction details in getblock
e3c9f2d
Use a verbosity instead of two verbose parameters (Andrew Chow)c99ab3c
RPC: Allow multiple names for parameters (Luke Dashjr) Tree-SHA512: 686b38f6b0106563738d51f55666fe6d49a5b121b30d4480c2bfb640a59ede8e6f7f3c05c3c5d80a5288e127991e191d19d1d4f9ace566fd39edeb27b31857ff
This commit is contained in:
commit
96c850c209
@ -688,13 +688,16 @@ UniValue getblock(const JSONRPCRequest& request)
|
|||||||
{
|
{
|
||||||
if (request.fHelp || request.params.size() < 1 || request.params.size() > 2)
|
if (request.fHelp || request.params.size() < 1 || request.params.size() > 2)
|
||||||
throw std::runtime_error(
|
throw std::runtime_error(
|
||||||
"getblock \"blockhash\" ( verbose )\n"
|
"getblock \"blockhash\" ( verbosity ) \n"
|
||||||
"\nIf verbose is false, returns a string that is serialized, hex-encoded data for block 'hash'.\n"
|
"\nIf verbosity is 0, returns a string that is serialized, hex-encoded data for block 'hash'.\n"
|
||||||
"If verbose is true, returns an Object with information about block <hash>.\n"
|
"If verbosity is 1, returns an Object with information about block <hash>.\n"
|
||||||
|
"If verbosity is 2, returns an Object with information about block <hash> and information about each transaction. \n"
|
||||||
"\nArguments:\n"
|
"\nArguments:\n"
|
||||||
"1. \"blockhash\" (string, required) The block hash\n"
|
"1. \"blockhash\" (string, required) The block hash\n"
|
||||||
"2. verbose (boolean, optional, default=true) true for a json object, false for the hex encoded data\n"
|
"2. verbosity (numeric, optional, default=1) 0 for hex encoded data, 1 for a json object, and 2 for json object with transaction data\n"
|
||||||
"\nResult (for verbose = true):\n"
|
"\nResult (for verbosity = 0):\n"
|
||||||
|
"\"data\" (string) A string that is serialized, hex-encoded data for block 'hash'.\n"
|
||||||
|
"\nResult (for verbosity = 1):\n"
|
||||||
"{\n"
|
"{\n"
|
||||||
" \"hash\" : \"hash\", (string) the block hash (same as provided)\n"
|
" \"hash\" : \"hash\", (string) the block hash (same as provided)\n"
|
||||||
" \"confirmations\" : n, (numeric) The number of confirmations, or -1 if the block is not on the main chain\n"
|
" \"confirmations\" : n, (numeric) The number of confirmations, or -1 if the block is not on the main chain\n"
|
||||||
@ -718,8 +721,14 @@ UniValue getblock(const JSONRPCRequest& request)
|
|||||||
" \"previousblockhash\" : \"hash\", (string) The hash of the previous block\n"
|
" \"previousblockhash\" : \"hash\", (string) The hash of the previous block\n"
|
||||||
" \"nextblockhash\" : \"hash\" (string) The hash of the next block\n"
|
" \"nextblockhash\" : \"hash\" (string) The hash of the next block\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"\nResult (for verbose=false):\n"
|
"\nResult (for verbosity = 2):\n"
|
||||||
"\"data\" (string) A string that is serialized, hex-encoded data for block 'hash'.\n"
|
"{\n"
|
||||||
|
" ..., Same output as verbosity = 1.\n"
|
||||||
|
" \"tx\" : [ (array of Objects) The transactions in the format of the getrawtransaction RPC. Different from verbosity = 1 \"tx\" result.\n"
|
||||||
|
" ,...\n"
|
||||||
|
" ],\n"
|
||||||
|
" ,... Same output as verbosity = 1.\n"
|
||||||
|
"}\n"
|
||||||
"\nExamples:\n"
|
"\nExamples:\n"
|
||||||
+ HelpExampleCli("getblock", "\"00000000c937983704a73af28acdec37b049d214adbda81d7e2a3dd146f6ed09\"")
|
+ HelpExampleCli("getblock", "\"00000000c937983704a73af28acdec37b049d214adbda81d7e2a3dd146f6ed09\"")
|
||||||
+ HelpExampleRpc("getblock", "\"00000000c937983704a73af28acdec37b049d214adbda81d7e2a3dd146f6ed09\"")
|
+ HelpExampleRpc("getblock", "\"00000000c937983704a73af28acdec37b049d214adbda81d7e2a3dd146f6ed09\"")
|
||||||
@ -730,9 +739,13 @@ UniValue getblock(const JSONRPCRequest& request)
|
|||||||
std::string strHash = request.params[0].get_str();
|
std::string strHash = request.params[0].get_str();
|
||||||
uint256 hash(uint256S(strHash));
|
uint256 hash(uint256S(strHash));
|
||||||
|
|
||||||
bool fVerbose = true;
|
int verbosity = 1;
|
||||||
if (request.params.size() > 1)
|
if (request.params.size() > 1) {
|
||||||
fVerbose = request.params[1].get_bool();
|
if(request.params[1].isNum())
|
||||||
|
verbosity = request.params[1].get_int();
|
||||||
|
else
|
||||||
|
verbosity = request.params[1].get_bool() ? 1 : 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (mapBlockIndex.count(hash) == 0)
|
if (mapBlockIndex.count(hash) == 0)
|
||||||
throw JSONRPCError(RPC_INVALID_ADDRESS_OR_KEY, "Block not found");
|
throw JSONRPCError(RPC_INVALID_ADDRESS_OR_KEY, "Block not found");
|
||||||
@ -751,7 +764,7 @@ UniValue getblock(const JSONRPCRequest& request)
|
|||||||
// block).
|
// block).
|
||||||
throw JSONRPCError(RPC_MISC_ERROR, "Block not found on disk");
|
throw JSONRPCError(RPC_MISC_ERROR, "Block not found on disk");
|
||||||
|
|
||||||
if (!fVerbose)
|
if (verbosity <= 0)
|
||||||
{
|
{
|
||||||
CDataStream ssBlock(SER_NETWORK, PROTOCOL_VERSION | RPCSerializationFlags());
|
CDataStream ssBlock(SER_NETWORK, PROTOCOL_VERSION | RPCSerializationFlags());
|
||||||
ssBlock << block;
|
ssBlock << block;
|
||||||
@ -759,7 +772,7 @@ UniValue getblock(const JSONRPCRequest& request)
|
|||||||
return strHex;
|
return strHex;
|
||||||
}
|
}
|
||||||
|
|
||||||
return blockToJSON(block, pblockindex);
|
return blockToJSON(block, pblockindex, verbosity >= 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct CCoinsStats
|
struct CCoinsStats
|
||||||
@ -1489,7 +1502,7 @@ static const CRPCCommand commands[] =
|
|||||||
{ "blockchain", "getchaintxstats", &getchaintxstats, true, {"nblocks", "blockhash"} },
|
{ "blockchain", "getchaintxstats", &getchaintxstats, true, {"nblocks", "blockhash"} },
|
||||||
{ "blockchain", "getbestblockhash", &getbestblockhash, true, {} },
|
{ "blockchain", "getbestblockhash", &getbestblockhash, true, {} },
|
||||||
{ "blockchain", "getblockcount", &getblockcount, true, {} },
|
{ "blockchain", "getblockcount", &getblockcount, true, {} },
|
||||||
{ "blockchain", "getblock", &getblock, true, {"blockhash","verbose"} },
|
{ "blockchain", "getblock", &getblock, true, {"blockhash","verbosity|verbose"} },
|
||||||
{ "blockchain", "getblockhash", &getblockhash, true, {"height"} },
|
{ "blockchain", "getblockhash", &getblockhash, true, {"height"} },
|
||||||
{ "blockchain", "getblockheader", &getblockheader, true, {"blockhash","verbose"} },
|
{ "blockchain", "getblockheader", &getblockheader, true, {"blockhash","verbose"} },
|
||||||
{ "blockchain", "getchaintips", &getchaintips, true, {} },
|
{ "blockchain", "getchaintips", &getchaintips, true, {} },
|
||||||
|
@ -77,7 +77,7 @@ static const CRPCConvertParam vRPCConvertParams[] =
|
|||||||
{ "listunspent", 0, "minconf" },
|
{ "listunspent", 0, "minconf" },
|
||||||
{ "listunspent", 1, "maxconf" },
|
{ "listunspent", 1, "maxconf" },
|
||||||
{ "listunspent", 2, "addresses" },
|
{ "listunspent", 2, "addresses" },
|
||||||
{ "getblock", 1, "verbose" },
|
{ "getblock", 1, "verbosity" },
|
||||||
{ "getblockheader", 1, "verbose" },
|
{ "getblockheader", 1, "verbose" },
|
||||||
{ "getchaintxstats", 0, "nblocks" },
|
{ "getchaintxstats", 0, "nblocks" },
|
||||||
{ "gettransaction", 1, "include_watchonly" },
|
{ "gettransaction", 1, "include_watchonly" },
|
||||||
|
@ -22,6 +22,8 @@
|
|||||||
#include <boost/signals2/signal.hpp>
|
#include <boost/signals2/signal.hpp>
|
||||||
#include <boost/thread.hpp>
|
#include <boost/thread.hpp>
|
||||||
#include <boost/algorithm/string/case_conv.hpp> // for to_upper()
|
#include <boost/algorithm/string/case_conv.hpp> // for to_upper()
|
||||||
|
#include <boost/algorithm/string/classification.hpp>
|
||||||
|
#include <boost/algorithm/string/split.hpp>
|
||||||
|
|
||||||
#include <memory> // for unique_ptr
|
#include <memory> // for unique_ptr
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
@ -432,8 +434,16 @@ static inline JSONRPCRequest transformNamedArguments(const JSONRPCRequest& in, c
|
|||||||
}
|
}
|
||||||
// Process expected parameters.
|
// Process expected parameters.
|
||||||
int hole = 0;
|
int hole = 0;
|
||||||
for (const std::string &argName: argNames) {
|
for (const std::string &argNamePattern: argNames) {
|
||||||
auto fr = argsIn.find(argName);
|
std::vector<std::string> vargNames;
|
||||||
|
boost::algorithm::split(vargNames, argNamePattern, boost::algorithm::is_any_of("|"));
|
||||||
|
auto fr = argsIn.end();
|
||||||
|
for (const std::string & argName : vargNames) {
|
||||||
|
fr = argsIn.find(argName);
|
||||||
|
if (fr != argsIn.end()) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
if (fr != argsIn.end()) {
|
if (fr != argsIn.end()) {
|
||||||
for (int i = 0; i < hole; ++i) {
|
for (int i = 0; i < hole; ++i) {
|
||||||
// Fill hole between specified parameters with JSON nulls,
|
// Fill hole between specified parameters with JSON nulls,
|
||||||
|
Loading…
Reference in New Issue
Block a user