djbdnscurve6 45
djbdnscurve6
Loading...
Searching...
No Matches
dns.h
Go to the documentation of this file.
1/*
2 * Revision 20231219, Erwin Hoffmann
3 * - MSGSIZE 1232 byte according to DNS Flag Day recommendation
4 * - Added additional return codes
5 * Revision 20210908, Erwin Hoffmann
6 * - included MINMSGSIZE, MAXMSGSIZE
7 * - included TCP_BACKLOG
8 * Revision 20210829, Erwin Hoffmann
9 * - added randombind4 for dns_transmit.c
10 * Revision 20180606, Erwin Hoffmann
11 * - struct dns_transmit is now curve-enabled
12 * Revision 20180222, Erwin Hoffmann
13 * - we consider in total 32 NS IPs (IPv4 + IPv6)
14 * - added dns_transmit_start6
15 * - added uint32 scope_ids[32],
16 * the initial NS scopes read from /etc/resolv.conf et al.
17 * Revision 20180118, Erwin Hoffmann
18 * - included MSGSIZE for DNS messages (instead of MTUSIZE)
19*/
20#ifndef DNS_H
21#define DNS_H
22
23#include "stralloc.h"
24#include "iopause.h"
25#include "taia.h"
26#include "ip.h"
27
28/* Note: The conventions are subject of change in forthcoming versions */
29
30#define DNS_NXD 0 /* NXDOMAIN,␣NODATA␣*/
31#define DNS_MEM -1 /* out of memory; fatal */
32#define DNS_ERR -2 /* parsing errors and others */
33#define DNS_COM -3 /* (socket) communication errors - SERVFAIL */
34#define DNS_INT -4 /* internal errors */
35#define DNS_SOFT -5 /* DNS_ERR␣or␣DNS_COM␣*/$
36#define DNS_HARD -6 /* DNS␣loop␣problem␣*/$
37
38#define MSGSIZE MTUSIZE - 48 /* DNS Flag Day 2020 recommendation */
39#define MINMSGSIZE 512 /* RFC 1035 */
40#define MAXMSGSIZE 4096 /* 4069 seen with EDNS0 */
41#define MAXSEGMENT 65535 /* Max TCP buffer size */
42#define MAX_TTL 655360 /* Default TTL for static DNS objects */
43
44#define QUERY_MAXNS 32 /* 16 IPv4 + 16 IPv6 NS */
45#define QUERY_MAXIPLEN 512 /* QUERY_MAXNS * 16 */
46#define TCP_BACKLOG 20 /* the number of TCP connections supported simultaneously */
47#define FQDN_LEN 255 /* length of FQDN including all labels + dots */
48
49#define EDNS0FLAG 1
50
51/* Note: These following definitions are subject of change */
52
53#define DNS_C_IN "\0\1"
54#define DNS_C_ANY "\0\377"
55
56#define DNS_T_A "\0\1"
57#define DNS_T_NS "\0\2"
58#define DNS_T_CNAME "\0\5"
59#define DNS_T_SOA "\0\6"
60#define DNS_T_PTR "\0\14"
61#define DNS_T_HINFO "\0\15"
62#define DNS_T_MX "\0\17"
63#define DNS_T_TXT "\0\20"
64#define DNS_T_RP "\0\21"
65#define DNS_T_SIG "\0\30"
66#define DNS_T_KEY "\0\31"
67#define DNS_T_AAAA "\0\34"
68#define DNS_T_SRV "\0\41"
69#define DNS_T_NAPTR "\0\43"
70#define DNS_T_CERT "\0\45"
71#define DNS_T_OPT "\0\51"
72#define DNS_T_DS "\0\53"
73#define DNS_T_SSHFP "\0\54"
74#define DNS_T_IPSECKEY "\0\55"
75#define DNS_T_RRSIG "\0\56"
76#define DNS_T_NSEC "\0\57"
77#define DNS_T_DNSKEY "\0\60"
78#define DNS_T_NSEC3 "\0\62"
79#define DNS_T_NSEC3PARAM "\0\63"
80#define DNS_T_TLSA "\0\64"
81#define DNS_T_HIP "\0\67"
82#define DNS_T_OPENPGPKEY "\0\75"
83#define DNS_T_SPF "\0\143"
84#define DNS_T_AXFR "\0\374"
85#define DNS_T_ANY "\0\377"
86#define DNS_T_CAA "\1\1"
87
88#define LOCALHOST "localhost" /* no clear distinction IPv4/IPv6 */
89#define IP4_LOOPBACK "ip4-loopback"
90#define IP6_LOOPBACK "ip6-loopback"
91
93 char *query; /* 0, or dynamically allocated */
94 unsigned int querylen;
95 char *packet; /* 0, or dynamically allocated */
96 unsigned int packetlen;
97 int s1; /* 0, or 1 + an open file descriptor */
100 unsigned int udploop;
101 unsigned int curserver;
102 struct taia deadline;
103 unsigned int pos;
104 const char *name; /* query name */
105 const char *servers;
106 const char *keys;
107 const char *pubkey;
108 const char *suffix; /* domain name */
109 char nonce[12];
110 uint32 scope_id;
111 char localip[16];
112 char qtype[2];
113} ;
114
115/* General */
116
117extern void dns_random_init(const char *);
118extern unsigned int dns_random(unsigned int);
119
120extern void dns_domain_free(char **);
121extern int dns_domain_copy(char **,const char *);
122extern unsigned int dns_domain_length(const char *);
123extern int dns_domain_equal(const char *,const char *);
124extern int dns_domain_suffix(const char *,const char *);
125extern unsigned int dns_domain_suffixpos(const char *,const char *);
126extern int dns_domain_fromdot(char **,const char *,unsigned int);
127extern int dns_domain_todot_cat(stralloc *,const char *);
128
129extern unsigned int dns_packet_copy(const char *,unsigned int,unsigned int,char *,unsigned int);
130extern unsigned int dns_packet_getname(const char *,unsigned int,unsigned int,char **);
131extern unsigned int dns_packet_skipname(const char *,unsigned int,unsigned int);
132
133extern struct dns_transmit dns_resolve_tx;
134extern int dns_transmit_start(struct dns_transmit *,const char *,int,const char *,const char *,const char *);
135extern void dns_transmit_free(struct dns_transmit *);
136extern void dns_transmit_io(struct dns_transmit *,iopause_fd *,struct taia *);
137extern int dns_transmit_get(struct dns_transmit *,const iopause_fd *,const struct taia *);
138
139/* Common IPv4 + IPv6 */
140
141extern int dns_resolvconfip(char *,uint32 *);
142extern int dns_resolvconfrewrite(stralloc *);
143extern int dns_resolve(const char *,const char *);
144
145extern int dns_name(stralloc *,const char *);
146extern int dns_name_packet(stralloc *,const char *,unsigned int);
147extern int dns_txt_packet(stralloc *,const char *,unsigned int);
148extern int dns_txt(stralloc *,const stralloc *);
149extern int dns_mx_packet(stralloc *,const char *,unsigned int);
150extern int dns_mx(stralloc *,const stralloc *);
151extern int dns_ip_qualify(stralloc *,stralloc *,const stralloc *);
152
153/* IPv4 specific */
154
155extern int dns_ip4_packet(stralloc *,const char *,unsigned int);
156extern int dns_ip4(stralloc *,stralloc *);
157extern void dns_sortip4(char *,unsigned int);
158
159extern int dns_ip4_qualify_rules(stralloc *,stralloc *,const stralloc *,const stralloc *);
160extern int dns_ip4_qualify(stralloc *,stralloc *,const stralloc *);
161
162#define DNS_NAME4_DOMAIN 31
163extern int dns_name4_domain(char *,const char *);
164extern int dns_name4(stralloc *,const char *);
165
166/* IPv6 specific */
167
168extern int dns_ip6_packet(stralloc *,const char *,unsigned int);
169extern int dns_ip6(stralloc *,stralloc *);
170extern void dns_sortip6(char *,unsigned int);
171
172extern int dns_ip6_qualify_rules(stralloc *,stralloc *,const stralloc *,const stralloc *);
173extern int dns_ip6_qualify(stralloc *,stralloc *,const stralloc *);
174
175#define DNS_NAME6_DOMAIN (4*16+11)
176extern int dns_name6_domain(char *,const char *);
177extern int dns_name6(stralloc *,const char *);
178
179extern int dns_transmit_start6(struct dns_transmit *,const char *,int,const char *,const char *,const char *,const uint32 *);
180
181extern unsigned int dns_packet_edns0(const char *,const char *,const int,unsigned int);
182
183/* General */
184
185extern void socketfree(struct dns_transmit *);
186extern void queryfree(struct dns_transmit *);
187extern void packetfree(struct dns_transmit *);
188extern int randombind(struct dns_transmit *);
189extern int randombind4(struct dns_transmit *);
190extern int serverwantstcp(const char *,unsigned int);
191extern int serverfailed(const char *,unsigned int,char *);
192extern int getscopeid(const struct dns_transmit *,const char *);
193extern int firstudp(struct dns_transmit *);
194extern int nextudp(struct dns_transmit *);
195extern int firsttcp(struct dns_transmit *);
196extern int nexttcp(struct dns_transmit *);
197
198#endif
void dns_transmit_free(struct dns_transmit *)
Definition: dns_transmit.c:95
int dns_name(stralloc *, const char *)
void dns_transmit_io(struct dns_transmit *, iopause_fd *, struct taia *)
Definition: dns_transmit.c:279
int dns_ip4_qualify_rules(stralloc *, stralloc *, const stralloc *, const stralloc *)
Definition: dns_ipq.c:47
void dns_sortip4(char *, unsigned int)
Definition: dns_sortip.c:10
int serverwantstcp(const char *, unsigned int)
Definition: dns_transmit.c:29
void socketfree(struct dns_transmit *)
Definition: dns_transmit.c:88
unsigned int dns_packet_copy(const char *, unsigned int, unsigned int, char *, unsigned int)
Definition: dns_packet.c:8
int dns_ip4_packet(stralloc *, const char *, unsigned int)
Definition: dns_ip.c:9
int dns_ip4(stralloc *, stralloc *)
Definition: dns_ip.c:42
int dns_resolvconfip(char *, uint32 *)
void packetfree(struct dns_transmit *)
Definition: dns_transmit.c:74
int dns_domain_equal(const char *, const char *)
Definition: dns_domain.c:39
int serverfailed(const char *, unsigned int, char *)
Definition: dns_transmit.c:38
int dns_name4(stralloc *, const char *)
unsigned int dns_random(unsigned int)
Definition: dns_random.c:56
int dns_domain_fromdot(char **, const char *, unsigned int)
Definition: dns_dfd.c:6
int dns_domain_todot_cat(stralloc *, const char *)
Definition: dns_dtda.c:11
int dns_ip_qualify(stralloc *, stralloc *, const stralloc *)
Definition: dns_ipq.c:228
int firstudp(struct dns_transmit *)
Definition: dns_transmit.c:193
int dns_resolve(const char *, const char *)
int dns_domain_copy(char **, const char *)
Definition: dns_domain.c:25
int nexttcp(struct dns_transmit *)
Definition: dns_transmit.c:256
void dns_sortip6(char *, unsigned int)
Definition: dns_sortip.c:25
int dns_domain_suffix(const char *, const char *)
Definition: dns_domain.c:50
int dns_name_packet(stralloc *, const char *, unsigned int)
Definition: dns_name.c:9
int firsttcp(struct dns_transmit *)
Definition: dns_transmit.c:250
int dns_ip4_qualify(stralloc *, stralloc *, const stralloc *)
Definition: dns_ipq.c:109
unsigned int dns_packet_edns0(const char *, const char *, const int, unsigned int)
unsigned int dns_packet_skipname(const char *, unsigned int, unsigned int)
Definition: dns_packet.c:18
int dns_transmit_start(struct dns_transmit *, const char *, int, const char *, const char *, const char *)
int dns_name4_domain(char *, const char *)
void dns_domain_free(char **)
Definition: dns_domain.c:17
unsigned int dns_domain_length(const char *)
Definition: dns_domain.c:6
int dns_txt_packet(stralloc *, const char *, unsigned int)
Definition: dns_txt.c:6
int dns_ip6_qualify_rules(stralloc *, stralloc *, const stralloc *, const stralloc *)
Definition: dns_ipq.c:121
unsigned int dns_domain_suffixpos(const char *, const char *)
Definition: dns_domain.c:62
void queryfree(struct dns_transmit *)
Definition: dns_transmit.c:81
int dns_resolvconfrewrite(stralloc *)
Definition: dns_rcrw.c:115
int dns_ip6(stralloc *, stralloc *)
Definition: dns_ip.c:133
int dns_name6_domain(char *, const char *)
int dns_transmit_start6(struct dns_transmit *, const char *, int, const char *, const char *, const char *, const uint32 *)
int dns_mx_packet(stralloc *, const char *, unsigned int)
Definition: dns_mx.c:8
int randombind(struct dns_transmit *)
Definition: dns_transmit.c:102
int dns_ip6_qualify(stralloc *, stralloc *, const stralloc *)
Definition: dns_ipq.c:157
unsigned int dns_packet_getname(const char *, unsigned int, unsigned int, char **)
Definition: dns_packet.c:35
int dns_mx(stralloc *, const stralloc *)
Definition: dns_mx.c:43
void dns_random_init(const char *)
int dns_txt(stralloc *, const stralloc *)
Definition: dns_txt.c:53
struct dns_transmit dns_resolve_tx
Definition: dns_resolve.c:7
int randombind4(struct dns_transmit *)
Definition: dns_transmit.c:132
int nextudp(struct dns_transmit *)
Definition: dns_transmit.c:200
int dns_ip6_packet(stralloc *, const char *, unsigned int)
Definition: dns_ip.c:93
int dns_name6(stralloc *, const char *)
int getscopeid(const struct dns_transmit *, const char *)
Definition: dns_transmit.c:18
int dns_transmit_get(struct dns_transmit *, const iopause_fd *, const struct taia *)
Definition: dns_transmit.c:296
uint32 scope_id
Definition: dns.h:110
unsigned int curserver
Definition: dns.h:101
char qtype[2]
Definition: dns.h:112
unsigned int udploop
Definition: dns.h:100
char localip[16]
Definition: dns.h:111
int flagrecursive
Definition: dns.h:99
int tcpstate
Definition: dns.h:98
const char * name
Definition: dns.h:104
char nonce[12]
Definition: dns.h:109
struct taia deadline
Definition: dns.h:102
const char * servers
Definition: dns.h:105
unsigned int packetlen
Definition: dns.h:96
const char * pubkey
Definition: dns.h:107
unsigned int querylen
Definition: dns.h:94
char * packet
Definition: dns.h:95
const char * suffix
Definition: dns.h:108
int s1
Definition: dns.h:97
const char * keys
Definition: dns.h:106
unsigned int pos
Definition: dns.h:103
char * query
Definition: dns.h:93