6#include <bitcoin-build-config.h>
8#include <chainparams.h>
30#ifdef HAVE_MALLOC_INFO
39 "\nSet the local time to given timestamp (-regtest only)\n",
42 "Pass 0 to go back to using the system time."},
49 throw std::runtime_error(
"setmocktime is for regression testing (-regtest mode) only");
59 const int64_t time{request.params[0].getInt<int64_t>()};
60 constexpr int64_t max_time{Ticks<std::chrono::seconds>(std::chrono::nanoseconds::max())};
61 if (time < 0 || time > max_time) {
67 for (
const auto& chain_client : node_context.chain_clients) {
68 chain_client->setMockTime(time);
79 "\nBump the scheduler into the future (-regtest only)\n",
88 throw std::runtime_error(
"mockscheduler is for regression testing (-regtest mode) only");
91 int64_t delta_seconds = request.params[0].getInt<int64_t>();
92 if (delta_seconds <= 0 || delta_seconds > 3600) {
93 throw std::runtime_error(
"delta_time must be between 1 and 3600 seconds (1 hr)");
97 CHECK_NONFATAL(node_context.scheduler)->MockForward(std::chrono::seconds{delta_seconds});
98 CHECK_NONFATAL(node_context.validation_signals)->SyncWithValidationInterfaceQueue();
99 for (
const auto& chain_client : node_context.chain_clients) {
100 chain_client->schedulerMockForward(std::chrono::seconds(delta_seconds));
121#ifdef HAVE_MALLOC_INFO
122static std::string RPCMallocInfo()
126 FILE *f = open_memstream(&ptr, &size);
131 std::string rv(ptr, size);
146 "Returns an object containing information about memory usage.\n",
149 " - \"stats\" returns general statistics about memory usage in the daemon.\n"
150 " - \"mallocinfo\" returns an XML string describing low-level heap state (only available if compiled with glibc)."},
161 {
RPCResult::Type::NUM,
"locked",
"Amount of bytes that succeeded locking. If this number is smaller than total, locking pages failed at some point and key data could be swapped to disk."},
177 std::string mode = request.params[0].
isNull() ?
"stats" : request.params[0].get_str();
178 if (mode ==
"stats") {
182 }
else if (mode ==
"mallocinfo") {
183#ifdef HAVE_MALLOC_INFO
184 return RPCMallocInfo();
197 for (
unsigned int i = 0; i < cats.
size(); ++i) {
198 std::string cat = cats[i].
get_str();
216 "Gets and sets the logging configuration.\n"
217 "When called without an argument, returns the list of categories with status that are currently being debug logged or not.\n"
218 "When called with arguments, adds or removes categories from debug logging and return the lists above.\n"
219 "The arguments are evaluated in order \"include\", \"exclude\".\n"
220 "If an item is both included and excluded, it will thus end up being excluded.\n"
222 "In addition, the following are available as category names with special meanings:\n"
223 " - \"all\", \"1\" : represent all logging categories.\n"
248 if (request.params[0].isArray()) {
251 if (request.params[1].isArray()) {
255 BCLog::CategoryMask changed_log_categories = original_log_categories ^ updated_log_categories;
263 for (
const auto& logCatActive :
LogInstance().LogCategoriesList()) {
264 result.
pushKV(logCatActive.category, logCatActive.active);
275 "\nSimply echo back the input arguments. This command is for testing.\n"
276 "\nIt will return an internal bug report when arg9='trigger_internal_bug' is passed.\n"
277 "\nThe difference between echo and echojson is that echojson has argument conversion enabled in the client-side table in "
278 "bitcoin-cli and the GUI. There is no server-side difference.",
295 if (request.params[9].isStr()) {
296 CHECK_NONFATAL(request.params[9].get_str() !=
"trigger_internal_bug");
299 return request.params;
311 "\nEcho back the input argument, passing it through a spawned process in a multiprocess build.\n"
312 "This command is for testing.\n",
319 std::unique_ptr<interfaces::Echo>
echo;
329 auto init =
ipc->spawnProcess(
"bitcoin-node");
340 return echo->echo(request.params[0].get_str());
348 if (!index_name.empty() && index_name != summary.name)
return ret_summary;
351 entry.
pushKV(
"synced", summary.synced);
352 entry.
pushKV(
"best_block_height", summary.best_block_height);
353 ret_summary.
pushKV(summary.name, std::move(entry));
360 "\nReturns the status of one or all available indices currently running in the node.\n",
384 const std::string index_name = request.params[0].isNull() ?
"" : request.params[0].get_str();
415 for (
const auto& c : commands) {
416 t.appendCommand(c.name, &c);
void ForEachBlockFilterIndex(std::function< void(BlockFilterIndex &)> fn)
Iterate over all running block filter indexes, invoking fn on each.
const CChainParams & Params()
Return the currently selected parameters.
#define CHECK_NONFATAL(condition)
Identity function.
CategoryMask GetCategoryMask() const
void EnableCategory(LogFlags flag)
std::string LogCategoriesString() const
Returns a string with the log categories in alphabetical order.
void DisableCategory(LogFlags flag)
IndexSummary GetSummary() const
Get a summary of the index and its state.
BlockFilterIndex is used to store and retrieve block filters, hashes, and headers for a range of bloc...
bool IsMockableChain() const
If this chain allows time to be mocked.
Stats stats() const
Get pool usage statistics.
static LockedPoolManager & Instance()
Return the current instance, or create it once.
const std::string & get_str() const
void pushKVs(UniValue obj)
const UniValue & get_array() const
void pushKV(std::string key, UniValue val)
Initial interface created when a process is first started, and used to give and get access to other i...
virtual std::unique_ptr< Echo > makeEcho()
Interface providing access to interprocess-communication (IPC) functionality.
std::unique_ptr< CoinStatsIndex > g_coin_stats_index
The global UTXO set hash object.
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate.
void UpdateHTTPServerLogging(bool enable)
Change logging level for libevent.
BCLog::Logger & LogInstance()
static RPCHelpMan logging()
static RPCHelpMan setmocktime()
void RegisterNodeRPCCommands(CRPCTable &t)
static void EnableOrDisableLogCategories(UniValue cats, bool enable)
static UniValue RPCLockedMemoryInfo()
static RPCHelpMan mockscheduler()
static RPCHelpMan getmemoryinfo()
static RPCHelpMan echo(const std::string &name)
static UniValue SummaryToJSON(const IndexSummary &&summary, std::string index_name)
static RPCHelpMan echojson()
static RPCHelpMan echoipc()
static RPCHelpMan getindexinfo()
UniValue JSONRPCError(int code, const std::string &message)
@ RPC_INVALID_PARAMETER
Invalid, missing or duplicate parameter.
std::string HelpExampleCli(const std::string &methodname, const std::string &args)
std::string HelpExampleRpc(const std::string &methodname, const std::string &args)
const std::string UNIX_EPOCH_TIME
String used to describe UNIX epoch time in documentation, factored out to a constant for consistency.
NodeContext & EnsureAnyNodeContext(const std::any &context)
@ OMITTED
Optional argument for which the default value is omitted from help text for one of two reasons:
@ ANY
Special type to disable type checks (for testing only)
@ OBJ_DYN
Special dictionary with keys that are not literals.
NodeContext struct containing references to chain state and connection state.
interfaces::Init * init
Init interface for initializing current process and connecting to other processes.
void SetMockTime(int64_t nMockTimeIn)
DEPRECATED Use SetMockTime with chrono type.
std::unique_ptr< TxIndex > g_txindex
The global transaction index, used in GetTransaction. May be null.