* methods/gpgv.cc:
[apt.git] / methods / rfc2553emu.h
CommitLineData
934b6582
AL
1// -*- mode: cpp; mode: fold -*-
2// Description /*{{{*/
82e0333e 3// $Id: rfc2553emu.h,v 1.4 2000/06/18 06:04:45 jgg Exp $
934b6582
AL
4/* ######################################################################
5
6 RFC 2553 Emulation - Provides emulation for RFC 2553 getaddrinfo,
7 freeaddrinfo and getnameinfo
8
9 These functions are necessary to write portable protocol independent
10 networking. They transparently support IPv4, IPv6 and probably many
11 other protocols too. This implementation is needed when the host does
12 not support these standards. It implements a simple wrapper that
13 basically supports only IPv4.
14
15 Perfect emulation is not provided, but it is passable..
16
17 Originally written by Jason Gunthorpe <jgg@debian.org> and placed into
18 the Public Domain, do with it what you will.
19
20 ##################################################################### */
21 /*}}}*/
22#ifndef RFC2553EMU_H
23#define RFC2553EMU_H
24
25#include <netdb.h>
26#include <sys/types.h>
27#include <sys/socket.h>
28
29// Autosense getaddrinfo
30#if defined(AI_PASSIVE) && defined(EAI_NONAME)
31#define HAVE_GETADDRINFO
32#endif
33
533151d3
AL
34// Autosense getnameinfo
35#if defined(NI_NUMERICHOST)
36#define HAVE_GETNAMEINFO
37#endif
38
934b6582
AL
39// getaddrinfo support?
40#ifndef HAVE_GETADDRINFO
934b6582
AL
41 // Renamed to advoid type clashing.. (for debugging)
42 struct addrinfo_emu
43 {
44 int ai_flags; /* AI_PASSIVE, AI_CANONNAME, AI_NUMERICHOST */
45 int ai_family; /* PF_xxx */
46 int ai_socktype; /* SOCK_xxx */
47 int ai_protocol; /* 0 or IPPROTO_xxx for IPv4 and IPv6 */
48 size_t ai_addrlen; /* length of ai_addr */
49 char *ai_canonname; /* canonical name for nodename */
50 struct sockaddr *ai_addr; /* binary address */
f58a97d3 51 struct addrinfo_emu *ai_next; /* next structure in linked list */
934b6582 52 };
f58a97d3 53 #define addrinfo addrinfo_emu
934b6582
AL
54
55 int getaddrinfo(const char *nodename, const char *servname,
56 const struct addrinfo *hints,
57 struct addrinfo **res);
58 void freeaddrinfo(struct addrinfo *ai);
59
60 #ifndef AI_PASSIVE
61 #define AI_PASSIVE (1<<1)
62 #endif
63
64 #ifndef EAI_NONAME
65 #define EAI_NONAME -1
66 #define EAI_AGAIN -2
67 #define EAI_FAIL -3
68 #define EAI_NODATA -4
69 #define EAI_FAMILY -5
70 #define EAI_SOCKTYPE -6
71 #define EAI_SERVICE -7
72 #define EAI_ADDRFAMILY -8
934b6582 73 #define EAI_SYSTEM -10
f58a97d3 74 #define EAI_MEMORY -11
934b6582
AL
75 #endif
76
82e0333e
AL
77 /* If we don't have getaddrinfo then we probably don't have
78 sockaddr_storage either (same RFC) so we definately will not be
79 doing any IPv6 stuff. Do not use the members of this structure to
80 retain portability, cast to a sockaddr. */
81 #define sockaddr_storage sockaddr_in
934b6582
AL
82#endif
83
84// getnameinfo support (glibc2.0 has getaddrinfo only)
85#ifndef HAVE_GETNAMEINFO
86
87 int getnameinfo(const struct sockaddr *sa, socklen_t salen,
88 char *host, size_t hostlen,
89 char *serv, size_t servlen,
90 int flags);
533151d3
AL
91
92 #ifndef NI_MAXHOST
93 #define NI_MAXHOST 1025
94 #define NI_MAXSERV 32
95 #endif
96
97 #ifndef NI_NUMERICHOST
98 #define NI_NUMERICHOST (1<<0)
99 #define NI_NUMERICSERV (1<<1)
100// #define NI_NOFQDN (1<<2)
101 #define NI_NAMEREQD (1<<3)
102 #define NI_DATAGRAM (1<<4)
103 #endif
104
82e0333e
AL
105 #define sockaddr_storage sockaddr_in
106#endif
107
108// Glibc 2.0.7 misses this one
109#ifndef AI_NUMERICHOST
110#define AI_NUMERICHOST 0
934b6582
AL
111#endif
112
113#endif