From 40b66da398695590f82594bb92fd824bfdb44836 Mon Sep 17 00:00:00 2001 From: cflip Date: Tue, 30 May 2023 16:18:31 -0600 Subject: Move request handling code out of net.c and into the main file --- net.c | 50 ++++++++++---------------------------------------- 1 file changed, 10 insertions(+), 40 deletions(-) (limited to 'net.c') diff --git a/net.c b/net.c index ce19fc7..bbf80d1 100644 --- a/net.c +++ b/net.c @@ -10,10 +10,7 @@ #include #include -#include "file.h" -#include "http.h" - -int initialize_server(int port) +int net_init_server(int port) { struct sockaddr_in addr; int rc; @@ -42,7 +39,7 @@ int initialize_server(int port) return -1; } - rc = listen(sockfd, CFWS_MAXCONN); + rc = listen(sockfd, CFWS_NET_MAXCONN); if (rc == -1) { perror("Failed to listen on server socket"); return -1; @@ -51,46 +48,19 @@ int initialize_server(int port) return sockfd; } -void handle_connection(int connfd) +struct http_request net_next_request(int serverfd, int *clientfd) { - char readbuf[CFWS_MAXREAD]; + int connfd; + char readbuf[CFWS_NET_MAXREAD]; struct http_request req; - char *filepath; - enum http_res_code res_code; - enum serve_method method; + connfd = accept(serverfd, NULL, NULL); /* Read and parse the HTTP request */ - memset(readbuf, 0, CFWS_MAXREAD); - read(connfd, readbuf, CFWS_MAXREAD - 1); + memset(readbuf, 0, CFWS_NET_MAXREAD); + read(connfd, readbuf, CFWS_NET_MAXREAD - 1); req = http_parse_request(readbuf); - /* Get the local file path for the given URI. */ - filepath = file_path_for_uri(req.uri); - - printf("GET %s : %s\n", req.uri, filepath); - - /* Determine the method that should be used to serve this file */ - method = file_method_for_path(filepath, &res_code); - - /* Write the HTTP response status and any required headers */ - http_response_statusline(res_code, connfd); - - /* Use the chosen method to fill in the rest of the response */ - switch (method) { - case SERVE_METHOD_FILE: - file_read(filepath, connfd); - break; - case SERVE_METHOD_PHP: - file_read_php(filepath, connfd); - break; - case SERVE_METHOD_ERROR: { - const char *errmsg = "Content-Type: text/plain\r\n\r\nEpic fail"; - write(connfd, errmsg, strlen(errmsg)); - break; - } - } - - free(filepath); - http_free_request(&req); + *clientfd = connfd; + return req; } -- cgit v1.2.3