169 lines
6.5 KiB
C
169 lines
6.5 KiB
C
#ifndef __NETDB_H__
|
|
#define __NETDB_H__
|
|
|
|
#ifndef _BSD_EXTENSION
|
|
This header file is an extension to ANSI/POSIX
|
|
#endif
|
|
|
|
#pragma lib "/$M/lib/ape/libbsd.a"
|
|
|
|
/*-
|
|
* Copyright (c) 1980, 1983, 1988 Regents of the University of California.
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms are permitted
|
|
* provided that: (1) source distributions retain this entire copyright
|
|
* notice and comment, and (2) distributions including binaries display
|
|
* the following acknowledgement: ``This product includes software
|
|
* developed by the University of California, Berkeley and its contributors''
|
|
* in the documentation or other materials provided with the distribution
|
|
* and in all advertising materials mentioning features or use of this
|
|
* software. Neither the name of the University nor the names of its
|
|
* contributors may be used to endorse or promote products derived
|
|
* from this software without specific prior written permission.
|
|
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
|
|
* IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
|
|
*
|
|
* @(#)netdb.h 5.11 (Berkeley) 5/21/90
|
|
*/
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/*
|
|
* Structures returned by network data base library. All addresses are
|
|
* supplied in host order, and returned in network order (suitable for
|
|
* use in system calls).
|
|
*/
|
|
struct hostent {
|
|
char *h_name; /* official name of host */
|
|
char **h_aliases; /* alias list */
|
|
int h_addrtype; /* host address type */
|
|
int h_length; /* length of address */
|
|
char **h_addr_list; /* list of addresses from name server */
|
|
#define h_addr h_addr_list[0] /* address, for backward compatiblity */
|
|
};
|
|
|
|
/*
|
|
* Assumption here is that a network number
|
|
* fits in 32 bits -- probably a poor one.
|
|
*/
|
|
struct netent {
|
|
char *n_name; /* official name of net */
|
|
char **n_aliases; /* alias list */
|
|
int n_addrtype; /* net address type */
|
|
unsigned long n_net; /* network # */
|
|
};
|
|
|
|
struct servent {
|
|
char *s_name; /* official service name */
|
|
char **s_aliases; /* alias list */
|
|
int s_port; /* port # */
|
|
char *s_proto; /* protocol to use */
|
|
};
|
|
|
|
struct protoent {
|
|
char *p_name; /* official protocol name */
|
|
char **p_aliases; /* alias list */
|
|
int p_proto; /* protocol # */
|
|
};
|
|
|
|
/* from 4.0 RPCSRC */
|
|
struct rpcent {
|
|
char *r_name; /* name of server for this rpc program */
|
|
char **r_aliases; /* alias list */
|
|
int r_number; /* rpc program number */
|
|
};
|
|
|
|
extern struct hostent *gethostbyname(const char *),
|
|
*gethostbyaddr(const void *, int, int),
|
|
*gethostent(void);
|
|
extern struct netent *getnetbyname(const char *),
|
|
*getnetbyaddr(long, int),
|
|
*getnetent(void);
|
|
extern struct servent *getservbyname(const char *, const char *),
|
|
*getservbyport(int, const char *),
|
|
*getservent(void);
|
|
extern struct protoent *getprotobyname(const char *),
|
|
*getprotobynumber(int),
|
|
*getprotoent(void);
|
|
extern struct rpcent *getrpcbyname(const char *),
|
|
*getrpcbynumber(int),
|
|
*getrpcent(void);
|
|
extern void sethostent(int), endhostent(void),
|
|
setnetent(int), endnetent(void),
|
|
setservent(int), endservent(void),
|
|
setprotoent(int), endprotoent(void),
|
|
setrpcent(int), endrpcent(void);
|
|
|
|
/*
|
|
* Error return codes from gethostbyname() and gethostbyaddr()
|
|
* (left in extern int h_errno).
|
|
*/
|
|
extern int h_errno;
|
|
extern void herror(const char *);
|
|
extern char *hstrerror(int);
|
|
|
|
#define HOST_NOT_FOUND 1 /* Authoritative Answer Host not found */
|
|
#define TRY_AGAIN 2 /* Non-Authoritive Host not found, or SERVERFAIL */
|
|
#define NO_RECOVERY 3 /* Non recoverable errors, FORMERR, REFUSED, NOTIMP */
|
|
#define NO_DATA 4 /* Valid name, no data record of requested type */
|
|
#define NO_ADDRESS NO_DATA /* no address, look for MX record */
|
|
|
|
#define __HOST_SVC_NOT_AVAIL 99 /* libc internal use only */
|
|
|
|
struct addrinfo {
|
|
int ai_flags; /* Input flags. */
|
|
int ai_family; /* Protocol family for socket. */
|
|
int ai_socktype; /* Socket type. */
|
|
int ai_protocol; /* Protocol for socket. */
|
|
int ai_addrlen; /* Length of socket address. */
|
|
struct sockaddr *ai_addr; /* Socket address for socket. */
|
|
char *ai_canonname; /* Canonical name for service location. */
|
|
struct addrinfo *ai_next; /* Pointer to next in list. */
|
|
};
|
|
|
|
extern int getaddrinfo(char *, char *, struct addrinfo *, struct addrinfo **);
|
|
extern void freeaddrinfo(struct addrinfo *);
|
|
extern int getnameinfo(struct sockaddr *, int, char *, int, char *, int, unsigned int);
|
|
extern char *gai_strerror(int);
|
|
|
|
/* Possible values for `ai_flags' field in `addrinfo' structure. */
|
|
#define AI_PASSIVE 0x0001 /* Socket address is intended for `bind'. */
|
|
#define AI_CANONNAME 0x0002 /* Request for canonical name. */
|
|
#define AI_NUMERICHOST 0x0004 /* Don't use name resolution. */
|
|
#define AI_V4MAPPED 0x0008 /* IPv4 mapped addresses are acceptable. */
|
|
#define AI_ALL 0x0010 /* Return IPv4 mapped and IPv6 addresses. */
|
|
#define AI_ADDRCONFIG 0x0020 /* Use configuration of this host to choose returned address type.. */
|
|
#define AI_NUMERICSERV 0x0400 /* Don't use name resolution. */
|
|
|
|
/* getnameinfo flags */
|
|
#define NI_NOFQDN 0x0001 /* Only the nodename portion of the FQDN is returned for local hosts. */
|
|
#define NI_NUMERICHOST 0x0002 /* The numeric form of the node's address is returned instead of its name. */
|
|
#define NI_NAMEREQD 0x0004 /* Return an error if the node's name cannot be located in the database. */
|
|
#define NI_NUMERICSERV 0x0008 /* The numeric form of the service address is returned instead of its name. */
|
|
#define NI_NUMERICSCOPE 0x0010 /* For IPv6 addresses, the numeric form of the scope identifier is returned
|
|
instead of its name. */
|
|
#define NI_DGRAM 0x0020 /* Indicates that the service is a datagram service (SOCK_DGRAM). */
|
|
|
|
/* Error values for `getaddrinfo' and `getnameinfo' functions. */
|
|
#define EAI_BADFLAGS -1 /* Invalid value for `ai_flags' field */
|
|
#define EAI_NONAME -2 /* NAME or SERVICE is unknown */
|
|
#define EAI_AGAIN -3 /* Temporary failure in name resolution */
|
|
#define EAI_FAIL -4 /* Non-recoverable failure in name resolution */
|
|
#define EAI_NODATA -5 /* No address associated with NAME */
|
|
#define EAI_FAMILY -6 /* `ai_family' not supported */
|
|
#define EAI_SOCKTYPE -7 /* `ai_socktype' not supported */
|
|
#define EAI_SERVICE -8 /* SERVICE not supported for `ai_socktype' */
|
|
#define EAI_ADDRFAMILY -9 /* Address family for NAME not supported */
|
|
#define EAI_MEMORY -10 /* Memory allocation failure */
|
|
#define EAI_SYSTEM -11 /* System error returned in `errno' */
|
|
#define EAI_OVERFLOW -12 /* Argument buffer overflow */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* !__NETDB_H__ */
|