X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/751302dd67ffdeb0dfe72c4d2a7a2d58303cf5f3..63715b9ec8f3b126b4e495a4c4485cd68fd6973a:/Server/include/plaqui/server/tcpserver.h diff --git a/Server/include/plaqui/server/tcpserver.h b/Server/include/plaqui/server/tcpserver.h index 0290629..17ce3b1 100644 --- a/Server/include/plaqui/server/tcpserver.h +++ b/Server/include/plaqui/server/tcpserver.h @@ -32,6 +32,7 @@ #include "plaqui/server/connection.h" #include #include +#include namespace PlaQui { @@ -43,16 +44,33 @@ namespace Server { */ class TCPServer: public Runnable { - // Tipos. + // Constantes. private: /// Cantidad máxima de conexiones pendientes. - static const unsigned MAX_PENDING_CONNECTIONS; + static const unsigned MAX_PENDING_CONNECTIONS = 10; + + // Tipos. + + private: /// Lista de conexiones de control. typedef std::list ConnectionList; + public: + + /// Información sobre una conexión de contro. + struct ConnectionInfo { + /// Host. + std::string host; + /// Port. + Connection::Port port; + }; + + /// Lista de información de conexiones de control. + typedef std::vector ConnectionInfoList; + // Atributos. private: @@ -63,6 +81,9 @@ namespace Server { /// Conexiones de control. ConnectionList connections; + /// Mutex para las conexiones. + Glib::Mutex connections_mutex; + // Métodos. private: @@ -95,7 +116,18 @@ namespace Server { * * \param port Puerto en el cual escuchar. */ - TCPServer(int port); + TCPServer(const Connection::Port& port); + + /** + * Finaliza la tarea. + * + * \param attach Si es true, la función no retorna hasta que no + * finalice la tearea (no recomendable). + * + * \note Para saber cuando la tarea fue finalizada puede utilizar + * la señal signal_finished(). + */ + virtual void finish(bool attach = false); /** * Se encarga de borrar una conexión de la lista cuando finaliza. @@ -104,6 +136,17 @@ namespace Server { */ void on_connection_finished(Connection* connection); + /** + * Detiene una conexión. + */ + bool disconnect(const std::string& host, + const Connection::Port& port); + + /** + * Obtiene una lista conexiones de control abiertas. + */ + ConnectionInfoList get_connected(void); + }; }