userver: server::http::HttpResponse Class Reference
Loading...
Searching...
No Matches
server::http::HttpResponse Class Referencefinal

HTTP Response data. More...

#include <userver/server/http/http_response.hpp>

+ Inheritance diagram for server::http::HttpResponse:
+ Collaboration diagram for server::http::HttpResponse:

Public Types

using HeadersMap = ::http::headers::HeaderMap
 
using HeadersMapKeys = decltype(utils::impl::MakeKeysView(HeadersMap()))
 
using CookiesMap = Cookie::CookiesMap
 
using CookiesMapKeys = decltype(utils::impl::MakeKeysView(CookiesMap()))
 
using Queue = concurrent::StringStreamQueue
 

Public Member Functions

bool SetHeader (std::string name, std::string value)
 Add a new response header or rewrite an existing one.
 
bool SetHeader (std::string_view name, std::string value)
 Add a new response header or rewrite an existing one.
 
bool SetHeader (const ::http::headers::PredefinedHeader &header, std::string value)
 This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
 
void SetContentType (const ::http::ContentType &type)
 Add or rewrite the Content-Type header.
 
void SetContentEncoding (std::string encoding)
 Add or rewrite the Content-Encoding header.
 
bool SetStatus (HttpStatus status)
 Set the HTTP response status code.
 
bool ClearHeaders ()
 Remove all headers from response.
 
void SetCookie (Cookie cookie)
 Sets a cookie if it was not set before.
 
void ClearCookies ()
 Remove all cookies from response.
 
HttpStatus GetStatus () const
 
HeadersMapKeys GetHeaderNames () const
 
const std::string & GetHeader (std::string_view header_name) const
 
const std::string & GetHeader (const ::http::headers::PredefinedHeader &header_name) const
 This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
 
bool HasHeader (std::string_view header_name) const
 
bool HasHeader (const ::http::headers::PredefinedHeader &header_name) const
 This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
 
CookiesMapKeys GetCookieNames () const
 
const CookieGetCookie (std::string_view cookie_name) const
 
void SetStatusServiceUnavailable () override
 
void SetStatusOk () override
 
void SetStatusNotFound () override
 
bool WaitForHeadersEnd () override
 
void SetHeadersEnd () override
 
void SetStreamBody ()
 
bool IsBodyStreamed () const override
 
Queue::Producer GetBodyProducer ()
 
- Public Member Functions inherited from server::request::ResponseBase
 ResponseBase (ResponseDataAccounter &data_accounter)
 
 ResponseBase (const ResponseBase &)=delete
 
 ResponseBase (ResponseBase &&)=delete
 
void SetData (std::string data)
 
const std::string & GetData () const
 

Additional Inherited Members

- Protected Member Functions inherited from server::request::ResponseBase
void SetSent (std::size_t bytes_sent, std::chrono::steady_clock::time_point sent_time)
 

Detailed Description

HTTP Response data.

Definition at line 35 of file http_response.hpp.

Member Typedef Documentation

◆ CookiesMap

using server::http::HttpResponse::CookiesMap = Cookie::CookiesMap

Definition at line 41 of file http_response.hpp.

◆ CookiesMapKeys

using server::http::HttpResponse::CookiesMapKeys = decltype(utils::impl::MakeKeysView(CookiesMap()))

Definition at line 43 of file http_response.hpp.

◆ HeadersMap

◆ HeadersMapKeys

using server::http::HttpResponse::HeadersMapKeys = decltype(utils::impl::MakeKeysView(HeadersMap()))

Definition at line 39 of file http_response.hpp.

◆ Queue

Member Function Documentation

◆ ClearHeaders()

bool server::http::HttpResponse::ClearHeaders ( )

Remove all headers from response.

Returns
true if the headers were cleared. Returns false if headers were already sent for stream'ed response and the headers were not cleared.

◆ GetCookie()

const Cookie & server::http::HttpResponse::GetCookie ( std::string_view  cookie_name) const
Returns
Value of the cookie with case sensitive name cookie_name, or an empty string if no such cookie exists.

◆ GetCookieNames()

CookiesMapKeys server::http::HttpResponse::GetCookieNames ( ) const
Returns
List of cookies names.

◆ GetHeader()

const std::string & server::http::HttpResponse::GetHeader ( std::string_view  header_name) const
Returns
Value of the header with case insensitive name header_name, or an empty string if no such header.

◆ GetHeaderNames()

HeadersMapKeys server::http::HttpResponse::GetHeaderNames ( ) const
Returns
List of HTTP headers names.

◆ GetStatus()

HttpStatus server::http::HttpResponse::GetStatus ( ) const
inline
Returns
HTTP response status

Definition at line 92 of file http_response.hpp.

◆ HasHeader()

bool server::http::HttpResponse::HasHeader ( std::string_view  header_name) const
Returns
true if header with case insensitive name header_name exists, false otherwise.

◆ IsBodyStreamed()

bool server::http::HttpResponse::IsBodyStreamed ( ) const
overridevirtual

◆ SetHeader() [1/2]

bool server::http::HttpResponse::SetHeader ( std::string  name,
std::string  value 
)

Add a new response header or rewrite an existing one.

Returns
true if the header was set. Returns false if headers were already sent for stream'ed response and the new header was not set.

◆ SetHeader() [2/2]

bool server::http::HttpResponse::SetHeader ( std::string_view  name,
std::string  value 
)

Add a new response header or rewrite an existing one.

Returns
true if the header was set. Returns false if headers were already sent for stream'ed response and the new header was not set.

◆ SetHeadersEnd()

void server::http::HttpResponse::SetHeadersEnd ( )
overridevirtual

◆ SetStatus()

bool server::http::HttpResponse::SetStatus ( HttpStatus  status)

Set the HTTP response status code.

Returns
true if the status was set. Returns false if headers were already sent for stream'ed response and the new status was not set.

◆ SetStatusNotFound()

void server::http::HttpResponse::SetStatusNotFound ( )
inlineoverride

Definition at line 128 of file http_response.hpp.

◆ SetStatusOk()

void server::http::HttpResponse::SetStatusOk ( )
inlineoverride

Definition at line 127 of file http_response.hpp.

◆ SetStatusServiceUnavailable()

void server::http::HttpResponse::SetStatusServiceUnavailable ( )
inlineoverride

Definition at line 124 of file http_response.hpp.

◆ WaitForHeadersEnd()

bool server::http::HttpResponse::WaitForHeadersEnd ( )
overridevirtual

The documentation for this class was generated from the following file: