From e0f119ed7899c183fa5196aa9ca4c99d91684036 Mon Sep 17 00:00:00 2001 From: Nishi Date: Sat, 21 Sep 2024 08:40:13 +0000 Subject: [PATCH] add access log git-svn-id: file:///raid/svn-personal/tewi/trunk@116 8739d7e6-ffea-ec47-b151-bdff447c6205 --- Server/main.c | 1 + Server/server.c | 40 +++++++++++++++++++++++++++++++++++++++- 2 files changed, 40 insertions(+), 1 deletion(-) diff --git a/Server/main.c b/Server/main.c index eac830b..433449e 100644 --- a/Server/main.c +++ b/Server/main.c @@ -8,6 +8,7 @@ #include #include #include +#include #ifndef NO_SSL #include diff --git a/Server/server.c b/Server/server.c index 362968c..6f4fda0 100644 --- a/Server/server.c +++ b/Server/server.c @@ -30,6 +30,8 @@ #include #ifdef __MINGW32__ +#include +#include #include #include #include @@ -41,6 +43,7 @@ #include #include #include +#include #endif #ifdef __HAIKU__ @@ -432,6 +435,12 @@ int32_t tw_server_pass(void* ptr) { #else void* s = NULL; #endif + + char address[513]; + address[0] = 0; + struct sockaddr* sa = (struct sockaddr*)&addr; + getnameinfo(sa, sizeof(addr), address, 512, NULL, 0, NI_NUMERICHOST); + struct tw_http_request req; struct tw_http_response res; struct tw_tool tools; @@ -439,8 +448,37 @@ int32_t tw_server_pass(void* ptr) { tw_init_tools(&tools); int ret = tw_http_parse(s, sock, &req); if(ret == 0) { - char* vhost = cm_strdup(config.hostname); + char date[513]; + time_t t = time(NULL); + struct tm* tm = localtime(&t); + strftime(date, 512, "%a, %d %b %Y %H:%M:%S %Z", tm); + + char* useragent = cm_strdup(""); + int i; + for(i = 0; req.headers[i] != NULL; i += 2){ + if(cm_strcaseequ(req.headers[i], "User-Agent")){ + free(useragent); + useragent = cm_strdup(req.headers[i + 1]); + } + } + + char* tmp = cm_strcat3(address, " - [", date); + char* tmp2 = cm_strcat3(tmp, "] \"", req.method); + char* tmp3 = cm_strcat3(tmp2, " ", req.path); + char* tmp4 = cm_strcat3(tmp3, " ", req.version); + char* tmp5 = cm_strcat3(tmp4, "\" \"", useragent); + char* log = cm_strcat(tmp5, "\""); + free(tmp); + free(tmp2); + free(tmp3); + free(tmp4); + free(tmp5); + free(useragent); + cm_force_log(log); + free(log); + + char* vhost = cm_strdup(config.hostname); time_t cmtime = 0; if(req.headers != NULL) { for(i = 0; req.headers[i] != NULL; i += 2) { -- 2.43.0