1 /*
2  * Copyright (c) 2006-2007 Niels Provos <provos@citi.umich.edu>
3  * Copyright (c) 2007-2012 Niels Provos and Nick Mathewson
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  * 3. The name of the author may not be used to endorse or promote products
14  *    derived from this software without specific prior written permission.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26  */
27 #ifndef _EVENT2_DNS_COMPAT_H_
28 #define _EVENT2_DNS_COMPAT_H_
29 
30 /** @file event2/dns_compat.h
31 
32   Potentially non-threadsafe versions of the functions in dns.h: provided
33   only for backwards compatibility.
34 
35 
36  */
37 
38 #ifdef __cplusplus
39 extern "C" {
40 #endif
41 
42 #include <event2/event-config.h>
43 #ifdef _EVENT_HAVE_SYS_TYPES_H
44 #include <sys/types.h>
45 #endif
46 #ifdef _EVENT_HAVE_SYS_TIME_H
47 #include <sys/time.h>
48 #endif
49 
50 /* For int types. */
51 #include <event2/util.h>
52 
53 /**
54   Initialize the asynchronous DNS library.
55 
56   This function initializes support for non-blocking name resolution by
57   calling evdns_resolv_conf_parse() on UNIX and
58   evdns_config_windows_nameservers() on Windows.
59 
60   @deprecated This function is deprecated because it always uses the current
61     event base, and is easily confused by multiple calls to event_init(), and
62     so is not safe for multithreaded use.  Additionally, it allocates a global
63     structure that only one thread can use. The replacement is
64     evdns_base_new().
65 
66   @return 0 if successful, or -1 if an error occurred
67   @see evdns_shutdown()
68  */
69 int evdns_init(void);
70 
71 struct evdns_base;
72 /**
73    Return the global evdns_base created by event_init() and used by the other
74    deprecated functions.
75 
76    @deprecated This function is deprecated because use of the global
77      evdns_base is error-prone.
78  */
79 struct evdns_base *evdns_get_global_base(void);
80 
81 /**
82   Shut down the asynchronous DNS resolver and terminate all active requests.
83 
84   If the 'fail_requests' option is enabled, all active requests will return
85   an empty result with the error flag set to DNS_ERR_SHUTDOWN. Otherwise,
86   the requests will be silently discarded.
87 
88   @deprecated This function is deprecated because it does not allow the
89     caller to specify which evdns_base it applies to.  The recommended
90     function is evdns_base_shutdown().
91 
92   @param fail_requests if zero, active requests will be aborted; if non-zero,
93 		active requests will return DNS_ERR_SHUTDOWN.
94   @see evdns_init()
95  */
96 void evdns_shutdown(int fail_requests);
97 
98 /**
99   Add a nameserver.
100 
101   The address should be an IPv4 address in network byte order.
102   The type of address is chosen so that it matches in_addr.s_addr.
103 
104   @deprecated This function is deprecated because it does not allow the
105     caller to specify which evdns_base it applies to.  The recommended
106     function is evdns_base_nameserver_add().
107 
108   @param address an IP address in network byte order
109   @return 0 if successful, or -1 if an error occurred
110   @see evdns_nameserver_ip_add()
111  */
112 int evdns_nameserver_add(unsigned long int address);
113 
114 /**
115   Get the number of configured nameservers.
116 
117   This returns the number of configured nameservers (not necessarily the
118   number of running nameservers).  This is useful for double-checking
119   whether our calls to the various nameserver configuration functions
120   have been successful.
121 
122   @deprecated This function is deprecated because it does not allow the
123     caller to specify which evdns_base it applies to.  The recommended
124     function is evdns_base_count_nameservers().
125 
126   @return the number of configured nameservers
127   @see evdns_nameserver_add()
128  */
129 int evdns_count_nameservers(void);
130 
131 /**
132   Remove all configured nameservers, and suspend all pending resolves.
133 
134   Resolves will not necessarily be re-attempted until evdns_resume() is called.
135 
136   @deprecated This function is deprecated because it does not allow the
137     caller to specify which evdns_base it applies to.  The recommended
138     function is evdns_base_clear_nameservers_and_suspend().
139 
140   @return 0 if successful, or -1 if an error occurred
141   @see evdns_resume()
142  */
143 int evdns_clear_nameservers_and_suspend(void);
144 
145 /**
146   Resume normal operation and continue any suspended resolve requests.
147 
148   Re-attempt resolves left in limbo after an earlier call to
149   evdns_clear_nameservers_and_suspend().
150 
151   @deprecated This function is deprecated because it does not allow the
152     caller to specify which evdns_base it applies to.  The recommended
153     function is evdns_base_resume().
154 
155   @return 0 if successful, or -1 if an error occurred
156   @see evdns_clear_nameservers_and_suspend()
157  */
158 int evdns_resume(void);
159 
160 /**
161   Add a nameserver.
162 
163   This wraps the evdns_nameserver_add() function by parsing a string as an IP
164   address and adds it as a nameserver.
165 
166   @deprecated This function is deprecated because it does not allow the
167     caller to specify which evdns_base it applies to.  The recommended
168     function is evdns_base_nameserver_ip_add().
169 
170   @return 0 if successful, or -1 if an error occurred
171   @see evdns_nameserver_add()
172  */
173 int evdns_nameserver_ip_add(const char *ip_as_string);
174 
175 /**
176   Lookup an A record for a given name.
177 
178   @deprecated This function is deprecated because it does not allow the
179     caller to specify which evdns_base it applies to.  The recommended
180     function is evdns_base_resolve_ipv4().
181 
182   @param name a DNS hostname
183   @param flags either 0, or DNS_QUERY_NO_SEARCH to disable searching for this query.
184   @param callback a callback function to invoke when the request is completed
185   @param ptr an argument to pass to the callback function
186   @return 0 if successful, or -1 if an error occurred
187   @see evdns_resolve_ipv6(), evdns_resolve_reverse(), evdns_resolve_reverse_ipv6()
188  */
189 int evdns_resolve_ipv4(const char *name, int flags, evdns_callback_type callback, void *ptr);
190 
191 /**
192   Lookup an AAAA record for a given name.
193 
194   @param name a DNS hostname
195   @param flags either 0, or DNS_QUERY_NO_SEARCH to disable searching for this query.
196   @param callback a callback function to invoke when the request is completed
197   @param ptr an argument to pass to the callback function
198   @return 0 if successful, or -1 if an error occurred
199   @see evdns_resolve_ipv4(), evdns_resolve_reverse(), evdns_resolve_reverse_ipv6()
200  */
201 int evdns_resolve_ipv6(const char *name, int flags, evdns_callback_type callback, void *ptr);
202 
203 struct in_addr;
204 struct in6_addr;
205 
206 /**
207   Lookup a PTR record for a given IP address.
208 
209   @deprecated This function is deprecated because it does not allow the
210     caller to specify which evdns_base it applies to.  The recommended
211     function is evdns_base_resolve_reverse().
212 
213   @param in an IPv4 address
214   @param flags either 0, or DNS_QUERY_NO_SEARCH to disable searching for this query.
215   @param callback a callback function to invoke when the request is completed
216   @param ptr an argument to pass to the callback function
217   @return 0 if successful, or -1 if an error occurred
218   @see evdns_resolve_reverse_ipv6()
219  */
220 int evdns_resolve_reverse(const struct in_addr *in, int flags, evdns_callback_type callback, void *ptr);
221 
222 /**
223   Lookup a PTR record for a given IPv6 address.
224 
225   @deprecated This function is deprecated because it does not allow the
226     caller to specify which evdns_base it applies to.  The recommended
227     function is evdns_base_resolve_reverse_ipv6().
228 
229   @param in an IPv6 address
230   @param flags either 0, or DNS_QUERY_NO_SEARCH to disable searching for this query.
231   @param callback a callback function to invoke when the request is completed
232   @param ptr an argument to pass to the callback function
233   @return 0 if successful, or -1 if an error occurred
234   @see evdns_resolve_reverse_ipv6()
235  */
236 int evdns_resolve_reverse_ipv6(const struct in6_addr *in, int flags, evdns_callback_type callback, void *ptr);
237 
238 /**
239   Set the value of a configuration option.
240 
241   The currently available configuration options are:
242 
243     ndots, timeout, max-timeouts, max-inflight, and attempts
244 
245   @deprecated This function is deprecated because it does not allow the
246     caller to specify which evdns_base it applies to.  The recommended
247     function is evdns_base_set_option().
248 
249   @param option the name of the configuration option to be modified
250   @param val the value to be set
251   @param flags Ignored.
252   @return 0 if successful, or -1 if an error occurred
253  */
254 int evdns_set_option(const char *option, const char *val, int flags);
255 
256 /**
257   Parse a resolv.conf file.
258 
259   The 'flags' parameter determines what information is parsed from the
260   resolv.conf file. See the man page for resolv.conf for the format of this
261   file.
262 
263   The following directives are not parsed from the file: sortlist, rotate,
264   no-check-names, inet6, debug.
265 
266   If this function encounters an error, the possible return values are: 1 =
267   failed to open file, 2 = failed to stat file, 3 = file too large, 4 = out of
268   memory, 5 = short read from file, 6 = no nameservers listed in the file
269 
270   @deprecated This function is deprecated because it does not allow the
271     caller to specify which evdns_base it applies to.  The recommended
272     function is evdns_base_resolv_conf_parse().
273 
274   @param flags any of DNS_OPTION_NAMESERVERS|DNS_OPTION_SEARCH|DNS_OPTION_MISC|
275     DNS_OPTIONS_ALL
276   @param filename the path to the resolv.conf file
277   @return 0 if successful, or various positive error codes if an error
278     occurred (see above)
279   @see resolv.conf(3), evdns_config_windows_nameservers()
280  */
281 int evdns_resolv_conf_parse(int flags, const char *const filename);
282 
283 /**
284   Clear the list of search domains.
285 
286   @deprecated This function is deprecated because it does not allow the
287     caller to specify which evdns_base it applies to.  The recommended
288     function is evdns_base_search_clear().
289  */
290 void evdns_search_clear(void);
291 
292 /**
293   Add a domain to the list of search domains
294 
295   @deprecated This function is deprecated because it does not allow the
296     caller to specify which evdns_base it applies to.  The recommended
297     function is evdns_base_search_add().
298 
299   @param domain the domain to be added to the search list
300  */
301 void evdns_search_add(const char *domain);
302 
303 /**
304   Set the 'ndots' parameter for searches.
305 
306   Sets the number of dots which, when found in a name, causes
307   the first query to be without any search domain.
308 
309   @deprecated This function is deprecated because it does not allow the
310     caller to specify which evdns_base it applies to.  The recommended
311     function is evdns_base_search_ndots_set().
312 
313   @param ndots the new ndots parameter
314  */
315 void evdns_search_ndots_set(const int ndots);
316 
317 /**
318    As evdns_server_new_with_base.
319 
320   @deprecated This function is deprecated because it does not allow the
321     caller to specify which even_base it uses.  The recommended
322     function is evdns_add_server_port_with_base().
323 
324 */
325 struct evdns_server_port *evdns_add_server_port(evutil_socket_t socket, int flags, evdns_request_callback_fn_type callback, void *user_data);
326 
327 #ifdef WIN32
328 int evdns_config_windows_nameservers(void);
329 #define EVDNS_CONFIG_WINDOWS_NAMESERVERS_IMPLEMENTED
330 #endif
331 
332 #ifdef __cplusplus
333 }
334 #endif
335 
336 #endif /* _EVENT2_EVENT_COMPAT_H_ */
337