formatting

This commit is contained in:
Benjamin Sergeant 2020-09-12 13:55:27 -07:00
parent 72d6651ded
commit 1e8c421d66
2 changed files with 26 additions and 20 deletions

View File

@ -129,24 +129,27 @@ namespace ix
{
return std::make_tuple(false, "Error parsing HTTP headers", httpRequest);
}
std::string body = "";
if (headers.find("Content-Length") != headers.end()){
if (headers.find("Content-Length") != headers.end())
{
int contentLength = 0;
try {
try
{
contentLength = std::stoi(headers["Content-Length"]);
}
catch (std::exception){
return std::make_tuple(false, "Error parsing HTTP Header 'Content-Length'", httpRequest);
catch (std::exception)
{
return std::make_tuple(
false, "Error parsing HTTP Header 'Content-Length'", httpRequest);
}
char c;
body.reserve(contentLength);
for (int i = 0; i < contentLength; i++){
if (socket->readByte(&c, isCancellationRequested))
body += c;
for (int i = 0; i < contentLength; i++)
{
if (socket->readByte(&c, isCancellationRequested)) body += c;
}
}

View File

@ -69,14 +69,17 @@ TEST_CASE("http server", "[httpd]")
int port = getFreePort();
ix::HttpServer server(port, "127.0.0.1");
server.setOnConnectionCallback([](HttpRequestPtr request, std::shared_ptr<ConnectionState>) -> HttpResponsePtr {
if (request->method == "POST"){
return std::make_shared<HttpResponse>(200, "OK", HttpErrorCode::Ok, WebSocketHttpHeaders(), request->body);
}
return std::make_shared<HttpResponse>(400, "BAD REQUEST");
});
server.setOnConnectionCallback(
[](HttpRequestPtr request, std::shared_ptr<ConnectionState>) -> HttpResponsePtr {
if (request->method == "POST")
{
return std::make_shared<HttpResponse>(
200, "OK", HttpErrorCode::Ok, WebSocketHttpHeaders(), request->body);
}
return std::make_shared<HttpResponse>(400, "BAD REQUEST");
});
auto res = server.listen();
REQUIRE(res.first);
server.start();
@ -97,7 +100,7 @@ TEST_CASE("http server", "[httpd]")
args->body = "Hello World!";
auto response = httpClient.post(url, args->body, args);
std::cerr << "Status: " << response->statusCode << std::endl;
std::cerr << "Error message: " << response->errorMsg << std::endl;
std::cerr << "Payload: " << response->payload << std::endl;