added fail support
This commit is contained in:
40
cmd/server.c
40
cmd/server.c
@@ -26,8 +26,19 @@ int parseHTTPRequest(char buffer[], struct HTTPRequest *r) {
|
|||||||
token = strtok(checkLine, " ");
|
token = strtok(checkLine, " ");
|
||||||
// HTTP Request Type
|
// HTTP Request Type
|
||||||
if (!strcmp(token, "GET")) {
|
if (!strcmp(token, "GET")) {
|
||||||
|
// Grabbing HTTP Request Type
|
||||||
r->requestType = malloc(strlen(token));
|
r->requestType = malloc(strlen(token));
|
||||||
strcpy(r->requestType, token);
|
strcpy(r->requestType, token);
|
||||||
|
// Grabbing HTTP Request Dir
|
||||||
|
token = strtok(NULL, " ");
|
||||||
|
r->requestDir = malloc(strlen(token));
|
||||||
|
strcpy(r->requestDir, token);
|
||||||
|
// Grabbing HTTP Request Version
|
||||||
|
token = strtok(NULL, "");
|
||||||
|
r->requestVersion = malloc(strlen(token));
|
||||||
|
strcpy(r->requestVersion, token);
|
||||||
|
} else {
|
||||||
|
return 1;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
token = strtok(checkLine, ":");
|
token = strtok(checkLine, ":");
|
||||||
@@ -52,18 +63,32 @@ int parseHTTPRequest(char buffer[], struct HTTPRequest *r) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int returnRequest(int socket) {
|
int returnRequest(int socket, char *message) {
|
||||||
char *hello = "HTTP/1.1 200 OK\nContent-Length: 5\nConnection: close\n\nhello\n\n";
|
send(socket, message, strlen(message), 0);
|
||||||
printf("Returning\n%s", hello);
|
|
||||||
send(socket, hello, strlen(hello), 0);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int return200Request(int socket) {
|
||||||
|
char *message = "HTTP/1.1 200 OK\nContent-Length: 6\nConnection: close\n\nhello\n";
|
||||||
|
return returnRequest(socket, message);
|
||||||
|
}
|
||||||
|
|
||||||
|
int return404Request(int socket) {
|
||||||
|
char *message = "HTTP/1.1 404 Not Found\nContent-Length: 12\nConnection: close\n\n404 Request\n";
|
||||||
|
return returnRequest(socket, message);
|
||||||
|
}
|
||||||
|
|
||||||
int handleRequest(char buffer[], int socket) {
|
int handleRequest(char buffer[], int socket) {
|
||||||
struct HTTPRequest r;
|
struct HTTPRequest r; // Holds relevant HTTP request information
|
||||||
|
int checkerr = 0;
|
||||||
// Grabbing relevant information out of request
|
// Grabbing relevant information out of request
|
||||||
parseHTTPRequest(buffer, &r);
|
checkerr = parseHTTPRequest(buffer, &r);
|
||||||
returnRequest(socket);
|
if (checkerr != 0) { // Checking for HTTP parsing error
|
||||||
|
perror("Badness!!!");
|
||||||
|
return return404Request(socket);
|
||||||
|
}
|
||||||
|
// Return response to socket
|
||||||
|
return200Request(socket);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -90,7 +115,6 @@ int main(int argc, char const *argv[]) {
|
|||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
read(new_socket, buffer, 1024);
|
read(new_socket, buffer, 1024);
|
||||||
printf("Conn received:\n%s\n", buffer);
|
|
||||||
handleRequest(buffer, new_socket);
|
handleRequest(buffer, new_socket);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -6,4 +6,5 @@ struct HTTPRequest {
|
|||||||
char *requestType;
|
char *requestType;
|
||||||
char *requestVersion;
|
char *requestVersion;
|
||||||
char *requestHost;
|
char *requestHost;
|
||||||
|
char *requestDir;
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user