mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-12-13 22:24:05 +01:00
cli: Implement human readable -getinfo.
This commit is contained in:
@@ -9,6 +9,7 @@
|
||||
|
||||
#include <chainparamsbase.h>
|
||||
#include <clientversion.h>
|
||||
#include <policy/feerate.h>
|
||||
#include <rpc/client.h>
|
||||
#include <rpc/mining.h>
|
||||
#include <rpc/protocol.h>
|
||||
@@ -28,6 +29,10 @@
|
||||
#include <string>
|
||||
#include <tuple>
|
||||
|
||||
#ifndef WIN32
|
||||
#include <unistd.h>
|
||||
#endif
|
||||
|
||||
#include <event2/buffer.h>
|
||||
#include <event2/keyvalq_struct.h>
|
||||
#include <support/events.h>
|
||||
@@ -48,6 +53,9 @@ static constexpr int8_t UNKNOWN_NETWORK{-1};
|
||||
/** Default number of blocks to generate for RPC generatetoaddress. */
|
||||
static const std::string DEFAULT_NBLOCKS = "1";
|
||||
|
||||
/** Default -color setting. */
|
||||
static const std::string DEFAULT_COLOR_SETTING{"auto"};
|
||||
|
||||
static void SetupCliArgs(ArgsManager& argsman)
|
||||
{
|
||||
SetupHelpOptions(argsman);
|
||||
@@ -66,6 +74,7 @@ static void SetupCliArgs(ArgsManager& argsman)
|
||||
argsman.AddArg("-netinfo", "Get network peer connection information from the remote server. An optional integer argument from 0 to 4 can be passed for different peers listings (default: 0). Pass \"help\" for detailed help documentation.", ArgsManager::ALLOW_ANY, OptionsCategory::OPTIONS);
|
||||
|
||||
SetupChainParamsBaseOptions(argsman);
|
||||
argsman.AddArg("-color=<when>", strprintf("Color setting for CLI output (default: %s). Valid values: always, auto (add color codes when standard output is connected to a terminal and OS is not WIN32), never.", DEFAULT_COLOR_SETTING), ArgsManager::ALLOW_STRING, OptionsCategory::OPTIONS);
|
||||
argsman.AddArg("-named", strprintf("Pass named instead of positional arguments (default: %s)", DEFAULT_NAMED), ArgsManager::ALLOW_ANY, OptionsCategory::OPTIONS);
|
||||
argsman.AddArg("-rpcclienttimeout=<n>", strprintf("Timeout in seconds during HTTP requests, or 0 for no timeout. (default: %d)", DEFAULT_HTTP_CLIENT_TIMEOUT), ArgsManager::ALLOW_ANY, OptionsCategory::OPTIONS);
|
||||
argsman.AddArg("-rpcconnect=<ip>", strprintf("Send commands to node running on <ip> (default: %s)", DEFAULT_RPCCONNECT), ArgsManager::ALLOW_ANY, OptionsCategory::OPTIONS);
|
||||
@@ -338,7 +347,9 @@ public:
|
||||
result.pushKV("difficulty", batch[ID_BLOCKCHAININFO]["result"]["difficulty"]);
|
||||
result.pushKV("chain", UniValue(batch[ID_BLOCKCHAININFO]["result"]["chain"]));
|
||||
if (!batch[ID_WALLETINFO]["result"].isNull()) {
|
||||
result.pushKV("has_wallet", true);
|
||||
result.pushKV("keypoolsize", batch[ID_WALLETINFO]["result"]["keypoolsize"]);
|
||||
result.pushKV("walletname", batch[ID_WALLETINFO]["result"]["walletname"]);
|
||||
if (!batch[ID_WALLETINFO]["result"]["unlocked_until"].isNull()) {
|
||||
result.pushKV("unlocked_until", batch[ID_WALLETINFO]["result"]["unlocked_until"]);
|
||||
}
|
||||
@@ -873,6 +884,100 @@ static void GetWalletBalances(UniValue& result)
|
||||
result.pushKV("balances", balances);
|
||||
}
|
||||
|
||||
/**
|
||||
* ParseGetInfoResult takes in -getinfo result in UniValue object and parses it
|
||||
* into a user friendly UniValue string to be printed on the console.
|
||||
* @param[out] result Reference to UniValue result containing the -getinfo output.
|
||||
*/
|
||||
static void ParseGetInfoResult(UniValue& result)
|
||||
{
|
||||
if (!find_value(result, "error").isNull()) return;
|
||||
|
||||
std::string RESET, GREEN, BLUE, YELLOW, MAGENTA, CYAN;
|
||||
bool should_colorize = false;
|
||||
|
||||
#ifndef WIN32
|
||||
if (isatty(fileno(stdout))) {
|
||||
// By default, only print colored text if OS is not WIN32 and stdout is connected to a terminal.
|
||||
should_colorize = true;
|
||||
}
|
||||
#endif
|
||||
|
||||
if (gArgs.IsArgSet("-color")) {
|
||||
const std::string color{gArgs.GetArg("-color", DEFAULT_COLOR_SETTING)};
|
||||
if (color == "always") {
|
||||
should_colorize = true;
|
||||
} else if (color == "never") {
|
||||
should_colorize = false;
|
||||
} else if (color != "auto") {
|
||||
throw std::runtime_error("Invalid value for -color option. Valid values: always, auto, never.");
|
||||
}
|
||||
}
|
||||
|
||||
if (should_colorize) {
|
||||
RESET = "\x1B[0m";
|
||||
GREEN = "\x1B[32m";
|
||||
BLUE = "\x1B[34m";
|
||||
YELLOW = "\x1B[33m";
|
||||
MAGENTA = "\x1B[35m";
|
||||
CYAN = "\x1B[36m";
|
||||
}
|
||||
|
||||
std::string result_string = strprintf("%sChain: %s%s\n", BLUE, result["chain"].getValStr(), RESET);
|
||||
result_string += strprintf("Blocks: %s\n", result["blocks"].getValStr());
|
||||
result_string += strprintf("Headers: %s\n", result["headers"].getValStr());
|
||||
result_string += strprintf("Verification progress: %.4f%%\n", result["verificationprogress"].get_real() * 100);
|
||||
result_string += strprintf("Difficulty: %s\n\n", result["difficulty"].getValStr());
|
||||
|
||||
result_string += strprintf(
|
||||
"%sNetwork: in %s, out %s, total %s%s\n",
|
||||
GREEN,
|
||||
result["connections"]["in"].getValStr(),
|
||||
result["connections"]["out"].getValStr(),
|
||||
result["connections"]["total"].getValStr(),
|
||||
RESET);
|
||||
result_string += strprintf("Version: %s\n", result["version"].getValStr());
|
||||
result_string += strprintf("Time offset (s): %s\n", result["timeoffset"].getValStr());
|
||||
const std::string proxy = result["proxy"].getValStr();
|
||||
result_string += strprintf("Proxy: %s\n", proxy.empty() ? "N/A" : proxy);
|
||||
result_string += strprintf("Min tx relay fee rate (%s/kvB): %s\n\n", CURRENCY_UNIT, result["relayfee"].getValStr());
|
||||
|
||||
if (!result["has_wallet"].isNull()) {
|
||||
const std::string walletname = result["walletname"].getValStr();
|
||||
result_string += strprintf("%sWallet: %s%s\n", MAGENTA, walletname.empty() ? "\"\"" : walletname, RESET);
|
||||
|
||||
result_string += strprintf("Keypool size: %s\n", result["keypoolsize"].getValStr());
|
||||
if (!result["unlocked_until"].isNull()) {
|
||||
result_string += strprintf("Unlocked until: %s\n", result["unlocked_until"].getValStr());
|
||||
}
|
||||
result_string += strprintf("Transaction fee rate (-paytxfee) (%s/kvB): %s\n\n", CURRENCY_UNIT, result["paytxfee"].getValStr());
|
||||
}
|
||||
if (!result["balance"].isNull()) {
|
||||
result_string += strprintf("%sBalance:%s %s\n\n", CYAN, RESET, result["balance"].getValStr());
|
||||
}
|
||||
|
||||
if (!result["balances"].isNull()) {
|
||||
result_string += strprintf("%sBalances%s\n", CYAN, RESET);
|
||||
|
||||
size_t max_balance_length{10};
|
||||
|
||||
for (const std::string& wallet : result["balances"].getKeys()) {
|
||||
max_balance_length = std::max(result["balances"][wallet].getValStr().length(), max_balance_length);
|
||||
}
|
||||
|
||||
for (const std::string& wallet : result["balances"].getKeys()) {
|
||||
result_string += strprintf("%*s %s\n",
|
||||
max_balance_length,
|
||||
result["balances"][wallet].getValStr(),
|
||||
wallet.empty() ? "\"\"" : wallet);
|
||||
}
|
||||
result_string += "\n";
|
||||
}
|
||||
|
||||
result_string += strprintf("%sWarnings:%s %s", YELLOW, RESET, result["warnings"].getValStr());
|
||||
result.setStr(result_string);
|
||||
}
|
||||
|
||||
/**
|
||||
* Call RPC getnewaddress.
|
||||
* @returns getnewaddress response as a UniValue object.
|
||||
@@ -994,9 +1099,13 @@ static int CommandLineRPC(int argc, char *argv[])
|
||||
UniValue result = find_value(reply, "result");
|
||||
const UniValue& error = find_value(reply, "error");
|
||||
if (error.isNull()) {
|
||||
if (gArgs.IsArgSet("-getinfo") && !gArgs.IsArgSet("-rpcwallet")) {
|
||||
GetWalletBalances(result); // fetch multiwallet balances and append to result
|
||||
if (gArgs.GetBoolArg("-getinfo", false)) {
|
||||
if (!gArgs.IsArgSet("-rpcwallet")) {
|
||||
GetWalletBalances(result); // fetch multiwallet balances and append to result
|
||||
}
|
||||
ParseGetInfoResult(result);
|
||||
}
|
||||
|
||||
ParseResult(result, strPrint);
|
||||
} else {
|
||||
ParseError(error, strPrint, nRet);
|
||||
|
||||
Reference in New Issue
Block a user