X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/6bffb655ac989fe4f115763270f84175bf24e4bb..e860608dbbbbaa43d0f241ab7a43da7c4608e192:/Server/include/plaqui/server/tcpserver.h diff --git a/Server/include/plaqui/server/tcpserver.h b/Server/include/plaqui/server/tcpserver.h index 1cd344f..66fe3be 100644 --- a/Server/include/plaqui/server/tcpserver.h +++ b/Server/include/plaqui/server/tcpserver.h @@ -44,6 +44,7 @@ namespace Server { */ class TCPServer: public Runnable { + ///////////////////////////////////////////////////////////////////// // Constantes. private: @@ -51,6 +52,7 @@ namespace Server { /// Cantidad máxima de conexiones pendientes. static const unsigned MAX_PENDING_CONNECTIONS = 10; + ///////////////////////////////////////////////////////////////////// // Tipos. private: @@ -65,25 +67,28 @@ namespace Server { /// Host. std::string host; /// Port. - unsigned port; + Connection::Port port; }; /// Lista de información de conexiones de control. typedef std::vector ConnectionInfoList; + ///////////////////////////////////////////////////////////////////// // Atributos. - private: + protected: //FIXME /// Socket para escuchar conexiones. sockinetbuf socket; - - /// Mutex para las conexiones. - Glib::Mutex connections_mutex; + private: // FIXME /// Conexiones de control. ConnectionList connections; + /// Mutex para las conexiones. + Glib::Mutex connections_mutex; + + ///////////////////////////////////////////////////////////////////// // Métodos. private: @@ -91,7 +96,7 @@ namespace Server { /** * Entra en el loop para atender conexiones. */ - virtual void real_run(void); + virtual void real_run(void) throw(); protected: @@ -116,7 +121,15 @@ namespace Server { * * \param port Puerto en el cual escuchar. */ - TCPServer(int port); + TCPServer(const Connection::Port& port) throw(sockerr); + + /** + * Finaliza la tarea. + * + * \note Para saber cuando la tarea fue finalizada puede utilizar + * la señal signal_finished(). + */ + virtual void finish(void); /** * Se encarga de borrar una conexión de la lista cuando finaliza. @@ -125,6 +138,12 @@ 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. */