heimdal: import heimdal's trunk svn rev 23697 + lorikeet-heimdal patches
[Samba/vfs_proxy.git] / source4 / heimdal / lib / roken / resolve.h
blobbf8829b361a3a42956631bc8ff0306c0c4a4222b
1 /*
2 * Copyright (c) 1995 - 2002 Kungliga Tekniska Högskolan
3 * (Royal Institute of Technology, Stockholm, Sweden).
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
17 * 3. Neither the name of the Institute nor the names of its contributors
18 * may be used to endorse or promote products derived from this software
19 * without specific prior written permission.
21 * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
22 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
25 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 * SUCH DAMAGE.
34 /* $Id$ */
36 #ifndef __RESOLVE_H__
37 #define __RESOLVE_H__
39 #ifndef ROKEN_LIB_FUNCTION
40 #ifdef _WIN32
41 #define ROKEN_LIB_FUNCTION _stdcall
42 #else
43 #define ROKEN_LIB_FUNCTION
44 #endif
45 #endif
47 typedef enum {
48 rk_ns_t_invalid = 0, /* Cookie. */
49 rk_ns_t_a = 1, /* Host address. */
50 rk_ns_t_ns = 2, /* Authoritative server. */
51 rk_ns_t_md = 3, /* Mail destination. */
52 rk_ns_t_mf = 4, /* Mail forwarder. */
53 rk_ns_t_cname = 5, /* Canonical name. */
54 rk_ns_t_soa = 6, /* Start of authority zone. */
55 rk_ns_t_mb = 7, /* Mailbox domain name. */
56 rk_ns_t_mg = 8, /* Mail group member. */
57 rk_ns_t_mr = 9, /* Mail rename name. */
58 rk_ns_t_null = 10, /* Null resource record. */
59 rk_ns_t_wks = 11, /* Well known service. */
60 rk_ns_t_ptr = 12, /* Domain name pointer. */
61 rk_ns_t_hinfo = 13, /* Host information. */
62 rk_ns_t_minfo = 14, /* Mailbox information. */
63 rk_ns_t_mx = 15, /* Mail routing information. */
64 rk_ns_t_txt = 16, /* Text strings. */
65 rk_ns_t_rp = 17, /* Responsible person. */
66 rk_ns_t_afsdb = 18, /* AFS cell database. */
67 rk_ns_t_x25 = 19, /* X_25 calling address. */
68 rk_ns_t_isdn = 20, /* ISDN calling address. */
69 rk_ns_t_rt = 21, /* Router. */
70 rk_ns_t_nsap = 22, /* NSAP address. */
71 rk_ns_t_nsap_ptr = 23, /* Reverse NSAP lookup (deprecated). */
72 rk_ns_t_sig = 24, /* Security signature. */
73 rk_ns_t_key = 25, /* Security key. */
74 rk_ns_t_px = 26, /* X.400 mail mapping. */
75 rk_ns_t_gpos = 27, /* Geographical position (withdrawn). */
76 rk_ns_t_aaaa = 28, /* Ip6 Address. */
77 rk_ns_t_loc = 29, /* Location Information. */
78 rk_ns_t_nxt = 30, /* Next domain (security). */
79 rk_ns_t_eid = 31, /* Endpoint identifier. */
80 rk_ns_t_nimloc = 32, /* Nimrod Locator. */
81 rk_ns_t_srv = 33, /* Server Selection. */
82 rk_ns_t_atma = 34, /* ATM Address */
83 rk_ns_t_naptr = 35, /* Naming Authority PoinTeR */
84 rk_ns_t_kx = 36, /* Key Exchange */
85 rk_ns_t_cert = 37, /* Certification record */
86 rk_ns_t_a6 = 38, /* IPv6 address (deprecates AAAA) */
87 rk_ns_t_dname = 39, /* Non-terminal DNAME (for IPv6) */
88 rk_ns_t_sink = 40, /* Kitchen sink (experimentatl) */
89 rk_ns_t_opt = 41, /* EDNS0 option (meta-RR) */
90 rk_ns_t_apl = 42, /* Address prefix list (RFC 3123) */
91 rk_ns_t_ds = 43, /* Delegation Signer (RFC 3658) */
92 rk_ns_t_sshfp = 44, /* SSH fingerprint */
93 rk_ns_t_tkey = 249, /* Transaction key */
94 rk_ns_t_tsig = 250, /* Transaction signature. */
95 rk_ns_t_ixfr = 251, /* Incremental zone transfer. */
96 rk_ns_t_axfr = 252, /* Transfer zone of authority. */
97 rk_ns_t_mailb = 253, /* Transfer mailbox records. */
98 rk_ns_t_maila = 254, /* Transfer mail agent records. */
99 rk_ns_t_any = 255, /* Wildcard match. */
100 rk_ns_t_zxfr = 256, /* BIND-specific, nonstandard. */
101 rk_ns_t_max = 65536
102 } rk_ns_type;
104 /* We use these, but they are not always present in <arpa/nameser.h> */
106 #ifndef C_IN
107 #define C_IN 1
108 #endif
110 #ifndef T_A
111 #define T_A 1
112 #endif
113 #ifndef T_NS
114 #define T_NS 2
115 #endif
116 #ifndef T_CNAME
117 #define T_CNAME 5
118 #endif
119 #ifndef T_SOA
120 #define T_SOA 5
121 #endif
122 #ifndef T_PTR
123 #define T_PTR 12
124 #endif
125 #ifndef T_MX
126 #define T_MX 15
127 #endif
128 #ifndef T_TXT
129 #define T_TXT 16
130 #endif
131 #ifndef T_AFSDB
132 #define T_AFSDB 18
133 #endif
134 #ifndef T_SIG
135 #define T_SIG 24
136 #endif
137 #ifndef T_KEY
138 #define T_KEY 25
139 #endif
140 #ifndef T_AAAA
141 #define T_AAAA 28
142 #endif
143 #ifndef T_SRV
144 #define T_SRV 33
145 #endif
146 #ifndef T_NAPTR
147 #define T_NAPTR 35
148 #endif
149 #ifndef T_CERT
150 #define T_CERT 37
151 #endif
152 #ifndef T_SSHFP
153 #define T_SSHFP 44
154 #endif
156 #ifndef MAXDNAME
157 #define MAXDNAME 1025
158 #endif
160 #define dns_query rk_dns_query
161 #define mx_record rk_mx_record
162 #define srv_record rk_srv_record
163 #define key_record rk_key_record
164 #define sig_record rk_sig_record
165 #define cert_record rk_cert_record
166 #define sshfp_record rk_sshfp_record
167 #define resource_record rk_resource_record
168 #define dns_reply rk_dns_reply
170 #define dns_lookup rk_dns_lookup
171 #define dns_free_data rk_dns_free_data
172 #define dns_string_to_type rk_dns_string_to_type
173 #define dns_type_to_string rk_dns_type_to_string
174 #define dns_srv_order rk_dns_srv_order
176 struct dns_query{
177 char *domain;
178 unsigned type;
179 unsigned class;
182 struct mx_record{
183 unsigned preference;
184 char domain[1];
187 struct srv_record{
188 unsigned priority;
189 unsigned weight;
190 unsigned port;
191 char target[1];
194 struct key_record {
195 unsigned flags;
196 unsigned protocol;
197 unsigned algorithm;
198 size_t key_len;
199 u_char key_data[1];
202 struct sig_record {
203 unsigned type;
204 unsigned algorithm;
205 unsigned labels;
206 unsigned orig_ttl;
207 unsigned sig_expiration;
208 unsigned sig_inception;
209 unsigned key_tag;
210 char *signer;
211 unsigned sig_len;
212 char sig_data[1]; /* also includes signer */
215 struct cert_record {
216 unsigned type;
217 unsigned tag;
218 unsigned algorithm;
219 size_t cert_len;
220 u_char cert_data[1];
223 struct sshfp_record {
224 unsigned algorithm;
225 unsigned type;
226 size_t sshfp_len;
227 u_char sshfp_data[1];
230 struct ds_record {
231 unsigned key_tag;
232 unsigned algorithm;
233 unsigned digest_type;
234 unsigned digest_len;
235 u_char digest_data[1];
238 struct resource_record{
239 char *domain;
240 unsigned type;
241 unsigned class;
242 unsigned ttl;
243 unsigned size;
244 union {
245 void *data;
246 struct mx_record *mx;
247 struct mx_record *afsdb; /* mx and afsdb are identical */
248 struct srv_record *srv;
249 struct in_addr *a;
250 char *txt;
251 struct key_record *key;
252 struct cert_record *cert;
253 struct sig_record *sig;
254 struct sshfp_record *sshfp;
255 struct ds_record *ds;
257 struct resource_record *next;
260 #define rk_DNS_MAX_PACKET_SIZE 0xffff
262 struct dns_header {
263 unsigned id;
264 unsigned flags;
265 #define rk_DNS_HEADER_RESPONSE_FLAG 1
266 #define rk_DNS_HEADER_AUTHORITIVE_ANSWER 2
267 #define rk_DNS_HEADER_TRUNCATED_MESSAGE 4
268 #define rk_DNS_HEADER_RECURSION_DESIRED 8
269 #define rk_DNS_HEADER_RECURSION_AVAILABLE 16
270 #define rk_DNS_HEADER_AUTHENTIC_DATA 32
271 #define rk_DNS_HEADER_CHECKING_DISABLED 64
272 unsigned opcode;
273 unsigned response_code;
274 unsigned qdcount;
275 unsigned ancount;
276 unsigned nscount;
277 unsigned arcount;
280 struct dns_reply{
281 struct dns_header h;
282 struct dns_query q;
283 struct resource_record *head;
287 struct dns_reply* ROKEN_LIB_FUNCTION
288 dns_lookup(const char *, const char *);
289 void ROKEN_LIB_FUNCTION
290 dns_free_data(struct dns_reply *);
291 int ROKEN_LIB_FUNCTION
292 dns_string_to_type(const char *name);
293 const char *ROKEN_LIB_FUNCTION
294 dns_type_to_string(int type);
295 void ROKEN_LIB_FUNCTION
296 dns_srv_order(struct dns_reply*);
298 #endif /* __RESOLVE_H__ */