X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=net.h;h=8b706178e635fda2ba5ae00568730e36c87fac6a;hp=8ec9fa52b9e4a05d259a820e82de56a584351ead;hb=7cb521f3eeb7fda02344c523989d5903251e673e;hpb=6ba0a5055cfdec25d54d90a56f9345d5d4be09be;ds=sidebyside diff --git a/net.h b/net.h index 8ec9fa52..8b706178 100644 --- a/net.h +++ b/net.h @@ -25,6 +25,14 @@ #endif /** \endcond */ + +/** + * Functions to parse and validate (parts of) URLs. + */ +extern char *parse_cidr(const char *cidr, + char *addr, ssize_t addrlen, int32_t *netmask); +extern char *parse_url(const char *url, + char *host, ssize_t hostlen, int32_t *port); /** * Ensure that string conforms to the IPv4 address format. * @@ -39,6 +47,21 @@ _static_inline_ bool is_valid_ipv4_address(const char *address) return inet_pton(AF_INET, address, &test_it) != 0; } +/** + * Ensure that string conforms to IPv6 address format. + * + * \param address The address string to check. + * + * \return 1 if string has a valid IPv6 address syntax, 0 if not. + * \sa RFC 4291 + */ +_static_inline_ bool is_valid_ipv6_address(const char *address) +{ + struct in6_addr test_it; + + return inet_pton(AF_INET6, address, &test_it) != 0; +} + /** * Generic socket creation (passive and active sockets). */