reply.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2009 by Marc Boris Duerner, Tommi Maekitalo
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2.1 of the License, or (at your option) any later version.
8  *
9  * As a special exception, you may use this file as part of a free
10  * software library without restriction. Specifically, if other files
11  * instantiate templates or use macros or inline functions from this
12  * file, or you compile this file and link it with other files to
13  * produce an executable, this file does not by itself cause the
14  * resulting executable to be covered by the GNU General Public
15  * License. This exception does not however invalidate any other
16  * reasons why the executable file might be covered by the GNU Library
17  * General Public License.
18  *
19  * This library is distributed in the hope that it will be useful,
20  * but WITHOUT ANY WARRANTY; without even the implied warranty of
21  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
22  * Lesser General Public License for more details.
23  *
24  * You should have received a copy of the GNU Lesser General Public
25  * License along with this library; if not, write to the Free Software
26  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
27  */
28 
29 #ifndef cxxtools_Http_Reply_h
30 #define cxxtools_Http_Reply_h
31 
33 #include <string>
34 #include <sstream>
35 
36 namespace cxxtools {
37 
38 namespace http {
39 
40 class Request;
41 
42 class Reply
43 {
44  ReplyHeader _header;
45  std::stringstream _body;
46 
47  public:
49  { }
50 
52  { return _header; }
53 
54  const ReplyHeader& header() const
55  { return _header; }
56 
57  void setHeader(const char* key, const char* value)
58  {
59  _header.setHeader(key, value);
60  }
61 
62  void addHeader(const char* key, const char* value)
63  {
64  _header.addHeader(key, value);
65  }
66 
67  void removeHeader(const char* key)
68  {
69  _header.removeHeader(key);
70  }
71 
72  const char* getHeader(const char* key) const
73  {
74  return _header.getHeader(key);
75  }
76 
77  bool hasHeader(const char* key) const
78  {
79  return _header.hasHeader(key);
80  }
81 
82  void clear()
83  {
84  _header.clear();
85  _body.clear();
86  _body.str(std::string());
87  }
88 
89  unsigned httpReturnCode() const
90  { return _header.httpReturnCode(); }
91 
92  const std::string& httpReturnText() const
93  { return _header.httpReturnText(); }
94 
95  void httpReturn(unsigned c, const std::string& t)
96  { _header.httpReturn(c, t); }
97 
98  std::string body() const
99  { return _body.str(); }
100 
101  std::stringstream& bodyStream()
102  { return _body; }
103 
104  std::size_t bodySize() const
105  { return _body.str().size(); }
106 
107  void sendBody(std::ostream& out) const
108  { out << _body.str(); }
109 
110  operator std::string() const
111  { return _body.str(); }
112 
113 };
114 
115 } // namespace http
116 
117 } // namespace cxxtools
118 
119 #endif