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: dom oct 26 18:54:30 ART 2003
22 // Autores: Leandro Lucarella <llucare@fi.uba.ar>
23 //----------------------------------------------------------------------------
28 #ifndef PLAQUI_HTTPREQUEST_H
29 #define PLAQUI_HTTPREQUEST_H
31 #include "plaqui/server/httperror.h"
32 #include "plaqui/server/httpmessage.h"
33 #include <socket++/sockstream.h>
43 class HTTPRequest: public HTTPMessage {
45 /////////////////////////////////////////////////////////////////////
50 /// Caracteres dígitos para URIs (RFC 2396).
51 static const std::string CHARS_DIGIT;
53 /// Caracteres alfabéticos en minúsculas para URIs (RFC 2396).
54 static const std::string CHARS_LOWALPHA;
56 /// Caracteres alfabéticos en mayúsculas para URIs (RFC 2396).
57 static const std::string CHARS_UPALPHA;
59 /// Caracteres alfabéticos para URIs (RFC 2396).
60 static const std::string CHARS_ALPHA;
62 /// Caracteres alfabnuméricos para URIs (RFC 2396).
63 static const std::string CHARS_ALPHANUM;
65 /// Caracteres reservados para URIs (RFC 2396).
66 static const std::string CHARS_RESERVED;
68 /// Caracteres de marca para URIs (RFC 2396).
69 static const std::string CHARS_MARK;
71 /// Caracteres no reservados para URIs (RFC 2396).
72 static const std::string CHARS_UNRESERVED;
74 /// Caracteres no hexa para URIs (RFC 2396).
75 static const std::string CHARS_HEX;
77 /////////////////////////////////////////////////////////////////////
82 /// Tipo de métodos HTTP reconocidos.
83 typedef enum {GET, POST} HTTPMethod;
85 /////////////////////////////////////////////////////////////////////
88 protected: // TODO hacer privados con get() y set() ???
93 /// @todo TODO - convertirlo a string? Hace todo más fácil (y más ineficiente :)
102 /////////////////////////////////////////////////////////////////////
110 virtual ~HTTPRequest(void);
115 HTTPRequest(const std::string& uri = "/",
116 const HTTPMethod& method = GET,
117 const std::string& query = "",
118 const std::string& body = "",
119 const std::string& version = "1.1");
122 * Obtiene el método como un string.
124 std::string method_str(void) const;
127 * Obtiene los datos del pedido HTTP desde un texto.
129 friend std::istream& operator>>(std::istream& is, HTTPRequest& req)
130 throw(HTTPError, sockerr, std::ios::failure);
133 * Convierte el pedido HTTP en texto.
135 friend std::ostream& operator<<(std::ostream& os,
136 const HTTPRequest& req) throw(sockerr);
144 #endif // PLAQUI_HTTPREQUEST_H