35 #ifndef _ABSTRACT_TCP_SERVER2_H_ 36 #define _ABSTRACT_TCP_SERVER2_H_ 41 #include <boost/noncopyable.hpp> 42 #include <boost/shared_ptr.hpp> 47 #include <condition_variable> 49 #include <boost/asio.hpp> 50 #include <boost/asio/ssl.hpp> 51 #include <boost/asio/strand.hpp> 52 #include <boost/asio/steady_timer.hpp> 53 #include <boost/array.hpp> 54 #include <boost/enable_shared_from_this.hpp> 55 #include <boost/thread/thread.hpp> 56 #include <boost/optional.hpp> 63 #undef MONERO_DEFAULT_LOG_CATEGORY 64 #define MONERO_DEFAULT_LOG_CATEGORY "net" 66 #define ABSTRACT_SERVER_SEND_QUE_MAX_COUNT 1000 85 template<
class t_protocol_handler>
87 :
public boost::enable_shared_from_this<connection<t_protocol_handler> >,
88 private boost::noncopyable,
98 using timer_t = boost::asio::steady_timer;
100 using ec_t = boost::system::error_code;
101 using handshake_t = boost::asio::ssl::stream_base::handshake_type;
137 bool is_multithreaded,
138 boost::optional<network_address> real_remote
272 std::shared_ptr<shared_state>
state,
277 std::shared_ptr<shared_state>
state,
286 bool start(
bool is_income,
bool is_multithreaded);
306 virtual bool close();
321 template<
class t_protocol_handler>
323 :
private boost::noncopyable
346 uint32_t port_ipv6 = 0,
const std::string& address_ipv6 =
"::",
bool use_ipv6 =
false,
bool require_ipv4 =
true,
349 const std::string port_ipv6 =
"",
const std::string address_ipv6 =
"::",
bool use_ipv6 =
false,
bool require_ipv4 =
true,
353 bool run_server(
size_t threads_count,
bool wait =
true,
const boost::thread::attributes& attrs = boost::thread::attributes());
381 template<
class t_callback>
408 auto connections_count =
m_state->sock_count > 0 ? (
m_state->sock_count - 1) : 0;
409 return connections_count;
426 template <
class t_handler>
442 template<
class t_handler>
445 boost::shared_ptr<idle_callback_conext<t_handler>> ptr(
new idle_callback_conext<t_handler>(
io_service_, t_callback, timeout_ms));
447 ptr->m_timer.expires_from_now(boost::posix_time::milliseconds(ptr->m_period));
452 template<
class t_handler>
456 if(!ptr->call_handler())
458 ptr->m_timer.expires_from_now(boost::posix_time::milliseconds(ptr->m_period));
463 template<
class t_handler>
480 const std::shared_ptr<typename connection<t_protocol_handler>::shared_state>
m_state;
490 boost::asio::io_service::work
work;
509 std::vector<boost::shared_ptr<boost::thread> >
m_threads;
void handle_accept_ipv6(const boost::system::error_code &e)
Definition: abstract_tcp_server2.inl:1464
t_connection_context m_conn_context
Definition: abstract_tcp_server2.h:251
virtual bool request_callback()
Definition: abstract_tcp_server2.inl:1071
state_t m_state
Definition: abstract_tcp_server2.h:257
void on_terminating()
Definition: abstract_tcp_server2.inl:718
virtual bool call_handler()
Definition: abstract_tcp_server2.h:418
size_t get_threads_count()
Definition: abstract_tcp_server2.h:369
void terminate()
Definition: abstract_tcp_server2.inl:703
bool m_use_ipv6
Definition: abstract_tcp_server2.h:505
virtual ~i_connection_filter()
Definition: abstract_tcp_server2.h:77
bool cancel_expire
Definition: abstract_tcp_server2.h:196
idle_callback_conext(boost::asio::io_service &io_serice, t_handler &h, uint64_t period)
Definition: abstract_tcp_server2.h:429
t_protocol_handler::connection_context t_connection_context
Definition: abstract_tcp_server2.h:334
timer_t in
Definition: abstract_tcp_server2.h:241
virtual bool call_run_once_service_io()
Definition: abstract_tcp_server2.inl:1057
Definition: abstract_tcp_server2.h:322
virtual bool close()
Definition: abstract_tcp_server2.inl:1047
t_handler m_handler
Definition: abstract_tcp_server2.h:434
shared_state()
Definition: abstract_tcp_server2.h:262
Definition: abstract_tcp_server2.h:231
boosted_tcp_server(t_connection_type connection_type)
Definition: abstract_tcp_server2.inl:1129
std::string m_address_ipv6
Definition: abstract_tcp_server2.h:504
bool wait_handshake
Definition: abstract_tcp_server2.h:179
critical_section m_threads_lock
Definition: abstract_tcp_server2.h:511
t_protocol_handler m_handler
Definition: abstract_tcp_server2.h:258
enum upnpconfigoptions id
Definition: options.c:29
bool cancel_write
Definition: abstract_tcp_server2.h:188
Definition: abstract_tcp_server2.h:328
::std::string string
Definition: gtest-port.h:1097
Definition: net_utils_base.h:222
bool wait_release
Definition: abstract_tcp_server2.h:215
the connection templated-class for one peer connection
boost::asio::io_service::strand strand_t
Definition: abstract_tcp_server2.h:104
std::unique_ptr< worker > m_io_service_local_instance
Definition: abstract_tcp_server2.h:492
t
Definition: console.py:33
bool connected
Definition: abstract_tcp_server2.h:177
std::atomic< uint32_t > m_thread_index
Definition: abstract_tcp_server2.h:512
std::array< uint8_t, 0x2000 > buffer
Definition: abstract_tcp_server2.h:161
timer_status_t in
Definition: abstract_tcp_server2.h:202
Definition: abstract_tcp_server2.h:176
std::string m_host
Definition: abstract_tcp_server2.h:256
t_connection_type m_connection_type
Definition: abstract_tcp_server2.h:250
boost::asio::ip::tcp::acceptor acceptor_ipv6
Definition: abstract_tcp_server2.h:497
std::vector< boost::shared_ptr< boost::thread > > m_threads
Definition: abstract_tcp_server2.h:509
boost::asio::ssl::context & get_ssl_context() noexcept
Definition: abstract_tcp_server2.h:384
timers_status_t timers
Definition: abstract_tcp_server2.h:225
std::unique_ptr< void, close > socket
Unique ZMQ socket handle, calls zmq_close on destruction.
Definition: zmq.h:108
virtual bool send_done()
Definition: abstract_tcp_server2.inl:1041
void start_handshake()
Definition: abstract_tcp_server2.inl:210
boost::mutex connections_mutex
Definition: abstract_tcp_server2.h:521
network_throttle_t throttle
Definition: abstract_tcp_server2.h:152
bool is_thread_worker()
Definition: abstract_tcp_server2.inl:1407
void save_dbg_log()
Definition: abstract_tcp_server2.inl:998
try_connect_result_t try_connect(connection_ptr new_connection_l, const std::string &adr, const std::string &port, boost::asio::ip::tcp::socket &sock_, const boost::asio::ip::tcp::endpoint &remote_endpoint, const std::string &bind_ip, uint32_t conn_timeout, epee::net_utils::ssl_support_t ssl_support)
Definition: abstract_tcp_server2.inl:1562
ssl_support_t
Definition: net_ssl.h:48
std::set< connection_ptr > connections_
Definition: abstract_tcp_server2.h:522
bool cancel_handshake
Definition: abstract_tcp_server2.h:180
timers_t(io_context_t &io_context)
Definition: abstract_tcp_server2.h:232
void cancel_handler()
Definition: abstract_tcp_server2.inl:629
~boosted_tcp_server()
Definition: abstract_tcp_server2.inl:1166
void on_interrupted()
Definition: abstract_tcp_server2.inl:659
boost::asio::deadline_timer m_timer
Definition: abstract_tcp_server2.h:423
epee::net_utils::network_address default_remote
Definition: abstract_tcp_server2.h:498
i_connection_filter * pfilter
Definition: abstract_tcp_server2.h:266
bool deinit_server()
Definition: abstract_tcp_server2.h:367
void start_write()
Definition: abstract_tcp_server2.inl:448
std::string m_thread_name_prefix
Definition: abstract_tcp_server2.h:507
bool enabled
Definition: abstract_tcp_server2.h:170
io_context_t & m_io_context
Definition: abstract_tcp_server2.h:249
Definition: abstract_tcp_server2.h:145
virtual bool call_handler()
Definition: abstract_tcp_server2.h:435
void async_wait_timer()
Definition: abstract_tcp_server2.inl:171
bool handle_read
Definition: abstract_tcp_server2.h:183
bool cancel_read
Definition: abstract_tcp_server2.h:184
bool connect(const std::string &adr, const std::string &port, uint32_t conn_timeot, t_connection_context &cn, const std::string &bind_ip="0.0.0.0", epee::net_utils::ssl_support_t ssl_support=epee::net_utils::ssl_support_t::e_ssl_support_autodetect)
Definition: abstract_tcp_server2.inl:1660
bool detected
Definition: abstract_tcp_server2.h:172
throttle_t throttle
Definition: abstract_tcp_server2.h:207
boost::thread::id m_main_thread_id
Definition: abstract_tcp_server2.h:510
boost::asio::io_service & get_io_service()
Definition: abstract_tcp_server2.h:412
Definition: abstract_tcp_server2.h:329
bool released
Definition: abstract_tcp_server2.h:212
bool wait_write
Definition: abstract_tcp_server2.h:186
boost::asio::io_service::work work
Definition: abstract_tcp_server2.h:490
virtual ~connection() noexcept(false)
Definition: abstract_tcp_server2.inl:966
size_t reference_counter
Definition: abstract_tcp_server2.h:211
bool reset_expire
Definition: abstract_tcp_server2.h:197
stat_t stat
Definition: abstract_tcp_server2.h:227
const std::atomic< bool > & get_stop_signal() const noexcept
Definition: abstract_tcp_server2.h:363
boost::asio::io_service io_service
Definition: levin.cpp:303
Definition: abstract_tcp_server2.h:210
e
Definition: pymoduletest.py:79
timer_status_t out
Definition: abstract_tcp_server2.h:203
void start_read()
Definition: abstract_tcp_server2.inl:323
bool add_idle_handler(t_handler t_callback, uint64_t timeout_ms)
Definition: abstract_tcp_server2.h:443
void start_timer(duration_t duration, bool add={})
Definition: abstract_tcp_server2.inl:143
virtual bool is_remote_host_allowed(const epee::net_utils::network_address &address, time_t *t=NULL)=0
uint64_t m_period
Definition: abstract_tcp_server2.h:439
void handle_accept_ipv4(const boost::system::error_code &e)
Handle completion of an asynchronous accept operation.
Definition: abstract_tcp_server2.inl:1458
Definition: abstract_tcp_server2.h:427
boost::asio::ssl::stream_base::handshake_type handshake_t
Definition: abstract_tcp_server2.h:101
bool init_server(uint32_t port, const std::string &address="0.0.0.0", uint32_t port_ipv6=0, const std::string &address_ipv6="::", bool use_ipv6=false, bool require_ipv4=true, ssl_options_t ssl_options=ssl_support_t::e_ssl_support_autodetect)
Definition: abstract_tcp_server2.inl:1181
bool handshaked
Definition: abstract_tcp_server2.h:173
Definition: abstract_tcp_server2.h:142
static void add(ge_p3 &p3, const ge_cached &other)
Definition: multiexp.cc:144
std::map< std::string, t_connection_type > server_type_map
Definition: abstract_tcp_server2.h:342
timer_t::duration duration_t
Definition: abstract_tcp_server2.h:99
data_t data
Definition: abstract_tcp_server2.h:228
bool wait_shutdown
Definition: abstract_tcp_server2.h:190
unsigned int uint32_t
Definition: stdint.h:126
size_t m_threads_count
Definition: abstract_tcp_server2.h:508
Definition: abstract_tcp_server2.h:260
Definition: abstract_tcp_server2.h:327
struct epee::net_utils::connection::state_t::stat_t::@1 out
Definition: abstract_tcp_server2.h:159
boost::shared_ptr< connection< t_protocol_handler > > connection_ptr
Definition: abstract_tcp_server2.h:333
Represents a single connection from a client.
Definition: abstract_tcp_server2.h:86
Definition: abstract_tcp_server2.h:414
throttle_t throttle
Definition: abstract_tcp_server2.h:246
std::condition_variable_any condition
Definition: abstract_tcp_server2.h:221
virtual boost::asio::io_service & get_io_service()
Definition: abstract_tcp_server2.inl:1091
struct epee::net_utils::connection::state_t::stat_t::@0 in
connection(boost::asio::io_service &io_service, std::shared_ptr< shared_state > state, t_connection_type connection_type, epee::net_utils::ssl_support_t ssl_support)
Construct a connection with the given io_service.
Definition: abstract_tcp_server2.inl:934
unsigned int host_count(int delta=0)
Definition: abstract_tcp_server2.inl:80
bool send(epee::byte_slice message)
Definition: abstract_tcp_server2.inl:756
idle_callback_conext_base(boost::asio::io_service &io_serice)
Definition: abstract_tcp_server2.h:420
unsigned __int64 uint64_t
Definition: stdint.h:136
duration_t get_timeout_from_bytes_read(size_t bytes) const
Definition: abstract_tcp_server2.inl:114
void handle_accept(const boost::system::error_code &e, bool ipv6=false)
Definition: abstract_tcp_server2.inl:1470
Definition: byte_slice.h:68
int get_binded_port_ipv6()
Definition: abstract_tcp_server2.h:403
std::unique_ptr< void, terminate > context
Unique ZMQ context handle, calls zmq_term on destruction.
Definition: zmq.h:105
virtual ~idle_callback_conext_base()
Definition: abstract_tcp_server2.h:416
Definition: abstract_tcp_server2.h:73
worker()
Definition: abstract_tcp_server2.h:485
boost::system::error_code ec_t
Definition: abstract_tcp_server2.h:100
const std::shared_ptr< typename connection< t_protocol_handler >::shared_state > m_state
Definition: abstract_tcp_server2.h:480
bool wait_consume
Definition: abstract_tcp_server2.h:165
#define false
Definition: stdbool.h:37
long get_connections_count() const
Definition: abstract_tcp_server2.h:405
bool forced
Definition: abstract_tcp_server2.h:171
bool connect_async(const std::string &adr, const std::string &port, uint32_t conn_timeot, const t_callback &cb, const std::string &bind_ip="0.0.0.0", epee::net_utils::ssl_support_t ssl_support=epee::net_utils::ssl_support_t::e_ssl_support_autodetect)
int get_binded_port()
Definition: abstract_tcp_server2.h:402
bool wait_init
Definition: abstract_tcp_server2.h:216
void set_default_remote(epee::net_utils::network_address remote)
Definition: abstract_tcp_server2.h:373
status_t status
Definition: abstract_tcp_server2.h:222
void cancel_socket()
Definition: abstract_tcp_server2.inl:601
void set_connection_filter(i_connection_filter *pfilter)
Definition: abstract_tcp_server2.inl:1345
bool cancel()
Definition: abstract_tcp_server2.inl:1029
connection_ptr new_connection_ipv6
Definition: abstract_tcp_server2.h:518
Definition: network_throttle.hpp:98
bool is_stop_signal_sent() const noexcept
Definition: abstract_tcp_server2.h:361
void setRpcStation()
Definition: abstract_tcp_server2.inl:1122
struct epee::net_utils::connection::state_t::data_t::@2 read
boost::asio::ip::tcp::acceptor acceptor_
Acceptor used to listen for incoming connections.
Definition: abstract_tcp_server2.h:496
bool add_connection(t_connection_context &out, boost::asio::ip::tcp::socket &&sock, network_address real_remote, epee::net_utils::ssl_support_t ssl_support=epee::net_utils::ssl_support_t::e_ssl_support_autodetect)
Definition: abstract_tcp_server2.inl:1542
Definition: abstract_tcp_server2.h:194
virtual bool add_ref()
Definition: abstract_tcp_server2.inl:1097
bool wait_read
Definition: abstract_tcp_server2.h:182
Definition: abstract_tcp_server2.h:149
bool timed_wait_server_stop(uint64_t wait_mseconds)
wait for service workers stop
Definition: abstract_tcp_server2.inl:1423
boost::endian::big_uint16_t port
Definition: socks.cpp:59
timer_t general
Definition: abstract_tcp_server2.h:245
timers_t m_timers
Definition: abstract_tcp_server2.h:253
t_protocol_handler::connection_context t_connection_context
Definition: abstract_tcp_server2.h:93
boost::asio::io_service io_context_t
Definition: abstract_tcp_server2.h:103
throttle_t(io_context_t &io_context)
Definition: abstract_tcp_server2.h:237
bool initialized
Definition: abstract_tcp_server2.h:213
void set_threads_prefix(const std::string &prefix_name)
Definition: abstract_tcp_server2.inl:1335
void create_server_type_map()
Definition: abstract_tcp_server2.inl:1173
bool m_local
Definition: abstract_tcp_server2.h:255
timer_status_t general
Definition: abstract_tcp_server2.h:206
boost::asio::io_service io_service
Definition: abstract_tcp_server2.h:489
bool handle_write
Definition: abstract_tcp_server2.h:187
TODO: (mj-xmr) This will be reduced in an another PR.
Definition: byte_slice.h:39
socket_status_t socket
Definition: abstract_tcp_server2.h:223
uint32_t address
Definition: getifaddr.c:269
bool start(bool is_income, bool is_multithreaded)
Start the first asynchronous operation for the connection.
Definition: abstract_tcp_server2.inl:979
bool speed_limit_is_enabled() const
tells us should we be sleeping here (e.g. do not sleep on RPC connections)
Definition: abstract_tcp_server2.inl:1023
Definition: abstract_tcp_server2.h:144
ssl_t ssl
Definition: abstract_tcp_server2.h:224
Definition: abstract_tcp_server2.h:146
Definition: net_utils_base.h:439
const T & move(const T &t)
Definition: gtest-port.h:1317
The io_service used to perform asynchronous operations.
Definition: abstract_tcp_server2.h:483
virtual bool do_send(byte_slice message)
(see do_send from i_service_endpoint)
Definition: abstract_tcp_server2.inl:1035
void get_context(t_connection_context &context_)
Definition: abstract_tcp_server2.h:291
Definition: blake256.h:36
std::mutex lock
Definition: abstract_tcp_server2.h:220
Definition: network_throttle-detail.hpp:48
size_t wait_callback
Definition: abstract_tcp_server2.h:217
Definition: abstract_tcp_server2.h:201
t_connection_type
Definition: connection_basic.hpp:93
std::string m_address
Definition: abstract_tcp_server2.h:503
boost::asio::steady_timer timer_t
Definition: abstract_tcp_server2.h:98
boost::asio::io_service::strand strand
Definition: levin_notify.cpp:257
std::atomic< bool > m_stop_signal_sent
Definition: abstract_tcp_server2.h:500
uint32_t m_port
Definition: abstract_tcp_server2.h:501
Definition: abstract_tcp_server2.h:169
virtual bool release()
Definition: abstract_tcp_server2.inl:1112
boost::asio::io_service & io_service_
Definition: abstract_tcp_server2.h:493
protocol_t protocol
Definition: abstract_tcp_server2.h:226
bool m_require_ipv4
Definition: abstract_tcp_server2.h:506
Definition: abstract_tcp_server2.h:236
bool worker_thread()
Run the server's io_service loop.
Definition: abstract_tcp_server2.inl:1305
bool cancel_shutdown
Definition: abstract_tcp_server2.h:191
connection_ptr new_connection_
The next connection to be accepted.
Definition: abstract_tcp_server2.h:517
status_t
Definition: abstract_tcp_server2.h:141
void start_shutdown()
Definition: abstract_tcp_server2.inl:560
void state_status_check()
Definition: abstract_tcp_server2.inl:124
std::shared_ptr< typename t_protocol_handler::config_type > get_config_shared()
Definition: abstract_tcp_server2.h:396
void cancel_timer()
Definition: abstract_tcp_server2.inl:199
t_connection_type m_connection_type
Definition: abstract_tcp_server2.h:514
Definition: abstract_tcp_server2.h:143
std::deque< epee::byte_slice > queue
Definition: abstract_tcp_server2.h:164
implementaion for throttling of connection (count and rate-limit speed etc)
bool global_timer_handler(boost::shared_ptr< idle_callback_conext< t_handler >> ptr)
Definition: abstract_tcp_server2.h:453
bool stop_signal_sent
Definition: abstract_tcp_server2.h:267
bool wait_expire
Definition: abstract_tcp_server2.h:195
boost::asio::ip::tcp::socket socket_t
Definition: abstract_tcp_server2.h:105
#define const
Definition: ipfrdr.c:80
tuple message
Definition: gtest_output_test.py:331
bool async_call(t_handler t_callback)
Definition: abstract_tcp_server2.h:464
static uint64_t h
Definition: blockchain_stats.cpp:55
base for connection, contains e.g. the ratelimit hooks
boost::shared_ptr< connection_t > connection_ptr
Definition: abstract_tcp_server2.h:96
strand_t m_strand
Definition: abstract_tcp_server2.h:252
Definition: connection_basic.hpp:62
bool start_internal(bool is_income, bool is_multithreaded, boost::optional< network_address > real_remote)
Definition: abstract_tcp_server2.inl:838
bool run_server(size_t threads_count, bool wait=true, const boost::thread::attributes &attrs=boost::thread::attributes())
Run the server's io_service loop.
Definition: abstract_tcp_server2.inl:1352
void send_stop_signal()
Stop the server.
Definition: abstract_tcp_server2.inl:1440
duration_t get_default_timeout()
Definition: abstract_tcp_server2.inl:97
uint32_t m_port_ipv6
Definition: abstract_tcp_server2.h:502
try_connect_result_t
Definition: abstract_tcp_server2.h:325
struct epee::net_utils::connection::state_t::data_t::@3 write
Definition: abstract_tcp_server2.h:150
t_protocol_handler::config_type & get_config_object()
Definition: abstract_tcp_server2.h:390
Definition: abstract_tcp_server2.h:200
void interrupt()
Definition: abstract_tcp_server2.inl:646
Definition: connection_basic.hpp:101
timer_t out
Definition: abstract_tcp_server2.h:242