diff options
| author | Nolan Prescott <mail@nprescott.com> | 2020-12-18 21:30:42 -0500 |
|---|---|---|
| committer | Drew DeVault <sir@cmpwn.com> | 2020-12-19 09:29:39 -0500 |
| commit | 61bf4c53aa1522c4f0e8d1f912b6ab19154ed538 (patch) | |
| tree | 03471fcf73071a4224df6172e3326526437e7749 /src/log.c | |
| parent | cb2c84b0ad9aadd4c92d8ef978c2bfca578cd3c4 (diff) | |
| download | gmnisrv-61bf4c53aa1522c4f0e8d1f912b6ab19154ed538.tar.gz gmnisrv-61bf4c53aa1522c4f0e8d1f912b6ab19154ed538.tar.xz gmnisrv-61bf4c53aa1522c4f0e8d1f912b6ab19154ed538.zip | |
Fix IP address logging
Cast generic sockaddr to the appropriate sockaddr_ AF and switch
inet_ntop argument accordingly.
Intended to fix issue reported on ~sircmpwn/gmni-discuss: "Logged IPv4
addresses are wrong"
Diffstat (limited to 'src/log.c')
| -rw-r--r-- | src/log.c | 24 |
1 files changed, 20 insertions, 4 deletions
@@ -1,6 +1,7 @@ #include <arpa/inet.h> #include <assert.h> #include <stdarg.h> +#include <string.h> #include <stdio.h> #include <sys/socket.h> #include "log.h" @@ -17,11 +18,26 @@ static void client_logf(FILE *f, struct sockaddr *addr, const char *fmt, va_list ap) { char abuf[INET6_ADDRSTRLEN + 1]; - const char *addrs = inet_ntop(addr->sa_family, - addr->sa_data, abuf, sizeof(abuf)); - assert(addrs); - fprintf(f, "%s ", addrs); + switch(addr->sa_family) { + case AF_INET: { + struct sockaddr_in *addr_in = (struct sockaddr_in *)addr; + const char* result = inet_ntop(AF_INET, &(addr_in->sin_addr), abuf, INET_ADDRSTRLEN); + assert(result); + break; + } + case AF_INET6: { + struct sockaddr_in6 *addr_in6 = (struct sockaddr_in6 *)addr; + const char* result = inet_ntop(AF_INET6, &(addr_in6->sin6_addr), abuf, INET6_ADDRSTRLEN); + assert(result); + break; + } + default: + strncpy(abuf, "Unknown AF", INET6_ADDRSTRLEN); + break; + } + + fprintf(f, "%s ", abuf); vfprintf(f, fmt, ap); fprintf(f, "\n"); } |
