Bitcoin ABC 0.32.4
P2P Digital Currency
net.cpp
Go to the documentation of this file.
1// Copyright (c) 2009-2019 The Bitcoin Core developers
2// Distributed under the MIT software license, see the accompanying
3// file COPYING or http://www.opensource.org/licenses/mit-license.php.
4
5#include <rpc/server.h>
6
7#include <addrman.h>
9#include <banman.h>
10#include <chainparams.h>
11#include <clientversion.h>
12#include <config.h>
13#include <net_permissions.h>
14#include <net_processing.h>
15#include <net_types.h> // For banmap_t
16#include <netbase.h>
17#include <node/context.h>
18#include <policy/settings.h>
19#include <rpc/blockchain.h>
20#include <rpc/protocol.h>
21#include <rpc/server_util.h>
22#include <rpc/util.h>
23#include <sync.h>
24#include <timedata.h>
25#include <util/chaintype.h>
26#include <util/strencodings.h>
27#include <util/string.h>
28#include <util/time.h>
29#include <util/translation.h>
30#include <validation.h>
31#include <version.h>
32#include <warnings.h>
33
34#include <optional>
35
36#include <univalue.h>
37
39
41 return RPCHelpMan{
42 "getconnectioncount",
43 "Returns the number of connections to other nodes.\n",
44 {},
45 RPCResult{RPCResult::Type::NUM, "", "The connection count"},
46 RPCExamples{HelpExampleCli("getconnectioncount", "") +
47 HelpExampleRpc("getconnectioncount", "")},
48 [&](const RPCHelpMan &self, const Config &config,
49 const JSONRPCRequest &request) -> UniValue {
50 NodeContext &node = EnsureAnyNodeContext(request.context);
51 const CConnman &connman = EnsureConnman(node);
52
54 },
55 };
56}
57
58static RPCHelpMan ping() {
59 return RPCHelpMan{
60 "ping",
61 "Requests that a ping be sent to all other nodes, to measure ping "
62 "time.\n"
63 "Results provided in getpeerinfo, pingtime and pingwait fields are "
64 "decimal seconds.\n"
65 "Ping command is handled in queue with all other commands, so it "
66 "measures processing backlog, not just network ping.\n",
67 {},
69 RPCExamples{HelpExampleCli("ping", "") + HelpExampleRpc("ping", "")},
70 [&](const RPCHelpMan &self, const Config &config,
71 const JSONRPCRequest &request) -> UniValue {
72 NodeContext &node = EnsureAnyNodeContext(request.context);
73 PeerManager &peerman = EnsurePeerman(node);
74
75 // Request that each node send a ping during next message processing
76 // pass
77 peerman.SendPings();
78 return NullUniValue;
79 },
80 };
81}
82
84 return RPCHelpMan{
85 "getpeerinfo",
86 "Returns data about each connected network node as a json array of "
87 "objects.\n",
88 {},
91 "",
92 "",
93 {{
95 "",
96 "",
97 {{
98 {RPCResult::Type::NUM, "id", "Peer index"},
99 {RPCResult::Type::STR, "addr",
100 "(host:port) The IP address and port of the peer"},
101 {RPCResult::Type::STR, "addrbind",
102 "(ip:port) Bind address of the connection to the peer"},
103 {RPCResult::Type::STR, "addrlocal",
104 "(ip:port) Local address as reported by the peer"},
105 {RPCResult::Type::NUM, "addr_processed",
106 "The total number of addresses processed, excluding those "
107 "dropped due to rate limiting"},
108 {RPCResult::Type::NUM, "addr_rate_limited",
109 "The total number of addresses dropped due to rate "
110 "limiting"},
111 {RPCResult::Type::STR, "network",
112 "Network (" +
113 Join(GetNetworkNames(/* append_unroutable */ true),
114 ", ") +
115 ")"},
116 {RPCResult::Type::NUM, "mapped_as",
117 "The AS in the BGP route to the peer used for "
118 "diversifying\n"
119 "peer selection (only available if the asmap config flag "
120 "is set)\n"},
121 {RPCResult::Type::STR_HEX, "services",
122 "The services offered"},
124 "servicesnames",
125 "the services offered, in human-readable form",
126 {{RPCResult::Type::STR, "SERVICE_NAME",
127 "the service name if it is recognised"}}},
128 {RPCResult::Type::BOOL, "relaytxes",
129 "Whether peer has asked us to relay transactions to it"},
130 {RPCResult::Type::NUM_TIME, "lastsend",
131 "The " + UNIX_EPOCH_TIME + " of the last send"},
132 {RPCResult::Type::NUM_TIME, "lastrecv",
133 "The " + UNIX_EPOCH_TIME + " of the last receive"},
134 {RPCResult::Type::NUM_TIME, "last_transaction",
135 "The " + UNIX_EPOCH_TIME +
136 " of the last valid transaction received from this "
137 "peer"},
138 {RPCResult::Type::NUM_TIME, "last_block",
139 "The " + UNIX_EPOCH_TIME +
140 " of the last block received from this peer"},
141 {RPCResult::Type::NUM, "bytessent", "The total bytes sent"},
142 {RPCResult::Type::NUM, "bytesrecv",
143 "The total bytes received"},
144 {RPCResult::Type::NUM_TIME, "conntime",
145 "The " + UNIX_EPOCH_TIME + " of the connection"},
146 {RPCResult::Type::NUM, "timeoffset",
147 "The time offset in seconds"},
148 {RPCResult::Type::NUM, "pingtime",
149 "ping time (if available)"},
150 {RPCResult::Type::NUM, "minping",
151 "minimum observed ping time (if any at all)"},
152 {RPCResult::Type::NUM, "pingwait",
153 "ping wait (if non-zero)"},
154 {RPCResult::Type::NUM, "version",
155 "The peer version, such as 70001"},
156 {RPCResult::Type::STR, "subver", "The string version"},
157 {RPCResult::Type::BOOL, "inbound",
158 "Inbound (true) or Outbound (false)"},
159 {RPCResult::Type::BOOL, "bip152_hb_to",
160 "Whether we selected peer as (compact blocks) "
161 "high-bandwidth peer"},
162 {RPCResult::Type::BOOL, "bip152_hb_from",
163 "Whether peer selected us as (compact blocks) "
164 "high-bandwidth peer"},
165 {RPCResult::Type::STR, "connection_type",
166 "Type of connection: \n" +
167 Join(CONNECTION_TYPE_DOC, ",\n") + "."},
168 {RPCResult::Type::NUM, "startingheight",
169 "The starting height (block) of the peer"},
170 {RPCResult::Type::NUM, "presynced_headers",
171 /*optional=*/true,
172 "The current height of header pre-synchronization with "
173 "this peer, or -1 if no low-work sync is in progress"},
174 {RPCResult::Type::NUM, "synced_headers",
175 "The last header we have in common with this peer"},
176 {RPCResult::Type::NUM, "synced_blocks",
177 "The last block we have in common with this peer"},
179 "inflight",
180 "",
181 {
183 "The heights of blocks we're currently asking from "
184 "this peer"},
185 }},
186 {RPCResult::Type::BOOL, "addr_relay_enabled",
187 "Whether we participate in address relay with this peer"},
188 {RPCResult::Type::NUM, "minfeefilter",
189 "The minimum fee rate for transactions this peer accepts"},
191 "bytessent_per_msg",
192 "",
193 {{RPCResult::Type::NUM, "msg",
194 "The total bytes sent aggregated by message type\n"
195 "When a message type is not listed in this json object, "
196 "the bytes sent are 0.\n"
197 "Only known message types can appear as keys in the "
198 "object."}}},
200 "bytesrecv_per_msg",
201 "",
202 {{RPCResult::Type::NUM, "msg",
203 "The total bytes received aggregated by message type\n"
204 "When a message type is not listed in this json object, "
205 "the bytes received are 0.\n"
206 "Only known message types can appear as keys in the "
207 "object and all bytes received\n"
208 "of unknown message types are listed under '" +
209 NET_MESSAGE_TYPE_OTHER + "'."}}},
210 {RPCResult::Type::NUM, "availability_score",
211 "DEPRECATED: Avalanche availability score of this node "
212 "(if any). Only present if the "
213 "deprecatedrpc=node_availability_score option is enabled"},
214 }},
215 }},
216 },
217 RPCExamples{HelpExampleCli("getpeerinfo", "") +
218 HelpExampleRpc("getpeerinfo", "")},
219 [&](const RPCHelpMan &self, const Config &config,
220 const JSONRPCRequest &request) -> UniValue {
221 NodeContext &node = EnsureAnyNodeContext(request.context);
222 const CConnman &connman = EnsureConnman(node);
223 const PeerManager &peerman = EnsurePeerman(node);
224 const ArgsManager &argsman = EnsureArgsman(node);
225
226 std::vector<CNodeStats> vstats;
227 connman.GetNodeStats(vstats);
228
230
231 for (const CNodeStats &stats : vstats) {
233 CNodeStateStats statestats;
234 bool fStateStats =
235 peerman.GetNodeStateStats(stats.nodeid, statestats);
236 obj.pushKV("id", stats.nodeid);
237 obj.pushKV("addr", stats.m_addr_name);
238 if (stats.addrBind.IsValid()) {
239 obj.pushKV("addrbind", stats.addrBind.ToString());
240 }
241 if (!(stats.addrLocal.empty())) {
242 obj.pushKV("addrlocal", stats.addrLocal);
243 }
244 obj.pushKV("network", GetNetworkName(stats.m_network));
245 if (stats.m_mapped_as != 0) {
246 obj.pushKV("mapped_as", uint64_t(stats.m_mapped_as));
247 }
248 ServiceFlags services{fStateStats ? statestats.their_services
250 obj.pushKV("services", strprintf("%016x", services));
251 obj.pushKV("servicesnames", GetServicesNames(services));
252 obj.pushKV("lastsend", count_seconds(stats.m_last_send));
253 obj.pushKV("lastrecv", count_seconds(stats.m_last_recv));
254 obj.pushKV("last_transaction",
255 count_seconds(stats.m_last_tx_time));
256 if (node.avalanche) {
257 obj.pushKV("last_proof",
258 count_seconds(stats.m_last_proof_time));
259 }
260 obj.pushKV("last_block",
261 count_seconds(stats.m_last_block_time));
262 obj.pushKV("bytessent", stats.nSendBytes);
263 obj.pushKV("bytesrecv", stats.nRecvBytes);
264 obj.pushKV("conntime", count_seconds(stats.m_connected));
265 obj.pushKV("timeoffset", stats.nTimeOffset);
266 if (stats.m_last_ping_time > 0us) {
267 obj.pushKV("pingtime",
268 CountSecondsDouble(stats.m_last_ping_time));
269 }
270 if (stats.m_min_ping_time < std::chrono::microseconds::max()) {
271 obj.pushKV("minping",
272 CountSecondsDouble(stats.m_min_ping_time));
273 }
274 if (fStateStats && statestats.m_ping_wait > 0s) {
275 obj.pushKV("pingwait",
276 CountSecondsDouble(statestats.m_ping_wait));
277 }
278 obj.pushKV("version", stats.nVersion);
279 // Use the sanitized form of subver here, to avoid tricksy
280 // remote peers from corrupting or modifying the JSON output by
281 // putting special characters in their ver message.
282 obj.pushKV("subver", stats.cleanSubVer);
283 obj.pushKV("inbound", stats.fInbound);
284 obj.pushKV("bip152_hb_to", stats.m_bip152_highbandwidth_to);
285 obj.pushKV("bip152_hb_from", stats.m_bip152_highbandwidth_from);
286 if (fStateStats) {
287 obj.pushKV("startingheight", statestats.m_starting_height);
288 obj.pushKV("presynced_headers", statestats.presync_height);
289 obj.pushKV("synced_headers", statestats.nSyncHeight);
290 obj.pushKV("synced_blocks", statestats.nCommonHeight);
291 UniValue heights(UniValue::VARR);
292 for (const int height : statestats.vHeightInFlight) {
293 heights.push_back(height);
294 }
295 obj.pushKV("inflight", heights);
296 obj.pushKV("relaytxes", statestats.m_relay_txs);
297 obj.pushKV("minfeefilter",
298 statestats.m_fee_filter_received);
299 obj.pushKV("addr_relay_enabled",
300 statestats.m_addr_relay_enabled);
301 obj.pushKV("addr_processed", statestats.m_addr_processed);
302 obj.pushKV("addr_rate_limited",
303 statestats.m_addr_rate_limited);
304 }
305 UniValue permissions(UniValue::VARR);
306 for (const auto &permission :
307 NetPermissions::ToStrings(stats.m_permission_flags)) {
308 permissions.push_back(permission);
309 }
310 obj.pushKV("permissions", permissions);
311
312 UniValue sendPerMsgType(UniValue::VOBJ);
313 for (const auto &i : stats.mapSendBytesPerMsgType) {
314 if (i.second > 0) {
315 sendPerMsgType.pushKV(i.first, i.second);
316 }
317 }
318 obj.pushKV("bytessent_per_msg", sendPerMsgType);
319
320 UniValue recvPerMsgType(UniValue::VOBJ);
321 for (const auto &i : stats.mapRecvBytesPerMsgType) {
322 if (i.second > 0) {
323 recvPerMsgType.pushKV(i.first, i.second);
324 }
325 }
326 obj.pushKV("bytesrecv_per_msg", recvPerMsgType);
327 obj.pushKV("connection_type",
328 ConnectionTypeAsString(stats.m_conn_type));
329
330 if (IsDeprecatedRPCEnabled(argsman,
331 "node_availability_score") &&
332 stats.m_availabilityScore) {
333 obj.pushKV("availability_score",
334 *stats.m_availabilityScore);
335 }
336
337 ret.push_back(obj);
338 }
339
340 return ret;
341 },
342 };
343}
344
346 return RPCHelpMan{
347 "addnode",
348 "Attempts to add or remove a node from the addnode list.\n"
349 "Or try a connection to a node once.\n"
350 "Nodes added using addnode (or -connect) are protected from "
351 "DoS disconnection and are not required to be\n"
352 "full nodes as other outbound peers are (though such peers "
353 "will not be synced from).\n",
354 {
356 "The address of the peer to connect to"},
358 "'add' to add a node to the list, 'remove' to remove a "
359 "node from the list, 'onetry' to try a connection to the "
360 "node once"},
361 },
364 HelpExampleCli("addnode", "\"192.168.0.6:8333\" \"onetry\"") +
365 HelpExampleRpc("addnode", "\"192.168.0.6:8333\", \"onetry\"")},
366 [&](const RPCHelpMan &self, const Config &config,
367 const JSONRPCRequest &request) -> UniValue {
368 const auto command{self.Arg<std::string>("command")};
369 if (command != "onetry" && command != "add" &&
370 command != "remove") {
371 throw std::runtime_error(self.ToString());
372 }
373
374 NodeContext &node = EnsureAnyNodeContext(request.context);
375 CConnman &connman = EnsureConnman(node);
376
377 const auto node_arg{self.Arg<std::string>("node")};
378 // TODO: apply core#29277 when backporting the "v2transport" arg
379
380 if (command == "onetry") {
381 CAddress addr;
382 connman.OpenNetworkConnection(
383 addr, /*fCountFailure=*/false, /*grantOutbound=*/nullptr,
384 node_arg.c_str(), ConnectionType::MANUAL);
385 return NullUniValue;
386 }
387
388 if ((command == "add") && (!connman.AddNode(node_arg))) {
390 "Error: Node already added");
391 } else if ((command == "remove") &&
392 (!connman.RemoveAddedNode(node_arg))) {
393 throw JSONRPCError(
395 "Error: Node could not be removed. It has not been "
396 "added previously.");
397 }
398
399 return NullUniValue;
400 },
401 };
402}
403
405 return RPCHelpMan{
406 "addconnection",
407 "\nOpen an outbound connection to a specified node. This RPC is for "
408 "testing only.\n",
409 {
411 "The IP address and port to attempt connecting to."},
412 {"connection_type", RPCArg::Type::STR, RPCArg::Optional::NO,
413 "Type of connection to open (\"outbound-full-relay\", "
414 "\"block-relay-only\", \"addr-fetch\", \"feeler\" or "
415 "\"avalanche\")."},
416 },
418 "",
419 "",
420 {
421 {RPCResult::Type::STR, "address",
422 "Address of newly added connection."},
423 {RPCResult::Type::STR, "connection_type",
424 "Type of connection opened."},
425 }},
427 HelpExampleCli("addconnection",
428 "\"192.168.0.6:8333\" \"outbound-full-relay\"") +
429 HelpExampleRpc("addconnection",
430 "\"192.168.0.6:8333\" \"outbound-full-relay\"")},
431 [&](const RPCHelpMan &self, const Config &config,
432 const JSONRPCRequest &request) -> UniValue {
433 if (config.GetChainParams().GetChainType() != ChainType::REGTEST) {
434 throw std::runtime_error("addconnection is for regression "
435 "testing (-regtest mode) only.");
436 }
437
438 NodeContext &node = EnsureAnyNodeContext(request.context);
439
440 const std::string address = request.params[0].get_str();
441 const std::string conn_type_in{
442 TrimString(request.params[1].get_str())};
443 ConnectionType conn_type{};
444 if (conn_type_in == "outbound-full-relay") {
446 } else if (conn_type_in == "block-relay-only") {
447 conn_type = ConnectionType::BLOCK_RELAY;
448 } else if (conn_type_in == "addr-fetch") {
449 conn_type = ConnectionType::ADDR_FETCH;
450 } else if (conn_type_in == "feeler") {
451 conn_type = ConnectionType::FEELER;
452 } else if (conn_type_in == "avalanche") {
453 if (!node.avalanche) {
455 "Error: avalanche outbound requested "
456 "but avalanche is not enabled.");
457 }
459 } else {
461 }
462
463 CConnman &connman = EnsureConnman(node);
464
465 const bool success = connman.AddConnection(address, conn_type);
466 if (!success) {
468 "Error: Already at capacity for specified "
469 "connection type.");
470 }
471
473 info.pushKV("address", address);
474 info.pushKV("connection_type", conn_type_in);
475
476 return info;
477 },
478 };
479}
480
482 return RPCHelpMan{
483 "disconnectnode",
484 "Immediately disconnects from the specified peer node.\n"
485 "\nStrictly one out of 'address' and 'nodeid' can be provided to "
486 "identify the node.\n"
487 "\nTo disconnect by nodeid, either set 'address' to the empty string, "
488 "or call using the named 'nodeid' argument only.\n",
489 {
490 {"address", RPCArg::Type::STR,
491 RPCArg::DefaultHint{"fallback to nodeid"},
492 "The IP address/port of the node"},
493 {"nodeid", RPCArg::Type::NUM,
494 RPCArg::DefaultHint{"fallback to address"},
495 "The node ID (see getpeerinfo for node IDs)"},
496 },
498 RPCExamples{HelpExampleCli("disconnectnode", "\"192.168.0.6:8333\"") +
499 HelpExampleCli("disconnectnode", "\"\" 1") +
500 HelpExampleRpc("disconnectnode", "\"192.168.0.6:8333\"") +
501 HelpExampleRpc("disconnectnode", "\"\", 1")},
502 [&](const RPCHelpMan &self, const Config &config,
503 const JSONRPCRequest &request) -> UniValue {
504 NodeContext &node = EnsureAnyNodeContext(request.context);
505 CConnman &connman = EnsureConnman(node);
506
507 bool success;
508 const UniValue &address_arg = request.params[0];
509 const UniValue &id_arg = request.params[1];
510
511 if (!address_arg.isNull() && id_arg.isNull()) {
512 /* handle disconnect-by-address */
513 success = connman.DisconnectNode(address_arg.get_str());
514 } else if (!id_arg.isNull() && (address_arg.isNull() ||
515 (address_arg.isStr() &&
516 address_arg.get_str().empty()))) {
517 /* handle disconnect-by-id */
518 NodeId nodeid = (NodeId)id_arg.getInt<int64_t>();
519 success = connman.DisconnectNode(nodeid);
520 } else {
521 throw JSONRPCError(
523 "Only one of address and nodeid should be provided.");
524 }
525
526 if (!success) {
528 "Node not found in connected nodes");
529 }
530
531 return NullUniValue;
532 },
533 };
534}
535
537 return RPCHelpMan{
538 "getaddednodeinfo",
539 "Returns information about the given added node, or all added nodes\n"
540 "(note that onetry addnodes are not listed here)\n",
541 {
542 {"node", RPCArg::Type::STR, RPCArg::DefaultHint{"all nodes"},
543 "If provided, return information about this specific node, "
544 "otherwise all nodes are returned."},
545 },
546 RPCResult{
548 "",
549 "",
550 {
552 "",
553 "",
554 {
555 {RPCResult::Type::STR, "addednode",
556 "The node IP address or name (as provided to addnode)"},
557 {RPCResult::Type::BOOL, "connected", "If connected"},
559 "addresses",
560 "Only when connected = true",
561 {
563 "",
564 "",
565 {
566 {RPCResult::Type::STR, "address",
567 "The bitcoin server IP and port we're "
568 "connected to"},
569 {RPCResult::Type::STR, "connected",
570 "connection, inbound or outbound"},
571 }},
572 }},
573 }},
574 }},
575 RPCExamples{HelpExampleCli("getaddednodeinfo", "\"192.168.0.201\"") +
576 HelpExampleRpc("getaddednodeinfo", "\"192.168.0.201\"")},
577 [&](const RPCHelpMan &self, const Config &config,
578 const JSONRPCRequest &request) -> UniValue {
579 NodeContext &node = EnsureAnyNodeContext(request.context);
580 const CConnman &connman = EnsureConnman(node);
581
582 std::vector<AddedNodeInfo> vInfo = connman.GetAddedNodeInfo();
583
584 if (!request.params[0].isNull()) {
585 bool found = false;
586 for (const AddedNodeInfo &info : vInfo) {
587 if (info.strAddedNode == request.params[0].get_str()) {
588 vInfo.assign(1, info);
589 found = true;
590 break;
591 }
592 }
593 if (!found) {
595 "Error: Node has not been added.");
596 }
597 }
598
600
601 for (const AddedNodeInfo &info : vInfo) {
603 obj.pushKV("addednode", info.strAddedNode);
604 obj.pushKV("connected", info.fConnected);
605 UniValue addresses(UniValue::VARR);
606 if (info.fConnected) {
607 UniValue address(UniValue::VOBJ);
608 address.pushKV("address", info.resolvedAddress.ToString());
609 address.pushKV("connected",
610 info.fInbound ? "inbound" : "outbound");
611 addresses.push_back(address);
612 }
613 obj.pushKV("addresses", addresses);
614 ret.push_back(obj);
615 }
616
617 return ret;
618 },
619 };
620}
621
623 return RPCHelpMan{
624 "getnettotals",
625 "Returns information about network traffic, including bytes in, "
626 "bytes out,\n"
627 "and current time.\n",
628 {},
629 RPCResult{
631 "",
632 "",
633 {
634 {RPCResult::Type::NUM, "totalbytesrecv",
635 "Total bytes received"},
636 {RPCResult::Type::NUM, "totalbytessent", "Total bytes sent"},
637 {RPCResult::Type::NUM_TIME, "timemillis",
638 "Current " + UNIX_EPOCH_TIME + " in milliseconds"},
640 "uploadtarget",
641 "",
642 {
643 {RPCResult::Type::NUM, "timeframe",
644 "Length of the measuring timeframe in seconds"},
645 {RPCResult::Type::NUM, "target", "Target in bytes"},
646 {RPCResult::Type::BOOL, "target_reached",
647 "True if target is reached"},
648 {RPCResult::Type::BOOL, "serve_historical_blocks",
649 "True if serving historical blocks"},
650 {RPCResult::Type::NUM, "bytes_left_in_cycle",
651 "Bytes left in current time cycle"},
652 {RPCResult::Type::NUM, "time_left_in_cycle",
653 "Seconds left in current time cycle"},
654 }},
655 }},
656 RPCExamples{HelpExampleCli("getnettotals", "") +
657 HelpExampleRpc("getnettotals", "")},
658 [&](const RPCHelpMan &self, const Config &config,
659 const JSONRPCRequest &request) -> UniValue {
660 NodeContext &node = EnsureAnyNodeContext(request.context);
661 const CConnman &connman = EnsureConnman(node);
662
664 obj.pushKV("totalbytesrecv", connman.GetTotalBytesRecv());
665 obj.pushKV("totalbytessent", connman.GetTotalBytesSent());
666 obj.pushKV("timemillis", GetTimeMillis());
667
668 UniValue outboundLimit(UniValue::VOBJ);
669 outboundLimit.pushKV(
670 "timeframe", count_seconds(connman.GetMaxOutboundTimeframe()));
671 outboundLimit.pushKV("target", connman.GetMaxOutboundTarget());
672 outboundLimit.pushKV("target_reached",
673 connman.OutboundTargetReached(false));
674 outboundLimit.pushKV("serve_historical_blocks",
675 !connman.OutboundTargetReached(true));
676 outboundLimit.pushKV("bytes_left_in_cycle",
678 outboundLimit.pushKV(
679 "time_left_in_cycle",
681 obj.pushKV("uploadtarget", outboundLimit);
682 return obj;
683 },
684 };
685}
686
688 UniValue networks(UniValue::VARR);
689 for (int n = 0; n < NET_MAX; ++n) {
690 enum Network network = static_cast<enum Network>(n);
691 if (network == NET_UNROUTABLE || network == NET_CJDNS ||
692 network == NET_INTERNAL) {
693 continue;
694 }
695 proxyType proxy;
697 GetProxy(network, proxy);
698 obj.pushKV("name", GetNetworkName(network));
699 obj.pushKV("limited", !IsReachable(network));
700 obj.pushKV("reachable", IsReachable(network));
701 obj.pushKV("proxy", proxy.IsValid() ? proxy.proxy.ToStringIPPort()
702 : std::string());
703 obj.pushKV("proxy_randomize_credentials", proxy.randomize_credentials);
704 networks.push_back(obj);
705 }
706 return networks;
707}
708
710 const auto &ticker = Currency::get().ticker;
711 return RPCHelpMan{
712 "getnetworkinfo",
713 "Returns an object containing various state info regarding P2P "
714 "networking.\n",
715 {},
716 RPCResult{
718 "",
719 "",
720 {
721 {RPCResult::Type::NUM, "version", "the server version"},
722 {RPCResult::Type::STR, "subversion",
723 "the server subversion string"},
724 {RPCResult::Type::NUM, "protocolversion",
725 "the protocol version"},
726 {RPCResult::Type::STR_HEX, "localservices",
727 "the services we offer to the network"},
729 "localservicesnames",
730 "the services we offer to the network, in human-readable form",
731 {
732 {RPCResult::Type::STR, "SERVICE_NAME", "the service name"},
733 }},
734 {RPCResult::Type::BOOL, "localrelay",
735 "true if transaction relay is requested from peers"},
736 {RPCResult::Type::NUM, "timeoffset", "the time offset"},
737 {RPCResult::Type::NUM, "connections",
738 "the total number of connections"},
739 {RPCResult::Type::NUM, "connections_in",
740 "the number of inbound connections"},
741 {RPCResult::Type::NUM, "connections_out",
742 "the number of outbound connections"},
743 {RPCResult::Type::BOOL, "networkactive",
744 "whether p2p networking is enabled"},
746 "networks",
747 "information per network",
748 {
750 "",
751 "",
752 {
753 {RPCResult::Type::STR, "name",
754 "network (" + Join(GetNetworkNames(), ", ") + ")"},
755 {RPCResult::Type::BOOL, "limited",
756 "is the network limited using -onlynet?"},
757 {RPCResult::Type::BOOL, "reachable",
758 "is the network reachable?"},
759 {RPCResult::Type::STR, "proxy",
760 "(\"host:port\") the proxy that is used for this "
761 "network, or empty if none"},
762 {RPCResult::Type::BOOL, "proxy_randomize_credentials",
763 "Whether randomized credentials are used"},
764 }},
765 }},
766 {RPCResult::Type::NUM, "relayfee",
767 "minimum relay fee for transactions in " + ticker + "/kB"},
769 "localaddresses",
770 "list of local addresses",
771 {
773 "",
774 "",
775 {
776 {RPCResult::Type::STR, "address", "network address"},
777 {RPCResult::Type::NUM, "port", "network port"},
778 {RPCResult::Type::NUM, "score", "relative score"},
779 }},
780 }},
781 {RPCResult::Type::STR, "warnings",
782 "any network and blockchain warnings"},
783 }},
784 RPCExamples{HelpExampleCli("getnetworkinfo", "") +
785 HelpExampleRpc("getnetworkinfo", "")},
786 [&](const RPCHelpMan &self, const Config &config,
787 const JSONRPCRequest &request) -> UniValue {
788 LOCK(cs_main);
790 obj.pushKV("version", CLIENT_VERSION);
791 obj.pushKV("subversion", userAgent(config));
792 obj.pushKV("protocolversion", PROTOCOL_VERSION);
793 NodeContext &node = EnsureAnyNodeContext(request.context);
794 if (node.connman) {
795 ServiceFlags services = node.connman->GetLocalServices();
796 obj.pushKV("localservices", strprintf("%016x", services));
797 obj.pushKV("localservicesnames", GetServicesNames(services));
798 }
799 if (node.peerman) {
800 obj.pushKV("localrelay", !node.peerman->IgnoresIncomingTxs());
801 }
802 obj.pushKV("timeoffset", GetTimeOffset());
803 if (node.connman) {
804 obj.pushKV("networkactive", node.connman->GetNetworkActive());
805 obj.pushKV("connections", node.connman->GetNodeCount(
807 obj.pushKV("connections_in",
808 node.connman->GetNodeCount(ConnectionDirection::In));
809 obj.pushKV("connections_out", node.connman->GetNodeCount(
811 }
812 obj.pushKV("networks", GetNetworksInfo());
813 if (node.mempool) {
814 // This field can be deprecated, to be replaced by the
815 // getmempoolinfo fields
816 obj.pushKV("relayfee",
817 node.mempool->m_min_relay_feerate.GetFeePerK());
818 }
819 UniValue localAddresses(UniValue::VARR);
820 {
822 for (const std::pair<const CNetAddr, LocalServiceInfo> &item :
823 mapLocalHost) {
825 rec.pushKV("address", item.first.ToString());
826 rec.pushKV("port", item.second.nPort);
827 rec.pushKV("score", item.second.nScore);
828 localAddresses.push_back(rec);
829 }
830 }
831 obj.pushKV("localaddresses", localAddresses);
832 obj.pushKV("warnings", GetWarnings(false).original);
833 return obj;
834 },
835 };
836}
837
839 return RPCHelpMan{
840 "setban",
841 "Attempts to add or remove an IP/Subnet from the banned list.\n",
842 {
844 "The IP/Subnet (see getpeerinfo for nodes IP) with an optional "
845 "netmask (default is /32 = single IP)"},
847 "'add' to add an IP/Subnet to the list, 'remove' to remove an "
848 "IP/Subnet from the list"},
849 {"bantime", RPCArg::Type::NUM, RPCArg::Default{0},
850 "time in seconds how long (or until when if [absolute] is set) "
851 "the IP is banned (0 or empty means using the default time of 24h "
852 "which can also be overwritten by the -bantime startup argument)"},
853 {"absolute", RPCArg::Type::BOOL, RPCArg::Default{false},
854 "If set, the bantime must be an absolute timestamp expressed in " +
856 },
859 HelpExampleCli("setban", "\"192.168.0.6\" \"add\" 86400") +
860 HelpExampleCli("setban", "\"192.168.0.0/24\" \"add\"") +
861 HelpExampleRpc("setban", "\"192.168.0.6\", \"add\", 86400")},
862 [&](const RPCHelpMan &help, const Config &config,
863 const JSONRPCRequest &request) -> UniValue {
864 std::string strCommand;
865 if (!request.params[1].isNull()) {
866 strCommand = request.params[1].get_str();
867 }
868
869 if (strCommand != "add" && strCommand != "remove") {
870 throw std::runtime_error(help.ToString());
871 }
872
873 NodeContext &node = EnsureAnyNodeContext(request.context);
874 if (!node.banman) {
876 "Error: Ban database not loaded");
877 }
878
879 CSubNet subNet;
880 CNetAddr netAddr;
881 bool isSubnet = false;
882
883 if (request.params[0].get_str().find('/') != std::string::npos) {
884 isSubnet = true;
885 }
886
887 if (!isSubnet) {
888 CNetAddr resolved;
889 LookupHost(request.params[0].get_str(), resolved, false);
890 netAddr = resolved;
891 } else {
892 LookupSubNet(request.params[0].get_str(), subNet);
893 }
894
895 if (!(isSubnet ? subNet.IsValid() : netAddr.IsValid())) {
897 "Error: Invalid IP/Subnet");
898 }
899
900 if (strCommand == "add") {
901 if (isSubnet ? node.banman->IsBanned(subNet)
902 : node.banman->IsBanned(netAddr)) {
904 "Error: IP/Subnet already banned");
905 }
906
907 // Use standard bantime if not specified.
908 int64_t banTime = 0;
909 if (!request.params[2].isNull()) {
910 banTime = request.params[2].getInt<int64_t>();
911 }
912
913 bool absolute = false;
914 if (request.params[3].isTrue()) {
915 absolute = true;
916 }
917
918 if (isSubnet) {
919 node.banman->Ban(subNet, banTime, absolute);
920 if (node.connman) {
921 node.connman->DisconnectNode(subNet);
922 }
923 } else {
924 node.banman->Ban(netAddr, banTime, absolute);
925 if (node.connman) {
926 node.connman->DisconnectNode(netAddr);
927 }
928 }
929 } else if (strCommand == "remove") {
930 if (!(isSubnet ? node.banman->Unban(subNet)
931 : node.banman->Unban(netAddr))) {
932 throw JSONRPCError(
934 "Error: Unban failed. Requested address/subnet "
935 "was not previously manually banned.");
936 }
937 }
938 return NullUniValue;
939 },
940 };
941}
942
944 return RPCHelpMan{
945 "listbanned",
946 "List all manually banned IPs/Subnets.\n",
947 {},
949 "",
950 "",
951 {
953 "",
954 "",
955 {
956 {RPCResult::Type::STR, "address", ""},
957 {RPCResult::Type::NUM_TIME, "banned_until", ""},
958 {RPCResult::Type::NUM_TIME, "ban_created", ""},
959 {RPCResult::Type::STR, "ban_reason", ""},
960 }},
961 }},
962 RPCExamples{HelpExampleCli("listbanned", "") +
963 HelpExampleRpc("listbanned", "")},
964 [&](const RPCHelpMan &self, const Config &config,
965 const JSONRPCRequest &request) -> UniValue {
966 NodeContext &node = EnsureAnyNodeContext(request.context);
967 if (!node.banman) {
969 "Error: Ban database not loaded");
970 }
971
972 banmap_t banMap;
973 node.banman->GetBanned(banMap);
974
975 UniValue bannedAddresses(UniValue::VARR);
976 for (const auto &entry : banMap) {
977 const CBanEntry &banEntry = entry.second;
979 rec.pushKV("address", entry.first.ToString());
980 rec.pushKV("banned_until", banEntry.nBanUntil);
981 rec.pushKV("ban_created", banEntry.nCreateTime);
982
983 bannedAddresses.push_back(rec);
984 }
985
986 return bannedAddresses;
987 },
988 };
989}
990
992 return RPCHelpMan{
993 "clearbanned",
994 "Clear all banned IPs.\n",
995 {},
997 RPCExamples{HelpExampleCli("clearbanned", "") +
998 HelpExampleRpc("clearbanned", "")},
999 [&](const RPCHelpMan &self, const Config &config,
1000 const JSONRPCRequest &request) -> UniValue {
1001 NodeContext &node = EnsureAnyNodeContext(request.context);
1002 if (!node.banman) {
1003 throw JSONRPCError(
1005 "Error: Peer-to-peer functionality missing or disabled");
1006 }
1007
1008 node.banman->ClearBanned();
1009
1010 return NullUniValue;
1011 },
1012 };
1013}
1014
1016 return RPCHelpMan{
1017 "setnetworkactive",
1018 "Disable/enable all p2p network activity.\n",
1019 {
1021 "true to enable networking, false to disable"},
1022 },
1023 RPCResult{RPCResult::Type::BOOL, "", "The value that was passed in"},
1024 RPCExamples{""},
1025 [&](const RPCHelpMan &self, const Config &config,
1026 const JSONRPCRequest &request) -> UniValue {
1027 NodeContext &node = EnsureAnyNodeContext(request.context);
1028 CConnman &connman = EnsureConnman(node);
1029
1030 connman.SetNetworkActive(request.params[0].get_bool());
1031
1032 return connman.GetNetworkActive();
1033 },
1034 };
1035}
1036
1038 return RPCHelpMan{
1039 "getnodeaddresses",
1040 "Return known addresses, which can potentially be used to find new "
1041 "nodes in the network.\n",
1042 {
1043 {"count", RPCArg::Type::NUM, RPCArg::Default{1},
1044 "The maximum number of addresses to return. Specify 0 to return "
1045 "all known addresses."},
1046 {"network", RPCArg::Type::STR, RPCArg::DefaultHint{"all networks"},
1047 "Return only addresses of the specified network. Can be one of: " +
1048 Join(GetNetworkNames(), ", ") + "."},
1049 },
1051 "",
1052 "",
1053 {
1055 "",
1056 "",
1057 {
1059 "The " + UNIX_EPOCH_TIME +
1060 " when the node was last seen"},
1061 {RPCResult::Type::NUM, "services",
1062 "The services offered by the node"},
1063 {RPCResult::Type::STR, "address",
1064 "The address of the node"},
1065 {RPCResult::Type::NUM, "port",
1066 "The port number of the node"},
1067 {RPCResult::Type::STR, "network",
1068 "The network (" + Join(GetNetworkNames(), ", ") +
1069 ") the node connected through"},
1070 }},
1071 }},
1072 RPCExamples{HelpExampleCli("getnodeaddresses", "8") +
1073 HelpExampleCli("getnodeaddresses", "4 \"i2p\"") +
1074 HelpExampleCli("-named getnodeaddresses",
1075 "network=onion count=12") +
1076 HelpExampleRpc("getnodeaddresses", "8") +
1077 HelpExampleRpc("getnodeaddresses", "4, \"i2p\"")},
1078 [&](const RPCHelpMan &self, const Config &config,
1079 const JSONRPCRequest &request) -> UniValue {
1080 NodeContext &node = EnsureAnyNodeContext(request.context);
1081 const CConnman &connman = EnsureConnman(node);
1082
1083 const int count{request.params[0].isNull()
1084 ? 1
1085 : request.params[0].getInt<int>()};
1086 if (count < 0) {
1088 "Address count out of range");
1089 }
1090
1091 const std::optional<Network> network{
1092 request.params[1].isNull()
1093 ? std::nullopt
1094 : std::optional<Network>{
1095 ParseNetwork(request.params[1].get_str())}};
1096 if (network == NET_UNROUTABLE) {
1098 strprintf("Network not recognized: %s",
1099 request.params[1].get_str()));
1100 }
1101 // returns a shuffled list of CAddress
1102 const std::vector<CAddress> vAddr{
1103 connman.GetAddresses(count, /* max_pct */ 0, network)};
1105
1106 for (const CAddress &addr : vAddr) {
1108 obj.pushKV(
1109 "time",
1110 int64_t{TicksSinceEpoch<std::chrono::seconds>(addr.nTime)});
1111 obj.pushKV("services", uint64_t(addr.nServices));
1112 obj.pushKV("address", addr.ToStringIP());
1113 obj.pushKV("port", addr.GetPort());
1114 obj.pushKV("network", GetNetworkName(addr.GetNetClass()));
1115 ret.push_back(obj);
1116 }
1117 return ret;
1118 },
1119 };
1120}
1121
1123 return RPCHelpMan{
1124 "addpeeraddress",
1125 "Add the address of a potential peer to the address manager. This "
1126 "RPC is for testing only.\n",
1127 {
1129 "The IP address of the peer"},
1131 "The port of the peer"},
1132 {"tried", RPCArg::Type::BOOL, RPCArg::Default{false},
1133 "If true, attempt to add the peer to the tried addresses table"},
1134 },
1135 RPCResult{
1137 "",
1138 "",
1139 {
1140 {RPCResult::Type::BOOL, "success",
1141 "whether the peer address was successfully added to the "
1142 "address manager"},
1143 },
1144 },
1146 HelpExampleCli("addpeeraddress", "\"1.2.3.4\" 8333 true") +
1147 HelpExampleRpc("addpeeraddress", "\"1.2.3.4\", 8333, true")},
1148 [&](const RPCHelpMan &self, const Config &config,
1149 const JSONRPCRequest &request) -> UniValue {
1150 NodeContext &node = EnsureAnyNodeContext(request.context);
1151 if (!node.addrman) {
1152 throw JSONRPCError(
1154 "Error: Address manager functionality missing or disabled");
1155 }
1156
1157 const std::string &addr_string{request.params[0].get_str()};
1158 const uint16_t port{
1159 static_cast<uint16_t>(request.params[1].getInt<int>())};
1160 const bool tried{request.params[2].isTrue()};
1161
1163 CNetAddr net_addr;
1164 bool success{false};
1165
1166 if (LookupHost(addr_string, net_addr, false)) {
1167 CAddress address{{net_addr, port}, ServiceFlags(NODE_NETWORK)};
1168 address.nTime = Now<NodeSeconds>();
1169 // The source address is set equal to the address. This is
1170 // equivalent to the peer announcing itself.
1171 if (node.addrman->Add({address}, address)) {
1172 success = true;
1173 if (tried) {
1174 // Attempt to move the address to the tried addresses
1175 // table.
1176 node.addrman->Good(address);
1177 }
1178 }
1179 }
1180
1181 obj.pushKV("success", success);
1182 return obj;
1183 },
1184 };
1185}
1186
1188 return RPCHelpMan{
1189 "sendmsgtopeer",
1190 "Send a p2p message to a peer specified by id.\n"
1191 "The message type and body must be provided, the message header will "
1192 "be generated.\n"
1193 "This RPC is for testing only.",
1194 {
1196 "The peer to send the message to."},
1198 strprintf("The message type (maximum length %i)",
1201 "The serialized message body to send, in hex, without a message "
1202 "header"},
1203 },
1204 RPCResult{RPCResult::Type::OBJ, "", "", std::vector<RPCResult>{}},
1205 RPCExamples{HelpExampleCli("sendmsgtopeer", "0 \"addr\" \"ffffff\"") +
1206 HelpExampleRpc("sendmsgtopeer", "0 \"addr\" \"ffffff\"")},
1207 [&](const RPCHelpMan &self, const Config &config,
1208 const JSONRPCRequest &request) -> UniValue {
1209 const NodeId peer_id{request.params[0].getInt<int64_t>()};
1210 const std::string &msg_type{request.params[1].get_str()};
1211 if (msg_type.size() > CMessageHeader::MESSAGE_TYPE_SIZE) {
1212 throw JSONRPCError(
1214 strprintf("Error: msg_type too long, max length is %i",
1216 }
1217 auto msg{TryParseHex<uint8_t>(request.params[2].get_str())};
1218 if (!msg.has_value()) {
1220 "Error parsing input for msg");
1221 }
1222
1223 NodeContext &node = EnsureAnyNodeContext(request.context);
1224 CConnman &connman = EnsureConnman(node);
1225
1226 CSerializedNetMsg msg_ser;
1227 msg_ser.data = msg.value();
1228 msg_ser.m_type = msg_type;
1229
1230 bool success = connman.ForNode(peer_id, [&](CNode *node) {
1231 connman.PushMessage(node, std::move(msg_ser));
1232 return true;
1233 });
1234
1235 if (!success) {
1237 "Error: Could not send message to peer");
1238 }
1239
1241 return ret;
1242 },
1243 };
1244}
1245
1247 // clang-format off
1248 static const CRPCCommand commands[] = {
1249 // category actor (function)
1250 // ------------------ ----------------------
1251 { "network", getconnectioncount, },
1252 { "network", ping, },
1253 { "network", getpeerinfo, },
1254 { "network", addnode, },
1255 { "network", disconnectnode, },
1256 { "network", getaddednodeinfo, },
1257 { "network", getnettotals, },
1258 { "network", getnetworkinfo, },
1259 { "network", setban, },
1260 { "network", listbanned, },
1261 { "network", clearbanned, },
1262 { "network", setnetworkactive, },
1263 { "network", getnodeaddresses, },
1264 { "hidden", addconnection, },
1265 { "hidden", addpeeraddress, },
1266 { "hidden", sendmsgtopeer },
1267 };
1268 // clang-format on
1269 for (const auto &c : commands) {
1270 t.appendCommand(c.name, &c);
1271 }
1272}
A CService with information about it as peer.
Definition: protocol.h:443
Definition: addrdb.h:30
int64_t nCreateTime
Definition: addrdb.h:34
int64_t nBanUntil
Definition: addrdb.h:35
Definition: net.h:824
std::chrono::seconds GetMaxOutboundTimeLeftInCycle() const
returns the time in second left in the current max outbound cycle in case of no limit,...
Definition: net.cpp:2874
bool OutboundTargetReached(bool historicalBlockServingLimit) const
check if the outbound target is reached.
Definition: net.cpp:2890
bool ForNode(NodeId id, std::function< bool(CNode *pnode)> func)
Definition: net.cpp:3085
bool AddConnection(const std::string &address, ConnectionType conn_type)
Attempts to open a connection.
Definition: net.cpp:1090
bool RemoveAddedNode(const std::string &node) EXCLUSIVE_LOCKS_REQUIRED(!m_added_nodes_mutex)
Definition: net.cpp:2746
bool GetNetworkActive() const
Definition: net.h:916
uint64_t GetOutboundTargetBytesLeft() const
response the bytes left in the current max outbound cycle in case of no limit, it will always respons...
Definition: net.cpp:2913
std::chrono::seconds GetMaxOutboundTimeframe() const
Definition: net.cpp:2870
bool DisconnectNode(const std::string &node)
Definition: net.cpp:2801
uint64_t GetMaxOutboundTarget() const
Definition: net.cpp:2865
size_t GetNodeCount(ConnectionDirection) const
Definition: net.cpp:2758
void GetNodeStats(std::vector< CNodeStats > &vstats) const
Definition: net.cpp:2776
std::vector< AddedNodeInfo > GetAddedNodeInfo() const EXCLUSIVE_LOCKS_REQUIRED(!m_added_nodes_mutex)
Definition: net.cpp:1992
uint64_t GetTotalBytesRecv() const
Definition: net.cpp:2924
std::vector< CAddress > GetAddresses(size_t max_addresses, size_t max_pct, std::optional< Network > network) const
Return all or many randomly selected addresses, optionally by network.
Definition: net.cpp:2669
void SetNetworkActive(bool active)
Definition: net.cpp:2352
void OpenNetworkConnection(const CAddress &addrConnect, bool fCountFailure, CSemaphoreGrant *grantOutbound, const char *strDest, ConnectionType conn_type)
Definition: net.cpp:2081
bool AddNode(const std::string &node) EXCLUSIVE_LOCKS_REQUIRED(!m_added_nodes_mutex)
Definition: net.cpp:2734
void PushMessage(CNode *pnode, CSerializedNetMsg &&msg)
Definition: net.cpp:3039
uint64_t GetTotalBytesSent() const
Definition: net.cpp:2928
static constexpr size_t MESSAGE_TYPE_SIZE
Definition: protocol.h:37
Network address.
Definition: netaddress.h:121
bool IsValid() const
Definition: netaddress.cpp:474
Information about a peer.
Definition: net.h:395
RPC command dispatcher.
Definition: server.h:194
void appendCommand(const std::string &name, const CRPCCommand *pcmd)
Appends a CRPCCommand to the dispatch table.
Definition: server.cpp:328
std::string ToStringIPPort() const
bool IsValid() const
Definition: config.h:19
static std::vector< std::string > ToStrings(NetPermissionFlags flags)
virtual void SendPings()=0
Send ping message to all peers.
virtual bool GetNodeStateStats(NodeId nodeid, CNodeStateStats &stats) const =0
Get statistics from node state.
auto Arg(size_t i) const
Helper to get a required or default-valued request argument.
Definition: util.h:410
std::string ToString() const
Definition: util.cpp:738
void push_back(UniValue val)
Definition: univalue.cpp:96
const std::string & get_str() const
@ VOBJ
Definition: univalue.h:31
@ VARR
Definition: univalue.h:32
bool isNull() const
Definition: univalue.h:104
bool isStr() const
Definition: univalue.h:108
Int getInt() const
Definition: univalue.h:157
void pushKV(std::string key, UniValue val)
Definition: univalue.cpp:115
bool IsValid() const
Definition: netbase.h:58
CService proxy
Definition: netbase.h:60
bool randomize_credentials
Definition: netbase.h:61
static constexpr int CLIENT_VERSION
bitcoind-res.rc includes this file, but it cannot cope with real c++ code.
Definition: clientversion.h:38
std::string ConnectionTypeAsString(ConnectionType conn_type)
Convert ConnectionType enum to a string value.
ConnectionType
Different types of connections to a peer.
@ BLOCK_RELAY
We use block-relay-only connections to help prevent against partition attacks.
@ MANUAL
We open manual connections to addresses that users explicitly inputted via the addnode RPC,...
@ OUTBOUND_FULL_RELAY
These are the default connections that we use to connect with the network.
@ FEELER
Feeler connections are short-lived connections made to check that a node is alive.
@ AVALANCHE_OUTBOUND
Special case of connection to a full relay outbound with avalanche service enabled.
@ ADDR_FETCH
AddrFetch connections are short lived connections used to solicit addresses from peers.
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate.
Definition: cs_main.cpp:7
int64_t NodeId
Definition: eviction.h:16
static path absolute(const path &p)
Definition: fs.h:101
Definition: init.h:31
const std::string NET_MESSAGE_TYPE_OTHER
Definition: net.cpp:114
GlobalMutex g_maplocalhost_mutex
Definition: net.cpp:129
std::string userAgent(const Config &config)
Definition: net.cpp:3137
bool IsReachable(enum Network net)
Definition: net.cpp:327
const std::vector< std::string > CONNECTION_TYPE_DOC
Definition: net.h:137
std::map< CSubNet, CBanEntry > banmap_t
Definition: net_types.h:13
Network
A network type.
Definition: netaddress.h:44
@ NET_CJDNS
CJDNS.
Definition: netaddress.h:62
@ NET_MAX
Dummy value to indicate the number of NET_* constants.
Definition: netaddress.h:69
@ NET_UNROUTABLE
Addresses from these networks are not publicly routable on the global Internet.
Definition: netaddress.h:47
@ NET_INTERNAL
A set of addresses that represent the hash of a string or FQDN.
Definition: netaddress.h:66
std::string GetNetworkName(enum Network net)
Definition: netbase.cpp:112
bool GetProxy(enum Network net, proxyType &proxyInfoOut)
Definition: netbase.cpp:730
bool LookupSubNet(const std::string &strSubnet, CSubNet &ret, DNSLookupFn dns_lookup_function)
Parse and resolve a specified subnet string into the appropriate internal representation.
Definition: netbase.cpp:796
enum Network ParseNetwork(const std::string &net_in)
Definition: netbase.cpp:90
bool LookupHost(const std::string &name, std::vector< CNetAddr > &vIP, unsigned int nMaxSolutions, bool fAllowLookup, DNSLookupFn dns_lookup_function)
Resolve a host string to its corresponding network addresses.
Definition: netbase.cpp:189
std::vector< std::string > GetNetworkNames(bool append_unroutable)
Return a vector of publicly routable Network names; optionally append NET_UNROUTABLE.
Definition: netbase.cpp:135
ServiceFlags
nServices flags.
Definition: protocol.h:336
@ NODE_NONE
Definition: protocol.h:339
@ NODE_NETWORK
Definition: protocol.h:343
UniValue JSONRPCError(int code, const std::string &message)
Definition: request.cpp:58
void RegisterNetRPCCommands(CRPCTable &t)
Register P2P networking RPC commands.
Definition: net.cpp:1246
static RPCHelpMan getnetworkinfo()
Definition: net.cpp:709
static RPCHelpMan addconnection()
Definition: net.cpp:404
static RPCHelpMan getaddednodeinfo()
Definition: net.cpp:536
static RPCHelpMan clearbanned()
Definition: net.cpp:991
static RPCHelpMan getnettotals()
Definition: net.cpp:622
static RPCHelpMan addnode()
Definition: net.cpp:345
static RPCHelpMan getnodeaddresses()
Definition: net.cpp:1037
static RPCHelpMan setban()
Definition: net.cpp:838
static UniValue GetNetworksInfo()
Definition: net.cpp:687
static RPCHelpMan ping()
Definition: net.cpp:58
static RPCHelpMan getconnectioncount()
Definition: net.cpp:40
static RPCHelpMan disconnectnode()
Definition: net.cpp:481
static RPCHelpMan listbanned()
Definition: net.cpp:943
static RPCHelpMan setnetworkactive()
Definition: net.cpp:1015
static RPCHelpMan addpeeraddress()
Definition: net.cpp:1122
static RPCHelpMan getpeerinfo()
Definition: net.cpp:83
static RPCHelpMan sendmsgtopeer()
Definition: net.cpp:1187
@ RPC_CLIENT_NODE_NOT_CONNECTED
Node to disconnect not found in connected nodes.
Definition: protocol.h:77
@ RPC_CLIENT_INVALID_IP_OR_SUBNET
Invalid IP/Subnet.
Definition: protocol.h:79
@ RPC_MISC_ERROR
General application defined errors std::exception thrown in command handling.
Definition: protocol.h:38
@ RPC_CLIENT_NODE_ALREADY_ADDED
Node is already added.
Definition: protocol.h:73
@ RPC_INVALID_PARAMS
Definition: protocol.h:30
@ RPC_INVALID_PARAMETER
Invalid, missing or duplicate parameter.
Definition: protocol.h:46
@ RPC_DATABASE_ERROR
Database error.
Definition: protocol.h:48
@ RPC_CLIENT_NODE_NOT_ADDED
Node has not been added before.
Definition: protocol.h:75
@ RPC_CLIENT_NODE_CAPACITY_REACHED
Max number of outbound or block-relay connections already open.
Definition: protocol.h:83
@ RPC_CLIENT_P2P_DISABLED
No valid connection manager instance found.
Definition: protocol.h:81
std::string HelpExampleCli(const std::string &methodname, const std::string &args)
Definition: util.cpp:153
UniValue GetServicesNames(ServiceFlags services)
Returns, given services flags, a list of humanly readable (known) network services.
Definition: util.cpp:1409
std::string HelpExampleRpc(const std::string &methodname, const std::string &args)
Definition: util.cpp:170
const std::string UNIX_EPOCH_TIME
String used to describe UNIX epoch time in documentation, factored out to a constant for consistency.
Definition: util.cpp:25
bool IsDeprecatedRPCEnabled(const ArgsManager &args, const std::string &method)
Definition: server.cpp:408
static RPCHelpMan help()
Definition: server.cpp:183
NodeContext & EnsureAnyNodeContext(const std::any &context)
Definition: server_util.cpp:21
PeerManager & EnsurePeerman(const NodeContext &node)
Definition: server_util.cpp:72
ArgsManager & EnsureArgsman(const NodeContext &node)
Definition: server_util.cpp:41
CConnman & EnsureConnman(const NodeContext &node)
Definition: server_util.cpp:63
auto Join(const std::vector< T > &list, const BaseType &separator, UnaryOp unary_op) -> decltype(unary_op(list.at(0)))
Join a list of items.
Definition: string.h:63
std::string TrimString(std::string_view str, std::string_view pattern=" \f\n\r\t\v")
Definition: string.h:38
std::chrono::microseconds m_ping_wait
Amount m_fee_filter_received
std::vector< int > vHeightInFlight
uint64_t m_addr_rate_limited
uint64_t m_addr_processed
int64_t presync_height
ServiceFlags their_services
POD that contains various stats about a node.
Definition: net.h:213
std::vector< uint8_t > data
Definition: net.h:133
std::string m_type
Definition: net.h:134
static const Currency & get()
Definition: amount.cpp:18
std::string ticker
Definition: amount.h:150
@ STR_HEX
Special type that is a STR with only hex chars.
std::string DefaultHint
Hint for default value.
Definition: util.h:206
@ NO
Required arg.
@ NUM_TIME
Special numeric to denote unix epoch time.
@ OBJ_DYN
Special dictionary with keys that are not literals.
@ STR_HEX
Special string with only hex chars.
NodeContext struct containing references to chain state and connection state.
Definition: context.h:48
#define LOCK(cs)
Definition: sync.h:306
static int count
Definition: tests.c:31
int64_t GetTimeMillis()
Returns the system time (not mockable)
Definition: time.cpp:101
constexpr int64_t count_seconds(std::chrono::seconds t)
Definition: time.h:57
double CountSecondsDouble(SecondsDouble t)
Helper to count the seconds in any std::chrono::duration type.
Definition: time.h:76
int64_t GetTimeOffset()
"Never go to sea with two chronometers; take one or three." Our three time sources are:
Definition: timedata.cpp:30
#define strprintf
Format arguments and return the string or write to given std::ostream (see tinyformat::format doc for...
Definition: tinyformat.h:1202
const UniValue NullUniValue
Definition: univalue.cpp:16
static const int PROTOCOL_VERSION
network protocol versioning
Definition: version.h:11
bilingual_str GetWarnings(bool verbose)
Format a string that describes several potential problems detected by the core.
Definition: warnings.cpp:41