summaryrefslogtreecommitdiffstats
path: root/src/log.c
diff options
context:
space:
mode:
authorNolan Prescott <mail@nprescott.com>2020-12-18 21:30:42 -0500
committerDrew DeVault <sir@cmpwn.com>2020-12-19 09:29:39 -0500
commit61bf4c53aa1522c4f0e8d1f912b6ab19154ed538 (patch)
tree03471fcf73071a4224df6172e3326526437e7749 /src/log.c
parentcb2c84b0ad9aadd4c92d8ef978c2bfca578cd3c4 (diff)
downloadgmnisrv-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.c24
1 files changed, 20 insertions, 4 deletions
diff --git a/src/log.c b/src/log.c
index c1aa13b..4d125b3 100644
--- a/src/log.c
+++ b/src/log.c
@@ -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");
}