.TH "event2/dns.h" 3 "Tue Jan 31 2017" "libevent" \" -*- nroff -*- .ad l .nh .SH NAME event2/dns.h \- Welcome, gentle reader\&. .SH SYNOPSIS .br .PP \fC#include \fP .br \fC#include \fP .br .SS "Macros" .in +1c .ti -1c .RI "#define \fBDNS_ERR_CANCEL\fP 69" .br .RI "\fIThe request was canceled via a call to evdns_cancel_request\&. \fP" .ti -1c .RI "#define \fBDNS_ERR_FORMAT\fP 1" .br .RI "\fIThe name server was unable to interpret the query\&. \fP" .ti -1c .RI "#define \fBDNS_ERR_NODATA\fP 70" .br .RI "\fIThere were no answers and no error condition in the DNS packet\&. \fP" .ti -1c .RI "#define \fBDNS_ERR_NONE\fP 0" .br .RI "\fIError codes 0-5 are as described in RFC 1035\&. \fP" .ti -1c .RI "#define \fBDNS_ERR_NOTEXIST\fP 3" .br .RI "\fIThe domain name does not exist\&. \fP" .ti -1c .RI "#define \fBDNS_ERR_NOTIMPL\fP 4" .br .RI "\fIThe name server does not support the requested kind of query\&. \fP" .ti -1c .RI "#define \fBDNS_ERR_REFUSED\fP 5" .br .RI "\fIThe name server refuses to reform the specified operation for policy reasons\&. \fP" .ti -1c .RI "#define \fBDNS_ERR_SERVERFAILED\fP 2" .br .RI "\fIThe name server was unable to process this query due to a problem with the name server\&. \fP" .ti -1c .RI "#define \fBDNS_ERR_SHUTDOWN\fP 68" .br .RI "\fIThe request was canceled because the DNS subsystem was shut down\&. \fP" .ti -1c .RI "#define \fBDNS_ERR_TIMEOUT\fP 67" .br .RI "\fICommunication with the server timed out\&. \fP" .ti -1c .RI "#define \fBDNS_ERR_TRUNCATED\fP 65" .br .RI "\fIThe reply was truncated or ill-formatted\&. \fP" .ti -1c .RI "#define \fBDNS_ERR_UNKNOWN\fP 66" .br .RI "\fIAn unknown error occurred\&. \fP" .ti -1c .RI "#define \fBDNS_IPv4_A\fP 1" .br .ti -1c .RI "#define \fBDNS_IPv6_AAAA\fP 3" .br .ti -1c .RI "#define \fBDNS_NO_SEARCH\fP DNS_QUERY_NO_SEARCH" .br .ti -1c .RI "#define \fBDNS_OPTION_HOSTSFILE\fP 8" .br .ti -1c .RI "#define \fBDNS_OPTION_MISC\fP 4" .br .ti -1c .RI "#define \fBDNS_OPTION_NAMESERVERS\fP 2" .br .ti -1c .RI "#define \fBDNS_OPTION_SEARCH\fP 1" .br .ti -1c .RI "#define \fBDNS_OPTIONS_ALL\fP 15" .br .ti -1c .RI "#define \fBDNS_PTR\fP 2" .br .ti -1c .RI "#define \fBDNS_QUERY_NO_SEARCH\fP 1" .br .ti -1c .RI "#define \fBEVDNS_ADDITIONAL_SECTION\fP 2" .br .ti -1c .RI "#define \fBEVDNS_ANSWER_SECTION\fP 0" .br .ti -1c .RI "#define \fBEVDNS_AUTHORITY_SECTION\fP 1" .br .ti -1c .RI "#define \fBEVDNS_BASE_DISABLE_WHEN_INACTIVE\fP 0x8000" .br .RI "\fIFlag for evdns_base_new: Do not prevent the libevent event loop from exiting when we have no active dns requests\&. \fP" .ti -1c .RI "#define \fBEVDNS_BASE_INITIALIZE_NAMESERVERS\fP 1" .br .RI "\fIFlag for evdns_base_new: process resolv\&.conf\&. \fP" .ti -1c .RI "#define \fBEVDNS_CLASS_INET\fP 1" .br .ti -1c .RI "#define \fBEVDNS_FLAGS_AA\fP 0x400" .br .ti -1c .RI "#define \fBEVDNS_FLAGS_RD\fP 0x080" .br .ti -1c .RI "#define \fBEVDNS_QTYPE_ALL\fP 255" .br .ti -1c .RI "#define \fBEVDNS_QTYPE_AXFR\fP 252" .br .ti -1c .RI "#define \fBEVDNS_TYPE_A\fP 1" .br .ti -1c .RI "#define \fBEVDNS_TYPE_AAAA\fP 28" .br .ti -1c .RI "#define \fBEVDNS_TYPE_CNAME\fP 5" .br .ti -1c .RI "#define \fBEVDNS_TYPE_MX\fP 15" .br .ti -1c .RI "#define \fBEVDNS_TYPE_NS\fP 2" .br .ti -1c .RI "#define \fBEVDNS_TYPE_PTR\fP 12" .br .ti -1c .RI "#define \fBEVDNS_TYPE_SOA\fP 6" .br .ti -1c .RI "#define \fBEVDNS_TYPE_TXT\fP 16" .br .in -1c .SS "Typedefs" .in +1c .ti -1c .RI "typedef void(* \fBevdns_callback_type\fP) (int result, char type, int count, int ttl, void *addresses, void *arg)" .br .RI "\fIThe callback that contains the results from a lookup\&. \fP" .ti -1c .RI "typedef void(* \fBevdns_debug_log_fn_type\fP) (int is_warning, const char *msg)" .br .RI "\fIA callback that is invoked when a log message is generated\&. \fP" .ti -1c .RI "typedef void(* \fBevdns_getaddrinfo_cb\fP) (int result, struct \fBevutil_addrinfo\fP *res, void *arg)" .br .RI "\fICallback for evdns_getaddrinfo\&. \fP" .ti -1c .RI "typedef void(* \fBevdns_request_callback_fn_type\fP) (struct evdns_server_request *, void *)" .br .RI "\fIA callback to implement a DNS server\&. \fP" .in -1c .SS "Functions" .in +1c .ti -1c .RI "EVENT2_EXPORT_SYMBOL struct evdns_server_port * \fBevdns_add_server_port_with_base\fP (struct \fBevent_base\fP *base, \fBevutil_socket_t\fP socket, int flags, \fBevdns_request_callback_fn_type\fP callback, void *user_data)" .br .RI "\fICreate a new DNS server port\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL void \fBevdns_base_clear_host_addresses\fP (struct evdns_base *base)" .br .RI "\fIRemove all hosts entries that have been loaded into the \fBevent_base\fP via evdns_base_load_hosts or via event_base_resolv_conf_parse\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_base_clear_nameservers_and_suspend\fP (struct evdns_base *base)" .br .RI "\fIRemove all configured nameservers, and suspend all pending resolves\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_base_count_nameservers\fP (struct evdns_base *base)" .br .RI "\fIGet the number of configured nameservers\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL void \fBevdns_base_free\fP (struct evdns_base *base, int fail_requests)" .br .RI "\fIShut down the asynchronous DNS resolver and terminate all active requests\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_base_get_nameserver_addr\fP (struct evdns_base *base, int idx, struct sockaddr *sa, ev_socklen_t len)" .br .RI "\fIRetrieve the address of the 'idx'th configured nameserver\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_base_load_hosts\fP (struct evdns_base *base, const char *hosts_fname)" .br .RI "\fILoad an /etc/hosts-style file from 'hosts_fname' into 'base'\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_base_nameserver_add\fP (struct evdns_base *base, unsigned long int address)" .br .RI "\fIAdd a nameserver\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_base_nameserver_ip_add\fP (struct evdns_base *base, const char *ip_as_string)" .br .RI "\fIAdd a nameserver by string address\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_base_nameserver_sockaddr_add\fP (struct evdns_base *base, const struct sockaddr *sa, ev_socklen_t len, unsigned flags)" .br .RI "\fIAdd a nameserver by sockaddr\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL struct evdns_base * \fBevdns_base_new\fP (struct \fBevent_base\fP *\fBevent_base\fP, int initialize_nameservers)" .br .RI "\fIInitialize the asynchronous DNS library\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_base_resolv_conf_parse\fP (struct evdns_base *base, int flags, const char *const filename)" .br .RI "\fIParse a resolv\&.conf file\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL struct evdns_request * \fBevdns_base_resolve_ipv4\fP (struct evdns_base *base, const char *name, int flags, \fBevdns_callback_type\fP callback, void *ptr)" .br .RI "\fILookup an A record for a given name\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL struct evdns_request * \fBevdns_base_resolve_ipv6\fP (struct evdns_base *base, const char *name, int flags, \fBevdns_callback_type\fP callback, void *ptr)" .br .RI "\fILookup an AAAA record for a given name\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL struct evdns_request * \fBevdns_base_resolve_reverse\fP (struct evdns_base *base, const struct in_addr *in, int flags, \fBevdns_callback_type\fP callback, void *ptr)" .br .RI "\fILookup a PTR record for a given IP address\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL struct evdns_request * \fBevdns_base_resolve_reverse_ipv6\fP (struct evdns_base *base, const struct in6_addr *in, int flags, \fBevdns_callback_type\fP callback, void *ptr)" .br .RI "\fILookup a PTR record for a given IPv6 address\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_base_resume\fP (struct evdns_base *base)" .br .RI "\fIResume normal operation and continue any suspended resolve requests\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL void \fBevdns_base_search_add\fP (struct evdns_base *base, const char *domain)" .br .RI "\fIAdd a domain to the list of search domains\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL void \fBevdns_base_search_clear\fP (struct evdns_base *base)" .br .RI "\fIObtain nameserver information using the Windows API\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL void \fBevdns_base_search_ndots_set\fP (struct evdns_base *base, const int ndots)" .br .RI "\fISet the 'ndots' parameter for searches\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_base_set_option\fP (struct evdns_base *base, const char *option, const char *val)" .br .RI "\fISet the value of a configuration option\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL void \fBevdns_cancel_request\fP (struct evdns_base *base, struct evdns_request *req)" .br .RI "\fICancels a pending DNS resolution request\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL void \fBevdns_close_server_port\fP (struct evdns_server_port *port)" .br .RI "\fIClose down a DNS server port, and free associated structures\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL const char * \fBevdns_err_to_string\fP (int err)" .br .RI "\fIConvert a DNS error code to a string\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL struct evdns_getaddrinfo_request * \fBevdns_getaddrinfo\fP (struct evdns_base *dns_base, const char *nodename, const char *servname, const struct \fBevutil_addrinfo\fP *hints_in, \fBevdns_getaddrinfo_cb\fP cb, void *arg)" .br .RI "\fIMake a non-blocking getaddrinfo request using the dns_base in 'dns_base'\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL void \fBevdns_getaddrinfo_cancel\fP (struct evdns_getaddrinfo_request *req)" .br .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_server_request_add_a_reply\fP (struct evdns_server_request *req, const char *name, int n, const void *addrs, int ttl)" .br .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_server_request_add_aaaa_reply\fP (struct evdns_server_request *req, const char *name, int n, const void *addrs, int ttl)" .br .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_server_request_add_cname_reply\fP (struct evdns_server_request *req, const char *name, const char *cname, int ttl)" .br .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_server_request_add_ptr_reply\fP (struct evdns_server_request *req, struct in_addr *in, const char *inaddr_name, const char *hostname, int ttl)" .br .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_server_request_add_reply\fP (struct evdns_server_request *req, int section, const char *name, int type, int dns_class, int ttl, int datalen, int is_name, const char *data)" .br .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_server_request_drop\fP (struct evdns_server_request *req)" .br .RI "\fIFree a DNS request without sending back a reply\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_server_request_get_requesting_addr\fP (struct evdns_server_request *req, struct sockaddr *sa, int addr_len)" .br .RI "\fIGet the address that made a DNS request\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL int \fBevdns_server_request_respond\fP (struct evdns_server_request *req, int err)" .br .RI "\fISend back a response to a DNS request, and free the request structure\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL void \fBevdns_server_request_set_flags\fP (struct evdns_server_request *req, int flags)" .br .RI "\fISets some flags in a reply we're building\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL void \fBevdns_set_log_fn\fP (\fBevdns_debug_log_fn_type\fP fn)" .br .RI "\fISet the callback function to handle DNS log messages\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL void \fBevdns_set_random_bytes_fn\fP (void(*fn)(char *, size_t))" .br .RI "\fISet a callback used to generate random bytes\&. \fP" .ti -1c .RI "EVENT2_EXPORT_SYMBOL void \fBevdns_set_transaction_id_fn\fP (ev_uint16_t(*fn)(void))" .br .RI "\fISet a callback that will be invoked to generate transaction IDs\&. \fP" .in -1c .SH "Detailed Description" .PP Welcome, gentle reader\&. Async DNS lookups are really a whole lot harder than they should be, mostly stemming from the fact that the libc resolver has never been very good at them\&. Before you use this library you should see if libc can do the job for you with the modern async call getaddrinfo_a (see http://www.imperialviolet.org/page25.html#e498)\&. Otherwise, please continue\&. .PP The library keeps track of the state of nameservers and will avoid them when they go down\&. Otherwise it will round robin between them\&. .PP Quick start guide: #include 'evdns\&.h' void callback(int result, char type, int count, int ttl, void *addresses, void *arg); evdns_resolv_conf_parse(DNS_OPTIONS_ALL, '/etc/resolv\&.conf'); evdns_resolve('www\&.hostname\&.com', 0, callback, NULL); .PP When the lookup is complete the callback function is called\&. The first argument will be one of the DNS_ERR_* defines in evdns\&.h\&. Hopefully it will be DNS_ERR_NONE, in which case type will be DNS_IPv4_A, count will be the number of IP addresses, ttl is the time which the data can be cached for (in seconds), addresses will point to an array of uint32_t's and arg will be whatever you passed to evdns_resolve\&. .PP Searching: .PP In order for this library to be a good replacement for glibc's resolver it supports searching\&. This involves setting a list of default domains, in which names will be queried for\&. The number of dots in the query name determines the order in which this list is used\&. .PP Searching appears to be a single lookup from the point of view of the API, although many DNS queries may be generated from a single call to evdns_resolve\&. Searching can also drastically slow down the resolution of names\&. .PP To disable searching: .IP "1." 4 Never set it up\&. If you never call evdns_resolv_conf_parse or evdns_search_add then no searching will occur\&. .IP "2." 4 If you do call evdns_resolv_conf_parse then don't pass DNS_OPTION_SEARCH (or DNS_OPTIONS_ALL, which implies it)\&. .IP "3." 4 When calling evdns_resolve, pass the DNS_QUERY_NO_SEARCH flag\&. .PP .PP The order of searches depends on the number of dots in the name\&. If the number is greater than the ndots setting then the names is first tried globally\&. Otherwise each search domain is appended in turn\&. .PP The ndots setting can either be set from a resolv\&.conf, or by calling evdns_search_ndots_set\&. .PP For example, with ndots set to 1 (the default) and a search domain list of ['myhome\&.net']: Query: www Order: www\&.myhome\&.net, www\&. .PP Query: www\&.abc Order: www\&.abc\&., www\&.abc\&.myhome\&.net .PP Internals: .PP Requests are kept in two queues\&. The first is the inflight queue\&. In this queue requests have an allocated transaction id and nameserver\&. They will soon be transmitted if they haven't already been\&. .PP The second is the waiting queue\&. The size of the inflight ring is limited and all other requests wait in waiting queue for space\&. This bounds the number of concurrent requests so that we don't flood the nameserver\&. Several algorithms require a full walk of the inflight queue and so bounding its size keeps thing going nicely under huge (many thousands of requests) loads\&. .PP If a nameserver loses too many requests it is considered down and we try not to use it\&. After a while we send a probe to that nameserver (a lookup for google\&.com) and, if it replies, we consider it working again\&. If the nameserver fails a probe we wait longer to try again with the next probe\&. .SH "Macro Definition Documentation" .PP .SS "#define DNS_ERR_NODATA 70" .PP There were no answers and no error condition in the DNS packet\&. This can happen when you ask for an address that exists, but a record type that doesn't\&. .SS "#define DNS_ERR_NONE 0" .PP Error codes 0-5 are as described in RFC 1035\&. .SS "#define DNS_ERR_SHUTDOWN 68" .PP The request was canceled because the DNS subsystem was shut down\&. .SS "#define EVDNS_BASE_DISABLE_WHEN_INACTIVE 0x8000" .PP Flag for evdns_base_new: Do not prevent the libevent event loop from exiting when we have no active dns requests\&. .SS "#define EVDNS_BASE_INITIALIZE_NAMESERVERS 1" .PP Flag for evdns_base_new: process resolv\&.conf\&. .SH "Typedef Documentation" .PP .SS "typedef void(* evdns_callback_type) (int result, char type, int count, int ttl, void *addresses, void *arg)" .PP The callback that contains the results from a lookup\&. .IP "\(bu" 2 result is one of the DNS_ERR_* values (DNS_ERR_NONE for success) .IP "\(bu" 2 type is either DNS_IPv4_A or DNS_PTR or DNS_IPv6_AAAA .IP "\(bu" 2 count contains the number of addresses of form type .IP "\(bu" 2 ttl is the number of seconds the resolution may be cached for\&. .IP "\(bu" 2 addresses needs to be cast according to type\&. It will be an array of 4-byte sequences for ipv4, or an array of 16-byte sequences for ipv6, or a nul-terminated string for PTR\&. .PP .SS "typedef void(* evdns_debug_log_fn_type) (int is_warning, const char *msg)" .PP A callback that is invoked when a log message is generated\&. .PP \fBParameters:\fP .RS 4 \fIis_warning\fP indicates if the log message is a 'warning' .br \fImsg\fP the content of the log message .RE .PP .SS "typedef void(* evdns_getaddrinfo_cb) (int result, struct \fBevutil_addrinfo\fP *res, void *arg)" .PP Callback for evdns_getaddrinfo\&. .SS "typedef void(* evdns_request_callback_fn_type) (struct evdns_server_request *, void *)" .PP A callback to implement a DNS server\&. The callback function receives a DNS request\&. It should then optionally add a number of answers to the reply using the evdns_server_request_add_*_reply functions, before calling either evdns_server_request_respond to send the reply back, or evdns_server_request_drop to decline to answer the request\&. .PP \fBParameters:\fP .RS 4 \fIreq\fP A newly received request .br \fIuser_data\fP A pointer that was passed to \fBevdns_add_server_port_with_base()\fP\&. .RE .PP .SH "Function Documentation" .PP .SS "EVENT2_EXPORT_SYMBOL struct evdns_server_port* evdns_add_server_port_with_base (struct \fBevent_base\fP * base, \fBevutil_socket_t\fP socket, int flags, \fBevdns_request_callback_fn_type\fP callback, void * user_data)" .PP Create a new DNS server port\&. .PP \fBParameters:\fP .RS 4 \fIbase\fP The event base to handle events for the server port\&. .br \fIsocket\fP A UDP socket to accept DNS requests\&. .br \fIflags\fP Always 0 for now\&. .br \fIcallback\fP A function to invoke whenever we get a DNS request on the socket\&. .br \fIuser_data\fP Data to pass to the callback\&. .RE .PP \fBReturns:\fP .RS 4 an evdns_server_port structure for this server port\&. .RE .PP .SS "EVENT2_EXPORT_SYMBOL void evdns_base_clear_host_addresses (struct evdns_base * base)" .PP Remove all hosts entries that have been loaded into the \fBevent_base\fP via evdns_base_load_hosts or via event_base_resolv_conf_parse\&. .PP \fBParameters:\fP .RS 4 \fIevdns_base\fP the evdns base to remove outdated host addresses from .RE .PP .SS "EVENT2_EXPORT_SYMBOL int evdns_base_clear_nameservers_and_suspend (struct evdns_base * base)" .PP Remove all configured nameservers, and suspend all pending resolves\&. Resolves will not necessarily be re-attempted until \fBevdns_base_resume()\fP is called\&. .PP \fBParameters:\fP .RS 4 \fIbase\fP the evdns_base to which to apply this operation .RE .PP \fBReturns:\fP .RS 4 0 if successful, or -1 if an error occurred .RE .PP \fBSee also:\fP .RS 4 \fBevdns_base_resume()\fP .RE .PP .SS "EVENT2_EXPORT_SYMBOL int evdns_base_count_nameservers (struct evdns_base * base)" .PP Get the number of configured nameservers\&. This returns the number of configured nameservers (not necessarily the number of running nameservers)\&. This is useful for double-checking whether our calls to the various nameserver configuration functions have been successful\&. .PP \fBParameters:\fP .RS 4 \fIbase\fP the evdns_base to which to apply this operation .RE .PP \fBReturns:\fP .RS 4 the number of configured nameservers .RE .PP \fBSee also:\fP .RS 4 \fBevdns_base_nameserver_add()\fP .RE .PP .SS "EVENT2_EXPORT_SYMBOL void evdns_base_free (struct evdns_base * base, int fail_requests)" .PP Shut down the asynchronous DNS resolver and terminate all active requests\&. If the 'fail_requests' option is enabled, all active requests will return an empty result with the error flag set to DNS_ERR_SHUTDOWN\&. Otherwise, the requests will be silently discarded\&. .PP \fBParameters:\fP .RS 4 \fIevdns_base\fP the evdns base to free .br \fIfail_requests\fP if zero, active requests will be aborted; if non-zero, active requests will return DNS_ERR_SHUTDOWN\&. .RE .PP \fBSee also:\fP .RS 4 \fBevdns_base_new()\fP .RE .PP .SS "EVENT2_EXPORT_SYMBOL int evdns_base_get_nameserver_addr (struct evdns_base * base, int idx, struct sockaddr * sa, ev_socklen_t len)" .PP Retrieve the address of the 'idx'th configured nameserver\&. .PP \fBParameters:\fP .RS 4 \fIbase\fP The evdns_base to examine\&. .br \fIidx\fP The index of the nameserver to get the address of\&. .br \fIsa\fP A location to receive the server's address\&. .br \fIlen\fP The number of bytes available at sa\&. .RE .PP \fBReturns:\fP .RS 4 the number of bytes written into sa on success\&. On failure, returns -1 if idx is greater than the number of configured nameservers, or a value greater than 'len' if len was not high enough\&. .RE .PP .SS "EVENT2_EXPORT_SYMBOL int evdns_base_load_hosts (struct evdns_base * base, const char * hosts_fname)" .PP Load an /etc/hosts-style file from 'hosts_fname' into 'base'\&. If hosts_fname is NULL, add minimal entries for localhost, and nothing else\&. .PP Note that only evdns_getaddrinfo uses the /etc/hosts entries\&. .PP This function does not replace previously loaded hosts entries; to do that, call evdns_base_clear_host_addresses first\&. .PP Return 0 on success, negative on failure\&. .SS "EVENT2_EXPORT_SYMBOL int evdns_base_nameserver_add (struct evdns_base * base, unsigned long int address)" .PP Add a nameserver\&. The address should be an IPv4 address in network byte order\&. The type of address is chosen so that it matches in_addr\&.s_addr\&. .PP \fBParameters:\fP .RS 4 \fIbase\fP the evdns_base to which to add the name server .br \fIaddress\fP an IP address in network byte order .RE .PP \fBReturns:\fP .RS 4 0 if successful, or -1 if an error occurred .RE .PP \fBSee also:\fP .RS 4 \fBevdns_base_nameserver_ip_add()\fP .RE .PP .SS "EVENT2_EXPORT_SYMBOL int evdns_base_nameserver_ip_add (struct evdns_base * base, const char * ip_as_string)" .PP Add a nameserver by string address\&. This function parses a n IPv4 or IPv6 address from a string and adds it as a nameserver\&. It supports the following formats: .IP "\(bu" 2 [IPv6Address]:port .IP "\(bu" 2 [IPv6Address] .IP "\(bu" 2 IPv6Address .IP "\(bu" 2 IPv4Address:port .IP "\(bu" 2 IPv4Address .PP .PP If no port is specified, it defaults to 53\&. .PP \fBParameters:\fP .RS 4 \fIbase\fP the evdns_base to which to apply this operation .RE .PP \fBReturns:\fP .RS 4 0 if successful, or -1 if an error occurred .RE .PP \fBSee also:\fP .RS 4 \fBevdns_base_nameserver_add()\fP .RE .PP .SS "EVENT2_EXPORT_SYMBOL struct evdns_base* evdns_base_new (struct \fBevent_base\fP * event_base, int initialize_nameservers)" .PP Initialize the asynchronous DNS library\&. This function initializes support for non-blocking name resolution by calling \fBevdns_resolv_conf_parse()\fP on UNIX and evdns_config_windows_nameservers() on Windows\&. .PP \fBParameters:\fP .RS 4 \fI\fBevent_base\fP\fP the event base to associate the dns client with .br \fIflags\fP any of EVDNS_BASE_INITIALIZE_NAMESERVERS| EVDNS_BASE_DISABLE_WHEN_INACTIVE .RE .PP \fBReturns:\fP .RS 4 evdns_base object if successful, or NULL if an error occurred\&. .RE .PP \fBSee also:\fP .RS 4 \fBevdns_base_free()\fP .RE .PP .SS "EVENT2_EXPORT_SYMBOL int evdns_base_resolv_conf_parse (struct evdns_base * base, int flags, const char *const filename)" .PP Parse a resolv\&.conf file\&. The 'flags' parameter determines what information is parsed from the resolv\&.conf file\&. See the man page for resolv\&.conf for the format of this file\&. .PP The following directives are not parsed from the file: sortlist, rotate, no-check-names, inet6, debug\&. .PP If this function encounters an error, the possible return values are: 1 = failed to open file, 2 = failed to stat file, 3 = file too large, 4 = out of memory, 5 = short read from file, 6 = no nameservers listed in the file .PP \fBParameters:\fP .RS 4 \fIbase\fP the evdns_base to which to apply this operation .br \fIflags\fP any of DNS_OPTION_NAMESERVERS|DNS_OPTION_SEARCH|DNS_OPTION_MISC| DNS_OPTION_HOSTSFILE|DNS_OPTIONS_ALL .br \fIfilename\fP the path to the resolv\&.conf file .RE .PP \fBReturns:\fP .RS 4 0 if successful, or various positive error codes if an error occurred (see above) .RE .PP \fBSee also:\fP .RS 4 resolv\&.conf(3), evdns_config_windows_nameservers() .RE .PP .SS "EVENT2_EXPORT_SYMBOL struct evdns_request* evdns_base_resolve_ipv4 (struct evdns_base * base, const char * name, int flags, \fBevdns_callback_type\fP callback, void * ptr)" .PP Lookup an A record for a given name\&. .PP \fBParameters:\fP .RS 4 \fIbase\fP the evdns_base to which to apply this operation .br \fIname\fP a DNS hostname .br \fIflags\fP either 0, or DNS_QUERY_NO_SEARCH to disable searching for this query\&. .br \fIcallback\fP a callback function to invoke when the request is completed .br \fIptr\fP an argument to pass to the callback function .RE .PP \fBReturns:\fP .RS 4 an evdns_request object if successful, or NULL if an error occurred\&. .RE .PP \fBSee also:\fP .RS 4 \fBevdns_resolve_ipv6()\fP, \fBevdns_resolve_reverse()\fP, \fBevdns_resolve_reverse_ipv6()\fP, \fBevdns_cancel_request()\fP .RE .PP .SS "EVENT2_EXPORT_SYMBOL struct evdns_request* evdns_base_resolve_ipv6 (struct evdns_base * base, const char * name, int flags, \fBevdns_callback_type\fP callback, void * ptr)" .PP Lookup an AAAA record for a given name\&. .PP \fBParameters:\fP .RS 4 \fIbase\fP the evdns_base to which to apply this operation .br \fIname\fP a DNS hostname .br \fIflags\fP either 0, or DNS_QUERY_NO_SEARCH to disable searching for this query\&. .br \fIcallback\fP a callback function to invoke when the request is completed .br \fIptr\fP an argument to pass to the callback function .RE .PP \fBReturns:\fP .RS 4 an evdns_request object if successful, or NULL if an error occurred\&. .RE .PP \fBSee also:\fP .RS 4 \fBevdns_resolve_ipv4()\fP, \fBevdns_resolve_reverse()\fP, \fBevdns_resolve_reverse_ipv6()\fP, \fBevdns_cancel_request()\fP .RE .PP .SS "EVENT2_EXPORT_SYMBOL struct evdns_request* evdns_base_resolve_reverse (struct evdns_base * base, const struct in_addr * in, int flags, \fBevdns_callback_type\fP callback, void * ptr)" .PP Lookup a PTR record for a given IP address\&. .PP \fBParameters:\fP .RS 4 \fIbase\fP the evdns_base to which to apply this operation .br \fIin\fP an IPv4 address .br \fIflags\fP either 0, or DNS_QUERY_NO_SEARCH to disable searching for this query\&. .br \fIcallback\fP a callback function to invoke when the request is completed .br \fIptr\fP an argument to pass to the callback function .RE .PP \fBReturns:\fP .RS 4 an evdns_request object if successful, or NULL if an error occurred\&. .RE .PP \fBSee also:\fP .RS 4 \fBevdns_resolve_reverse_ipv6()\fP, \fBevdns_cancel_request()\fP .RE .PP .SS "EVENT2_EXPORT_SYMBOL struct evdns_request* evdns_base_resolve_reverse_ipv6 (struct evdns_base * base, const struct in6_addr * in, int flags, \fBevdns_callback_type\fP callback, void * ptr)" .PP Lookup a PTR record for a given IPv6 address\&. .PP \fBParameters:\fP .RS 4 \fIbase\fP the evdns_base to which to apply this operation .br \fIin\fP an IPv6 address .br \fIflags\fP either 0, or DNS_QUERY_NO_SEARCH to disable searching for this query\&. .br \fIcallback\fP a callback function to invoke when the request is completed .br \fIptr\fP an argument to pass to the callback function .RE .PP \fBReturns:\fP .RS 4 an evdns_request object if successful, or NULL if an error occurred\&. .RE .PP \fBSee also:\fP .RS 4 \fBevdns_resolve_reverse_ipv6()\fP, \fBevdns_cancel_request()\fP .RE .PP .SS "EVENT2_EXPORT_SYMBOL int evdns_base_resume (struct evdns_base * base)" .PP Resume normal operation and continue any suspended resolve requests\&. Re-attempt resolves left in limbo after an earlier call to \fBevdns_base_clear_nameservers_and_suspend()\fP\&. .PP \fBParameters:\fP .RS 4 \fIbase\fP the evdns_base to which to apply this operation .RE .PP \fBReturns:\fP .RS 4 0 if successful, or -1 if an error occurred .RE .PP \fBSee also:\fP .RS 4 \fBevdns_base_clear_nameservers_and_suspend()\fP .RE .PP .SS "EVENT2_EXPORT_SYMBOL void evdns_base_search_add (struct evdns_base * base, const char * domain)" .PP Add a domain to the list of search domains\&. .PP \fBParameters:\fP .RS 4 \fIdomain\fP the domain to be added to the search list .RE .PP .SS "EVENT2_EXPORT_SYMBOL void evdns_base_search_clear (struct evdns_base * base)" .PP Obtain nameserver information using the Windows API\&. Attempt to configure a set of nameservers based on platform settings on a win32 host\&. Preferentially tries to use GetNetworkParams; if that fails, looks in the registry\&. .PP \fBReturns:\fP .RS 4 0 if successful, or -1 if an error occurred .RE .PP \fBSee also:\fP .RS 4 \fBevdns_resolv_conf_parse()\fP Clear the list of search domains\&. .RE .PP .SS "EVENT2_EXPORT_SYMBOL void evdns_base_search_ndots_set (struct evdns_base * base, const int ndots)" .PP Set the 'ndots' parameter for searches\&. Sets the number of dots which, when found in a name, causes the first query to be without any search domain\&. .PP \fBParameters:\fP .RS 4 \fIndots\fP the new ndots parameter .RE .PP .SS "EVENT2_EXPORT_SYMBOL int evdns_base_set_option (struct evdns_base * base, const char * option, const char * val)" .PP Set the value of a configuration option\&. The currently available configuration options are: .PP ndots, timeout, max-timeouts, max-inflight, attempts, randomize-case, bind-to, initial-probe-timeout, getaddrinfo-allow-skew\&. .PP In versions before Libevent 2\&.0\&.3-alpha, the option name needed to end with a colon\&. .PP \fBParameters:\fP .RS 4 \fIbase\fP the evdns_base to which to apply this operation .br \fIoption\fP the name of the configuration option to be modified .br \fIval\fP the value to be set .RE .PP \fBReturns:\fP .RS 4 0 if successful, or -1 if an error occurred .RE .PP .SS "EVENT2_EXPORT_SYMBOL void evdns_cancel_request (struct evdns_base * base, struct evdns_request * req)" .PP Cancels a pending DNS resolution request\&. .PP \fBParameters:\fP .RS 4 \fIbase\fP the evdns_base that was used to make the request .br \fIreq\fP the evdns_request that was returned by calling a resolve function .RE .PP \fBSee also:\fP .RS 4 \fBevdns_base_resolve_ipv4()\fP, \fBevdns_base_resolve_ipv6\fP, \fBevdns_base_resolve_reverse\fP .RE .PP .SS "EVENT2_EXPORT_SYMBOL void evdns_close_server_port (struct evdns_server_port * port)" .PP Close down a DNS server port, and free associated structures\&. .SS "EVENT2_EXPORT_SYMBOL const char* evdns_err_to_string (int err)" .PP Convert a DNS error code to a string\&. .PP \fBParameters:\fP .RS 4 \fIerr\fP the DNS error code .RE .PP \fBReturns:\fP .RS 4 a string containing an explanation of the error code .RE .PP .SS "EVENT2_EXPORT_SYMBOL struct evdns_getaddrinfo_request* evdns_getaddrinfo (struct evdns_base * dns_base, const char * nodename, const char * servname, const struct \fBevutil_addrinfo\fP * hints_in, \fBevdns_getaddrinfo_cb\fP cb, void * arg)" .PP Make a non-blocking getaddrinfo request using the dns_base in 'dns_base'\&. If we can answer the request immediately (with an error or not!), then we invoke cb immediately and return NULL\&. Otherwise we return an evdns_getaddrinfo_request and invoke cb later\&. .PP When the callback is invoked, we pass as its first argument the error code that getaddrinfo would return (or 0 for no error)\&. As its second argument, we pass the \fBevutil_addrinfo\fP structures we found (or NULL on error)\&. We pass 'arg' as the third argument\&. .PP Limitations: .PP .IP "\(bu" 2 The AI_V4MAPPED and AI_ALL flags are not currently implemented\&. .IP "\(bu" 2 For ai_socktype, we only handle SOCKTYPE_STREAM, SOCKTYPE_UDP, and 0\&. .IP "\(bu" 2 For ai_protocol, we only handle IPPROTO_TCP, IPPROTO_UDP, and 0\&. .PP .SS "EVENT2_EXPORT_SYMBOL void evdns_server_request_set_flags (struct evdns_server_request * req, int flags)" .PP Sets some flags in a reply we're building\&. Allows setting of the AA or RD flags .SS "EVENT2_EXPORT_SYMBOL void evdns_set_log_fn (\fBevdns_debug_log_fn_type\fP fn)" .PP Set the callback function to handle DNS log messages\&. If this callback is not set, evdns log messages are handled with the regular Libevent logging system\&. .PP \fBParameters:\fP .RS 4 \fIfn\fP the callback to be invoked when a log message is generated .RE .PP .SS "EVENT2_EXPORT_SYMBOL void evdns_set_random_bytes_fn (void(*)(char *, size_t) fn)" .PP Set a callback used to generate random bytes\&. By default, we use the same function as passed to evdns_set_transaction_id_fn to generate bytes two at a time\&. If a function is provided here, it's also used to generate transaction IDs\&. .PP NOTE: This function has no effect in Libevent 2\&.0\&.4-alpha and later, since Libevent now provides its own secure RNG\&. .SS "EVENT2_EXPORT_SYMBOL void evdns_set_transaction_id_fn (ev_uint16_t(*)(void) fn)" .PP Set a callback that will be invoked to generate transaction IDs\&. By default, we pick transaction IDs based on the current clock time, which is bad for security\&. .PP \fBParameters:\fP .RS 4 \fIfn\fP the new callback, or NULL to use the default\&. .RE .PP NOTE: This function has no effect in Libevent 2\&.0\&.4-alpha and later, since Libevent now provides its own secure RNG\&. .SH "Author" .PP Generated automatically by Doxygen for libevent from the source code\&.