X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=net.h;h=11b1708f4382f831b99a027db94fc92737fa0035;hp=3c6628c28c325f6804023553c1c8a362b2f53766;hb=36bc7580a5ddee8f6e46bccfea7519291f372f0f;hpb=82ec559332572814f76a8db3ed6751792687570d diff --git a/net.h b/net.h index 3c6628c2..11b1708f 100644 --- a/net.h +++ b/net.h @@ -3,6 +3,7 @@ * * Licensed under the GPL v2. For licencing details see COPYING. */ +#include /** \file net.h exported symbols from net.c */ @@ -24,6 +25,41 @@ #endif /** \endcond */ + +/** + * Functions to parse and validate (parts of) URLs. + */ +extern char *parse_url(const char *url, + char *host, ssize_t hostlen, int32_t *port); +/** + * Ensure that string conforms to the IPv4 address format. + * + * \param address The address string to check. + * + * \return 1 if \a address conforms to the IPv4 address format, else 0. + */ +_static_inline_ bool is_valid_ipv4_address(const char *address) +{ + struct in_addr test_it; + + 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). */