Bitcoin ABC 0.30.9
P2P Digital Currency
|
#include <compat.h>
#include <netaddress.h>
#include <serialize.h>
#include <util/sock.h>
#include <cstdint>
#include <functional>
#include <memory>
#include <string>
#include <type_traits>
#include <vector>
Go to the source code of this file.
Classes | |
class | proxyType |
struct | ProxyCredentials |
Credentials for proxy authentication. More... | |
Typedefs | |
using | DNSLookupFn = std::function< std::vector< CNetAddr >(const std::string &, bool)> |
Enumerations | |
enum class | ConnectionDirection { None = 0 , In = (1U << 0) , Out = (1U << 1) , Both = (In | Out) } |
Functions | |
static ConnectionDirection & | operator|= (ConnectionDirection &a, ConnectionDirection b) |
static bool | operator& (ConnectionDirection a, ConnectionDirection b) |
std::vector< CNetAddr > | WrappedGetAddrInfo (const std::string &name, bool allow_lookup) |
Wrapper for getaddrinfo(3). More... | |
enum Network | ParseNetwork (const std::string &net) |
std::string | GetNetworkName (enum Network net) |
std::vector< std::string > | GetNetworkNames (bool append_unroutable=false) |
Return a vector of publicly routable Network names; optionally append NET_UNROUTABLE. More... | |
bool | SetProxy (enum Network net, const proxyType &addrProxy) |
bool | GetProxy (enum Network net, proxyType &proxyInfoOut) |
bool | IsProxy (const CNetAddr &addr) |
bool | SetNameProxy (const proxyType &addrProxy) |
Set the name proxy to use for all connections to nodes specified by a hostname. More... | |
bool | HaveNameProxy () |
bool | GetNameProxy (proxyType &nameProxyOut) |
bool | LookupHost (const std::string &name, std::vector< CNetAddr > &vIP, unsigned int nMaxSolutions, bool fAllowLookup, DNSLookupFn dns_lookup_function=g_dns_lookup) |
Resolve a host string to its corresponding network addresses. More... | |
bool | LookupHost (const std::string &name, CNetAddr &addr, bool fAllowLookup, DNSLookupFn dns_lookup_function=g_dns_lookup) |
Resolve a host string to its first corresponding network address. More... | |
bool | Lookup (const std::string &name, std::vector< CService > &vAddr, uint16_t portDefault, bool fAllowLookup, unsigned int nMaxSolutions, DNSLookupFn dns_lookup_function=g_dns_lookup) |
Resolve a service string to its corresponding service. More... | |
bool | Lookup (const std::string &name, CService &addr, uint16_t portDefault, bool fAllowLookup, DNSLookupFn dns_lookup_function=g_dns_lookup) |
Resolve a service string to its first corresponding service. More... | |
CService | LookupNumeric (const std::string &name, uint16_t portDefault=0, DNSLookupFn dns_lookup_function=g_dns_lookup) |
Resolve a service string with a numeric IP to its first corresponding service. More... | |
bool | LookupSubNet (const std::string &strSubnet, CSubNet &subnet, DNSLookupFn dns_lookup_function=g_dns_lookup) |
Parse and resolve a specified subnet string into the appropriate internal representation. More... | |
std::unique_ptr< Sock > | CreateSockTCP (const CService &address_family) |
Create a TCP socket in the given address family. More... | |
bool | ConnectSocketDirectly (const CService &addrConnect, const Sock &sock, int nTimeout, bool manual_connection) |
Try to connect to the specified service on the specified socket. More... | |
bool | ConnectThroughProxy (const proxyType &proxy, const std::string &strDest, uint16_t port, const Sock &sock, int nTimeout, bool &outProxyConnectionFailed) |
Connect to a specified destination service through a SOCKS5 proxy by first connecting to the SOCKS5 proxy. More... | |
bool | SetSocketNonBlocking (const SOCKET &hSocket, bool fNonBlocking) |
Disable or enable blocking-mode for a socket. More... | |
bool | SetSocketNoDelay (const SOCKET &hSocket) |
Set the TCP_NODELAY flag on a socket. More... | |
void | InterruptSocks5 (bool interrupt) |
bool | Socks5 (const std::string &strDest, uint16_t port, const ProxyCredentials *auth, const Sock &socket) |
Connect to a specified destination service through an already connected SOCKS5 proxy. More... | |
bool | IsBadPort (uint16_t port) |
Determine if a port is "bad" from the perspective of attempting to connect to a node on that port. More... | |
Variables | |
int | nConnectTimeout |
bool | fNameLookup |
static const int | DEFAULT_CONNECT_TIMEOUT = 5000 |
-timeout default More... | |
static const int | DEFAULT_NAME_LOOKUP = true |
-dns default More... | |
DNSLookupFn | g_dns_lookup |
std::function< std::unique_ptr< Sock >(const CService &)> | CreateSock |
Socket factory. More... | |
using DNSLookupFn = std::function<std::vector<CNetAddr>(const std::string &, bool)> |
|
strong |
bool ConnectSocketDirectly | ( | const CService & | addrConnect, |
const Sock & | sock, | ||
int | nTimeout, | ||
bool | manual_connection | ||
) |
Try to connect to the specified service on the specified socket.
addrConnect | The service to which to connect. |
sock | The socket on which to connect. |
nTimeout | Wait this many milliseconds for the connection to be established. |
manual_connection | Whether or not the connection was manually requested (e.g. through the addnode RPC) |
Definition at line 629 of file netbase.cpp.
bool ConnectThroughProxy | ( | const proxyType & | proxy, |
const std::string & | strDest, | ||
uint16_t | port, | ||
const Sock & | sock, | ||
int | nTimeout, | ||
bool & | outProxyConnectionFailed | ||
) |
Connect to a specified destination service through a SOCKS5 proxy by first connecting to the SOCKS5 proxy.
proxy | The SOCKS5 proxy. | |
strDest | The destination service to which to connect. | |
port | The destination port. | |
sock | The socket on which to connect to the SOCKS5 proxy. | |
nTimeout | Wait this many milliseconds for the connection to the SOCKS5 proxy to be established. | |
[out] | outProxyConnectionFailed | Whether or not the connection to the SOCKS5 proxy failed. |
Definition at line 758 of file netbase.cpp.
Create a TCP socket in the given address family.
[in] | address_family | The socket is created in the same address family as this address. |
Definition at line 567 of file netbase.cpp.
bool GetNameProxy | ( | proxyType & | nameProxyOut | ) |
std::string GetNetworkName | ( | enum Network | net | ) |
Definition at line 114 of file netbase.cpp.
std::vector< std::string > GetNetworkNames | ( | bool | append_unroutable = false | ) |
Return a vector of publicly routable Network names; optionally append NET_UNROUTABLE.
Definition at line 137 of file netbase.cpp.
Definition at line 715 of file netbase.cpp.
bool HaveNameProxy | ( | ) |
void InterruptSocks5 | ( | bool | interrupt | ) |
Definition at line 850 of file netbase.cpp.
bool IsBadPort | ( | uint16_t | port | ) |
Determine if a port is "bad" from the perspective of attempting to connect to a node on that port.
[in] | port | Port to check. |
Definition at line 854 of file netbase.cpp.
bool IsProxy | ( | const CNetAddr & | addr | ) |
Definition at line 748 of file netbase.cpp.
bool Lookup | ( | const std::string & | name, |
CService & | addr, | ||
uint16_t | portDefault, | ||
bool | fAllowLookup, | ||
DNSLookupFn | dns_lookup_function = g_dns_lookup |
||
) |
Resolve a service string to its first corresponding service.
Definition at line 246 of file netbase.cpp.
bool Lookup | ( | const std::string & | name, |
std::vector< CService > & | vAddr, | ||
uint16_t | portDefault, | ||
bool | fAllowLookup, | ||
unsigned int | nMaxSolutions, | ||
DNSLookupFn | dns_lookup_function = g_dns_lookup |
||
) |
Resolve a service string to its corresponding service.
name | The string representing a service. Could be a name or a numerical IP address (IPv6 addresses should be in their disambiguated bracketed form), optionally followed by a uint16_t port number. (e.g. example.com:8333 or | |
[out] | vAddr | The resulting services to which the specified service string resolved. |
portDefault | The default port for resulting services if not specified by the service string. | |
fAllowLookup | Whether or not hostname lookups are permitted. If yes, external queries may be performed. | |
nMaxSolutions | The maximum number of results we want, specifying 0 means "as many solutions as we get." |
Definition at line 223 of file netbase.cpp.
bool LookupHost | ( | const std::string & | name, |
CNetAddr & | addr, | ||
bool | fAllowLookup, | ||
DNSLookupFn | dns_lookup_function = g_dns_lookup |
||
) |
Resolve a host string to its first corresponding network address.
Definition at line 209 of file netbase.cpp.
bool LookupHost | ( | const std::string & | name, |
std::vector< CNetAddr > & | vIP, | ||
unsigned int | nMaxSolutions, | ||
bool | fAllowLookup, | ||
DNSLookupFn | dns_lookup_function = g_dns_lookup |
||
) |
Resolve a host string to its corresponding network addresses.
name | The string representing a host. Could be a name or a numerical IP address (IPv6 addresses in their bracketed form are allowed). | |
[out] | vIP | The resulting network addresses to which the specified host string resolved. |
Definition at line 191 of file netbase.cpp.
CService LookupNumeric | ( | const std::string & | name, |
uint16_t | portDefault = 0 , |
||
DNSLookupFn | dns_lookup_function = g_dns_lookup |
||
) |
Resolve a service string with a numeric IP to its first corresponding service.
Definition at line 261 of file netbase.cpp.
bool LookupSubNet | ( | const std::string & | strSubnet, |
CSubNet & | subnet, | ||
DNSLookupFn | dns_lookup_function = g_dns_lookup |
||
) |
Parse and resolve a specified subnet string into the appropriate internal representation.
strSubnet | A string representation of a subnet of the form network address [ "/", ( CIDR-style suffix | netmask ) ] (e.g. 2001:db8::/32 , 192.0.2.0/255.255.255.0 , or 8.8.8.8 ). |
subnet | The resulting internal representation of a subnet. |
Definition at line 781 of file netbase.cpp.
|
inlinestatic |
|
inlinestatic |
enum Network ParseNetwork | ( | const std::string & | net | ) |
Definition at line 92 of file netbase.cpp.
bool SetNameProxy | ( | const proxyType & | addrProxy | ) |
Set the name proxy to use for all connections to nodes specified by a hostname.
After setting this proxy, connecting to a node specified by a hostname won't result in a local lookup of said hostname, rather, connect to the node by asking the name proxy for a proxy connection to the hostname, effectively delegating the hostname lookup to the specified proxy.
This delegation increases privacy for those who set the name proxy as they no longer leak their external hostname queries to their DNS servers.
Definition at line 725 of file netbase.cpp.
Definition at line 705 of file netbase.cpp.
bool SetSocketNoDelay | ( | const SOCKET & | hSocket | ) |
Set the TCP_NODELAY flag on a socket.
Definition at line 843 of file netbase.cpp.
bool SetSocketNonBlocking | ( | const SOCKET & | hSocket, |
bool | fNonBlocking | ||
) |
Disable or enable blocking-mode for a socket.
Definition at line 817 of file netbase.cpp.
bool Socks5 | ( | const std::string & | strDest, |
uint16_t | port, | ||
const ProxyCredentials * | auth, | ||
const Sock & | sock | ||
) |
Connect to a specified destination service through an already connected SOCKS5 proxy.
strDest | The destination fully-qualified domain name. |
port | The destination port. |
auth | The credentials with which to authenticate with the specified SOCKS5 proxy. |
sock | The SOCKS5 proxy socket. |
If a timeout happens here, this effectively means we timed out while connecting to the remote node. This is very common for Tor, so do not print an error message.
Definition at line 421 of file netbase.cpp.
std::vector< CNetAddr > WrappedGetAddrInfo | ( | const std::string & | name, |
bool | allow_lookup | ||
) |
Wrapper for getaddrinfo(3).
Do not use directly: call Lookup/LookupHost/LookupNumeric/LookupSubNet.
Definition at line 46 of file netbase.cpp.
Socket factory.
Defaults to CreateSockTCP()
, but can be overridden by unit tests.
Definition at line 615 of file netbase.cpp.
|
static |
|
extern |
Definition at line 38 of file netbase.cpp.
|
extern |
Definition at line 90 of file netbase.cpp.
|
extern |
Definition at line 37 of file netbase.cpp.