mirror of
https://github.com/PurpleI2P/i2pd
synced 2024-11-10 08:00:38 +03:00
* HTTPConnection::reply : to_buffers() -> to_string()
This commit is contained in:
parent
a5c0b48b57
commit
87dd890eb0
@ -206,42 +206,33 @@ namespace util
|
|||||||
const char HTTP_HEADER_KV_SEP[] = ": ";
|
const char HTTP_HEADER_KV_SEP[] = ": ";
|
||||||
const char HTTP_CRLF[] = "\r\n";
|
const char HTTP_CRLF[] = "\r\n";
|
||||||
|
|
||||||
std::vector<boost::asio::const_buffer> HTTPConnection::reply::to_buffers(int status)
|
std::string HTTPConnection::reply::to_string(int code)
|
||||||
{
|
{
|
||||||
std::vector<boost::asio::const_buffer> buffers;
|
std::stringstream ss("");
|
||||||
if (headers.size () > 0)
|
if (headers.size () > 0)
|
||||||
{
|
{
|
||||||
status_string = "HTTP/1.1 ";
|
const char *status;
|
||||||
status_string += std::to_string (status);
|
switch (code)
|
||||||
status_string += " ";
|
|
||||||
switch (status)
|
|
||||||
{
|
{
|
||||||
case 105: status_string += "Name Not Resolved"; break;
|
case 105: status = "Name Not Resolved"; break;
|
||||||
case 200: status_string += "OK"; break;
|
case 200: status = "OK"; break;
|
||||||
case 400: status_string += "Bad Request"; break;
|
case 400: status = "Bad Request"; break;
|
||||||
case 404: status_string += "Not Found"; break;
|
case 404: status = "Not Found"; break;
|
||||||
case 408: status_string += "Request Timeout"; break;
|
case 408: status = "Request Timeout"; break;
|
||||||
case 500: status_string += "Internal Server Error"; break;
|
case 500: status = "Internal Server Error"; break;
|
||||||
case 502: status_string += "Bad Gateway"; break;
|
case 502: status = "Bad Gateway"; break;
|
||||||
case 503: status_string += "Not Implemented"; break;
|
case 503: status = "Not Implemented"; break;
|
||||||
case 504: status_string += "Gateway Timeout"; break;
|
case 504: status = "Gateway Timeout"; break;
|
||||||
default: status_string += "WTF";
|
default: status = "WTF";
|
||||||
}
|
}
|
||||||
buffers.push_back(boost::asio::buffer(status_string, status_string.size()));
|
ss << "HTTP/1.1 " << code << "" << status << HTTP_CRLF;
|
||||||
buffers.push_back(boost::asio::buffer(HTTP_CRLF));
|
for (header & h : headers) {
|
||||||
|
ss << h.name << HTTP_HEADER_KV_SEP << h.value << HTTP_CRLF;
|
||||||
for (std::size_t i = 0; i < headers.size(); ++i)
|
|
||||||
{
|
|
||||||
header& h = headers[i];
|
|
||||||
buffers.push_back(boost::asio::buffer(h.name));
|
|
||||||
buffers.push_back(boost::asio::buffer(HTTP_HEADER_KV_SEP));
|
|
||||||
buffers.push_back(boost::asio::buffer(h.value));
|
|
||||||
buffers.push_back(boost::asio::buffer(HTTP_CRLF));
|
|
||||||
}
|
}
|
||||||
buffers.push_back(boost::asio::buffer(HTTP_CRLF));
|
ss << HTTP_CRLF; /* end of headers */
|
||||||
}
|
}
|
||||||
buffers.push_back(boost::asio::buffer(content));
|
ss << content;
|
||||||
return buffers;
|
return ss.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
void HTTPConnection::Terminate ()
|
void HTTPConnection::Terminate ()
|
||||||
|
@ -40,7 +40,7 @@ namespace util
|
|||||||
{
|
{
|
||||||
std::vector<header> headers;
|
std::vector<header> headers;
|
||||||
std::string status_string, content;
|
std::string status_string, content;
|
||||||
std::vector<boost::asio::const_buffer> to_buffers (int status);
|
std::string to_string (int status);
|
||||||
};
|
};
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
Loading…
Reference in New Issue
Block a user