]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Server/include/plaqui/server/server.h
Se corrigen detalles en la documentacion.
[z.facultad/75.42/plaqui.git] / Server / include / plaqui / server / server.h
index b29548350bd3b87449a72295fe65b096195d23e3..f0f1644b9e7de0c991cfa7631dd7cfbc90dffb3e 100644 (file)
 
 #include "plaqui/server/tcpserver.h"
 #include "plaqui/server/controlserver.h"
-#include "plaqui/server/transmitter.h"
+//#include "plaqui/server/transmitter.h"
 #include "plaqui/server/plant.h"
 #include "plaqui/server/command.h"
+#include "plaqui/server/response.h"
 #include <socket++/sockinet.h>
 #include <string>
 #include <map>
@@ -43,10 +44,22 @@ namespace Server {
 
        /**
         * Servidor de plantas químicas.
-        * Maneja múltiples conexiones, de control o de transmisión.
+        *
+        * Esta clase se encarga, entre otras cosas, de definir el método
+        * new_connection() de TCPServer para crear una nueva
+        * \ref ControlServer "conexión de control" para atender las conexiones que
+        * éste recibe.
+        *
+        * Una vez recibida una conexión, esta clase se encarga de manejar los
+        * comandos que a través de ella se reciben a través de los métodos como
+        * cmd_server_info(), cmd_connection_list(), etc.
+        *
+        * Esta clase es también la encargado de mantener la \ref plants "lista" de
+        * \ref Plant "plantas" que se están sirviendo (y simulando).
         */
        class Server: public TCPServer {
 
+               /////////////////////////////////////////////////////////////////////
                // Tipos.
 
                private:
@@ -54,6 +67,7 @@ namespace Server {
                        /// Lista de plantas químicas.
                        typedef std::map<std::string, Plant*> PlantList;
 
+               /////////////////////////////////////////////////////////////////////
                // Atributos.
 
                private:
@@ -64,6 +78,7 @@ namespace Server {
                        /// Mutex para las plantas.
                        Glib::Mutex plants_mutex;
 
+               /////////////////////////////////////////////////////////////////////
                // Métodos.
 
                protected:
@@ -78,54 +93,69 @@ namespace Server {
                        virtual Connection* new_connection(const sockbuf::sockdesc& sd);
 
                        /**
-                        * Maneja el comando server/status.
+                        * Maneja el comando server/info.
                         */
-                       HTTPResponse* cmd_server_status(void) const;
+                       Response* cmd_server_info(void) const;
 
                        /**
                         * Maneja el comando connection/list.
                         */
-                       HTTPResponse* cmd_connection_list(void);
+                       Response* cmd_connection_list(void);
 
                        /**
                         * Maneja el comando connection/stop.
                         */
-                       HTTPResponse* cmd_connection_stop(const Command& command);
+                       Response* cmd_connection_stop(const Command& command);
 
                        /**
                         * Maneja el comando transmission/list.
                         */
-                       HTTPResponse* cmd_transmission_list(void);
+                       Response* cmd_transmission_list(void);
 
                        /**
                         * Maneja el comando transmission/start.
                         */
-                       HTTPResponse* cmd_transmission_start(const Command& command);
+                       Response* cmd_transmission_start(const Command& command);
 
                        /**
                         * Maneja el comando transmission/stop.
                         */
-                       HTTPResponse* cmd_transmission_stop(const Command& command);
+                       Response* cmd_transmission_stop(const Command& command);
 
                        /**
                         * Maneja el comando plant/list.
                         */
-                       HTTPResponse* cmd_plant_list(void);
+                       Response* cmd_plant_list(void);
 
                        /**
                         * Maneja el comando plant/get.
                         */
-                       HTTPResponse* cmd_plant_get(const Command& command);
+                       Response* cmd_plant_get(const Command& command);
 
                        /**
-                        * Maneja el comando plant/get.
+                        * Maneja el comando plant/set.
                         */
-                       HTTPResponse* cmd_plant_set(const Command& command);
+                       Response* cmd_plant_set(const Command& command);
+
+                       /**
+                        * Maneja el comando plant/set_frequency.
+                        */
+                       Response* cmd_plant_set_frequency(const Command& command);
+
+                       /**
+                        * Maneja el comando plant/start.
+                        */
+                       Response* cmd_plant_start(const Command& command);
 
                        /**
                         * Maneja el comando plant/stop.
                         */
-                       HTTPResponse* cmd_plant_stop(const Command& command);
+                       Response* cmd_plant_stop(const Command& command);
+
+                       /**
+                        * Maneja el comando plant/remove.
+                        */
+                       Response* cmd_plant_remove(const Command& command);
 
                public:
 
@@ -139,8 +169,19 @@ namespace Server {
                         *
                         * \param port Puerto en el cual escuchar.
                         */
-                       Server(const std::string& plant_filename,
-                                       const Connection::Port& port = 7522);
+                       Server(const Connection::Port& port = 7522) throw(sockerr);
+
+                       /**
+                        * Agrega una planta al servidor.
+                        *
+                        * \param name     Nombre que utilizará el servidor para identificar
+                        *                 a la planta.
+                        * \param filename Nombre del archivo con la planta a cargar.
+                        * \return true si se agregó la planta, false si ya existía una
+                        *         planta con ese nombre.
+                        */
+                       bool add_plant(const std::string& name,
+                                       const std::string& filename);
 
                        /**
                         * Maneja los comandos recibidos por las conexiones.
@@ -151,17 +192,10 @@ namespace Server {
                        /**
                         * Se encarga de borrar una planta de la lista cuando finaliza.
                         *
-                        * \param connection Conexión a eliminar.
+                        * \param plant Nombre de la planta a elminar.
                         */
                        void on_plant_finished(const char* plant);
 
-                       /**
-                        * Envia el estado de una planta cuando esta se actualiza.
-                        *
-                        * \param plant Planta actualizada.
-                        */
-                       void on_plant_updated(const Plant* const);
-
        };
 
 }