Browse Source

check_method client function

master
nicolas-arnaud 2 years ago
parent
commit
a645a3567c
  1. 3
      includes/Client.hpp
  2. 32
      srcs/sock/Client.cpp

3
includes/Client.hpp

@ -15,7 +15,8 @@ class Client {
~Client(void); ~Client(void);
bool getRequest(string paquet); bool getRequest(string paquet);
bool parseHeader(); bool parseHeader();
int answer(Env *env); void answer(Env *env);
bool check_method(Server *server, Route *route, string method);
void send_cgi(string cgi, string path); void send_cgi(string cgi, string path);
void send_error(int error_code); void send_error(int error_code);
void send_answer(string msg); void send_answer(string msg);

32
srcs/sock/Client.cpp

@ -63,15 +63,7 @@ bool Client::parseHeader() {
return true; return true;
} }
int Client::answer(Env *env) { bool Client::check_method(Server *server, Route *route, string method) {
cout << "Method: " << _request["Method:"].at(0) << "\n";
cout << "URI: " << _request["Method:"].at(1) << "\n";
cout << "Host: " << _request["Host:"].at(0) << "\n";
string ret;
Server *server = _parent->choose_server(env, _request["Host:"].at(0));
Route *route = server->choose_route(_request["Method:"].at(1));
string method = _request["Method:"].at(0);
std::vector< string > allowed; std::vector< string > allowed;
if (method != "GET" && method != "POST" && method != "DELETE") if (method != "GET" && method != "POST" && method != "DELETE")
send_error(405); send_error(405);
@ -81,21 +73,35 @@ int Client::answer(Env *env) {
} else if ((allowed = server->_headers).size() > 0) { } else if ((allowed = server->_headers).size() > 0) {
if (std::find(allowed.begin(), allowed.end(), method) == allowed.end()) if (std::find(allowed.begin(), allowed.end(), method) == allowed.end())
send_error(405); send_error(405);
} } else
return (true);
return (false);
}
void Client::answer(Env *env) {
cout << "Method: " << _request["Method:"].at(0) << "\n";
cout << "URI: " << _request["Method:"].at(1) << "\n";
cout << "Host: " << _request["Host:"].at(0) << "\n";
string ret;
Server *server = _parent->choose_server(env, _request["Host:"].at(0));
Route *route = server->choose_route(_request["Method:"].at(1));
string method = _request["Method:"].at(0);
if (check_method(server, route, method)) {
string path = route->correctUri(_request["Method:"].at(1)); string path = route->correctUri(_request["Method:"].at(1));
string cgi = route->_cgi.size() ? route->_cgi[get_extension(path)] : ""; string cgi = route->_cgi.size() ? route->_cgi[get_extension(path)] : "";
if (cgi == "") { if (cgi == "") {
if ((ret = route->getIndex(_request["Method:"].at(1), path)) == "" && if ((ret = route->getIndex(_request["Method:"].at(1), path)) ==
"" &&
(ret = read_file(path)) == "") (ret = read_file(path)) == "")
send_error(404); send_error(404);
else else
send_answer("HTTP/1.1 200 OK\r\n" + ret); send_answer("HTTP/1.1 200 OK\r\n" + ret);
} else } else
send_cgi(cgi, path); send_cgi(cgi, path);
}
_content = ""; _content = "";
_header = ""; _header = "";
return EXIT_SUCCESS;
} }
void Client::send_cgi(string cgi, string path) { void Client::send_cgi(string cgi, string path) {
@ -105,7 +111,7 @@ void Client::send_cgi(string cgi, string path) {
string ret; string ret;
if (!std::ifstream(cgi.c_str()).good()) if (!std::ifstream(cgi.c_str()).good())
send_error(404); // another error else ? return send_error(404);
pipe(fd); pipe(fd);
int pid = fork(); int pid = fork();
if (pid == 0) { if (pid == 0) {

Loading…
Cancel
Save