123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937 |
- /* MIT License
- *
- * Copyright (c) Massachusetts Institute of Technology
- * Copyright (c) Daniel Stenberg
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice (including the next
- * paragraph) shall be included in all copies or substantial portions of the
- * Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- *
- * SPDX-License-Identifier: MIT
- */
- #ifndef ARES__H
- #define ARES__H
- #include "ares_version.h" /* c-ares version defines */
- #include "ares_build.h" /* c-ares build definitions */
- #if defined(_WIN32)
- # ifndef WIN32_LEAN_AND_MEAN
- # define WIN32_LEAN_AND_MEAN
- # endif
- #endif
- #ifdef CARES_HAVE_SYS_TYPES_H
- # include <sys/types.h>
- #endif
- #ifdef CARES_HAVE_SYS_SOCKET_H
- # include <sys/socket.h>
- #endif
- #ifdef CARES_HAVE_SYS_SELECT_H
- # include <sys/select.h>
- #endif
- #ifdef CARES_HAVE_WINSOCK2_H
- # include <winsock2.h>
- /* To aid with linking against a static c-ares build, lets tell the microsoft
- * compiler to pull in needed dependencies */
- # ifdef _MSC_VER
- # pragma comment(lib, "ws2_32")
- # pragma comment(lib, "advapi32")
- # pragma comment(lib, "iphlpapi")
- # endif
- #endif
- #ifdef CARES_HAVE_WS2TCPIP_H
- # include <ws2tcpip.h>
- #endif
- #ifdef CARES_HAVE_WINDOWS_H
- # include <windows.h>
- #endif
- /* HP-UX systems version 9, 10 and 11 lack sys/select.h and so does oldish
- libc5-based Linux systems. Only include it on system that are known to
- require it! */
- #if defined(_AIX) || defined(__NOVELL_LIBC__) || defined(__NetBSD__) || \
- defined(__minix) || defined(__SYMBIAN32__) || defined(__INTEGRITY) || \
- defined(ANDROID) || defined(__ANDROID__) || defined(__OpenBSD__) || \
- defined(__QNXNTO__) || defined(__MVS__) || defined(__HAIKU__)
- # include <sys/select.h>
- #endif
- #if (defined(NETWARE) && !defined(__NOVELL_LIBC__))
- # include <sys/bsdskt.h>
- #endif
- #if !defined(_WIN32)
- # include <netinet/in.h>
- #endif
- #ifdef WATT32
- # include <tcp.h>
- #endif
- #if defined(ANDROID) || defined(__ANDROID__)
- # include <jni.h>
- #endif
- typedef CARES_TYPEOF_ARES_SOCKLEN_T ares_socklen_t;
- typedef CARES_TYPEOF_ARES_SSIZE_T ares_ssize_t;
- #ifdef __cplusplus
- extern "C" {
- #endif
- /*
- ** c-ares external API function linkage decorations.
- */
- #if defined(_WIN32) || defined(__CYGWIN__) || defined(__SYMBIAN32__)
- # ifdef CARES_STATICLIB
- # define CARES_EXTERN
- # else
- # ifdef CARES_BUILDING_LIBRARY
- # define CARES_EXTERN __declspec(dllexport)
- # else
- # define CARES_EXTERN __declspec(dllimport)
- # endif
- # endif
- #else
- # if defined(__GNUC__) && __GNUC__ >= 4
- # define CARES_EXTERN __attribute__((visibility("default")))
- # elif defined(__INTEL_COMPILER) && __INTEL_COMPILER >= 900
- # define CARES_EXTERN __attribute__((visibility("default")))
- # elif defined(__SUNPRO_C)
- # define CARES_EXTERN _global
- # else
- # define CARES_EXTERN
- # endif
- #endif
- #ifdef __GNUC__
- # define CARES_GCC_VERSION \
- (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__)
- #else
- # define CARES_GCC_VERSION 0
- #endif
- #ifndef __has_attribute
- # define __has_attribute(x) 0
- #endif
- #if 1
- # define CARES_DEPRECATED
- # define CARES_DEPRECATED_FOR(f)
- #else
- # if CARES_GCC_VERSION >= 30200 || __has_attribute(__deprecated__)
- # define CARES_DEPRECATED __attribute__((__deprecated__))
- # else
- # define CARES_DEPRECATED
- # endif
- # if CARES_GCC_VERSION >= 40500 || defined(__clang__)
- # define CARES_DEPRECATED_FOR(f) \
- __attribute__((deprecated("Use " #f " instead")))
- # elif defined(_MSC_VER)
- # define CARES_DEPRECATED_FOR(f) __declspec(deprecated("Use " #f " instead"))
- # else
- # define CARES_DEPRECATED_FOR(f) CARES_DEPRECATED
- # endif
- #endif
- typedef enum {
- ARES_SUCCESS = 0,
- /* Server error codes (ARES_ENODATA indicates no relevant answer) */
- ARES_ENODATA = 1,
- ARES_EFORMERR = 2,
- ARES_ESERVFAIL = 3,
- ARES_ENOTFOUND = 4,
- ARES_ENOTIMP = 5,
- ARES_EREFUSED = 6,
- /* Locally generated error codes */
- ARES_EBADQUERY = 7,
- ARES_EBADNAME = 8,
- ARES_EBADFAMILY = 9,
- ARES_EBADRESP = 10,
- ARES_ECONNREFUSED = 11,
- ARES_ETIMEOUT = 12,
- ARES_EOF = 13,
- ARES_EFILE = 14,
- ARES_ENOMEM = 15,
- ARES_EDESTRUCTION = 16,
- ARES_EBADSTR = 17,
- /* ares_getnameinfo error codes */
- ARES_EBADFLAGS = 18,
- /* ares_getaddrinfo error codes */
- ARES_ENONAME = 19,
- ARES_EBADHINTS = 20,
- /* Uninitialized library error code */
- ARES_ENOTINITIALIZED = 21, /* introduced in 1.7.0 */
- /* ares_library_init error codes */
- ARES_ELOADIPHLPAPI = 22, /* introduced in 1.7.0 */
- ARES_EADDRGETNETWORKPARAMS = 23, /* introduced in 1.7.0 */
- /* More error codes */
- ARES_ECANCELLED = 24, /* introduced in 1.7.0 */
- /* More ares_getaddrinfo error codes */
- ARES_ESERVICE = 25, /* ares_getaddrinfo() was passed a text service name that
- * is not recognized. introduced in 1.16.0 */
- ARES_ENOSERVER = 26 /* No DNS servers were configured */
- } ares_status_t;
- typedef enum {
- ARES_FALSE = 0,
- ARES_TRUE = 1
- } ares_bool_t;
- /*! Values for ARES_OPT_EVENT_THREAD */
- typedef enum {
- /*! Default (best choice) event system */
- ARES_EVSYS_DEFAULT = 0,
- /*! Win32 IOCP/AFD_POLL event system */
- ARES_EVSYS_WIN32 = 1,
- /*! Linux epoll */
- ARES_EVSYS_EPOLL = 2,
- /*! BSD/MacOS kqueue */
- ARES_EVSYS_KQUEUE = 3,
- /*! POSIX poll() */
- ARES_EVSYS_POLL = 4,
- /*! last fallback on Unix-like systems, select() */
- ARES_EVSYS_SELECT = 5
- } ares_evsys_t;
- /* Flag values */
- #define ARES_FLAG_USEVC (1 << 0)
- #define ARES_FLAG_PRIMARY (1 << 1)
- #define ARES_FLAG_IGNTC (1 << 2)
- #define ARES_FLAG_NORECURSE (1 << 3)
- #define ARES_FLAG_STAYOPEN (1 << 4)
- #define ARES_FLAG_NOSEARCH (1 << 5)
- #define ARES_FLAG_NOALIASES (1 << 6)
- #define ARES_FLAG_NOCHECKRESP (1 << 7)
- #define ARES_FLAG_EDNS (1 << 8)
- #define ARES_FLAG_NO_DFLT_SVR (1 << 9)
- #define ARES_FLAG_DNS0x20 (1 << 10)
- /* Option mask values */
- #define ARES_OPT_FLAGS (1 << 0)
- #define ARES_OPT_TIMEOUT (1 << 1)
- #define ARES_OPT_TRIES (1 << 2)
- #define ARES_OPT_NDOTS (1 << 3)
- #define ARES_OPT_UDP_PORT (1 << 4)
- #define ARES_OPT_TCP_PORT (1 << 5)
- #define ARES_OPT_SERVERS (1 << 6)
- #define ARES_OPT_DOMAINS (1 << 7)
- #define ARES_OPT_LOOKUPS (1 << 8)
- #define ARES_OPT_SOCK_STATE_CB (1 << 9)
- #define ARES_OPT_SORTLIST (1 << 10)
- #define ARES_OPT_SOCK_SNDBUF (1 << 11)
- #define ARES_OPT_SOCK_RCVBUF (1 << 12)
- #define ARES_OPT_TIMEOUTMS (1 << 13)
- #define ARES_OPT_ROTATE (1 << 14)
- #define ARES_OPT_EDNSPSZ (1 << 15)
- #define ARES_OPT_NOROTATE (1 << 16)
- #define ARES_OPT_RESOLVCONF (1 << 17)
- #define ARES_OPT_HOSTS_FILE (1 << 18)
- #define ARES_OPT_UDP_MAX_QUERIES (1 << 19)
- #define ARES_OPT_MAXTIMEOUTMS (1 << 20)
- #define ARES_OPT_QUERY_CACHE (1 << 21)
- #define ARES_OPT_EVENT_THREAD (1 << 22)
- #define ARES_OPT_SERVER_FAILOVER (1 << 23)
- /* Nameinfo flag values */
- #define ARES_NI_NOFQDN (1 << 0)
- #define ARES_NI_NUMERICHOST (1 << 1)
- #define ARES_NI_NAMEREQD (1 << 2)
- #define ARES_NI_NUMERICSERV (1 << 3)
- #define ARES_NI_DGRAM (1 << 4)
- #define ARES_NI_TCP 0
- #define ARES_NI_UDP ARES_NI_DGRAM
- #define ARES_NI_SCTP (1 << 5)
- #define ARES_NI_DCCP (1 << 6)
- #define ARES_NI_NUMERICSCOPE (1 << 7)
- #define ARES_NI_LOOKUPHOST (1 << 8)
- #define ARES_NI_LOOKUPSERVICE (1 << 9)
- /* Reserved for future use */
- #define ARES_NI_IDN (1 << 10)
- #define ARES_NI_IDN_ALLOW_UNASSIGNED (1 << 11)
- #define ARES_NI_IDN_USE_STD3_ASCII_RULES (1 << 12)
- /* Addrinfo flag values */
- #define ARES_AI_CANONNAME (1 << 0)
- #define ARES_AI_NUMERICHOST (1 << 1)
- #define ARES_AI_PASSIVE (1 << 2)
- #define ARES_AI_NUMERICSERV (1 << 3)
- #define ARES_AI_V4MAPPED (1 << 4)
- #define ARES_AI_ALL (1 << 5)
- #define ARES_AI_ADDRCONFIG (1 << 6)
- #define ARES_AI_NOSORT (1 << 7)
- #define ARES_AI_ENVHOSTS (1 << 8)
- /* Reserved for future use */
- #define ARES_AI_IDN (1 << 10)
- #define ARES_AI_IDN_ALLOW_UNASSIGNED (1 << 11)
- #define ARES_AI_IDN_USE_STD3_ASCII_RULES (1 << 12)
- #define ARES_AI_CANONIDN (1 << 13)
- #define ARES_AI_MASK \
- (ARES_AI_CANONNAME | ARES_AI_NUMERICHOST | ARES_AI_PASSIVE | \
- ARES_AI_NUMERICSERV | ARES_AI_V4MAPPED | ARES_AI_ALL | ARES_AI_ADDRCONFIG)
- #define ARES_GETSOCK_MAXNUM \
- 16 /* ares_getsock() can return info about this \
- many sockets */
- #define ARES_GETSOCK_READABLE(bits, num) (bits & (1 << (num)))
- #define ARES_GETSOCK_WRITABLE(bits, num) \
- (bits & (1 << ((num) + ARES_GETSOCK_MAXNUM)))
- /* c-ares library initialization flag values */
- #define ARES_LIB_INIT_NONE (0)
- #define ARES_LIB_INIT_WIN32 (1 << 0)
- #define ARES_LIB_INIT_ALL (ARES_LIB_INIT_WIN32)
- /* Server state callback flag values */
- #define ARES_SERV_STATE_UDP (1 << 0) /* Query used UDP */
- #define ARES_SERV_STATE_TCP (1 << 1) /* Query used TCP */
- /*
- * Typedef our socket type
- */
- #ifndef ares_socket_typedef
- # if defined(_WIN32) && !defined(WATT32)
- typedef SOCKET ares_socket_t;
- # define ARES_SOCKET_BAD INVALID_SOCKET
- # else
- typedef int ares_socket_t;
- # define ARES_SOCKET_BAD -1
- # endif
- # define ares_socket_typedef
- #endif /* ares_socket_typedef */
- typedef void (*ares_sock_state_cb)(void *data, ares_socket_t socket_fd,
- int readable, int writable);
- struct apattern;
- /* Options controlling server failover behavior.
- * The retry chance is the probability (1/N) by which we will retry a failed
- * server instead of the best server when selecting a server to send queries
- * to.
- * The retry delay is the minimum time in milliseconds to wait between doing
- * such retries (applied per-server).
- */
- struct ares_server_failover_options {
- unsigned short retry_chance;
- size_t retry_delay;
- };
- /* NOTE about the ares_options struct to users and developers.
- This struct will remain looking like this. It will not be extended nor
- shrunk in future releases, but all new options will be set by ares_set_*()
- options instead of with the ares_init_options() function.
- Eventually (in a galaxy far far away), all options will be settable by
- ares_set_*() options and the ares_init_options() function will become
- deprecated.
- When new options are added to c-ares, they are not added to this
- struct. And they are not "saved" with the ares_save_options() function but
- instead we encourage the use of the ares_dup() function. Needless to say,
- if you add config options to c-ares you need to make sure ares_dup()
- duplicates this new option.
- */
- struct ares_options {
- int flags;
- int timeout; /* in seconds or milliseconds, depending on options */
- int tries;
- int ndots;
- unsigned short udp_port; /* host byte order */
- unsigned short tcp_port; /* host byte order */
- int socket_send_buffer_size;
- int socket_receive_buffer_size;
- struct in_addr *servers;
- int nservers;
- char **domains;
- int ndomains;
- char *lookups;
- ares_sock_state_cb sock_state_cb;
- void *sock_state_cb_data;
- struct apattern *sortlist;
- int nsort;
- int ednspsz;
- char *resolvconf_path;
- char *hosts_path;
- int udp_max_queries;
- int maxtimeout; /* in milliseconds */
- unsigned int qcache_max_ttl; /* Maximum TTL for query cache, 0=disabled */
- ares_evsys_t evsys;
- struct ares_server_failover_options server_failover_opts;
- };
- struct hostent;
- struct timeval;
- struct sockaddr;
- struct ares_channeldata;
- struct ares_addrinfo;
- struct ares_addrinfo_hints;
- /* Legacy typedef, don't use, you can't specify "const" */
- typedef struct ares_channeldata *ares_channel;
- /* Current main channel typedef */
- typedef struct ares_channeldata ares_channel_t;
- /*
- * NOTE: before c-ares 1.7.0 we would most often use the system in6_addr
- * struct below when ares itself was built, but many apps would use this
- * private version since the header checked a HAVE_* define for it. Starting
- * with 1.7.0 we always declare and use our own to stop relying on the
- * system's one.
- */
- struct ares_in6_addr {
- union {
- unsigned char _S6_u8[16];
- } _S6_un;
- };
- struct ares_addr {
- int family;
- union {
- struct in_addr addr4;
- struct ares_in6_addr addr6;
- } addr;
- };
- /* DNS record parser, writer, and helpers */
- #include "ares_dns_record.h"
- typedef void (*ares_callback)(void *arg, int status, int timeouts,
- unsigned char *abuf, int alen);
- typedef void (*ares_callback_dnsrec)(void *arg, ares_status_t status,
- size_t timeouts,
- const ares_dns_record_t *dnsrec);
- typedef void (*ares_host_callback)(void *arg, int status, int timeouts,
- struct hostent *hostent);
- typedef void (*ares_nameinfo_callback)(void *arg, int status, int timeouts,
- char *node, char *service);
- typedef int (*ares_sock_create_callback)(ares_socket_t socket_fd, int type,
- void *data);
- typedef int (*ares_sock_config_callback)(ares_socket_t socket_fd, int type,
- void *data);
- typedef void (*ares_addrinfo_callback)(void *arg, int status, int timeouts,
- struct ares_addrinfo *res);
- typedef void (*ares_server_state_callback)(const char *server_string,
- ares_bool_t success, int flags,
- void *data);
- CARES_EXTERN int ares_library_init(int flags);
- CARES_EXTERN int ares_library_init_mem(int flags, void *(*amalloc)(size_t size),
- void (*afree)(void *ptr),
- void *(*arealloc)(void *ptr,
- size_t size));
- #if defined(ANDROID) || defined(__ANDROID__)
- CARES_EXTERN void ares_library_init_jvm(JavaVM *jvm);
- CARES_EXTERN int ares_library_init_android(jobject connectivity_manager);
- CARES_EXTERN int ares_library_android_initialized(void);
- #endif
- CARES_EXTERN int ares_library_initialized(void);
- CARES_EXTERN void ares_library_cleanup(void);
- CARES_EXTERN const char *ares_version(int *version);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_init_options) int ares_init(
- ares_channel_t **channelptr);
- CARES_EXTERN int ares_init_options(ares_channel_t **channelptr,
- const struct ares_options *options,
- int optmask);
- CARES_EXTERN int ares_save_options(const ares_channel_t *channel,
- struct ares_options *options, int *optmask);
- CARES_EXTERN void ares_destroy_options(struct ares_options *options);
- CARES_EXTERN int ares_dup(ares_channel_t **dest, const ares_channel_t *src);
- CARES_EXTERN ares_status_t ares_reinit(ares_channel_t *channel);
- CARES_EXTERN void ares_destroy(ares_channel_t *channel);
- CARES_EXTERN void ares_cancel(ares_channel_t *channel);
- /* These next 3 configure local binding for the out-going socket
- * connection. Use these to specify source IP and/or network device
- * on multi-homed systems.
- */
- CARES_EXTERN void ares_set_local_ip4(ares_channel_t *channel,
- unsigned int local_ip);
- /* local_ip6 should be 16 bytes in length */
- CARES_EXTERN void ares_set_local_ip6(ares_channel_t *channel,
- const unsigned char *local_ip6);
- /* local_dev_name should be null terminated. */
- CARES_EXTERN void ares_set_local_dev(ares_channel_t *channel,
- const char *local_dev_name);
- CARES_EXTERN void ares_set_socket_callback(ares_channel_t *channel,
- ares_sock_create_callback callback,
- void *user_data);
- CARES_EXTERN void ares_set_socket_configure_callback(
- ares_channel_t *channel, ares_sock_config_callback callback, void *user_data);
- CARES_EXTERN void
- ares_set_server_state_callback(ares_channel_t *channel,
- ares_server_state_callback callback,
- void *user_data);
- CARES_EXTERN int ares_set_sortlist(ares_channel_t *channel,
- const char *sortstr);
- CARES_EXTERN void ares_getaddrinfo(ares_channel_t *channel, const char *node,
- const char *service,
- const struct ares_addrinfo_hints *hints,
- ares_addrinfo_callback callback, void *arg);
- CARES_EXTERN void ares_freeaddrinfo(struct ares_addrinfo *ai);
- /*
- * Virtual function set to have user-managed socket IO.
- * Note that all functions need to be defined, and when
- * set, the library will not do any bind nor set any
- * socket options, assuming the client handles these
- * through either socket creation or the
- * ares_sock_config_callback call.
- */
- struct iovec;
- struct ares_socket_functions {
- ares_socket_t (*asocket)(int, int, int, void *);
- int (*aclose)(ares_socket_t, void *);
- int (*aconnect)(ares_socket_t, const struct sockaddr *, ares_socklen_t,
- void *);
- ares_ssize_t (*arecvfrom)(ares_socket_t, void *, size_t, int,
- struct sockaddr *, ares_socklen_t *, void *);
- ares_ssize_t (*asendv)(ares_socket_t, const struct iovec *, int, void *);
- };
- CARES_EXTERN void
- ares_set_socket_functions(ares_channel_t *channel,
- const struct ares_socket_functions *funcs,
- void *user_data);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_send_dnsrec) void ares_send(
- ares_channel_t *channel, const unsigned char *qbuf, int qlen,
- ares_callback callback, void *arg);
- /*! Send a DNS query as an ares_dns_record_t with a callback containing the
- * parsed DNS record.
- *
- * \param[in] channel Pointer to channel on which queries will be sent.
- * \param[in] dnsrec DNS Record to send
- * \param[in] callback Callback function invoked on completion or failure of
- * the query sequence.
- * \param[in] arg Additional argument passed to the callback function.
- * \param[out] qid Query ID
- * \return One of the c-ares status codes.
- */
- CARES_EXTERN ares_status_t ares_send_dnsrec(ares_channel_t *channel,
- const ares_dns_record_t *dnsrec,
- ares_callback_dnsrec callback,
- void *arg, unsigned short *qid);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_query_dnsrec) void ares_query(
- ares_channel_t *channel, const char *name, int dnsclass, int type,
- ares_callback callback, void *arg);
- /*! Perform a DNS query with a callback containing the parsed DNS record.
- *
- * \param[in] channel Pointer to channel on which queries will be sent.
- * \param[in] name Query name
- * \param[in] dnsclass DNS Class
- * \param[in] type DNS Record Type
- * \param[in] callback Callback function invoked on completion or failure of
- * the query sequence.
- * \param[in] arg Additional argument passed to the callback function.
- * \param[out] qid Query ID
- * \return One of the c-ares status codes.
- */
- CARES_EXTERN ares_status_t ares_query_dnsrec(ares_channel_t *channel,
- const char *name,
- ares_dns_class_t dnsclass,
- ares_dns_rec_type_t type,
- ares_callback_dnsrec callback,
- void *arg, unsigned short *qid);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_search_dnsrec) void ares_search(
- ares_channel_t *channel, const char *name, int dnsclass, int type,
- ares_callback callback, void *arg);
- /*! Search for a complete DNS message.
- *
- * \param[in] channel Pointer to channel on which queries will be sent.
- * \param[in] dnsrec Pointer to initialized and filled DNS record object.
- * \param[in] callback Callback function invoked on completion or failure of
- * the query sequence.
- * \param[in] arg Additional argument passed to the callback function.
- * \return One of the c-ares status codes. In all cases, except
- * ARES_EFORMERR due to misuse, this error code will also be sent
- * to the provided callback.
- */
- CARES_EXTERN ares_status_t ares_search_dnsrec(ares_channel_t *channel,
- const ares_dns_record_t *dnsrec,
- ares_callback_dnsrec callback,
- void *arg);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_getaddrinfo) void ares_gethostbyname(
- ares_channel_t *channel, const char *name, int family,
- ares_host_callback callback, void *arg);
- CARES_EXTERN int ares_gethostbyname_file(ares_channel_t *channel,
- const char *name, int family,
- struct hostent **host);
- CARES_EXTERN void ares_gethostbyaddr(ares_channel_t *channel, const void *addr,
- int addrlen, int family,
- ares_host_callback callback, void *arg);
- CARES_EXTERN void ares_getnameinfo(ares_channel_t *channel,
- const struct sockaddr *sa,
- ares_socklen_t salen, int flags,
- ares_nameinfo_callback callback, void *arg);
- CARES_EXTERN CARES_DEPRECATED_FOR(
- ARES_OPT_EVENT_THREAD or
- ARES_OPT_SOCK_STATE_CB) int ares_fds(const ares_channel_t *channel,
- fd_set *read_fds, fd_set *write_fds);
- CARES_EXTERN CARES_DEPRECATED_FOR(
- ARES_OPT_EVENT_THREAD or
- ARES_OPT_SOCK_STATE_CB) int ares_getsock(const ares_channel_t *channel,
- ares_socket_t *socks, int numsocks);
- CARES_EXTERN struct timeval *ares_timeout(const ares_channel_t *channel,
- struct timeval *maxtv,
- struct timeval *tv);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_process_fd) void ares_process(
- ares_channel_t *channel, fd_set *read_fds, fd_set *write_fds);
- CARES_EXTERN void ares_process_fd(ares_channel_t *channel,
- ares_socket_t read_fd,
- ares_socket_t write_fd);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_record_create) int ares_create_query(
- const char *name, int dnsclass, int type, unsigned short id, int rd,
- unsigned char **buf, int *buflen, int max_udp_size);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_record_create) int ares_mkquery(
- const char *name, int dnsclass, int type, unsigned short id, int rd,
- unsigned char **buf, int *buflen);
- CARES_EXTERN int ares_expand_name(const unsigned char *encoded,
- const unsigned char *abuf, int alen, char **s,
- long *enclen);
- CARES_EXTERN int ares_expand_string(const unsigned char *encoded,
- const unsigned char *abuf, int alen,
- unsigned char **s, long *enclen);
- struct ares_addrttl {
- struct in_addr ipaddr;
- int ttl;
- };
- struct ares_addr6ttl {
- struct ares_in6_addr ip6addr;
- int ttl;
- };
- struct ares_caa_reply {
- struct ares_caa_reply *next;
- int critical;
- unsigned char *property;
- size_t plength; /* plength excludes null termination */
- unsigned char *value;
- size_t length; /* length excludes null termination */
- };
- struct ares_srv_reply {
- struct ares_srv_reply *next;
- char *host;
- unsigned short priority;
- unsigned short weight;
- unsigned short port;
- };
- struct ares_mx_reply {
- struct ares_mx_reply *next;
- char *host;
- unsigned short priority;
- };
- struct ares_txt_reply {
- struct ares_txt_reply *next;
- unsigned char *txt;
- size_t length; /* length excludes null termination */
- };
- /* NOTE: This structure is a superset of ares_txt_reply
- */
- struct ares_txt_ext {
- struct ares_txt_ext *next;
- unsigned char *txt;
- size_t length;
- /* 1 - if start of new record
- * 0 - if a chunk in the same record */
- unsigned char record_start;
- };
- struct ares_naptr_reply {
- struct ares_naptr_reply *next;
- unsigned char *flags;
- unsigned char *service;
- unsigned char *regexp;
- char *replacement;
- unsigned short order;
- unsigned short preference;
- };
- struct ares_soa_reply {
- char *nsname;
- char *hostmaster;
- unsigned int serial;
- unsigned int refresh;
- unsigned int retry;
- unsigned int expire;
- unsigned int minttl;
- };
- struct ares_uri_reply {
- struct ares_uri_reply *next;
- unsigned short priority;
- unsigned short weight;
- char *uri;
- int ttl;
- };
- /*
- * Similar to addrinfo, but with extra ttl and missing canonname.
- */
- struct ares_addrinfo_node {
- int ai_ttl;
- int ai_flags;
- int ai_family;
- int ai_socktype;
- int ai_protocol;
- ares_socklen_t ai_addrlen;
- struct sockaddr *ai_addr;
- struct ares_addrinfo_node *ai_next;
- };
- /*
- * alias - label of the resource record.
- * name - value (canonical name) of the resource record.
- * See RFC2181 10.1.1. CNAME terminology.
- */
- struct ares_addrinfo_cname {
- int ttl;
- char *alias;
- char *name;
- struct ares_addrinfo_cname *next;
- };
- struct ares_addrinfo {
- struct ares_addrinfo_cname *cnames;
- struct ares_addrinfo_node *nodes;
- char *name;
- };
- struct ares_addrinfo_hints {
- int ai_flags;
- int ai_family;
- int ai_socktype;
- int ai_protocol;
- };
- /*
- ** Parse the buffer, starting at *abuf and of length alen bytes, previously
- ** obtained from an ares_search call. Put the results in *host, if nonnull.
- ** Also, if addrttls is nonnull, put up to *naddrttls IPv4 addresses along with
- ** their TTLs in that array, and set *naddrttls to the number of addresses
- ** so written.
- */
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_parse) int ares_parse_a_reply(
- const unsigned char *abuf, int alen, struct hostent **host,
- struct ares_addrttl *addrttls, int *naddrttls);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_parse) int ares_parse_aaaa_reply(
- const unsigned char *abuf, int alen, struct hostent **host,
- struct ares_addr6ttl *addrttls, int *naddrttls);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_parse) int ares_parse_caa_reply(
- const unsigned char *abuf, int alen, struct ares_caa_reply **caa_out);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_parse) int ares_parse_ptr_reply(
- const unsigned char *abuf, int alen, const void *addr, int addrlen,
- int family, struct hostent **host);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_parse) int ares_parse_ns_reply(
- const unsigned char *abuf, int alen, struct hostent **host);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_parse) int ares_parse_srv_reply(
- const unsigned char *abuf, int alen, struct ares_srv_reply **srv_out);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_parse) int ares_parse_mx_reply(
- const unsigned char *abuf, int alen, struct ares_mx_reply **mx_out);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_parse) int ares_parse_txt_reply(
- const unsigned char *abuf, int alen, struct ares_txt_reply **txt_out);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_parse) int ares_parse_txt_reply_ext(
- const unsigned char *abuf, int alen, struct ares_txt_ext **txt_out);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_parse) int ares_parse_naptr_reply(
- const unsigned char *abuf, int alen, struct ares_naptr_reply **naptr_out);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_parse) int ares_parse_soa_reply(
- const unsigned char *abuf, int alen, struct ares_soa_reply **soa_out);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_dns_parse) int ares_parse_uri_reply(
- const unsigned char *abuf, int alen, struct ares_uri_reply **uri_out);
- CARES_EXTERN void ares_free_string(void *str);
- CARES_EXTERN void ares_free_hostent(struct hostent *host);
- CARES_EXTERN void ares_free_data(void *dataptr);
- CARES_EXTERN const char *ares_strerror(int code);
- struct ares_addr_node {
- struct ares_addr_node *next;
- int family;
- union {
- struct in_addr addr4;
- struct ares_in6_addr addr6;
- } addr;
- };
- struct ares_addr_port_node {
- struct ares_addr_port_node *next;
- int family;
- union {
- struct in_addr addr4;
- struct ares_in6_addr addr6;
- } addr;
- int udp_port;
- int tcp_port;
- };
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_set_servers_csv) int ares_set_servers(
- ares_channel_t *channel, const struct ares_addr_node *servers);
- CARES_EXTERN
- CARES_DEPRECATED_FOR(ares_set_servers_ports_csv)
- int ares_set_servers_ports(ares_channel_t *channel,
- const struct ares_addr_port_node *servers);
- /* Incoming string format: host[:port][,host[:port]]... */
- CARES_EXTERN int ares_set_servers_csv(ares_channel_t *channel,
- const char *servers);
- CARES_EXTERN int ares_set_servers_ports_csv(ares_channel_t *channel,
- const char *servers);
- CARES_EXTERN char *ares_get_servers_csv(const ares_channel_t *channel);
- CARES_EXTERN CARES_DEPRECATED_FOR(ares_get_servers_csv) int ares_get_servers(
- const ares_channel_t *channel, struct ares_addr_node **servers);
- CARES_EXTERN
- CARES_DEPRECATED_FOR(ares_get_servers_csv)
- int ares_get_servers_ports(const ares_channel_t *channel,
- struct ares_addr_port_node **servers);
- CARES_EXTERN const char *ares_inet_ntop(int af, const void *src, char *dst,
- ares_socklen_t size);
- CARES_EXTERN int ares_inet_pton(int af, const char *src, void *dst);
- /*! Whether or not the c-ares library was built with threadsafety
- *
- * \return ARES_TRUE if built with threadsafety, ARES_FALSE if not
- */
- CARES_EXTERN ares_bool_t ares_threadsafety(void);
- /*! Block until notified that there are no longer any queries in queue, or
- * the specified timeout has expired.
- *
- * \param[in] channel Initialized ares channel
- * \param[in] timeout_ms Number of milliseconds to wait for the queue to be
- * empty. -1 for Infinite.
- * \return ARES_ENOTIMP if not built with threading support, ARES_ETIMEOUT
- * if requested timeout expires, ARES_SUCCESS when queue is empty.
- */
- CARES_EXTERN ares_status_t ares_queue_wait_empty(ares_channel_t *channel,
- int timeout_ms);
- /*! Retrieve the total number of active queries pending answers from servers.
- * Some c-ares requests may spawn multiple queries, such as ares_getaddrinfo()
- * when using AF_UNSPEC, which will be reflected in this number.
- *
- * \param[in] channel Initialized ares channel
- * \return Number of active queries to servers
- */
- CARES_EXTERN size_t ares_queue_active_queries(const ares_channel_t *channel);
- #ifdef __cplusplus
- }
- #endif
- #endif /* ARES__H */
|