From: Vsevolod Stakhov Date: Tue, 5 Nov 2019 15:42:06 +0000 (+0000) Subject: [Minor] Copy ipv6 address in full on accept X-Git-Tag: 2.2~80 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=08e517da1b18105b16fe7124f304f248a7a86e2f;p=thirdparty%2Frspamd.git [Minor] Copy ipv6 address in full on accept --- diff --git a/src/libutil/addr.c b/src/libutil/addr.c index 138dc1318a..15480a9ad1 100644 --- a/src/libutil/addr.c +++ b/src/libutil/addr.c @@ -248,18 +248,19 @@ rspamd_accept_from_socket (gint sock, rspamd_inet_addr_t **target, addr = rspamd_inet_addr_create (AF_INET, NULL); memcpy (&addr->u.in.addr.s4.sin_addr, &p[12], sizeof (struct in_addr)); + addr->u.in.addr.s4.sin_port = su.s6.sin6_port; } else { /* Something strange but not mapped v4 address */ addr = rspamd_inet_addr_create (AF_INET6, NULL); - memcpy (&addr->u.in.addr.s6.sin6_addr, &su.s6.sin6_addr, - sizeof (struct in6_addr)); + memcpy (&addr->u.in.addr.s6, &su.s6, + sizeof (struct sockaddr_in6)); } } else { addr = rspamd_inet_addr_create (AF_INET6, NULL); - memcpy (&addr->u.in.addr.s6.sin6_addr, &su.s6.sin6_addr, - sizeof (struct in6_addr)); + memcpy (&addr->u.in.addr.s6, &su.s6, + sizeof (struct sockaddr_in6)); } }