]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Server/include/plaqui/server/server.h
- Se mejora el manejo de errores (excepciones) en los tests (y en algunas otras
[z.facultad/75.42/plaqui.git] / Server / include / plaqui / server / server.h
index 2364273e0d731a97440133aa573ec65218972089..1179fdc2b9ae3524519238a088d5b63f646ca3f7 100644 (file)
 #ifndef PLAQUI_SERVER_H
 #define PLAQUI_SERVER_H
 
 #ifndef PLAQUI_SERVER_H
 #define PLAQUI_SERVER_H
 
+#include "plaqui/server/tcpserver.h"
 #include "plaqui/server/controlserver.h"
 #include "plaqui/server/transmitter.h"
 #include "plaqui/server/controlserver.h"
 #include "plaqui/server/transmitter.h"
+#include "plaqui/server/plant.h"
+#include "plaqui/server/command.h"
 #include <socket++/sockinet.h>
 #include <string>
 #include <list>
 
 #include <socket++/sockinet.h>
 #include <string>
 #include <list>
 
-namespace Plaqui {
+namespace PlaQui {
+
+namespace Server {
 
        /**
         * Servidor de plantas químicas.
 
        /**
         * Servidor de plantas químicas.
-        * Maneja muchas conexiones, de control o de transmisión.
+        * Maneja múltiples conexiones, de control o de transmisión.
         */
         */
-       class Server: public Runnable {
+       class Server: public TCPServer {
 
 
-               private:
+               // Tipos.
 
 
-                       /// Lista de conexiones de control.
-                       typedef std::list<ControlServer*> ControllerList;
+               private:
 
                        /// Lista de conexiones de control.
                        typedef std::list<Transmitter*> TransmitterList;
 
 
                        /// Lista de conexiones de control.
                        typedef std::list<Transmitter*> TransmitterList;
 
-                       /// Socket para escuchar conexiones.
-                       sockinetbuf socket;
+                       /// Lista de plantas químicas.
+                       typedef std::list<Plant*> PlantList;
 
 
-                       /// Conexiones de control.
-                       ControllerList controllers;
+               // Atributos.
+
+               private:
 
                        /// Transmisiones del estado de las plantas.
                        TransmitterList transmissions;
 
 
                        /// Transmisiones del estado de las plantas.
                        TransmitterList transmissions;
 
+                       /// Mutex para las transmisiones.
+                       Glib::Mutex transmissions_mutex;
+
+                       // Plantas disponibles en el servidor.
+                       PlantList plants;
+
+                       /// Mutex para las plantas.
+                       Glib::Mutex plants_mutex;
+
+               // Métodos.
+
+               protected:
+
+                       /**
+                        * Obtiene una nueva \ref Connection "conexión".
+                        *
+                        * \param sd Descriptor del socket de la nueva conexión.
+                        *
+                        * \return Nueva conexión.
+                        */
+                       virtual Connection* new_connection(const sockbuf::sockdesc& sd);
+
                        /**
                        /**
-                        * Entra en el loop para atender conexiones.
+                        * Maneja el comando server/status.
                         */
                         */
-                       virtual void real_run(void);
+                       HTTPResponse* cmd_server_status(void) const;
+
+                       /**
+                        * Maneja el comando connection/list.
+                        */
+                       HTTPResponse* cmd_connection_list(void);
+
+                       /**
+                        * Maneja el comando connection/stop.
+                        */
+                       HTTPResponse* cmd_connection_stop(const Command& command);
 
                public:
 
                        /**
                         * Destructor.
                         */
 
                public:
 
                        /**
                         * Destructor.
                         */
-                       virtual ~Server(void) {}
+                       virtual ~Server(void);
 
                        /**
                         * Constructor.
 
                        /**
                         * Constructor.
@@ -101,15 +138,20 @@ namespace Plaqui {
                         *
                         * \return true si se pudo empezar a transmitir, false si no.
                         *
                         *
                         * \return true si se pudo empezar a transmitir, false si no.
                         *
-                        * \todo Ver si es necesario que devuelva algo y si devuelve ver si
-                        *       no sería mejor que dé más información (si no se pudo abrir
-                        *       o si ya estaba abierto por ejemplo.
+                        * \todo Ver de hacer un TransmissionManager.
                         */
                         */
-                       bool stop_transmission(std::string host = "localhost",
-                                       int port = 7528);
+                       bool stop_transmission(std::string host, int port);
+
+                       /**
+                        * Maneja los comandos recibidos por las conexiones.
+                        */
+                       void on_control_command_received(const Command& command,
+                                       ControlServer* controlserver);
 
        };
 
 }
 
 
        };
 
 }
 
+}
+
 #endif // PLAQUI_SERVER_H
 #endif // PLAQUI_SERVER_H