/* * Copyright (C) 2008-2011 Teluu Inc. (http://www.teluu.com) * Copyright (C) 2003-2008 Benny Prijono * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef __PJ_ADDR_RESOLV_H__ #define __PJ_ADDR_RESOLV_H__ /** * @file addr_resolv.h * @brief IP address resolution. */ #include PJ_BEGIN_DECL /** * @defgroup pj_addr_resolve Network Address Resolution * @ingroup PJ_IO * @{ * * This module provides function to resolve Internet address of the * specified host name. To resolve a particular host name, application * can just call #pj_gethostbyname(). * * Example: *
 *   ...
 *   pj_hostent he;
 *   pj_status_t rc;
 *   pj_str_t host = pj_str("host.example.com");
 *   
 *   rc = pj_gethostbyname( &host, &he);
 *   if (rc != PJ_SUCCESS) {
 *      char errbuf[80];
 *      pj_strerror( rc, errbuf, sizeof(errbuf));
 *      PJ_LOG(2,("sample", "Unable to resolve host, error=%s", errbuf));
 *      return rc;
 *   }
 *
 *   // process address...
 *   addr.sin_addr.s_addr = *(pj_uint32_t*)he.h_addr;
 *   ...
 * 
* * It's pretty simple really... */ /** This structure describes an Internet host address. */ typedef struct pj_hostent { char *h_name; /**< The official name of the host. */ char **h_aliases; /**< Aliases list. */ int h_addrtype; /**< Host address type. */ int h_length; /**< Length of address. */ char **h_addr_list; /**< List of addresses. */ } pj_hostent; /** Shortcut to h_addr_list[0] */ #define h_addr h_addr_list[0] /** * This structure describes address information pj_getaddrinfo(). */ typedef struct pj_addrinfo { char ai_canonname[PJ_MAX_HOSTNAME]; /**< Canonical name for host*/ pj_sockaddr ai_addr; /**< Binary address. */ } pj_addrinfo; /** * This function fills the structure of type pj_hostent for a given host name. * For host resolution function that also works with IPv6, please see * #pj_getaddrinfo(). * * @param name Host name to resolve. Specifying IPv4 address here * may fail on some platforms (e.g. Windows) * @param he The pj_hostent structure to be filled. Note that * the pointers in this structure points to temporary * variables which value will be reset upon subsequent * invocation. * * @return PJ_SUCCESS, or the appropriate error codes. */ PJ_DECL(pj_status_t) pj_gethostbyname(const pj_str_t *name, pj_hostent *he); /** * Resolve the primary IP address of local host. * * @param af The desired address family to query. Valid values * are pj_AF_INET() or pj_AF_INET6(). * @param addr On successful resolution, the address family and address * part of this socket address will be filled up with the host * IP address, in network byte order. Other parts of the socket * address are untouched. * * @return PJ_SUCCESS on success, or the appropriate error code. */ PJ_DECL(pj_status_t) pj_gethostip(int af, pj_sockaddr *addr); /** * Get the interface IP address to send data to the specified destination. * * @param af The desired address family to query. Valid values * are pj_AF_INET() or pj_AF_INET6(). * @param dst The destination host. * @param itf_addr On successful resolution, the address family and address * part of this socket address will be filled up with the host * IP address, in network byte order. Other parts of the socket * address should be ignored. * @param allow_resolve If \a dst may contain hostname (instead of IP * address), specify whether hostname resolution should * be performed. If not, default interface address will * be returned. * @param p_dst_addr If not NULL, it will be filled with the IP address of * the destination host. * * @return PJ_SUCCESS on success, or the appropriate error code. */ PJ_DECL(pj_status_t) pj_getipinterface(int af, const pj_str_t *dst, pj_sockaddr *itf_addr, pj_bool_t allow_resolve, pj_sockaddr *p_dst_addr); /** * Get the IP address of the default interface. Default interface is the * interface of the default route. * * @param af The desired address family to query. Valid values * are pj_AF_INET() or pj_AF_INET6(). * @param addr On successful resolution, the address family and address * part of this socket address will be filled up with the host * IP address, in network byte order. Other parts of the socket * address are untouched. * * @return PJ_SUCCESS on success, or the appropriate error code. */ PJ_DECL(pj_status_t) pj_getdefaultipinterface(int af, pj_sockaddr *addr); /** * This function translates the name of a service location (for example, * a host name) and returns a set of addresses and associated information * to be used in creating a socket with which to address the specified * service. * * @param af The desired address family to query. Valid values * are pj_AF_INET(), pj_AF_INET6(), or pj_AF_UNSPEC(). * @param name Descriptive name or an address string, such as host * name. * @param count On input, it specifies the number of elements in * \a ai array. On output, this will be set with the * number of address informations found for the * specified name. * @param ai Array of address info to be filled with the information * about the host. * * @return PJ_SUCCESS on success, or the appropriate error code. */ PJ_DECL(pj_status_t) pj_getaddrinfo(int af, const pj_str_t *name, unsigned *count, pj_addrinfo ai[]); /** * Enumeration of IP address type. */ typedef enum pj_addr_type { /** * Disabled: 0.0.0.0/8 or ::/128 */ PJ_ADDR_TYPE_DISABLED = 1, /** * Loopback: 127.0.0.0/8 or ::1/128 */ PJ_ADDR_TYPE_LOOPBACK = 2, /** * Link-local: 169.254.0.0/16 or fe80::/64 */ PJ_ADDR_TYPE_LINK_LOCAL = 4, /** * Private: 10.0.0.0/8, 172.16.0.0/12, 192.168.0.0/16 or fc00::/7 */ PJ_ADDR_TYPE_PRIVATE = 8, /** * Multicast: 224.0.0.0/3 or ff00::/8 */ PJ_ADDR_TYPE_MULTICAST = 16, } pj_addr_type; /** * Check IP address type. * * @param addr The IP address to check, must be IPv4 or IPv6 address. * @param type Bit mask of address type pj_addr_type. * * @return PJ_TRUE if the type of specified address \addr match to * the specified types \a type. */ PJ_DECL(pj_bool_t) pj_check_addr_type(const pj_sockaddr *addr, unsigned type); /** @} */ PJ_END_DECL #endif /* __PJ_ADDR_RESOLV_H__ */