235 lines
7.8 KiB
C
235 lines
7.8 KiB
C
/*
|
|
* Copyright (C) 2008-2011 Teluu Inc. (http://www.teluu.com)
|
|
* Copyright (C) 2003-2008 Benny Prijono <benny@prijono.org>
|
|
*
|
|
* 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/sock.h>
|
|
|
|
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:
|
|
* <pre>
|
|
* ...
|
|
* 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;
|
|
* ...
|
|
* </pre>
|
|
*
|
|
* 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__ */
|
|
|