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 22:02:09 ART 2003
22 // Autores: Leandro Lucarella <llucare@fi.uba.ar>
23 //----------------------------------------------------------------------------
28 #include "plaqui/server/string.h"
29 #include "plaqui/server/httpmessage.h"
42 HTTPMessage::~HTTPMessage(void) {
44 cerr << __FILE__ << "(" << __LINE__ << ")"
45 << ": destructor." << endl;
49 HTTPMessage::HTTPMessage(const string& _body, const string& _version):
52 cerr << __FILE__ << "(" << __LINE__ << ")"
53 << ": version = " << version << " | body ("
54 << _body.length() << ") = " << _body << endl;
56 headers["Accept-Ranges"] = "bytes";
60 void HTTPMessage::set_body(const string& _body) {
62 headers["Content-Length"] = String().from(body.length());
65 const string& HTTPMessage::get_body(void) const {
69 istream& operator>>(istream& is, HTTPMessage& m)
70 throw(HTTPError, sockerr, ios::failure) {
72 cerr << __FILE__ << "(" << __LINE__ << ")"
73 << ": operator>>()" << endl;
76 while (is.getline(buf, BUFSIZ)) {
80 stringstream ss(sbuf);
82 // Fin de las cabeceras.
84 // Hay Content-Length, entonces hay body (no respeta RFC AFAIK).
85 if (m.headers.find("Content-Length") != m.headers.end()) {
86 streamsize size, readed;
87 to(m.headers["Content-Length"], size);
88 char* const buf2 = new char[size+1];
90 if (is.gcount() == size) {
91 // Agrego fin de string porque el readsome no lo hace.
95 cerr << __FILE__ << "(" << __LINE__ << ")"
96 << ": operator>>() raaaaw body: " << buf2 << endl;
99 // TODO else dar error?
101 cerr << __FILE__ << "(" << __LINE__ << ")"
102 << ": operator>>() ERROR: No se pudo leer el mensaje completo. Se leyeron sóolo "
103 << is.gcount() << " bytes de " << size << " que deberían haberse leído." << endl;
108 // Después de una línea vacía, haya obtenido el body o no, sale del
116 ostream& operator<<(ostream& os, const HTTPMessage& m) {
118 cerr << __FILE__ << "(" << __LINE__ << ")"
119 << ": operator<<()" << endl;
121 return os << m.headers << "\r\n" // Fin de cabeceras
125 string HTTPMessage::reason(unsigned code) {
127 // TODO completar los códigos.
131 return "Bad Request";
134 case LENGTH_REQUIRED:
135 return "Length Required";
136 case INTERNAL_SERVER_ERROR:
137 return "Internal Server Error";
138 case NOT_IMPLEMENTED:
139 return "Not Implemented";
140 case HTTP_VERSION_NOT_SUPPORTED:
141 return "HTTP Version Not Supported";
147 } // namespace Server
149 } // namespace PlaQui