2014-12-16 22:47:57 -03:00
// Copyright (c) 2009-2014 The Bitcoin Core developers
2014-11-19 23:19:29 -03:00
// Distributed under the MIT software license, see the accompanying
2012-06-28 23:18:38 -04:00
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
2013-11-17 21:25:17 -03:00
2013-12-09 06:12:08 -03:00
# include "rpcserver.h"
2013-11-17 21:25:17 -03:00
2014-10-28 22:33:23 -03:00
# include "clientversion.h"
2013-11-17 21:25:17 -03:00
# include "main.h"
2013-04-13 02:13:08 -03:00
# include "net.h"
# include "netbase.h"
# include "protocol.h"
# include "sync.h"
2014-06-19 09:08:37 -04:00
# include "timedata.h"
2013-04-13 02:13:08 -03:00
# include "util.h"
2014-09-14 22:54:32 -03:00
# include "version.h"
2013-04-13 02:13:08 -03:00
# include <boost/foreach.hpp>
2014-09-14 07:43:56 -03:00
2015-05-18 09:02:18 -03:00
# include "univalue/univalue.h"
2012-06-28 23:18:38 -04:00
using namespace std ;
2015-05-18 09:02:18 -03:00
UniValue getconnectioncount ( const UniValue & params , bool fHelp )
2012-06-28 23:18:38 -04:00
{
if ( fHelp | | params . size ( ) ! = 0 )
throw runtime_error (
" getconnectioncount \n "
2013-10-29 08:29:44 -03:00
" \n Returns the number of connections to other nodes. \n "
" \n bResult: \n "
" n (numeric) The connection count \n "
" \n Examples: \n "
+ HelpExampleCli ( " getconnectioncount " , " " )
+ HelpExampleRpc ( " getconnectioncount " , " " )
) ;
2012-06-28 23:18:38 -04:00
2014-10-19 05:46:17 -03:00
LOCK2 ( cs_main , cs_vNodes ) ;
2012-06-28 23:18:38 -04:00
return ( int ) vNodes . size ( ) ;
}
2015-05-18 09:02:18 -03:00
UniValue ping ( const UniValue & params , bool fHelp )
2013-08-22 07:34:33 -04:00
{
if ( fHelp | | params . size ( ) ! = 0 )
throw runtime_error (
" ping \n "
2013-10-29 08:29:44 -03:00
" \n Requests that a ping be sent to all other nodes, to measure ping time. \n "
2013-08-22 07:34:33 -04:00
" Results provided in getpeerinfo, pingtime and pingwait fields are decimal seconds. \n "
2014-01-30 10:13:30 -03:00
" Ping command is handled in queue with all other commands, so it measures processing backlog, not just network ping. \n "
2013-10-29 08:29:44 -03:00
" \n Examples: \n "
+ HelpExampleCli ( " ping " , " " )
+ HelpExampleRpc ( " ping " , " " )
) ;
2013-10-23 11:19:49 -03:00
2013-08-22 07:34:33 -04:00
// Request that each node send a ping during next message processing pass
2014-10-19 05:46:17 -03:00
LOCK2 ( cs_main , cs_vNodes ) ;
2013-08-22 07:34:33 -04:00
BOOST_FOREACH ( CNode * pNode , vNodes ) {
pNode - > fPingQueued = true ;
}
2014-08-20 15:15:16 -04:00
return NullUniValue ;
2013-08-22 07:34:33 -04:00
}
2012-06-29 17:24:53 -04:00
static void CopyNodeStats ( std : : vector < CNodeStats > & vstats )
{
vstats . clear ( ) ;
LOCK ( cs_vNodes ) ;
vstats . reserve ( vNodes . size ( ) ) ;
BOOST_FOREACH ( CNode * pnode , vNodes ) {
CNodeStats stats ;
pnode - > copyStats ( stats ) ;
vstats . push_back ( stats ) ;
}
}
2015-05-18 09:02:18 -03:00
UniValue getpeerinfo ( const UniValue & params , bool fHelp )
2012-06-29 17:24:53 -04:00
{
if ( fHelp | | params . size ( ) ! = 0 )
throw runtime_error (
" getpeerinfo \n "
2013-10-29 08:29:44 -03:00
" \n Returns data about each connected network node as a json array of objects. \n "
" \n bResult: \n "
" [ \n "
" { \n "
2014-07-15 10:13:10 -04:00
" \" id \" : n, (numeric) Peer index \n "
2013-10-29 08:29:44 -03:00
" \" addr \" : \" host:port \" , (string) The ip address and port of the peer \n "
" \" addrlocal \" : \" ip:port \" , (string) local address \n "
2014-06-06 03:15:55 -04:00
" \" services \" : \" xxxxxxxxxxxxxxxx \" , (string) The services offered \n "
2013-10-29 08:29:44 -03:00
" \" lastsend \" : ttt, (numeric) The time in seconds since epoch (Jan 1 1970 GMT) of the last send \n "
" \" lastrecv \" : ttt, (numeric) The time in seconds since epoch (Jan 1 1970 GMT) of the last receive \n "
" \" bytessent \" : n, (numeric) The total bytes sent \n "
" \" bytesrecv \" : n, (numeric) The total bytes received \n "
" \" conntime \" : ttt, (numeric) The connection time in seconds since epoch (Jan 1 1970 GMT) \n "
2014-12-15 07:06:15 -03:00
" \" timeoffset \" : ttt, (numeric) The time offset in seconds \n "
2013-10-29 08:29:44 -03:00
" \" pingtime \" : n, (numeric) ping time \n "
" \" pingwait \" : n, (numeric) ping wait \n "
" \" version \" : v, (numeric) The peer version, such as 7001 \n "
" \" subver \" : \" /Satoshi:0.8.5/ \" , (string) The string version \n "
" \" inbound \" : true|false, (boolean) Inbound (true) or Outbound (false) \n "
" \" startingheight \" : n, (numeric) The starting height (block) of the peer \n "
2014-09-16 04:00:36 -03:00
" \" banscore \" : n, (numeric) The ban score \n "
2014-07-11 18:03:10 -04:00
" \" synced_headers \" : n, (numeric) The last header we have in common with this peer \n "
" \" synced_blocks \" : n, (numeric) The last block we have in common with this peer \n "
" \" inflight \" : [ \n "
" n, (numeric) The heights of blocks we're currently asking from this peer \n "
" ... \n "
" ] \n "
2013-10-29 08:29:44 -03:00
" } \n "
" ,... \n "
2014-07-17 09:09:03 -04:00
" ] \n "
2013-10-29 08:29:44 -03:00
" \n Examples: \n "
+ HelpExampleCli ( " getpeerinfo " , " " )
+ HelpExampleRpc ( " getpeerinfo " , " " )
) ;
2012-06-29 17:24:53 -04:00
2014-10-19 05:46:17 -03:00
LOCK ( cs_main ) ;
2012-06-29 17:24:53 -04:00
vector < CNodeStats > vstats ;
CopyNodeStats ( vstats ) ;
2015-05-10 09:48:35 -03:00
UniValue ret ( UniValue : : VARR ) ;
2012-06-29 17:24:53 -04:00
BOOST_FOREACH ( const CNodeStats & stats , vstats ) {
2015-05-10 09:48:35 -03:00
UniValue obj ( UniValue : : VOBJ ) ;
2013-11-17 21:25:17 -03:00
CNodeStateStats statestats ;
bool fStateStats = GetNodeStateStats ( stats . nodeid , statestats ) ;
2014-07-15 10:13:10 -04:00
obj . push_back ( Pair ( " id " , stats . nodeid ) ) ;
2012-06-29 17:24:53 -04:00
obj . push_back ( Pair ( " addr " , stats . addrName ) ) ;
2013-08-22 01:50:19 -04:00
if ( ! ( stats . addrLocal . empty ( ) ) )
obj . push_back ( Pair ( " addrlocal " , stats . addrLocal ) ) ;
2014-06-06 03:15:55 -04:00
obj . push_back ( Pair ( " services " , strprintf ( " %016x " , stats . nServices ) ) ) ;
2014-05-06 08:58:43 -04:00
obj . push_back ( Pair ( " lastsend " , stats . nLastSend ) ) ;
obj . push_back ( Pair ( " lastrecv " , stats . nLastRecv ) ) ;
obj . push_back ( Pair ( " bytessent " , stats . nSendBytes ) ) ;
obj . push_back ( Pair ( " bytesrecv " , stats . nRecvBytes ) ) ;
obj . push_back ( Pair ( " conntime " , stats . nTimeConnected ) ) ;
2014-12-15 07:06:15 -03:00
obj . push_back ( Pair ( " timeoffset " , stats . nTimeOffset ) ) ;
2013-08-22 07:34:33 -04:00
obj . push_back ( Pair ( " pingtime " , stats . dPingTime ) ) ;
if ( stats . dPingWait > 0.0 )
obj . push_back ( Pair ( " pingwait " , stats . dPingWait ) ) ;
2012-06-29 17:24:53 -04:00
obj . push_back ( Pair ( " version " , stats . nVersion ) ) ;
2013-11-26 08:52:21 -03:00
// Use the sanitized form of subver here, to avoid tricksy remote peers from
// corrupting or modifiying the JSON output by putting special characters in
// their ver message.
obj . push_back ( Pair ( " subver " , stats . cleanSubVer ) ) ;
2012-06-29 17:24:53 -04:00
obj . push_back ( Pair ( " inbound " , stats . fInbound ) ) ;
2012-06-30 23:40:26 -04:00
obj . push_back ( Pair ( " startingheight " , stats . nStartingHeight ) ) ;
2013-11-17 21:25:17 -03:00
if ( fStateStats ) {
obj . push_back ( Pair ( " banscore " , statestats . nMisbehavior ) ) ;
2014-07-11 18:03:10 -04:00
obj . push_back ( Pair ( " synced_headers " , statestats . nSyncHeight ) ) ;
obj . push_back ( Pair ( " synced_blocks " , statestats . nCommonHeight ) ) ;
2015-05-10 09:48:35 -03:00
UniValue heights ( UniValue : : VARR ) ;
2014-07-11 18:03:10 -04:00
BOOST_FOREACH ( int height , statestats . vHeightInFlight ) {
heights . push_back ( height ) ;
}
obj . push_back ( Pair ( " inflight " , heights ) ) ;
2013-11-17 21:25:17 -03:00
}
2014-06-21 07:34:36 -04:00
obj . push_back ( Pair ( " whitelisted " , stats . fWhitelisted ) ) ;
2012-06-29 17:24:53 -04:00
ret . push_back ( obj ) ;
}
2012-09-18 16:07:58 -03:00
2012-06-29 17:24:53 -04:00
return ret ;
}
2012-06-28 23:18:38 -04:00
2015-05-18 09:02:18 -03:00
UniValue addnode ( const UniValue & params , bool fHelp )
2013-01-23 13:45:00 -03:00
{
string strCommand ;
if ( params . size ( ) = = 2 )
strCommand = params [ 1 ] . get_str ( ) ;
if ( fHelp | | params . size ( ) ! = 2 | |
( strCommand ! = " onetry " & & strCommand ! = " add " & & strCommand ! = " remove " ) )
throw runtime_error (
2013-10-29 08:29:44 -03:00
" addnode \" node \" \" add|remove|onetry \" \n "
" \n Attempts add or remove a node from the addnode list. \n "
" Or try a connection to a node once. \n "
" \n Arguments: \n "
" 1. \" node \" (string, required) The node (see getpeerinfo for nodes) \n "
" 2. \" command \" (string, required) 'add' to add a node to the list, 'remove' to remove a node from the list, 'onetry' to try a connection to the node once \n "
" \n Examples: \n "
+ HelpExampleCli ( " addnode " , " \" 192.168.0.6:8333 \" \" onetry \" " )
+ HelpExampleRpc ( " addnode " , " \" 192.168.0.6:8333 \" , \" onetry \" " )
) ;
2013-01-23 13:45:00 -03:00
string strNode = params [ 0 ] . get_str ( ) ;
if ( strCommand = = " onetry " )
{
CAddress addr ;
2014-05-09 18:39:49 -04:00
OpenNetworkConnection ( addr , NULL , strNode . c_str ( ) ) ;
2014-08-20 15:15:16 -04:00
return NullUniValue ;
2013-01-23 13:45:00 -03:00
}
LOCK ( cs_vAddedNodes ) ;
vector < string > : : iterator it = vAddedNodes . begin ( ) ;
for ( ; it ! = vAddedNodes . end ( ) ; it + + )
if ( strNode = = * it )
break ;
if ( strCommand = = " add " )
{
if ( it ! = vAddedNodes . end ( ) )
2013-10-23 11:19:49 -03:00
throw JSONRPCError ( RPC_CLIENT_NODE_ALREADY_ADDED , " Error: Node already added " ) ;
2013-01-23 13:45:00 -03:00
vAddedNodes . push_back ( strNode ) ;
}
else if ( strCommand = = " remove " )
{
if ( it = = vAddedNodes . end ( ) )
2013-10-23 11:19:49 -03:00
throw JSONRPCError ( RPC_CLIENT_NODE_NOT_ADDED , " Error: Node has not been added. " ) ;
2013-01-23 13:45:00 -03:00
vAddedNodes . erase ( it ) ;
}
2014-08-20 15:15:16 -04:00
return NullUniValue ;
2013-01-23 13:45:00 -03:00
}
2015-06-12 00:20:54 -03:00
UniValue disconnectnode ( const UniValue & params , bool fHelp )
{
if ( fHelp | | params . size ( ) ! = 1 )
throw runtime_error (
" disconnectnode \" node \" \n "
" \n Immediately disconnects from the specified node. \n "
" \n Arguments: \n "
" 1. \" node \" (string, required) The node (see getpeerinfo for nodes) \n "
" \n Examples: \n "
+ HelpExampleCli ( " disconnectnode " , " \" 192.168.0.6:8333 \" " )
+ HelpExampleRpc ( " disconnectnode " , " \" 192.168.0.6:8333 \" " )
) ;
CNode * pNode = FindNode ( params [ 0 ] . get_str ( ) ) ;
if ( pNode = = NULL )
throw JSONRPCError ( RPC_CLIENT_NODE_NOT_CONNECTED , " Node not found in connected nodes " ) ;
pNode - > CloseSocketDisconnect ( ) ;
return NullUniValue ;
}
2015-05-18 09:02:18 -03:00
UniValue getaddednodeinfo ( const UniValue & params , bool fHelp )
2013-01-23 13:48:17 -03:00
{
if ( fHelp | | params . size ( ) < 1 | | params . size ( ) > 2 )
throw runtime_error (
2013-10-29 08:29:44 -03:00
" getaddednodeinfo dns ( \" node \" ) \n "
" \n Returns information about the given added node, or all added nodes \n "
2013-01-23 13:48:17 -03:00
" (note that onetry addnodes are not listed here) \n "
" If dns is false, only a list of added nodes will be provided, \n "
2013-10-29 08:29:44 -03:00
" otherwise connected information will also be available. \n "
" \n Arguments: \n "
" 1. dns (boolean, required) If false, only a list of added nodes will be provided, otherwise connected information will also be available. \n "
" 2. \" node \" (string, optional) If provided, return information about this specific node, otherwise all nodes are returned. \n "
" \n Result: \n "
" [ \n "
" { \n "
" \" addednode \" : \" 192.168.0.201 \" , (string) The node ip address \n "
" \" connected \" : true|false, (boolean) If connected \n "
" \" addresses \" : [ \n "
" { \n "
" \" address \" : \" 192.168.0.201:8333 \" , (string) The bitcoin server host and port \n "
" \" connected \" : \" outbound \" (string) connection, inbound or outbound \n "
" } \n "
" ,... \n "
" ] \n "
" } \n "
" ,... \n "
" ] \n "
" \n Examples: \n "
+ HelpExampleCli ( " getaddednodeinfo " , " true " )
+ HelpExampleCli ( " getaddednodeinfo " , " true \" 192.168.0.201 \" " )
+ HelpExampleRpc ( " getaddednodeinfo " , " true, \" 192.168.0.201 \" " )
) ;
2013-01-23 13:48:17 -03:00
bool fDns = params [ 0 ] . get_bool ( ) ;
list < string > laddedNodes ( 0 ) ;
if ( params . size ( ) = = 1 )
{
LOCK ( cs_vAddedNodes ) ;
2015-05-31 10:36:44 -03:00
BOOST_FOREACH ( const std : : string & strAddNode , vAddedNodes )
2013-01-23 13:48:17 -03:00
laddedNodes . push_back ( strAddNode ) ;
}
else
{
string strNode = params [ 1 ] . get_str ( ) ;
LOCK ( cs_vAddedNodes ) ;
2015-05-31 10:36:44 -03:00
BOOST_FOREACH ( const std : : string & strAddNode , vAddedNodes ) {
2013-01-23 13:48:17 -03:00
if ( strAddNode = = strNode )
{
laddedNodes . push_back ( strAddNode ) ;
break ;
}
2015-05-31 10:36:44 -03:00
}
2013-01-23 13:48:17 -03:00
if ( laddedNodes . size ( ) = = 0 )
2013-10-23 11:19:49 -03:00
throw JSONRPCError ( RPC_CLIENT_NODE_NOT_ADDED , " Error: Node has not been added. " ) ;
2013-01-23 13:48:17 -03:00
}
2015-05-10 09:48:35 -03:00
UniValue ret ( UniValue : : VARR ) ;
2013-01-23 13:48:17 -03:00
if ( ! fDns )
{
2015-05-31 10:36:44 -03:00
BOOST_FOREACH ( const std : : string & strAddNode , laddedNodes ) {
2015-05-10 09:48:35 -03:00
UniValue obj ( UniValue : : VOBJ ) ;
2014-01-27 06:31:22 -03:00
obj . push_back ( Pair ( " addednode " , strAddNode ) ) ;
ret . push_back ( obj ) ;
}
2013-01-23 13:48:17 -03:00
return ret ;
}
list < pair < string , vector < CService > > > laddedAddreses ( 0 ) ;
2015-05-31 10:36:44 -03:00
BOOST_FOREACH ( const std : : string & strAddNode , laddedNodes ) {
2013-01-23 13:48:17 -03:00
vector < CService > vservNode ( 0 ) ;
2013-05-07 09:16:25 -04:00
if ( Lookup ( strAddNode . c_str ( ) , vservNode , Params ( ) . GetDefaultPort ( ) , fNameLookup , 0 ) )
2013-01-23 13:48:17 -03:00
laddedAddreses . push_back ( make_pair ( strAddNode , vservNode ) ) ;
else
{
2015-05-10 09:48:35 -03:00
UniValue obj ( UniValue : : VOBJ ) ;
2013-01-23 13:48:17 -03:00
obj . push_back ( Pair ( " addednode " , strAddNode ) ) ;
obj . push_back ( Pair ( " connected " , false ) ) ;
2015-05-10 09:48:35 -03:00
UniValue addresses ( UniValue : : VARR ) ;
2013-01-23 13:48:17 -03:00
obj . push_back ( Pair ( " addresses " , addresses ) ) ;
}
}
LOCK ( cs_vNodes ) ;
for ( list < pair < string , vector < CService > > > : : iterator it = laddedAddreses . begin ( ) ; it ! = laddedAddreses . end ( ) ; it + + )
{
2015-05-10 09:48:35 -03:00
UniValue obj ( UniValue : : VOBJ ) ;
2013-01-23 13:48:17 -03:00
obj . push_back ( Pair ( " addednode " , it - > first ) ) ;
2015-05-10 09:48:35 -03:00
UniValue addresses ( UniValue : : VARR ) ;
2013-01-23 13:48:17 -03:00
bool fConnected = false ;
2015-05-31 10:36:44 -03:00
BOOST_FOREACH ( const CService & addrNode , it - > second ) {
2013-01-23 13:48:17 -03:00
bool fFound = false ;
2015-05-10 09:48:35 -03:00
UniValue node ( UniValue : : VOBJ ) ;
2013-01-23 13:48:17 -03:00
node . push_back ( Pair ( " address " , addrNode . ToString ( ) ) ) ;
2015-05-31 10:36:44 -03:00
BOOST_FOREACH ( CNode * pnode , vNodes ) {
2013-01-23 13:48:17 -03:00
if ( pnode - > addr = = addrNode )
{
fFound = true ;
fConnected = true ;
node . push_back ( Pair ( " connected " , pnode - > fInbound ? " inbound " : " outbound " ) ) ;
break ;
}
2015-05-31 10:36:44 -03:00
}
2013-01-23 13:48:17 -03:00
if ( ! fFound )
node . push_back ( Pair ( " connected " , " false " ) ) ;
addresses . push_back ( node ) ;
}
obj . push_back ( Pair ( " connected " , fConnected ) ) ;
obj . push_back ( Pair ( " addresses " , addresses ) ) ;
ret . push_back ( obj ) ;
}
return ret ;
}
2015-05-18 09:02:18 -03:00
UniValue getnettotals ( const UniValue & params , bool fHelp )
2013-08-22 12:09:32 -04:00
{
if ( fHelp | | params . size ( ) > 0 )
throw runtime_error (
" getnettotals \n "
2013-10-29 08:29:44 -03:00
" \n Returns information about network traffic, including bytes in, bytes out, \n "
" and current time. \n "
" \n Result: \n "
" { \n "
" \" totalbytesrecv \" : n, (numeric) Total bytes received \n "
2013-12-05 04:46:50 -03:00
" \" totalbytessent \" : n, (numeric) Total bytes sent \n "
2013-10-29 08:29:44 -03:00
" \" timemillis \" : t (numeric) Total cpu time \n "
" } \n "
" \n Examples: \n "
+ HelpExampleCli ( " getnettotals " , " " )
+ HelpExampleRpc ( " getnettotals " , " " )
) ;
2013-08-22 12:09:32 -04:00
2015-05-10 09:48:35 -03:00
UniValue obj ( UniValue : : VOBJ ) ;
2014-05-06 08:58:43 -04:00
obj . push_back ( Pair ( " totalbytesrecv " , CNode : : GetTotalBytesRecv ( ) ) ) ;
obj . push_back ( Pair ( " totalbytessent " , CNode : : GetTotalBytesSent ( ) ) ) ;
obj . push_back ( Pair ( " timemillis " , GetTimeMillis ( ) ) ) ;
2013-08-22 12:09:32 -04:00
return obj ;
}
2014-05-05 07:22:28 -04:00
2015-05-13 16:29:19 -03:00
static UniValue GetNetworksInfo ( )
2014-07-30 09:35:14 -04:00
{
2015-05-10 09:48:35 -03:00
UniValue networks ( UniValue : : VARR ) ;
2014-07-30 09:35:14 -04:00
for ( int n = 0 ; n < NET_MAX ; + + n )
{
enum Network network = static_cast < enum Network > ( n ) ;
if ( network = = NET_UNROUTABLE )
continue ;
proxyType proxy ;
2015-05-10 09:48:35 -03:00
UniValue obj ( UniValue : : VOBJ ) ;
2014-07-30 09:35:14 -04:00
GetProxy ( network , proxy ) ;
obj . push_back ( Pair ( " name " , GetNetworkName ( network ) ) ) ;
obj . push_back ( Pair ( " limited " , IsLimited ( network ) ) ) ;
obj . push_back ( Pair ( " reachable " , IsReachable ( network ) ) ) ;
2015-03-16 12:30:49 -03:00
obj . push_back ( Pair ( " proxy " , proxy . IsValid ( ) ? proxy . proxy . ToStringIPPort ( ) : string ( ) ) ) ;
obj . push_back ( Pair ( " proxy_randomize_credentials " , proxy . randomize_credentials ) ) ;
2014-07-30 09:35:14 -04:00
networks . push_back ( obj ) ;
}
return networks ;
}
2015-05-18 09:02:18 -03:00
UniValue getnetworkinfo ( const UniValue & params , bool fHelp )
2014-05-05 07:22:28 -04:00
{
if ( fHelp | | params . size ( ) ! = 0 )
throw runtime_error (
" getnetworkinfo \n "
" Returns an object containing various state info regarding P2P networking. \n "
" \n Result: \n "
" { \n "
2014-09-25 06:56:05 -03:00
" \" version \" : xxxxx, (numeric) the server version \n "
" \" subversion \" : \" /Satoshi:x.x.x/ \" , (string) the server subversion string \n "
" \" protocolversion \" : xxxxx, (numeric) the protocol version \n "
" \" localservices \" : \" xxxxxxxxxxxxxxxx \" , (string) the services we offer to the network \n "
" \" timeoffset \" : xxxxx, (numeric) the time offset \n "
" \" connections \" : xxxxx, (numeric) the number of connections \n "
" \" networks \" : [ (array) information per network \n "
" { \n "
" \" name \" : \" xxx \" , (string) network (ipv4, ipv6 or onion) \n "
" \" limited \" : true|false, (boolean) is the network limited using -onlynet? \n "
" \" reachable \" : true|false, (boolean) is the network reachable? \n "
" \" proxy \" : \" host:port \" (string) the proxy that is used for this network, or empty if none \n "
" } \n "
" ,... \n "
2014-07-30 09:35:14 -04:00
" ], \n "
2014-09-25 06:56:05 -03:00
" \" relayfee \" : x.xxxxxxxx, (numeric) minimum relay fee for non-free transactions in btc/kb \n "
" \" localaddresses \" : [ (array) list of local addresses \n "
" { \n "
" \" address \" : \" xxxx \" , (string) network address \n "
" \" port \" : xxx, (numeric) network port \n "
" \" score \" : xxx (numeric) relative score \n "
" } \n "
" ,... \n "
2014-05-05 07:22:28 -04:00
" ] \n "
2015-06-11 17:12:34 -03:00
" \" warnings \" : \" ... \" (string) any network warnings (such as alert messages) \n "
2014-05-05 07:22:28 -04:00
" } \n "
" \n Examples: \n "
+ HelpExampleCli ( " getnetworkinfo " , " " )
+ HelpExampleRpc ( " getnetworkinfo " , " " )
) ;
2014-10-19 05:46:17 -03:00
LOCK ( cs_main ) ;
2015-05-10 09:48:35 -03:00
UniValue obj ( UniValue : : VOBJ ) ;
2014-09-25 06:56:05 -03:00
obj . push_back ( Pair ( " version " , CLIENT_VERSION ) ) ;
2014-09-14 22:54:32 -03:00
obj . push_back ( Pair ( " subversion " ,
FormatSubVersion ( CLIENT_NAME , CLIENT_VERSION , std : : vector < string > ( ) ) ) ) ;
2014-09-25 06:56:05 -03:00
obj . push_back ( Pair ( " protocolversion " , PROTOCOL_VERSION ) ) ;
2014-06-06 03:15:55 -04:00
obj . push_back ( Pair ( " localservices " , strprintf ( " %016x " , nLocalServices ) ) ) ;
2014-05-06 08:58:43 -04:00
obj . push_back ( Pair ( " timeoffset " , GetTimeOffset ( ) ) ) ;
2014-05-05 07:22:28 -04:00
obj . push_back ( Pair ( " connections " , ( int ) vNodes . size ( ) ) ) ;
2014-07-30 09:35:14 -04:00
obj . push_back ( Pair ( " networks " , GetNetworksInfo ( ) ) ) ;
2014-07-03 14:25:32 -04:00
obj . push_back ( Pair ( " relayfee " , ValueFromAmount ( : : minRelayTxFee . GetFeePerK ( ) ) ) ) ;
2015-05-10 09:48:35 -03:00
UniValue localAddresses ( UniValue : : VARR ) ;
2014-05-05 07:22:28 -04:00
{
LOCK ( cs_mapLocalHost ) ;
BOOST_FOREACH ( const PAIRTYPE ( CNetAddr , LocalServiceInfo ) & item , mapLocalHost )
{
2015-05-10 09:48:35 -03:00
UniValue rec ( UniValue : : VOBJ ) ;
2014-05-05 07:22:28 -04:00
rec . push_back ( Pair ( " address " , item . first . ToString ( ) ) ) ;
rec . push_back ( Pair ( " port " , item . second . nPort ) ) ;
rec . push_back ( Pair ( " score " , item . second . nScore ) ) ;
localAddresses . push_back ( rec ) ;
}
}
obj . push_back ( Pair ( " localaddresses " , localAddresses ) ) ;
2015-06-11 17:12:34 -03:00
obj . push_back ( Pair ( " warnings " , GetWarnings ( " statusbar " ) ) ) ;
2014-05-05 07:22:28 -04:00
return obj ;
}
2015-05-19 05:07:46 -03:00
Value setban ( const Array & params , bool fHelp )
{
string strCommand ;
if ( params . size ( ) > = 2 )
strCommand = params [ 1 ] . get_str ( ) ;
if ( fHelp | | params . size ( ) < 2 | |
( strCommand ! = " add " & & strCommand ! = " remove " ) )
throw runtime_error (
2015-05-25 15:03:51 -03:00
" setban \" ip(/netmask) \" \" add|remove \" (bantime) \n "
" \n Attempts add or remove a IP/Subnet from the banned list. \n "
2015-05-19 05:07:46 -03:00
" \n Arguments: \n "
2015-05-25 15:03:51 -03:00
" 1. \" ip(/netmask) \" (string, required) The IP/Subnet (see getpeerinfo for nodes ip) with a optional netmask (default is /32 = single ip) \n "
" 2. \" command \" (string, required) 'add' to add a IP/Subnet to the list, 'remove' to remove a IP/Subnet from the list \n "
" 1. \" bantime \" (numeric, optional) time in seconds how long the ip is banned (0 or empty means using the default time of 24h which can also be overwritten by the -bantime startup argument) \n "
2015-05-19 05:07:46 -03:00
" \n Examples: \n "
+ HelpExampleCli ( " setban " , " \" 192.168.0.6 \" \" add \" 86400 " )
2015-05-25 15:03:51 -03:00
+ HelpExampleCli ( " setban " , " \" 192.168.0.0/24 \" \" add \" " )
2015-05-19 05:07:46 -03:00
+ HelpExampleRpc ( " setban " , " \" 192.168.0.6 \" , \" add \" 86400 " )
) ;
2015-05-25 15:03:51 -03:00
CSubNet subNet ;
CNetAddr netAddr ;
bool isSubnet = false ;
if ( params [ 0 ] . get_str ( ) . find ( " / " ) ! = string : : npos )
isSubnet = true ;
if ( ! isSubnet )
netAddr = CNetAddr ( params [ 0 ] . get_str ( ) ) ;
else
subNet = CSubNet ( params [ 0 ] . get_str ( ) ) ;
if ( ! ( isSubnet ? subNet . IsValid ( ) : netAddr . IsValid ( ) ) )
throw JSONRPCError ( RPC_CLIENT_NODE_ALREADY_ADDED , " Error: Invalid IP/Subnet " ) ;
2015-05-19 05:07:46 -03:00
if ( strCommand = = " add " )
{
2015-05-25 15:03:51 -03:00
if ( isSubnet ? CNode : : IsBanned ( subNet ) : CNode : : IsBanned ( netAddr ) )
throw JSONRPCError ( RPC_CLIENT_NODE_ALREADY_ADDED , " Error: IP/Subnet already banned " ) ;
2015-05-19 05:07:46 -03:00
int64_t banTime = 0 ; //use standard bantime if not specified
if ( params . size ( ) = = 3 & & ! params [ 2 ] . is_null ( ) )
banTime = params [ 2 ] . get_int64 ( ) ;
2015-05-25 15:03:51 -03:00
isSubnet ? CNode : : Ban ( subNet , banTime ) : CNode : : Ban ( netAddr , banTime ) ;
2015-05-19 05:07:46 -03:00
//disconnect possible nodes
2015-05-25 15:03:51 -03:00
while ( CNode * bannedNode = ( isSubnet ? FindNode ( subNet ) : FindNode ( netAddr ) ) )
2015-05-19 05:07:46 -03:00
bannedNode - > CloseSocketDisconnect ( ) ;
}
else if ( strCommand = = " remove " )
{
2015-05-25 15:03:51 -03:00
if ( ! ( isSubnet ? CNode : : Unban ( subNet ) : CNode : : Unban ( netAddr ) ) )
2015-05-19 05:07:46 -03:00
throw JSONRPCError ( RPC_CLIENT_NODE_ALREADY_ADDED , " Error: Unban failed " ) ;
}
return Value : : null ;
}
Value listbanned ( const Array & params , bool fHelp )
{
if ( fHelp | | params . size ( ) ! = 0 )
throw runtime_error (
" listbanned \n "
2015-05-25 15:03:51 -03:00
" \n List all banned IPs/Subnets. \n "
2015-05-19 05:07:46 -03:00
" \n Examples: \n "
+ HelpExampleCli ( " listbanned " , " " )
+ HelpExampleRpc ( " listbanned " , " " )
) ;
2015-05-25 15:03:51 -03:00
std : : map < CSubNet , int64_t > banMap ;
2015-05-19 05:07:46 -03:00
CNode : : GetBanned ( banMap ) ;
Array bannedAddresses ;
2015-05-25 15:03:51 -03:00
for ( std : : map < CSubNet , int64_t > : : iterator it = banMap . begin ( ) ; it ! = banMap . end ( ) ; it + + )
2015-05-19 05:07:46 -03:00
{
Object rec ;
rec . push_back ( Pair ( " address " , ( * it ) . first . ToString ( ) ) ) ;
rec . push_back ( Pair ( " bannedtill " , ( * it ) . second ) ) ;
bannedAddresses . push_back ( rec ) ;
}
return bannedAddresses ;
}
Value clearbanned ( const Array & params , bool fHelp )
{
if ( fHelp | | params . size ( ) ! = 0 )
throw runtime_error (
" clearbanned \n "
" \n Clear all banned IPs. \n "
" \n Examples: \n "
+ HelpExampleCli ( " clearbanned " , " " )
+ HelpExampleRpc ( " clearbanned " , " " )
) ;
CNode : : ClearBanned ( ) ;
return Value : : null ;
}