X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=blobdiff_plain;f=src%2Fsocket_server.hxx;h=4c928c5f020026d392d60ce64ae086b99830ad22;hp=5dcf4f33227f1c52cec54c481d51a951d48b2ada;hb=4ddaa0f5ce6d2f7b6a2419dad9ff83879e04df2c;hpb=07e98688a1a8c3e915ce923f79261a88251a9edd diff --git a/src/socket_server.hxx b/src/socket_server.hxx index 5dcf4f3..4c928c5 100644 --- a/src/socket_server.hxx +++ b/src/socket_server.hxx @@ -29,22 +29,33 @@ namespace libt2n { -/** - Socket based server class +class socket_server_connection; + +/** @brief Socket based server class + + Use this class to instantiate a server listening for client connections. + Call fill_buffer() to read data from the network and get_packet() to retrieve + this data. Don't forget to call cleanup() from time to time to remove closed + connections and close idle ones. */ class socket_server : public socket_handler, public server { + friend class socket_server_connection; + private: fd_set connection_set; std::string unix_path; + void start_listening(); + void new_connection(); + bool fill_connection_buffers(); + void remove_connection_socket(int sock); + protected: - void log(log_level_values level, const std::string& message) - { log(level,message.c_str()); } - void log(log_level_values level, const char* message) - { server::log(level,message); } + std::ostream* get_logstream(log_level_values level) + { return server::get_logstream(level); } public: socket_server(int port, const std::string& ip="0.0.0.0"); @@ -52,14 +63,12 @@ class socket_server : public socket_handler, public server ~socket_server(); - void fill_buffer(long long usec_timeout=-1); - void fill_connection_buffers(); - - void remove_connection_socket(int sock); + bool fill_buffer(long long usec_timeout=-1,long long* usec_timeout_remaining=NULL); }; -/** - Socket based connection class +/** @brief Socket based connection + + This class is used within a socket_server to represent the connection to each client. */ class socket_server_connection : public socket_handler, public server_connection { @@ -70,14 +79,15 @@ class socket_server_connection : public socket_handler, public server_connection : server_connection(_timeout), socket_handler(_sock,_stype) { } - void log(log_level_values level, const char* message); + std::ostream* get_logstream(log_level_values level) + { return server_connection::get_logstream(level); } void real_write(const std::string& data) { socket_write(data); } public: - bool fill_buffer(long long usec_timeout=-1) - { return socket_handler::fill_buffer(buffer,usec_timeout); } + bool fill_buffer(long long usec_timeout=-1,long long* usec_timeout_remaining=NULL) + { return socket_handler::fill_buffer(buffer,usec_timeout,usec_timeout_remaining); } void close(); };