memgraph/speedy/http/response.inl

66 lines
1.6 KiB
Plaintext
Raw Normal View History

#ifndef MEMGRAPH_SERVER_HTTP_RESPONSE_INL
#define MEMGRAPH_SERVER_HTTP_RESPONSE_INL
#include "response.hpp"
#include "httpconnection.hpp"
2015-10-09 07:24:12 +08:00
#include "utils/memory/block_allocator.hpp"
namespace http
{
2015-10-09 07:24:12 +08:00
constexpr size_t buffer_size = 65536;
static BlockAllocator<sizeof(uv_write_t)> write_req_allocator;
template <class Req, class Res>
Response<Req, Res>::Response(connection_t& connection)
: status(Status::Ok), connection(connection),
buffer(buffer_size) {}
2015-10-09 07:24:12 +08:00
template <class Req, class Res>
void Response<Req, Res>::send(Status status, const std::string& body)
{
2015-10-09 07:24:12 +08:00
this->status = status;
this->send(body);
}
2015-10-09 07:24:12 +08:00
template <class Req, class Res>
void Response<Req, Res>::send(const std::string& body)
{
uv_write_t* write_req =
2015-10-09 07:24:12 +08:00
static_cast<uv_write_t*>(write_req_allocator.acquire());
write_req->data = &connection;
2015-10-09 07:24:12 +08:00
buffer << "HTTP/1.1 " << to_string[status] << "\r\n";
2015-10-09 07:24:12 +08:00
buffer << "Content-Length:" << std::to_string(body.size()) << "\r\n";
2015-10-09 07:24:12 +08:00
buffer << "Connection:" << (connection.keep_alive ? "Keep-Alive" : "Close")
<< "\r\n";
for(auto it = headers.begin(); it != headers.end(); ++it)
buffer << it->first << ":" << it->second << "\r\n";
buffer << "\r\n" << body;
2015-10-09 07:24:12 +08:00
uv_write(write_req, connection.client, buffer, 1,
[](uv_write_t* write_req, int) {
2015-10-09 07:24:12 +08:00
connection_t& conn = *reinterpret_cast<connection_t*>(write_req->data);
if(!conn.keep_alive)
conn.close();
2015-10-09 07:24:12 +08:00
conn.response.status = Status::Ok;
conn.response.buffer.clear();
conn.response.headers.clear();
2015-10-09 07:24:12 +08:00
write_req_allocator.release(write_req);
});
}
}
#endif