diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-12-02 13:42:23 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-12-02 13:42:23 +0000 |
commit | b1e028b0fdc7b6b9a34a5757ff6703e098595256 (patch) | |
tree | 0fdda07b63fc02d76d47b67bfdbd687f0106e242 /src | |
parent | d2150fc165e99bb8d6a7411bffee6fd7d36d4763 (diff) | |
download | rspamd-b1e028b0fdc7b6b9a34a5757ff6703e098595256.tar.gz rspamd-b1e028b0fdc7b6b9a34a5757ff6703e098595256.zip |
Validate inet_addr before connecting/listening.
Diffstat (limited to 'src')
-rw-r--r-- | src/libutil/addr.c | 27 |
1 files changed, 26 insertions, 1 deletions
diff --git a/src/libutil/addr.c b/src/libutil/addr.c index bf9fc5d8a..8602676c9 100644 --- a/src/libutil/addr.c +++ b/src/libutil/addr.c @@ -32,6 +32,28 @@ enum { RSPAMD_IPV6_UNSUPPORTED } ipv6_status = RSPAMD_IPV6_UNDEFINED; + +static void +rspamd_ip_validate_af (rspamd_inet_addr_t *addr) +{ + if (addr->addr.sa.sa_family != addr->af) { + addr->addr.sa.sa_family = addr->af; + } + if (addr->af == AF_INET) { + addr->slen = sizeof (addr->addr.s4); + } + else if (addr->af == AF_INET6) { + addr->slen = sizeof (addr->addr.s6); + } + else if (addr->af == AF_UNIX) { +#ifdef SUN_LEN + addr->slen = SUN_LEN (&addr->addr.su); +#else + addr->slen = sizeof (addr->addr.su); +#endif + } +} + static void rspamd_ip_check_ipv6 (void) { @@ -215,6 +237,8 @@ rspamd_inet_address_connect (rspamd_inet_addr_t *addr, gint type, return -1; } + rspamd_ip_validate_af (addr); + fd = rspamd_socket_create (addr->af, type, 0, async); if (fd == -1) { return -1; @@ -245,6 +269,7 @@ rspamd_inet_address_listen (rspamd_inet_addr_t *addr, gint type, return -1; } + rspamd_ip_validate_af (addr); fd = rspamd_socket_create (addr->af, type, 0, async); if (fd == -1) { return -1; @@ -385,7 +410,7 @@ rspamd_parse_host_port_priority_strv (gchar **tokens, memcpy (&cur_addr->addr, cur->ai_addr, MIN (sizeof (cur_addr->addr), cur->ai_addrlen)); cur_addr->af = cur->ai_family; - cur_addr->addr.sa.sa_family = cur->ai_family; + rspamd_ip_validate_af (cur_addr); cur_addr->slen = cur->ai_addrlen; cur = cur->ai_next; addr_cnt ++; |