]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Server/include/plaqui/server/server.h
Capturo las seniales ANSI C SIGINT, SIGTERM y SIGQUIT para que el server salga
[z.facultad/75.42/plaqui.git] / Server / include / plaqui / server / server.h
index f16e2dfbb5eed5e0e4666abf23386345fa7982a4..0e5fe2b7e8a9841b0c33b0721567e36297e9d186 100644 (file)
 #include "plaqui/server/tcpserver.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 <map>
 
 namespace PlaQui {
 
@@ -45,82 +47,117 @@ namespace Server {
         */
        class Server: public TCPServer {
 
+               /////////////////////////////////////////////////////////////////////
                // Tipos.
 
                private:
 
-                       /// Lista de conexiones de control.
-                       typedef std::list<Transmitter*> TransmitterList;
-
-                       // TODO:
-                       // typedef std::list<Plant*> PlantList;
+                       /// Lista de plantas químicas.
+                       typedef std::map<std::string, Plant*> PlantList;
 
+               /////////////////////////////////////////////////////////////////////
                // Atributos.
 
                private:
 
-                       /// Transmisiones del estado de las plantas.
-                       TransmitterList transmissions;
+                       // Plantas disponibles en el servidor.
+                       PlantList plants;
 
-                       // TODO:
-                       // PlantList plants;
+                       /// Mutex para las plantas.
+                       Glib::Mutex plants_mutex;
 
+               /////////////////////////////////////////////////////////////////////
                // Métodos.
 
-               private:
+               protected:
 
                        /**
-                        * Entra en el loop para atender conexiones.
+                        * Obtiene una nueva \ref Connection "conexión".
+                        *
+                        * \param sd Descriptor del socket de la nueva conexión.
+                        *
+                        * \return Nueva conexión.
                         */
-                       virtual void real_run(void);
+                       virtual Connection* new_connection(const sockbuf::sockdesc& sd);
 
-               public:
+                       /**
+                        * Maneja el comando server/status.
+                        */
+                       HTTPResponse* cmd_server_status(void) const;
 
                        /**
-                        * Destructor.
+                        * Maneja el comando connection/list.
                         */
-                       virtual ~Server(void) {}
+                       HTTPResponse* cmd_connection_list(void);
 
                        /**
-                        * Constructor.
-                        *
-                        * \param port Puerto en el cual escuchar.
+                        * Maneja el comando connection/stop.
                         */
-                       Server(int port = 7522);
+                       HTTPResponse* cmd_connection_stop(const Command& command);
 
                        /**
-                        * Comienza la transimisión del estado de una planta.
-                        *
-                        * \param host Host al cual se quiere transmitir.
-                        * \param port Puerto al cual transmitir.
-                        *
-                        * \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.
+                        * Maneja el comando transmission/list.
                         */
-                       bool start_transmission(std::string host = "localhost",
-                                       int port = 7528);
+                       HTTPResponse* cmd_transmission_list(void);
 
                        /**
-                        * Finaliza la transimisión del estado de una planta.
-                        *
-                        * \param host Host al cual se quiere dejar de transmitir.
-                        * \param port Puerto al cual dejar de transmitir.
-                        *
-                        * \return true si se pudo empezar a transmitir, false si no.
+                        * Maneja el comando transmission/start.
+                        */
+                       HTTPResponse* cmd_transmission_start(const Command& command);
+
+                       /**
+                        * Maneja el comando transmission/stop.
+                        */
+                       HTTPResponse* cmd_transmission_stop(const Command& command);
+
+                       /**
+                        * Maneja el comando plant/list.
+                        */
+                       HTTPResponse* cmd_plant_list(void);
+
+                       /**
+                        * Maneja el comando plant/get.
+                        */
+                       HTTPResponse* cmd_plant_get(const Command& command);
+
+                       /**
+                        * Maneja el comando plant/get.
+                        */
+                       HTTPResponse* cmd_plant_set(const Command& command);
+
+                       /**
+                        * Maneja el comando plant/stop.
+                        */
+                       HTTPResponse* cmd_plant_stop(const Command& command);
+
+               public:
+
+                       /**
+                        * Destructor.
+                        */
+                       virtual ~Server(void);
+
+                       /**
+                        * Constructor.
                         *
-                        * \todo Ver de hacer un TransmissionManager.
+                        * \param plant_filename Nombre del archivo con la planta a cargar.
+                        * \param port           Puerto en el cual escuchar.
                         */
-                       bool stop_transmission(std::string host, int port);
+                       Server(const std::string& plant_filename,
+                                       const Connection::Port& port = 7522) throw(sockerr);
 
                        /**
                         * Maneja los comandos recibidos por las conexiones.
+                        */
+                       void on_control_command_received(const Command& command,
+                                       ControlServer* controlserver);
+
+                       /**
+                        * Se encarga de borrar una planta de la lista cuando finaliza.
                         *
-                        * \todo Hacer un tipo Command abstracto o algo así.
+                        * \param plant Nombre de la planta a elminar.
                         */
-                       void on_connection_command_received(void* command);
+                       void on_plant_finished(const char* plant);
 
        };