X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/00cffd5f7c35a915c09d55e6292775e9e01bdeec..289cd57714db01c97f3fa7cb65efedf30114919f:/Server/include/plaqui/server/tcpserver.h?ds=inline diff --git a/Server/include/plaqui/server/tcpserver.h b/Server/include/plaqui/server/tcpserver.h index b3ecfa6..66fe3be 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,6 +44,15 @@ namespace Server { */ class TCPServer: public Runnable { + ///////////////////////////////////////////////////////////////////// + // Constantes. + + private: + + /// Cantidad máxima de conexiones pendientes. + static const unsigned MAX_PENDING_CONNECTIONS = 10; + + ///////////////////////////////////////////////////////////////////// // Tipos. private: @@ -50,16 +60,35 @@ namespace Server { /// 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: + protected: //FIXME /// Socket para escuchar conexiones. sockinetbuf socket; + private: // FIXME /// Conexiones de control. ConnectionList connections; + /// Mutex para las conexiones. + Glib::Mutex connections_mutex; + + ///////////////////////////////////////////////////////////////////// // Métodos. private: @@ -67,7 +96,7 @@ namespace Server { /** * Entra en el loop para atender conexiones. */ - virtual void real_run(void); + virtual void real_run(void) throw(); protected: @@ -92,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. @@ -101,6 +138,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); + }; }