]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Server/include/plaqui/server/tcpserver.h
- Se cambia el refresco por defecto de una planta a 0,3 veces por segundo (algo
[z.facultad/75.42/plaqui.git] / Server / include / plaqui / server / tcpserver.h
index 7465faa7a2d0cb9563a29285ade035b3aa3ba3da..5277f2bf188d2b9fb4c867495c518bfcf7c743ab 100644 (file)
@@ -31,7 +31,9 @@
 #include "plaqui/server/runnable.h"
 #include "plaqui/server/connection.h"
 #include <socket++/sockinet.h>
 #include "plaqui/server/runnable.h"
 #include "plaqui/server/connection.h"
 #include <socket++/sockinet.h>
+#include <sigc++/signal.h>
 #include <list>
 #include <list>
+#include <vector>
 
 namespace PlaQui {
 
 
 namespace PlaQui {
 
@@ -43,6 +45,7 @@ namespace Server {
         */
        class TCPServer: public Runnable {
 
         */
        class TCPServer: public Runnable {
 
+               /////////////////////////////////////////////////////////////////////
                // Constantes.
 
                private:
                // Constantes.
 
                private:
@@ -50,6 +53,7 @@ namespace Server {
                        /// Cantidad máxima de conexiones pendientes.
                        static const unsigned MAX_PENDING_CONNECTIONS = 10;
 
                        /// Cantidad máxima de conexiones pendientes.
                        static const unsigned MAX_PENDING_CONNECTIONS = 10;
 
+               /////////////////////////////////////////////////////////////////////
                // Tipos.
 
                private:
                // Tipos.
 
                private:
@@ -57,19 +61,54 @@ namespace Server {
                        /// Lista de conexiones de control.
                        typedef std::list<Connection*> ConnectionList;
 
                        /// Lista de conexiones de control.
                        typedef std::list<Connection*> 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<ConnectionInfo> ConnectionInfoList;
+
+               /////////////////////////////////////////////////////////////////////
+               /// \name Señales
+               //@{
+
+               public:
+
+                       /// Tipo de señal para indicar que se inició una conexión.
+                       typedef SigC::Signal2<void, const std::string&,
+                                       const Connection::Port&> SignalConnectionOpened;
+
+                       /// Obtiene la señal que avisa que se inició una conexión.
+                       SignalConnectionOpened& signal_connection_opened(void);
+
+               //@}
+
+               /////////////////////////////////////////////////////////////////////
                // Atributos.
 
                // Atributos.
 
-               private:
+               protected:
 
                        /// Socket para escuchar conexiones.
                        sockinetbuf socket;
 
 
                        /// Socket para escuchar conexiones.
                        sockinetbuf socket;
 
-                       /// Mutex para las conexiones.
-                       Glib::Mutex connections_mutex;
+               private:
+
+                       /// Señal que indica que se inició una conexión.
+                       SignalConnectionOpened _connection_opened;
 
                        /// Conexiones de control.
                        ConnectionList connections;
 
 
                        /// Conexiones de control.
                        ConnectionList connections;
 
+                       /// Mutex para las conexiones.
+                       Glib::Mutex connections_mutex;
+
+               /////////////////////////////////////////////////////////////////////
                // Métodos.
 
                private:
                // Métodos.
 
                private:
@@ -77,7 +116,7 @@ namespace Server {
                        /**
                         * Entra en el loop para atender conexiones.
                         */
                        /**
                         * Entra en el loop para atender conexiones.
                         */
-                       virtual void real_run(void);
+                       virtual void real_run(void) throw();
 
                protected:
 
 
                protected:
 
@@ -102,7 +141,15 @@ namespace Server {
                         *
                         * \param port Puerto en el cual escuchar.
                         */
                         *
                         * \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.
 
                        /**
                         * Se encarga de borrar una conexión de la lista cuando finaliza.
@@ -111,6 +158,17 @@ namespace Server {
                         */
                        void on_connection_finished(Connection* connection);
 
                         */
                        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);
+
        };
 
 }
        };
 
 }