diff options
-rw-r--r-- | cfws.c | 2 | ||||
-rw-r--r-- | file.c | 13 | ||||
-rw-r--r-- | file.h | 2 |
3 files changed, 8 insertions, 9 deletions
@@ -56,7 +56,7 @@ static void handle_request(const struct http_request *req, int sockfd) file_read(filepath, sockfd); break; case SERVE_METHOD_PHP: - file_read_php(filepath, sockfd); + file_read_php(filepath, req->query_str, sockfd); break; case SERVE_METHOD_ERROR: { const char *errmsg = "Content-Type: text/plain\r\n\r\nEpic fail"; @@ -69,19 +69,18 @@ int file_read(const char *filepath, int sockfd) return 0; } -int file_read_php(const char *filepath, int sockfd) +int file_read_php(const char *filepath, const char *query_str, int sockfd) { FILE *fp; - char cmdbuf[PATH_MAX]; char buffer[FILE_READBUF_SIZE]; size_t bytes_read; - strcpy(cmdbuf, "php-cgi "); - strcat(cmdbuf, filepath); + setenv("REQUEST_METHOD", "GET", 1); + setenv("SCRIPT_FILENAME", filepath, 1); + if (query_str) + setenv("QUERY_STRING", query_str, 1); - printf("r %s\n", cmdbuf); - - fp = popen(cmdbuf, "r"); + fp = popen("php-cgi", "r"); if (fp == NULL) { perror("Failed to read command"); return 1; @@ -16,6 +16,6 @@ const char *file_path_for_uri(const char *); enum serve_method file_method_for_path(const char *, enum http_res_code *); int file_read(const char *, int); -int file_read_php(const char *, int); +int file_read_php(const char *, const char *, int); #endif |