Libinfo-173.1.tar.gz
[apple/libinfo.git] / lookup.subproj / netdb.h
1 /*
2 * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
6 * The contents of this file constitute Original Code as defined in and
7 * are subject to the Apple Public Source License Version 1.1 (the
8 * "License"). You may not use this file except in compliance with the
9 * License. Please obtain a copy of the License at
10 * http://www.apple.com/publicsource and read it before using this file.
11 *
12 * This Original Code and all software distributed under the License are
13 * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
14 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
17 * License for the specific language governing rights and limitations
18 * under the License.
19 *
20 * @APPLE_LICENSE_HEADER_END@
21 */
22 /*
23 * ++Copyright++ 1980, 1983, 1988, 1993
24 * -
25 * Copyright (c) 1980, 1983, 1988, 1993
26 * The Regents of the University of California. All rights reserved.
27 *
28 * Redistribution and use in source and binary forms, with or without
29 * modification, are permitted provided that the following conditions
30 * are met:
31 * 1. Redistributions of source code must retain the above copyright
32 * notice, this list of conditions and the following disclaimer.
33 * 2. Redistributions in binary form must reproduce the above copyright
34 * notice, this list of conditions and the following disclaimer in the
35 * documentation and/or other materials provided with the distribution.
36 * 3. All advertising materials mentioning features or use of this software
37 * must display the following acknowledgement:
38 * This product includes software developed by the University of
39 * California, Berkeley and its contributors.
40 * 4. Neither the name of the University nor the names of its contributors
41 * may be used to endorse or promote products derived from this software
42 * without specific prior written permission.
43 *
44 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
45 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
46 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
47 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
48 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
49 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
50 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
51 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
52 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
53 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
54 * SUCH DAMAGE.
55 * -
56 * Portions Copyright (c) 1993 by Digital Equipment Corporation.
57 *
58 * Permission to use, copy, modify, and distribute this software for any
59 * purpose with or without fee is hereby granted, provided that the above
60 * copyright notice and this permission notice appear in all copies, and that
61 * the name of Digital Equipment Corporation not be used in advertising or
62 * publicity pertaining to distribution of the document or software without
63 * specific, written prior permission.
64 *
65 * THE SOFTWARE IS PROVIDED "AS IS" AND DIGITAL EQUIPMENT CORP. DISCLAIMS ALL
66 * WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES
67 * OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL DIGITAL EQUIPMENT
68 * CORPORATION BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
69 * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
70 * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS
71 * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
72 * SOFTWARE.
73 * -
74 * --Copyright--
75 */
76
77 /*
78 * @(#)netdb.h 8.1 (Berkeley) 6/2/93
79 */
80
81 #ifndef _NETDB_H_
82 #define _NETDB_H_
83
84 #include <sys/param.h>
85 #include <sys/cdefs.h>
86 #include <sys/socket.h>
87
88 #define _PATH_HEQUIV "/etc/hosts.equiv"
89 #define _PATH_HOSTS "/etc/hosts"
90 #define _PATH_NETWORKS "/etc/networks"
91 #define _PATH_PROTOCOLS "/etc/protocols"
92 #define _PATH_SERVICES "/etc/services"
93
94 extern int h_errno;
95
96 /*
97 * Structures returned by network data base library. All addresses are
98 * supplied in host order, and returned in network order (suitable for
99 * use in system calls).
100 */
101 struct hostent {
102 char *h_name; /* official name of host */
103 char **h_aliases; /* alias list */
104 int h_addrtype; /* host address type */
105 int h_length; /* length of address */
106 char **h_addr_list; /* list of addresses from name server */
107 #define h_addr h_addr_list[0] /* address, for backward compatiblity */
108 };
109
110 /*
111 * Assumption here is that a network number
112 * fits in an unsigned long -- probably a poor one.
113 */
114 struct netent {
115 char *n_name; /* official name of net */
116 char **n_aliases; /* alias list */
117 int n_addrtype; /* net address type */
118 unsigned long n_net; /* network # */
119 };
120
121 struct servent {
122 char *s_name; /* official service name */
123 char **s_aliases; /* alias list */
124 int s_port; /* port # */
125 char *s_proto; /* protocol to use */
126 };
127
128 struct protoent {
129 char *p_name; /* official protocol name */
130 char **p_aliases; /* alias list */
131 int p_proto; /* protocol # */
132 };
133
134 struct addrinfo {
135 int ai_flags; /* AI_PASSIVE, AI_CANONNAME, AI_NUMERICHOST */
136 int ai_family; /* PF_xxx */
137 int ai_socktype; /* SOCK_xxx */
138 int ai_protocol; /* 0 or IPPROTO_xxx for IPv4 and IPv6 */
139 size_t ai_addrlen; /* length of ai_addr */
140 char *ai_canonname; /* canonical name for hostname */
141 struct sockaddr *ai_addr; /* binary address */
142 struct addrinfo *ai_next; /* next structure in linked list */
143 };
144
145 struct rpcent {
146 char *r_name; /* name of server for this rpc program */
147 char **r_aliases; /* alias list */
148 int r_number; /* rpc program number */
149 };
150
151 /*
152 * Error return codes from gethostbyname() and gethostbyaddr()
153 * (left in extern int h_errno).
154 */
155
156 #define NETDB_INTERNAL -1 /* see errno */
157 #define NETDB_SUCCESS 0 /* no problem */
158 #define HOST_NOT_FOUND 1 /* Authoritative Answer Host not found */
159 #define TRY_AGAIN 2 /* Non-Authoritative Host not found, or SERVERFAIL */
160 #define NO_RECOVERY 3 /* Non recoverable errors, FORMERR, REFUSED, NOTIMP */
161 #define NO_DATA 4 /* Valid name, no data record of requested type */
162 #define NO_ADDRESS NO_DATA /* no address, look for MX record */
163
164 /*
165 * Error return codes from getaddrinfo()
166 */
167 #define EAI_ADDRFAMILY 1 /* address family for hostname not supported */
168 #define EAI_AGAIN 2 /* temporary failure in name resolution */
169 #define EAI_BADFLAGS 3 /* invalid value for ai_flags */
170 #define EAI_FAIL 4 /* non-recoverable failure in name resolution */
171 #define EAI_FAMILY 5 /* ai_family not supported */
172 #define EAI_MEMORY 6 /* memory allocation failure */
173 #define EAI_NODATA 7 /* no address associated with hostname */
174 #define EAI_NONAME 8 /* hostname nor servname provided, or not known */
175 #define EAI_SERVICE 9 /* servname not supported for ai_socktype */
176 #define EAI_SOCKTYPE 10 /* ai_socktype not supported */
177 #define EAI_SYSTEM 11 /* system error returned in errno */
178 #define EAI_BADHINTS 12
179 #define EAI_PROTOCOL 13
180 #define EAI_MAX 14
181
182 /*
183 * Flag values for getaddrinfo()
184 */
185 #define AI_PASSIVE 0x00000001 /* get address to use bind() */
186 #define AI_CANONNAME 0x00000002 /* fill ai_canonname */
187 #define AI_NUMERICHOST 0x00000004 /* prevent name resolution */
188 /* valid flags for addrinfo */
189 #define AI_MASK (AI_PASSIVE | AI_CANONNAME | AI_NUMERICHOST)
190
191 #define AI_ALL 0x00000100 /* IPv6 and IPv4-mapped (with AI_V4MAPPED) */
192 #define AI_V4MAPPED_CFG 0x00000200 /* accept IPv4-mapped if kernel supports */
193 #define AI_ADDRCONFIG 0x00000400 /* only if any address is assigned */
194 #define AI_V4MAPPED 0x00000800 /* accept IPv4-mapped IPv6 address */
195 /* special recommended flags for getipnodebyname */
196 #define AI_DEFAULT (AI_V4MAPPED_CFG | AI_ADDRCONFIG)
197
198 /*
199 * Constants for getnameinfo()
200 */
201 #define NI_MAXHOST 1025
202 #define NI_MAXSERV 32
203
204 /*
205 * Flag values for getnameinfo()
206 */
207 #define NI_NOFQDN 0x00000001
208 #define NI_NUMERICHOST 0x00000002
209 #define NI_NAMEREQD 0x00000004
210 #define NI_NUMERICSERV 0x00000008
211 #define NI_DGRAM 0x00000010
212 #define NI_WITHSCOPEID 0x00000020
213
214 /*
215 * Scope delimit character
216 */
217 #define SCOPE_DELIMITER '%'
218
219 __BEGIN_DECLS
220 void endhostent(void);
221 void endnetent(void);
222 void endprotoent(void);
223 void endservent(void);
224 void freehostent(struct hostent *);
225 struct hostent *gethostbyaddr(const char *, int, int);
226 struct hostent *gethostbyname(const char *);
227 struct hostent *gethostbyname2(const char *, int);
228 struct hostent *gethostent(void);
229 struct hostent *getipnodebyaddr(const void *, size_t, int, int *);
230 struct hostent *getipnodebyname(const char *, int, int, int *);
231 struct netent *getnetbyaddr(long, int);
232 struct netent *getnetbyname(const char *);
233 struct netent *getnetent(void);
234 struct protoent *getprotobyname(const char *);
235 struct protoent *getprotobynumber(int);
236 struct protoent *getprotoent(void);
237 struct servent *getservbyname(const char *, const char *);
238 struct servent *getservbyport(int, const char *);
239 struct servent *getservent(void);
240 struct rpcent *getrpcbyname(const char *name);
241 struct rpcent *getrpcbynumber(long number);
242 struct rpcent *getrpcent(void);
243 void setrpcent(int stayopen);
244 void endrpcent(void);
245
246 void herror(const char *);
247 const char *hstrerror(int);
248 int innetgr(const char *, const char *, const char *, const char *);
249 void sethostent(int);
250 /* void sethostfile(const char *); */
251 void setnetent(int);
252 void setprotoent(int);
253 void setservent(int);
254 const char *gai_strerror(int);
255 void freeaddrinfo(struct addrinfo *);
256 int getaddrinfo(const char *, const char *, const struct addrinfo *, struct addrinfo **);
257 int getnameinfo(const struct sockaddr *, socklen_t, char *, size_t, char *, size_t, int);
258 __END_DECLS
259
260 #endif /* !_NETDB_H_ */