Kea
1.9.9-git
|
Represents HTTP response message. More...
#include <response.h>
Public Member Functions | |
HttpResponse () | |
Constructor for the inbound HTTP response. More... | |
HttpResponse (const HttpVersion &version, const HttpStatusCode &status_code, const CallSetGenericBody &generic_body=CallSetGenericBody::yes()) | |
Constructor for outbound HTTP response. More... | |
const HttpResponseContextPtr & | context () const |
Returns pointer to the HttpResponseContext. More... | |
virtual void | create () |
Commits information held in the context into the response. More... | |
virtual void | finalize () |
Completes creation of the HTTP response. More... | |
virtual std::string | getBody () const |
Returns HTTP response body as string. More... | |
data::ConstElementPtr | getJsonElement (const std::string &element_name) const |
Retrieves a single JSON element. More... | |
HttpStatusCode | getStatusCode () const |
Returns HTTP status code. More... | |
std::string | getStatusPhrase () const |
Returns HTTP status phrase. More... | |
virtual void | reset () |
Reset the state of the object. More... | |
std::string | toBriefString () const |
Returns HTTP version and HTTP status as a string. More... | |
virtual std::string | toString () const |
Returns HTTP response as string. More... | |
Public Member Functions inherited from isc::http::HttpMessage | |
HttpMessage (const Direction &direction) | |
Constructor. More... | |
virtual | ~HttpMessage () |
Destructor. More... | |
Direction | getDirection () const |
Returns HTTP message direction. More... | |
HttpHeaderPtr | getHeader (const std::string &header_name) const |
Returns object encapsulating HTTP header. More... | |
std::string | getHeaderValue (const std::string &header_name) const |
Returns a value of the specified HTTP header. More... | |
uint64_t | getHeaderValueAsUint64 (const std::string &header_name) const |
Returns a value of the specified HTTP header as number. More... | |
HttpVersion | getHttpVersion () const |
Returns HTTP version number (major and minor). More... | |
bool | isFinalized () const |
Checks if the message has been successfully finalized. More... | |
void | requireHeader (const std::string &header_name) |
Specifies a required HTTP header for the HTTP message. More... | |
void | requireHeaderValue (const std::string &header_name, const std::string &header_value) |
Specifies a required value of a header in the message. More... | |
void | requireHttpVersion (const HttpVersion &version) |
Specifies HTTP version allowed. More... | |
bool | requiresBody () const |
Checks if the body is required for the HTTP message. More... | |
void | setDirection (const Direction &direction) |
Sets direction for the HTTP message. More... | |
Static Public Member Functions | |
static bool | isClientError (const HttpStatusCode &status_code) |
Checks if the status code indicates client error. More... | |
static bool | isServerError (const HttpStatusCode &status_code) |
Checks if the status code indicates server error. More... | |
static std::string | statusCodeToString (const HttpStatusCode &status_code) |
Converts status code to string. More... | |
Protected Member Functions | |
virtual std::string | getDateHeaderValue () const |
Returns current time formatted as required by RFC 1123. More... | |
Protected Member Functions inherited from isc::http::HttpMessage | |
void | checkCreated () const |
Checks if the create was called. More... | |
void | checkFinalized () const |
Checks if the finalize was called. More... | |
template<typename T > | |
bool | inRequiredSet (const T &element, const std::set< T > &element_set) const |
Checks if the set is empty or the specified element belongs to this set. More... | |
Static Protected Member Functions | |
static uint16_t | statusCodeToNumber (const HttpStatusCode &status_code) |
Convenience method converting status code to numeric value. More... | |
Protected Attributes | |
HttpResponseContextPtr | context_ |
Pointer to the HttpResponseContext holding parsed data. More... | |
Protected Attributes inherited from isc::http::HttpMessage | |
bool | created_ |
Flag indicating whether create was called. More... | |
Direction | direction_ |
Message direction (inbound or outbound). More... | |
bool | finalized_ |
Flag indicating whether finalize was called. More... | |
HttpHeaderMap | headers_ |
Parsed HTTP headers. More... | |
HttpVersion | http_version_ |
HTTP version numbers. More... | |
HttpHeaderMap | required_headers_ |
Map holding required HTTP headers. More... | |
std::set< HttpVersion > | required_versions_ |
Set of required HTTP versions. More... | |
Additional Inherited Members | |
Public Types inherited from isc::http::HttpMessage | |
enum | Direction { INBOUND, OUTBOUND } |
Specifies the direction of the HTTP message. More... | |
Protected Types inherited from isc::http::HttpMessage | |
typedef std::map< std::string, HttpHeaderPtr > | HttpHeaderMap |
Map of HTTP headers indexed by lower case header names. More... | |
Represents HTTP response message.
This derivation of the HttpMessage
class is specialized to represent HTTP responses. This class provides two constructors for creating an inbound and outbound response instance respectively. This class is associated with an instance of the HttpResponseContext
, which is used to provide response specific values, such as HTTP status and headers.
The derivations of this class provide specializations and specify the HTTP versions and headers supported/required in the specific use cases. For example, the HttpResponseJson
class derives from the HttpResponse
and it requires that response includes a body in the JSON format.
Definition at line 98 of file response.h.
|
explicit |
Constructor for the inbound HTTP response.
Definition at line 49 of file response.cc.
|
explicit |
Constructor for outbound HTTP response.
Creates basic instance of the object. It sets the HTTP version and the status code to be included in the response.
version | HTTP version. |
status_code | HTTP status code. |
generic_body | Indicates if the constructor should call setGenericBody to create a generic content for the given status code. This should be set to "no" when the constructor is called by the derived class which provides its own implementation of the setGenericBody method. |
Definition at line 53 of file response.cc.
References context_, isc::http::HttpVersion::major_, isc::http::HttpVersion::minor_, and isc::http::CallSetGenericBody::set_.
|
inline |
Returns pointer to the HttpResponseContext.
The context holds intermediate data for creating a response. The response parser stores parsed raw data in the context. When parsing is finished, the data are validated and committed into the HttpResponse
.
Definition at line 129 of file response.h.
References context_.
Referenced by isc::http::HttpResponseJson::HttpResponseJson(), and isc::http::HttpResponseJson::setBodyAsJson().
|
virtual |
Commits information held in the context into the response.
This function reads HTTP version, status code and headers from the context and validates their values. For the outbound messages, it automatically appends Content-Length and Date headers to the response. The Content-Length is set to the body size. The Date is set to the current date and time.
Implements isc::http::HttpMessage.
Definition at line 69 of file response.cc.
References context_, isc::http::HttpMessage::created_, getDateHeaderValue(), isc::http::HttpMessage::getDirection(), isc::http::HttpMessage::headers_, isc::http::HttpMessage::http_version_, isc::http::HttpMessage::inRequiredSet(), isc_throw, isc::http::HttpVersion::major_, isc::http::HttpVersion::minor_, isc::http::HttpMessage::OUTBOUND, isc::http::HttpMessage::required_headers_, isc::http::HttpMessage::required_versions_, reset(), and isc::Exception::what().
Referenced by isc::http::HttpResponseJson::finalize(), and finalize().
|
virtual |
Completes creation of the HTTP response.
This method marks the response as finalized. The outbound response may now be sent over the TCP socket. The information from the inbound message may be read, including the response body.
Implements isc::http::HttpMessage.
Reimplemented in isc::http::HttpResponseJson.
Definition at line 129 of file response.cc.
References create(), isc::http::HttpMessage::created_, and isc::http::HttpMessage::finalized_.
|
virtual |
Returns HTTP response body as string.
Implements isc::http::HttpMessage.
Definition at line 157 of file response.cc.
References isc::http::HttpMessage::checkFinalized(), and context_.
Referenced by toString().
|
protectedvirtual |
Returns current time formatted as required by RFC 1123.
This method is virtual so as it can be overridden in unit tests to return a "predictable" value of time, e.g. constant value.
Definition at line 193 of file response.cc.
References isc::http::HttpDateTime::rfc1123Format().
Referenced by create().
data::ConstElementPtr isc::http::HttpResponse::getJsonElement | ( | const std::string & | element_name | ) | const |
Retrieves a single JSON element.
The element must be at top level of the JSON structure.
element_name | Element name. |
HttpResponseJsonError | if an error occurred. |
HttpStatusCode isc::http::HttpResponse::getStatusCode | ( | ) | const |
Returns HTTP status code.
Definition at line 145 of file response.cc.
References isc::http::HttpMessage::checkCreated(), and context_.
std::string isc::http::HttpResponse::getStatusPhrase | ( | ) | const |
Returns HTTP status phrase.
Definition at line 151 of file response.cc.
References isc::http::HttpMessage::checkCreated(), and context_.
|
static |
Checks if the status code indicates client error.
status_code | HTTP status code. |
Definition at line 163 of file response.cc.
References statusCodeToNumber().
|
static |
Checks if the status code indicates server error.
status_code | HTTP status code. |
Definition at line 170 of file response.cc.
References statusCodeToNumber().
|
virtual |
Reset the state of the object.
Implements isc::http::HttpMessage.
Reimplemented in isc::http::HttpResponseJson.
Definition at line 138 of file response.cc.
References isc::http::HttpMessage::created_, isc::http::HttpMessage::finalized_, and isc::http::HttpMessage::headers_.
Referenced by create(), and isc::http::HttpResponseJson::reset().
|
staticprotected |
Convenience method converting status code to numeric value.
status_code | Status code represented as enum. |
Definition at line 188 of file response.cc.
Referenced by isClientError(), and isServerError().
|
static |
Converts status code to string.
status_code | HTTP status code. |
Definition at line 177 of file response.cc.
References isc_throw.
Referenced by toBriefString().
std::string isc::http::HttpResponse::toBriefString | ( | ) | const |
Returns HTTP version and HTTP status as a string.
Definition at line 200 of file response.cc.
References isc::http::HttpMessage::checkFinalized(), context_, isc::http::HttpMessage::http_version_, isc::http::HttpVersion::major_, isc::http::HttpVersion::minor_, and statusCodeToString().
Referenced by toString().
|
virtual |
Returns HTTP response as string.
This method is called to generate the outbound HTTP response. Make sure to call finalize
prior to calling this method.
Implements isc::http::HttpMessage.
Definition at line 212 of file response.cc.
References getBody(), isc::http::HttpMessage::headers_, and toBriefString().
|
protected |
Pointer to the HttpResponseContext holding parsed data.
Definition at line 237 of file response.h.
Referenced by context(), create(), getBody(), getStatusCode(), getStatusPhrase(), HttpResponse(), isc::http::HttpResponseJson::parseBodyAsJson(), and toBriefString().