code: plan9front

ref: e72da62915b09d5673b0c0179ba8dfe045aeb8c3
dir: /sys/include/ape/netdb.h/

View raw version
#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__ */