1 // vim: set noexpandtab tabstop=4 shiftwidth=4:
2 //----------------------------------------------------------------------------
4 //----------------------------------------------------------------------------
5 // This file is part of PlaQui.
7 // PlaQui is free software; you can redistribute it and/or modify it under the
8 // terms of the GNU General Public License as published by the Free Software
9 // Foundation; either version 2 of the License, or (at your option) any later
12 // PlaQui is distributed in the hope that it will be useful, but WITHOUT ANY
13 // WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
14 // FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
17 // You should have received a copy of the GNU General Public License along
18 // with PlaQui; if not, write to the Free Software Foundation, Inc., 59 Temple
19 // Place, Suite 330, Boston, MA 02111-1307 USA
20 //----------------------------------------------------------------------------
21 // Creado: Sat Oct 18 18:18:36 2003
22 // Autores: Leandro Lucarella <llucare@fi.uba.ar>
23 //----------------------------------------------------------------------------
28 #include "plaqui/server/controlserver.h"
29 #include "plaqui/server/command.h"
30 #include "plaqui/server/httperror.h"
31 #include "plaqui/server/httpresponse.h"
35 # include "plaqui/server/string.h"
45 ControlServer::~ControlServer(void) {
47 cerr << __FILE__ << ": destructor." << endl;
51 ControlServer::ControlServer(const sockbuf::sockdesc& sd):
54 cerr << __FILE__ << ": sd = " << sd.sock << endl;
58 void ControlServer::real_run(void) {
60 cerr << __FILE__ << ": real_run()" << endl;
66 //Glib::Mutex::Lock lock(socket_mutex);
68 // Si se cerró el socket.
69 } catch (const ios::failure& e) {
72 // Si hay un error al parsear el comando, se envia una respuesta con el
74 } catch (const HTTPError& e) {
76 cerr << __FILE__ << " : real_run() ERROR: status_code = "
77 << e.code << " | reason = " << HTTPMessage::reason(e.code)
78 << " | desc = " << e.what() << endl;
80 //Glib::Mutex::Lock lock(socket_mutex);
81 socket << HTTPResponse(e) << flush;
84 // TODO agregar las verificaciones de abajo a HTTPRequest y padres.
85 // Actualizacion: Estoy usando trim() en casi todos lados, no debería
88 // Primera línea no vacía (que debe ser el request).
90 while (!stop && socket.getline(buf, BUFSIZ)) {
92 cerr << __FILE__ << " Recibiendo inea: " << buf << endl;
94 int len = strlen(buf);
95 // Si tiene un retorno de carro, lo elimina.
96 if (len && (buf[len-1] == '\r')) {
99 // Si tiene contenido, lo agrego a la información del request.
101 // Si es la primera línea, es el request.
103 request.set_request(buf, socket->peerhost(),
107 // TODO request.parse_header(buf);
109 // Si viene la línea vacía
111 // Si no es la primera, terminan las cabeceras HTTP.
113 // Podría ir un break.
117 // Si es la primera, no pasa nada, sigue esperando un request.
122 cerr << __FILE__ << " : real_run() Despachando comando: target = "
123 << command.get_target() << " | command = " << command.get_command()
124 << " | args = [" << String::join(command.get_args(), ", ") << "]"
128 command_received(command);
132 void ControlServer::send(const HTTPResponse& response) {
133 //Glib::Mutex::Lock lock(socket_mutex);
134 socket << response << flush;
136 cerr << __FILE__ << ": send() Enviado!" << endl;
140 ControlServer::SignalCommandReceived& ControlServer::signal_command_received(void) {
141 return command_received;
144 } // namespace Server
146 } // namespace PlaQui