mirror of
https://github.com/KeyZox71/webserv.git
synced 2025-06-25 09:33:36 +02:00
「🏗️」 wip: now clearing client resource at sigint
This commit is contained in:
@ -6,7 +6,7 @@
|
||||
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2025/04/30 09:50:20 by adjoly #+# #+# */
|
||||
/* Updated: 2025/05/29 11:44:46 by adjoly ### ########.fr */
|
||||
/* Updated: 2025/05/29 12:06:54 by adjoly ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@ -23,6 +23,8 @@
|
||||
|
||||
using namespace webserv::http;
|
||||
|
||||
Response parseCgiOut(std::string cgi_str);
|
||||
|
||||
Post::Post(std::string &data, config::Server *srv) {
|
||||
_url = not_nullptr;
|
||||
_srv = srv;
|
||||
@ -52,6 +54,8 @@ void Post::parse(std::string const &data) {
|
||||
}
|
||||
}
|
||||
|
||||
_route = _srv->whatRoute(URL(_target));
|
||||
|
||||
std::ostringstream body_stream;
|
||||
while (std::getline(stream, line))
|
||||
body_stream << line << "\n";
|
||||
@ -118,34 +122,6 @@ void Post::handleMultipartData(const std::string &body,
|
||||
}
|
||||
}
|
||||
|
||||
Response parseCgiOut(std::string cgi_str) {
|
||||
Response response;
|
||||
std::istringstream stream(cgi_str);
|
||||
std::string line;
|
||||
|
||||
response.setStatusCode(200);
|
||||
while (std::getline(stream, line) && line != "") {
|
||||
size_t delimiter_index = line.find(':');
|
||||
if (delimiter_index != std::string::npos) {
|
||||
std::string key = line.substr(0, delimiter_index);
|
||||
std::string value = line.substr(delimiter_index + 2);
|
||||
response.addHeader(key, value);
|
||||
}
|
||||
}
|
||||
std::ostringstream body_stream;
|
||||
while (std::getline(stream, line))
|
||||
body_stream << line << "\n";
|
||||
response.setBody(body_stream.str());
|
||||
|
||||
if (response.getHeader("Content-Length") == "") {
|
||||
std::stringstream length;
|
||||
length << response.getBody().length();
|
||||
response.addHeader("Content-Length", length.str());
|
||||
}
|
||||
return response;
|
||||
}
|
||||
|
||||
|
||||
Response Post::execute(void) {
|
||||
http::Response response;
|
||||
|
||||
|
Reference in New Issue
Block a user