]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blob - Server/src/command.cpp
- Se agrega el método HTTPRequest::method_str() para obtener el método como un
[z.facultad/75.42/plaqui.git] / Server / src / command.cpp
1 // vim: set noexpandtab tabstop=4 shiftwidth=4:
2 //----------------------------------------------------------------------------
3 //                                  PlaQui
4 //----------------------------------------------------------------------------
5 // This file is part of PlaQui.
6 //
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
10 // version.
11 //
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
15 // details.
16 //
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:  sáb nov  8 17:12:10 ART 2003
22 // Autores: Leandro Lucarella <llucare@fi.uba.ar>
23 //----------------------------------------------------------------------------
24 //
25 // $Id$
26 //
27
28 #include "plaqui/server/command.h"
29 #include "plaqui/server/string.h"
30 #include <algorithm>
31 #ifdef DEBUG
32 #       include <iostream>
33 #endif // DEBUG
34
35 using namespace std;
36
37 namespace PlaQui {
38
39 namespace Server {
40
41 Command::~Command(void) {
42 #ifdef DEBUG
43         cerr << __FILE__ << ": destructor." << endl;
44 #endif // DEBUG
45 }
46
47 Command::Command(const string& _target, const string& _command) {
48 #ifdef DEBUG
49         cerr << __FILE__ << ": target = " << target << " | "
50                         << "command = " << command << endl;
51 #endif // DEBUG
52         set_target(_target);
53         set_command(_command);
54 }
55
56 void Command::build(void) {
57         uri = string("/") + target + '/' + command + String::join(args, "/");
58 #ifdef DEBUG
59         cerr << __FILE__ << ": build() = " << uri << endl;
60 #endif // DEBUG
61 }
62
63 void Command::set_target(const std::string& _target) {
64         target = _target;
65         build();
66 }
67
68 const std::string& Command::get_target(void) const {
69         return target;
70 }
71
72 void Command::set_command(const std::string& _command) {
73         command = _command;
74         build();
75 }
76
77 const std::string& Command::get_command(void) const {
78         return command;
79 }
80
81 void Command::set_args(const Command::Arguments& _args) {
82         args = _args;
83         build();
84 }
85
86 const Command::Arguments& Command::get_args(void) const {
87         return args;
88 }
89
90 void Command::add_arg(const std::string& arg) {
91         args.push_back(arg);
92         build();
93 }
94
95 istream& operator>>(istream& is, Command& command) {
96 #ifdef DEBUG
97         cerr << __FILE__ << ": operator>>()" << endl;
98 #endif // DEBUG
99         // Obtengo datos del Request HTTP.
100         is >> static_cast<HTTPRequest&>(command);
101         // Segun la URI, obtengo los fragmentos del comando.
102         String uri(command.uri);
103         command.args = uri.split('/');
104         // Borro el primero porque debe estar vacio porque la URI empieza con /.
105         command.args.erase(command.args.begin());
106         if (command.args.size() > 0) {
107                 command.target = command.args[0];
108                 command.args.erase(command.args.begin());
109         } else {
110                 command.target = "";
111         }
112         if (command.args.size() > 0) {
113                 command.command = command.args[0];
114                 command.args.erase(command.args.begin());
115         } else {
116                 command.command = "";
117         }
118         return is;
119 }
120
121 ostream& operator<<(ostream& os, const Command& command) {
122 #ifdef DEBUG
123         cerr << __FILE__ << ": operator<<()" << endl;
124 #endif // DEBUG
125         // Manda el request HTTP con la URI que representa el comando.
126         os << static_cast<const HTTPRequest&>(command);
127         return os;
128 }
129
130 } // namespace Server
131
132 } // namespace PlaQui
133