diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-10-28 13:36:15 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-10-28 13:36:15 +0000 |
commit | b4ce748572e3097982b951fac69c0e65db8b4118 (patch) | |
tree | 3e372ff1f7e9d2ef5e4b7a33e12e34b31e95f1a5 /src/libutil/util.c | |
parent | d95807104076189411987dcc733a23a94b8812a5 (diff) | |
download | rspamd-b4ce748572e3097982b951fac69c0e65db8b4118.tar.gz rspamd-b4ce748572e3097982b951fac69c0e65db8b4118.zip |
Split addr definition from the utils code.
Diffstat (limited to 'src/libutil/util.c')
-rw-r--r-- | src/libutil/util.c | 159 |
1 files changed, 1 insertions, 158 deletions
diff --git a/src/libutil/util.c b/src/libutil/util.c index 73ab64453..ec125704f 100644 --- a/src/libutil/util.c +++ b/src/libutil/util.c @@ -98,7 +98,7 @@ poll_sync_socket (gint fd, gint timeout, short events) return r; } -static gint +gint rspamd_socket_create (gint af, gint type, gint protocol, gboolean async) { gint fd; @@ -1973,32 +1973,6 @@ restart: #endif } -gboolean -rspamd_ip_is_valid (rspamd_inet_addr_t *addr) -{ - const struct in_addr ip4_any = { INADDR_ANY }, ip4_none = { INADDR_NONE }; - const struct in6_addr ip6_any = IN6ADDR_ANY_INIT; - - gboolean ret = FALSE; - - if (G_LIKELY (addr->af == AF_INET)) { - if (memcmp (&addr->addr.s4.sin_addr, &ip4_any, - sizeof (struct in_addr)) != 0 && - memcmp (&addr->addr.s4.sin_addr, &ip4_none, - sizeof (struct in_addr)) != 0) { - ret = TRUE; - } - } - else if (G_UNLIKELY (addr->af == AF_INET6)) { - if (memcmp (&addr->addr.s6.sin6_addr, &ip6_any, - sizeof (struct in6_addr)) != 0) { - ret = TRUE; - } - } - - return ret; -} - /* * GString ucl emitting functions */ @@ -2079,137 +2053,6 @@ rspamd_ucl_emit_gstring (ucl_object_t *obj, ucl_object_emit_full (obj, emit_type, &func); } -gint -rspamd_accept_from_socket (gint sock, rspamd_inet_addr_t *addr) -{ - gint nfd, serrno; - socklen_t len = sizeof (addr->addr.ss); - - if ((nfd = accept (sock, &addr->addr.sa, &len)) == -1) { - if (errno == EAGAIN || errno == EINTR || errno == EWOULDBLOCK) { - return 0; - } - return -1; - } - - addr->slen = len; - addr->af = addr->addr.sa.sa_family; - - if (make_socket_nonblocking (nfd) < 0) { - goto out; - } - - /* Set close on exec */ - if (fcntl (nfd, F_SETFD, FD_CLOEXEC) == -1) { - msg_warn ("fcntl failed: %d, '%s'", errno, strerror (errno)); - goto out; - } - - return (nfd); - -out: - serrno = errno; - close (nfd); - errno = serrno; - return (-1); - -} - -gboolean -rspamd_parse_inet_address (rspamd_inet_addr_t *target, const char *src) -{ - gboolean ret = FALSE; - - if (inet_pton (AF_INET6, src, &target->addr.s6.sin6_addr) == 1) { - target->af = AF_INET6; - target->slen = sizeof (target->addr.s6); - ret = TRUE; - } - else if (inet_pton (AF_INET, src, &target->addr.s4.sin_addr) == 1) { - target->af = AF_INET; - target->slen = sizeof (target->addr.s4); - ret = TRUE; - } - - target->addr.sa.sa_family = target->af; - - return ret; -} - -const char * -rspamd_inet_address_to_string (rspamd_inet_addr_t *addr) -{ - static char addr_str[INET6_ADDRSTRLEN + 1]; - - switch (addr->af) { - case AF_INET: - return inet_ntop (addr->af, &addr->addr.s4.sin_addr, addr_str, - sizeof (addr_str)); - case AF_INET6: - return inet_ntop (addr->af, &addr->addr.s6.sin6_addr, addr_str, - sizeof (addr_str)); - case AF_UNIX: - return addr->addr.su.sun_path; - } - - return "undefined"; -} - -uint16_t -rspamd_inet_address_get_port (rspamd_inet_addr_t *addr) -{ - switch (addr->af) { - case AF_INET: - return ntohs (addr->addr.s4.sin_port); - case AF_INET6: - return ntohs (addr->addr.s6.sin6_port); - } - - return 0; -} - -void -rspamd_inet_address_set_port (rspamd_inet_addr_t *addr, uint16_t port) -{ - switch (addr->af) { - case AF_INET: - addr->addr.s4.sin_port = htons (port); - break; - case AF_INET6: - addr->addr.s6.sin6_port = htons (port); - break; - } -} - -int -rspamd_inet_address_connect (rspamd_inet_addr_t *addr, gint type, - gboolean async) -{ - int fd, r; - - if (addr == NULL) { - return -1; - } - - fd = rspamd_socket_create (addr->af, type, 0, async); - if (fd == -1) { - return -1; - } - - r = connect (fd, &addr->addr.sa, addr->slen); - - if (r == -1) { - if (!async || errno != EINPROGRESS) { - close (fd); - msg_warn ("connect failed: %d, '%s'", errno, - strerror (errno)); - return -1; - } - } - - return fd; -} - /* * We use here z-base32 encoding described here: * http://philzimmermann.com/docs/human-oriented-base-32-encoding.txt |