From 962373e5c61fbed30f4288fb34f9f0ab1415055e Mon Sep 17 00:00:00 2001 From: rofl0r Date: Sun, 21 Jul 2019 14:27:55 +0100 Subject: [PATCH] getaddrinfo: fix behaviour when node is null and !passive according to the spec, if these 2 conditions hold, the name shall resolve to localhost. closes #292 --- src/core.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/core.c b/src/core.c index a6f39df..0d79c3a 100644 --- a/src/core.c +++ b/src/core.c @@ -879,6 +879,10 @@ int proxy_getaddrinfo(const char *node, const char *service, const struct addrin goto err2; } else if(node) { af = ((struct sockaddr_in *) &space->sockaddr_space)->sin_family; + } else if(!node && !(hints->ai_flags & AI_PASSIVE)) { + af = ((struct sockaddr_in *) &space->sockaddr_space)->sin_family = AF_INET; + memcpy(&((struct sockaddr_in *) &space->sockaddr_space)->sin_addr, + (char[]){127,0,0,1}, 4); } if(service) mygetservbyname_r(service, NULL, &se_buf, buf, sizeof(buf), &se);