xref: /freebsd/contrib/unbound/util/net_help.c (revision 1323ec571215a77ddd21294f0871979d5ad6b992)
1 /*
2  * util/net_help.c - implementation of the network helper code
3  *
4  * Copyright (c) 2007, NLnet Labs. All rights reserved.
5  *
6  * This software is open source.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * Redistributions of source code must retain the above copyright notice,
13  * this list of conditions and the following disclaimer.
14  *
15  * Redistributions in binary form must reproduce the above copyright notice,
16  * this list of conditions and the following disclaimer in the documentation
17  * and/or other materials provided with the distribution.
18  *
19  * Neither the name of the NLNET LABS nor the names of its contributors may
20  * be used to endorse or promote products derived from this software without
21  * specific prior written permission.
22  *
23  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
26  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
27  * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
28  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
29  * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
30  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
31  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
32  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
33  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34  */
35 /**
36  * \file
37  * Implementation of net_help.h.
38  */
39 
40 #include "config.h"
41 #ifdef HAVE_SYS_TYPES_H
42 #  include <sys/types.h>
43 #endif
44 #ifdef HAVE_NET_IF_H
45 #include <net/if.h>
46 #endif
47 #ifdef HAVE_NETIOAPI_H
48 #include <netioapi.h>
49 #endif
50 #include "util/net_help.h"
51 #include "util/log.h"
52 #include "util/data/dname.h"
53 #include "util/module.h"
54 #include "util/regional.h"
55 #include "util/config_file.h"
56 #include "sldns/parseutil.h"
57 #include "sldns/wire2str.h"
58 #include "sldns/str2wire.h"
59 #include <fcntl.h>
60 #ifdef HAVE_OPENSSL_SSL_H
61 #include <openssl/ssl.h>
62 #include <openssl/evp.h>
63 #include <openssl/rand.h>
64 #endif
65 #ifdef HAVE_OPENSSL_ERR_H
66 #include <openssl/err.h>
67 #endif
68 #ifdef HAVE_OPENSSL_CORE_NAMES_H
69 #include <openssl/core_names.h>
70 #endif
71 #ifdef USE_WINSOCK
72 #include <wincrypt.h>
73 #endif
74 #ifdef HAVE_NGHTTP2_NGHTTP2_H
75 #include <nghttp2/nghttp2.h>
76 #endif
77 
78 /** max length of an IP address (the address portion) that we allow */
79 #define MAX_ADDR_STRLEN 128 /* characters */
80 /** default value for EDNS ADVERTISED size */
81 uint16_t EDNS_ADVERTISED_SIZE = 4096;
82 
83 /** minimal responses when positive answer: default is no */
84 int MINIMAL_RESPONSES = 0;
85 
86 /** rrset order roundrobin: default is yes */
87 int RRSET_ROUNDROBIN = 1;
88 
89 /** log tag queries with name instead of 'info' for filtering */
90 int LOG_TAG_QUERYREPLY = 0;
91 
92 static struct tls_session_ticket_key {
93 	unsigned char *key_name;
94 	unsigned char *aes_key;
95 	unsigned char *hmac_key;
96 } *ticket_keys;
97 
98 #ifdef HAVE_SSL
99 /**
100  * callback TLS session ticket encrypt and decrypt
101  * For use with SSL_CTX_set_tlsext_ticket_key_cb or
102  * SSL_CTX_set_tlsext_ticket_key_evp_cb
103  * @param s: the SSL_CTX to use (from connect_sslctx_create())
104  * @param key_name: secret name, 16 bytes
105  * @param iv: up to EVP_MAX_IV_LENGTH.
106  * @param evp_ctx: the evp cipher context, function sets this.
107  * @param hmac_ctx: the hmac context, function sets this.
108  * 	with ..key_cb it is of type HMAC_CTX*
109  * 	with ..key_evp_cb it is of type EVP_MAC_CTX*
110  * @param enc: 1 is encrypt, 0 is decrypt
111  * @return 0 on no ticket, 1 for okay, and 2 for okay but renew the ticket
112  * 	(the ticket is decrypt only). and <0 for failures.
113  */
114 int tls_session_ticket_key_cb(SSL *s, unsigned char* key_name,
115 	unsigned char* iv, EVP_CIPHER_CTX *evp_ctx,
116 #ifdef HAVE_SSL_CTX_SET_TLSEXT_TICKET_KEY_EVP_CB
117 	EVP_MAC_CTX *hmac_ctx,
118 #else
119 	HMAC_CTX* hmac_ctx,
120 #endif
121 	int enc);
122 #endif /* HAVE_SSL */
123 
124 /* returns true is string addr is an ip6 specced address */
125 int
126 str_is_ip6(const char* str)
127 {
128 	if(strchr(str, ':'))
129 		return 1;
130 	else    return 0;
131 }
132 
133 int
134 fd_set_nonblock(int s)
135 {
136 #ifdef HAVE_FCNTL
137 	int flag;
138 	if((flag = fcntl(s, F_GETFL)) == -1) {
139 		log_err("can't fcntl F_GETFL: %s", strerror(errno));
140 		flag = 0;
141 	}
142 	flag |= O_NONBLOCK;
143 	if(fcntl(s, F_SETFL, flag) == -1) {
144 		log_err("can't fcntl F_SETFL: %s", strerror(errno));
145 		return 0;
146 	}
147 #elif defined(HAVE_IOCTLSOCKET)
148 	unsigned long on = 1;
149 	if(ioctlsocket(s, FIONBIO, &on) != 0) {
150 		log_err("can't ioctlsocket FIONBIO on: %s",
151 			wsa_strerror(WSAGetLastError()));
152 	}
153 #endif
154 	return 1;
155 }
156 
157 int
158 fd_set_block(int s)
159 {
160 #ifdef HAVE_FCNTL
161 	int flag;
162 	if((flag = fcntl(s, F_GETFL)) == -1) {
163 		log_err("cannot fcntl F_GETFL: %s", strerror(errno));
164 		flag = 0;
165 	}
166 	flag &= ~O_NONBLOCK;
167 	if(fcntl(s, F_SETFL, flag) == -1) {
168 		log_err("cannot fcntl F_SETFL: %s", strerror(errno));
169 		return 0;
170 	}
171 #elif defined(HAVE_IOCTLSOCKET)
172 	unsigned long off = 0;
173 	if(ioctlsocket(s, FIONBIO, &off) != 0) {
174 		if(WSAGetLastError() != WSAEINVAL || verbosity >= 4)
175 			log_err("can't ioctlsocket FIONBIO off: %s",
176 				wsa_strerror(WSAGetLastError()));
177 	}
178 #endif
179 	return 1;
180 }
181 
182 int
183 is_pow2(size_t num)
184 {
185 	if(num == 0) return 1;
186 	return (num & (num-1)) == 0;
187 }
188 
189 void*
190 memdup(void* data, size_t len)
191 {
192 	void* d;
193 	if(!data) return NULL;
194 	if(len == 0) return NULL;
195 	d = malloc(len);
196 	if(!d) return NULL;
197 	memcpy(d, data, len);
198 	return d;
199 }
200 
201 void
202 log_addr(enum verbosity_value v, const char* str,
203 	struct sockaddr_storage* addr, socklen_t addrlen)
204 {
205 	uint16_t port;
206 	const char* family = "unknown";
207 	char dest[100];
208 	int af = (int)((struct sockaddr_in*)addr)->sin_family;
209 	void* sinaddr = &((struct sockaddr_in*)addr)->sin_addr;
210 	if(verbosity < v)
211 		return;
212 	switch(af) {
213 		case AF_INET: family="ip4"; break;
214 		case AF_INET6: family="ip6";
215 			sinaddr = &((struct sockaddr_in6*)addr)->sin6_addr;
216 			break;
217 		case AF_LOCAL:
218 			dest[0]=0;
219 			(void)inet_ntop(af, sinaddr, dest,
220 				(socklen_t)sizeof(dest));
221 			verbose(v, "%s local %s", str, dest);
222 			return; /* do not continue and try to get port */
223 		default: break;
224 	}
225 	if(inet_ntop(af, sinaddr, dest, (socklen_t)sizeof(dest)) == 0) {
226 		(void)strlcpy(dest, "(inet_ntop error)", sizeof(dest));
227 	}
228 	dest[sizeof(dest)-1] = 0;
229 	port = ntohs(((struct sockaddr_in*)addr)->sin_port);
230 	if(verbosity >= 4)
231 		verbose(v, "%s %s %s port %d (len %d)", str, family, dest,
232 			(int)port, (int)addrlen);
233 	else	verbose(v, "%s %s port %d", str, dest, (int)port);
234 }
235 
236 int
237 extstrtoaddr(const char* str, struct sockaddr_storage* addr,
238 	socklen_t* addrlen)
239 {
240 	char* s;
241 	int port = UNBOUND_DNS_PORT;
242 	if((s=strchr(str, '@'))) {
243 		char buf[MAX_ADDR_STRLEN];
244 		if(s-str >= MAX_ADDR_STRLEN) {
245 			return 0;
246 		}
247 		(void)strlcpy(buf, str, sizeof(buf));
248 		buf[s-str] = 0;
249 		port = atoi(s+1);
250 		if(port == 0 && strcmp(s+1,"0")!=0) {
251 			return 0;
252 		}
253 		return ipstrtoaddr(buf, port, addr, addrlen);
254 	}
255 	return ipstrtoaddr(str, port, addr, addrlen);
256 }
257 
258 
259 int
260 ipstrtoaddr(const char* ip, int port, struct sockaddr_storage* addr,
261 	socklen_t* addrlen)
262 {
263 	uint16_t p;
264 	if(!ip) return 0;
265 	p = (uint16_t) port;
266 	if(str_is_ip6(ip)) {
267 		char buf[MAX_ADDR_STRLEN];
268 		char* s;
269 		struct sockaddr_in6* sa = (struct sockaddr_in6*)addr;
270 		*addrlen = (socklen_t)sizeof(struct sockaddr_in6);
271 		memset(sa, 0, *addrlen);
272 		sa->sin6_family = AF_INET6;
273 		sa->sin6_port = (in_port_t)htons(p);
274 		if((s=strchr(ip, '%'))) { /* ip6%interface, rfc 4007 */
275 			if(s-ip >= MAX_ADDR_STRLEN)
276 				return 0;
277 			(void)strlcpy(buf, ip, sizeof(buf));
278 			buf[s-ip]=0;
279 #ifdef HAVE_IF_NAMETOINDEX
280 			if (!(sa->sin6_scope_id = if_nametoindex(s+1)))
281 #endif /* HAVE_IF_NAMETOINDEX */
282 				sa->sin6_scope_id = (uint32_t)atoi(s+1);
283 			ip = buf;
284 		}
285 		if(inet_pton((int)sa->sin6_family, ip, &sa->sin6_addr) <= 0) {
286 			return 0;
287 		}
288 	} else { /* ip4 */
289 		struct sockaddr_in* sa = (struct sockaddr_in*)addr;
290 		*addrlen = (socklen_t)sizeof(struct sockaddr_in);
291 		memset(sa, 0, *addrlen);
292 		sa->sin_family = AF_INET;
293 		sa->sin_port = (in_port_t)htons(p);
294 		if(inet_pton((int)sa->sin_family, ip, &sa->sin_addr) <= 0) {
295 			return 0;
296 		}
297 	}
298 	return 1;
299 }
300 
301 int netblockstrtoaddr(const char* str, int port, struct sockaddr_storage* addr,
302         socklen_t* addrlen, int* net)
303 {
304 	char buf[64];
305 	char* s;
306 	*net = (str_is_ip6(str)?128:32);
307 	if((s=strchr(str, '/'))) {
308 		if(atoi(s+1) > *net) {
309 			log_err("netblock too large: %s", str);
310 			return 0;
311 		}
312 		*net = atoi(s+1);
313 		if(*net == 0 && strcmp(s+1, "0") != 0) {
314 			log_err("cannot parse netblock: '%s'", str);
315 			return 0;
316 		}
317 		strlcpy(buf, str, sizeof(buf));
318 		s = strchr(buf, '/');
319 		if(s) *s = 0;
320 		s = buf;
321 	}
322 	if(!ipstrtoaddr(s?s:str, port, addr, addrlen)) {
323 		log_err("cannot parse ip address: '%s'", str);
324 		return 0;
325 	}
326 	if(s) {
327 		addr_mask(addr, *addrlen, *net);
328 	}
329 	return 1;
330 }
331 
332 /* RPZ format address dname to network byte order address */
333 static int ipdnametoaddr(uint8_t* dname, size_t dnamelen,
334 	struct sockaddr_storage* addr, socklen_t* addrlen, int* af)
335 {
336 	uint8_t* ia;
337 	int dnamelabs = dname_count_labels(dname);
338 	uint8_t lablen;
339 	char* e = NULL;
340 	int z = 0;
341 	size_t len = 0;
342 	int i;
343 	*af = AF_INET;
344 
345 	/* need 1 byte for label length */
346 	if(dnamelen < 1)
347 		return 0;
348 
349 	if(dnamelabs > 6 ||
350 		dname_has_label(dname, dnamelen, (uint8_t*)"\002zz")) {
351 		*af = AF_INET6;
352 	}
353 	len = *dname;
354 	lablen = *dname++;
355 	i = (*af == AF_INET) ? 3 : 15;
356 	if(*af == AF_INET6) {
357 		struct sockaddr_in6* sa = (struct sockaddr_in6*)addr;
358 		*addrlen = (socklen_t)sizeof(struct sockaddr_in6);
359 		memset(sa, 0, *addrlen);
360 		sa->sin6_family = AF_INET6;
361 		ia = (uint8_t*)&sa->sin6_addr;
362 	} else { /* ip4 */
363 		struct sockaddr_in* sa = (struct sockaddr_in*)addr;
364 		*addrlen = (socklen_t)sizeof(struct sockaddr_in);
365 		memset(sa, 0, *addrlen);
366 		sa->sin_family = AF_INET;
367 		ia = (uint8_t*)&sa->sin_addr;
368 	}
369 	while(lablen && i >= 0 && len <= dnamelen) {
370 		char buff[LDNS_MAX_LABELLEN+1];
371 		uint16_t chunk; /* big enough to not overflow on IPv6 hextet */
372 		if((*af == AF_INET && (lablen > 3 || dnamelabs > 6)) ||
373 			(*af == AF_INET6 && (lablen > 4 || dnamelabs > 10))) {
374 			return 0;
375 		}
376 		if(memcmp(dname, "zz", 2) == 0 && *af == AF_INET6) {
377 			/* Add one or more 0 labels. Address is initialised at
378 			 * 0, so just skip the zero part. */
379 			int zl = 11 - dnamelabs;
380 			if(z || zl < 0)
381 				return 0;
382 			z = 1;
383 			i -= (zl*2);
384 		} else {
385 			memcpy(buff, dname, lablen);
386 			buff[lablen] = '\0';
387 			chunk = strtol(buff, &e, (*af == AF_INET) ? 10 : 16);
388 			if(!e || *e != '\0' || (*af == AF_INET && chunk > 255))
389 				return 0;
390 			if(*af == AF_INET) {
391 				log_assert(i < 4 && i >= 0);
392 				ia[i] = (uint8_t)chunk;
393 				i--;
394 			} else {
395 				log_assert(i < 16 && i >= 1);
396 				/* ia in network byte order */
397 				ia[i-1] = (uint8_t)(chunk >> 8);
398 				ia[i] = (uint8_t)(chunk & 0x00FF);
399 				i -= 2;
400 			}
401 		}
402 		dname += lablen;
403 		lablen = *dname++;
404 		len += lablen;
405 	}
406 	if(i != -1)
407 		/* input too short */
408 		return 0;
409 	return 1;
410 }
411 
412 int netblockdnametoaddr(uint8_t* dname, size_t dnamelen,
413 	struct sockaddr_storage* addr, socklen_t* addrlen, int* net, int* af)
414 {
415 	char buff[3 /* 3 digit netblock */ + 1];
416 	size_t nlablen;
417 	if(dnamelen < 1 || *dname > 3)
418 		/* netblock invalid */
419 		return 0;
420 	nlablen = *dname;
421 
422 	if(dnamelen < 1 + nlablen)
423 		return 0;
424 
425 	memcpy(buff, dname+1, nlablen);
426 	buff[nlablen] = '\0';
427 	*net = atoi(buff);
428 	if(*net == 0 && strcmp(buff, "0") != 0)
429 		return 0;
430 	dname += nlablen;
431 	dname++;
432 	if(!ipdnametoaddr(dname, dnamelen-1-nlablen, addr, addrlen, af))
433 		return 0;
434 	if((*af == AF_INET6 && *net > 128) || (*af == AF_INET && *net > 32))
435 		return 0;
436 	return 1;
437 }
438 
439 int authextstrtoaddr(char* str, struct sockaddr_storage* addr,
440 	socklen_t* addrlen, char** auth_name)
441 {
442 	char* s;
443 	int port = UNBOUND_DNS_PORT;
444 	if((s=strchr(str, '@'))) {
445 		char buf[MAX_ADDR_STRLEN];
446 		size_t len = (size_t)(s-str);
447 		char* hash = strchr(s+1, '#');
448 		if(hash) {
449 			*auth_name = hash+1;
450 		} else {
451 			*auth_name = NULL;
452 		}
453 		if(len >= MAX_ADDR_STRLEN) {
454 			return 0;
455 		}
456 		(void)strlcpy(buf, str, sizeof(buf));
457 		buf[len] = 0;
458 		port = atoi(s+1);
459 		if(port == 0) {
460 			if(!hash && strcmp(s+1,"0")!=0)
461 				return 0;
462 			if(hash && strncmp(s+1,"0#",2)!=0)
463 				return 0;
464 		}
465 		return ipstrtoaddr(buf, port, addr, addrlen);
466 	}
467 	if((s=strchr(str, '#'))) {
468 		char buf[MAX_ADDR_STRLEN];
469 		size_t len = (size_t)(s-str);
470 		if(len >= MAX_ADDR_STRLEN) {
471 			return 0;
472 		}
473 		(void)strlcpy(buf, str, sizeof(buf));
474 		buf[len] = 0;
475 		port = UNBOUND_DNS_OVER_TLS_PORT;
476 		*auth_name = s+1;
477 		return ipstrtoaddr(buf, port, addr, addrlen);
478 	}
479 	*auth_name = NULL;
480 	return ipstrtoaddr(str, port, addr, addrlen);
481 }
482 
483 uint8_t* authextstrtodname(char* str, int* port, char** auth_name)
484 {
485 	char* s;
486 	uint8_t* dname;
487 	size_t dname_len;
488 	*port = UNBOUND_DNS_PORT;
489 	*auth_name = NULL;
490 	if((s=strchr(str, '@'))) {
491 		char* hash = strchr(s+1, '#');
492 		if(hash) {
493 			*auth_name = hash+1;
494 		} else {
495 			*auth_name = NULL;
496 		}
497 		*port = atoi(s+1);
498 		if(*port == 0) {
499 			if(!hash && strcmp(s+1,"0")!=0)
500 				return 0;
501 			if(hash && strncmp(s+1,"0#",2)!=0)
502 				return 0;
503 		}
504 		*s = 0;
505 		dname = sldns_str2wire_dname(str, &dname_len);
506 		*s = '@';
507 	} else if((s=strchr(str, '#'))) {
508 		*port = UNBOUND_DNS_OVER_TLS_PORT;
509 		*auth_name = s+1;
510 		*s = 0;
511 		dname = sldns_str2wire_dname(str, &dname_len);
512 		*s = '#';
513 	} else {
514 		dname = sldns_str2wire_dname(str, &dname_len);
515 	}
516 	return dname;
517 }
518 
519 /** store port number into sockaddr structure */
520 void
521 sockaddr_store_port(struct sockaddr_storage* addr, socklen_t addrlen, int port)
522 {
523 	if(addr_is_ip6(addr, addrlen)) {
524 		struct sockaddr_in6* sa = (struct sockaddr_in6*)addr;
525 		sa->sin6_port = (in_port_t)htons((uint16_t)port);
526 	} else {
527 		struct sockaddr_in* sa = (struct sockaddr_in*)addr;
528 		sa->sin_port = (in_port_t)htons((uint16_t)port);
529 	}
530 }
531 
532 void
533 log_nametypeclass(enum verbosity_value v, const char* str, uint8_t* name,
534 	uint16_t type, uint16_t dclass)
535 {
536 	char buf[LDNS_MAX_DOMAINLEN+1];
537 	char t[12], c[12];
538 	const char *ts, *cs;
539 	if(verbosity < v)
540 		return;
541 	dname_str(name, buf);
542 	if(type == LDNS_RR_TYPE_TSIG) ts = "TSIG";
543 	else if(type == LDNS_RR_TYPE_IXFR) ts = "IXFR";
544 	else if(type == LDNS_RR_TYPE_AXFR) ts = "AXFR";
545 	else if(type == LDNS_RR_TYPE_MAILB) ts = "MAILB";
546 	else if(type == LDNS_RR_TYPE_MAILA) ts = "MAILA";
547 	else if(type == LDNS_RR_TYPE_ANY) ts = "ANY";
548 	else if(sldns_rr_descript(type) && sldns_rr_descript(type)->_name)
549 		ts = sldns_rr_descript(type)->_name;
550 	else {
551 		snprintf(t, sizeof(t), "TYPE%d", (int)type);
552 		ts = t;
553 	}
554 	if(sldns_lookup_by_id(sldns_rr_classes, (int)dclass) &&
555 		sldns_lookup_by_id(sldns_rr_classes, (int)dclass)->name)
556 		cs = sldns_lookup_by_id(sldns_rr_classes, (int)dclass)->name;
557 	else {
558 		snprintf(c, sizeof(c), "CLASS%d", (int)dclass);
559 		cs = c;
560 	}
561 	log_info("%s %s %s %s", str, buf, ts, cs);
562 }
563 
564 void
565 log_query_in(const char* str, uint8_t* name, uint16_t type, uint16_t dclass)
566 {
567 	char buf[LDNS_MAX_DOMAINLEN+1];
568 	char t[12], c[12];
569 	const char *ts, *cs;
570 	dname_str(name, buf);
571 	if(type == LDNS_RR_TYPE_TSIG) ts = "TSIG";
572 	else if(type == LDNS_RR_TYPE_IXFR) ts = "IXFR";
573 	else if(type == LDNS_RR_TYPE_AXFR) ts = "AXFR";
574 	else if(type == LDNS_RR_TYPE_MAILB) ts = "MAILB";
575 	else if(type == LDNS_RR_TYPE_MAILA) ts = "MAILA";
576 	else if(type == LDNS_RR_TYPE_ANY) ts = "ANY";
577 	else if(sldns_rr_descript(type) && sldns_rr_descript(type)->_name)
578 		ts = sldns_rr_descript(type)->_name;
579 	else {
580 		snprintf(t, sizeof(t), "TYPE%d", (int)type);
581 		ts = t;
582 	}
583 	if(sldns_lookup_by_id(sldns_rr_classes, (int)dclass) &&
584 		sldns_lookup_by_id(sldns_rr_classes, (int)dclass)->name)
585 		cs = sldns_lookup_by_id(sldns_rr_classes, (int)dclass)->name;
586 	else {
587 		snprintf(c, sizeof(c), "CLASS%d", (int)dclass);
588 		cs = c;
589 	}
590 	if(LOG_TAG_QUERYREPLY)
591 		log_query("%s %s %s %s", str, buf, ts, cs);
592 	else	log_info("%s %s %s %s", str, buf, ts, cs);
593 }
594 
595 void log_name_addr(enum verbosity_value v, const char* str, uint8_t* zone,
596 	struct sockaddr_storage* addr, socklen_t addrlen)
597 {
598 	uint16_t port;
599 	const char* family = "unknown_family ";
600 	char namebuf[LDNS_MAX_DOMAINLEN+1];
601 	char dest[100];
602 	int af = (int)((struct sockaddr_in*)addr)->sin_family;
603 	void* sinaddr = &((struct sockaddr_in*)addr)->sin_addr;
604 	if(verbosity < v)
605 		return;
606 	switch(af) {
607 		case AF_INET: family=""; break;
608 		case AF_INET6: family="";
609 			sinaddr = &((struct sockaddr_in6*)addr)->sin6_addr;
610 			break;
611 		case AF_LOCAL: family="local "; break;
612 		default: break;
613 	}
614 	if(inet_ntop(af, sinaddr, dest, (socklen_t)sizeof(dest)) == 0) {
615 		(void)strlcpy(dest, "(inet_ntop error)", sizeof(dest));
616 	}
617 	dest[sizeof(dest)-1] = 0;
618 	port = ntohs(((struct sockaddr_in*)addr)->sin_port);
619 	dname_str(zone, namebuf);
620 	if(af != AF_INET && af != AF_INET6)
621 		verbose(v, "%s <%s> %s%s#%d (addrlen %d)",
622 			str, namebuf, family, dest, (int)port, (int)addrlen);
623 	else	verbose(v, "%s <%s> %s%s#%d",
624 			str, namebuf, family, dest, (int)port);
625 }
626 
627 void log_err_addr(const char* str, const char* err,
628 	struct sockaddr_storage* addr, socklen_t addrlen)
629 {
630 	uint16_t port;
631 	char dest[100];
632 	int af = (int)((struct sockaddr_in*)addr)->sin_family;
633 	void* sinaddr = &((struct sockaddr_in*)addr)->sin_addr;
634 	if(af == AF_INET6)
635 		sinaddr = &((struct sockaddr_in6*)addr)->sin6_addr;
636 	if(inet_ntop(af, sinaddr, dest, (socklen_t)sizeof(dest)) == 0) {
637 		(void)strlcpy(dest, "(inet_ntop error)", sizeof(dest));
638 	}
639 	dest[sizeof(dest)-1] = 0;
640 	port = ntohs(((struct sockaddr_in*)addr)->sin_port);
641 	if(verbosity >= 4)
642 		log_err("%s: %s for %s port %d (len %d)", str, err, dest,
643 			(int)port, (int)addrlen);
644 	else	log_err("%s: %s for %s port %d", str, err, dest, (int)port);
645 }
646 
647 int
648 sockaddr_cmp(struct sockaddr_storage* addr1, socklen_t len1,
649 	struct sockaddr_storage* addr2, socklen_t len2)
650 {
651 	struct sockaddr_in* p1_in = (struct sockaddr_in*)addr1;
652 	struct sockaddr_in* p2_in = (struct sockaddr_in*)addr2;
653 	struct sockaddr_in6* p1_in6 = (struct sockaddr_in6*)addr1;
654 	struct sockaddr_in6* p2_in6 = (struct sockaddr_in6*)addr2;
655 	if(len1 < len2)
656 		return -1;
657 	if(len1 > len2)
658 		return 1;
659 	log_assert(len1 == len2);
660 	if( p1_in->sin_family < p2_in->sin_family)
661 		return -1;
662 	if( p1_in->sin_family > p2_in->sin_family)
663 		return 1;
664 	log_assert( p1_in->sin_family == p2_in->sin_family );
665 	/* compare ip4 */
666 	if( p1_in->sin_family == AF_INET ) {
667 		/* just order it, ntohs not required */
668 		if(p1_in->sin_port < p2_in->sin_port)
669 			return -1;
670 		if(p1_in->sin_port > p2_in->sin_port)
671 			return 1;
672 		log_assert(p1_in->sin_port == p2_in->sin_port);
673 		return memcmp(&p1_in->sin_addr, &p2_in->sin_addr, INET_SIZE);
674 	} else if (p1_in6->sin6_family == AF_INET6) {
675 		/* just order it, ntohs not required */
676 		if(p1_in6->sin6_port < p2_in6->sin6_port)
677 			return -1;
678 		if(p1_in6->sin6_port > p2_in6->sin6_port)
679 			return 1;
680 		log_assert(p1_in6->sin6_port == p2_in6->sin6_port);
681 		return memcmp(&p1_in6->sin6_addr, &p2_in6->sin6_addr,
682 			INET6_SIZE);
683 	} else {
684 		/* eek unknown type, perform this comparison for sanity. */
685 		return memcmp(addr1, addr2, len1);
686 	}
687 }
688 
689 int
690 sockaddr_cmp_addr(struct sockaddr_storage* addr1, socklen_t len1,
691 	struct sockaddr_storage* addr2, socklen_t len2)
692 {
693 	struct sockaddr_in* p1_in = (struct sockaddr_in*)addr1;
694 	struct sockaddr_in* p2_in = (struct sockaddr_in*)addr2;
695 	struct sockaddr_in6* p1_in6 = (struct sockaddr_in6*)addr1;
696 	struct sockaddr_in6* p2_in6 = (struct sockaddr_in6*)addr2;
697 	if(len1 < len2)
698 		return -1;
699 	if(len1 > len2)
700 		return 1;
701 	log_assert(len1 == len2);
702 	if( p1_in->sin_family < p2_in->sin_family)
703 		return -1;
704 	if( p1_in->sin_family > p2_in->sin_family)
705 		return 1;
706 	log_assert( p1_in->sin_family == p2_in->sin_family );
707 	/* compare ip4 */
708 	if( p1_in->sin_family == AF_INET ) {
709 		return memcmp(&p1_in->sin_addr, &p2_in->sin_addr, INET_SIZE);
710 	} else if (p1_in6->sin6_family == AF_INET6) {
711 		return memcmp(&p1_in6->sin6_addr, &p2_in6->sin6_addr,
712 			INET6_SIZE);
713 	} else {
714 		/* eek unknown type, perform this comparison for sanity. */
715 		return memcmp(addr1, addr2, len1);
716 	}
717 }
718 
719 int
720 addr_is_ip6(struct sockaddr_storage* addr, socklen_t len)
721 {
722 	if(len == (socklen_t)sizeof(struct sockaddr_in6) &&
723 		((struct sockaddr_in6*)addr)->sin6_family == AF_INET6)
724 		return 1;
725 	else    return 0;
726 }
727 
728 void
729 addr_mask(struct sockaddr_storage* addr, socklen_t len, int net)
730 {
731 	uint8_t mask[8] = {0x0, 0x80, 0xc0, 0xe0, 0xf0, 0xf8, 0xfc, 0xfe};
732 	int i, max;
733 	uint8_t* s;
734 	if(addr_is_ip6(addr, len)) {
735 		s = (uint8_t*)&((struct sockaddr_in6*)addr)->sin6_addr;
736 		max = 128;
737 	} else {
738 		s = (uint8_t*)&((struct sockaddr_in*)addr)->sin_addr;
739 		max = 32;
740 	}
741 	if(net >= max)
742 		return;
743 	for(i=net/8+1; i<max/8; i++) {
744 		s[i] = 0;
745 	}
746 	s[net/8] &= mask[net&0x7];
747 }
748 
749 int
750 addr_in_common(struct sockaddr_storage* addr1, int net1,
751 	struct sockaddr_storage* addr2, int net2, socklen_t addrlen)
752 {
753 	int min = (net1<net2)?net1:net2;
754 	int i, to;
755 	int match = 0;
756 	uint8_t* s1, *s2;
757 	if(addr_is_ip6(addr1, addrlen)) {
758 		s1 = (uint8_t*)&((struct sockaddr_in6*)addr1)->sin6_addr;
759 		s2 = (uint8_t*)&((struct sockaddr_in6*)addr2)->sin6_addr;
760 		to = 16;
761 	} else {
762 		s1 = (uint8_t*)&((struct sockaddr_in*)addr1)->sin_addr;
763 		s2 = (uint8_t*)&((struct sockaddr_in*)addr2)->sin_addr;
764 		to = 4;
765 	}
766 	/* match = bits_in_common(s1, s2, to); */
767 	for(i=0; i<to; i++) {
768 		if(s1[i] == s2[i]) {
769 			match += 8;
770 		} else {
771 			uint8_t z = s1[i]^s2[i];
772 			log_assert(z);
773 			while(!(z&0x80)) {
774 				match++;
775 				z<<=1;
776 			}
777 			break;
778 		}
779 	}
780 	if(match > min) match = min;
781 	return match;
782 }
783 
784 void
785 addr_to_str(struct sockaddr_storage* addr, socklen_t addrlen,
786 	char* buf, size_t len)
787 {
788 	int af = (int)((struct sockaddr_in*)addr)->sin_family;
789 	void* sinaddr = &((struct sockaddr_in*)addr)->sin_addr;
790 	if(addr_is_ip6(addr, addrlen))
791 		sinaddr = &((struct sockaddr_in6*)addr)->sin6_addr;
792 	if(inet_ntop(af, sinaddr, buf, (socklen_t)len) == 0) {
793 		snprintf(buf, len, "(inet_ntop_error)");
794 	}
795 }
796 
797 int
798 addr_is_ip4mapped(struct sockaddr_storage* addr, socklen_t addrlen)
799 {
800 	/* prefix for ipv4 into ipv6 mapping is ::ffff:x.x.x.x */
801 	const uint8_t map_prefix[16] =
802 		{0,0,0,0,  0,0,0,0, 0,0,0xff,0xff, 0,0,0,0};
803 	uint8_t* s;
804 	if(!addr_is_ip6(addr, addrlen))
805 		return 0;
806 	/* s is 16 octet ipv6 address string */
807 	s = (uint8_t*)&((struct sockaddr_in6*)addr)->sin6_addr;
808 	return (memcmp(s, map_prefix, 12) == 0);
809 }
810 
811 int addr_is_broadcast(struct sockaddr_storage* addr, socklen_t addrlen)
812 {
813 	int af = (int)((struct sockaddr_in*)addr)->sin_family;
814 	void* sinaddr = &((struct sockaddr_in*)addr)->sin_addr;
815 	return af == AF_INET && addrlen>=(socklen_t)sizeof(struct sockaddr_in)
816 		&& memcmp(sinaddr, "\377\377\377\377", 4) == 0;
817 }
818 
819 int addr_is_any(struct sockaddr_storage* addr, socklen_t addrlen)
820 {
821 	int af = (int)((struct sockaddr_in*)addr)->sin_family;
822 	void* sinaddr = &((struct sockaddr_in*)addr)->sin_addr;
823 	void* sin6addr = &((struct sockaddr_in6*)addr)->sin6_addr;
824 	if(af == AF_INET && addrlen>=(socklen_t)sizeof(struct sockaddr_in)
825 		&& memcmp(sinaddr, "\000\000\000\000", 4) == 0)
826 		return 1;
827 	else if(af==AF_INET6 && addrlen>=(socklen_t)sizeof(struct sockaddr_in6)
828 		&& memcmp(sin6addr, "\000\000\000\000\000\000\000\000"
829 		"\000\000\000\000\000\000\000\000", 16) == 0)
830 		return 1;
831 	return 0;
832 }
833 
834 void sock_list_insert(struct sock_list** list, struct sockaddr_storage* addr,
835 	socklen_t len, struct regional* region)
836 {
837 	struct sock_list* add = (struct sock_list*)regional_alloc(region,
838 		sizeof(*add) - sizeof(add->addr) + (size_t)len);
839 	if(!add) {
840 		log_err("out of memory in socketlist insert");
841 		return;
842 	}
843 	log_assert(list);
844 	add->next = *list;
845 	add->len = len;
846 	*list = add;
847 	if(len) memmove(&add->addr, addr, len);
848 }
849 
850 void sock_list_prepend(struct sock_list** list, struct sock_list* add)
851 {
852 	struct sock_list* last = add;
853 	if(!last)
854 		return;
855 	while(last->next)
856 		last = last->next;
857 	last->next = *list;
858 	*list = add;
859 }
860 
861 int sock_list_find(struct sock_list* list, struct sockaddr_storage* addr,
862         socklen_t len)
863 {
864 	while(list) {
865 		if(len == list->len) {
866 			if(len == 0 || sockaddr_cmp_addr(addr, len,
867 				&list->addr, list->len) == 0)
868 				return 1;
869 		}
870 		list = list->next;
871 	}
872 	return 0;
873 }
874 
875 void sock_list_merge(struct sock_list** list, struct regional* region,
876 	struct sock_list* add)
877 {
878 	struct sock_list* p;
879 	for(p=add; p; p=p->next) {
880 		if(!sock_list_find(*list, &p->addr, p->len))
881 			sock_list_insert(list, &p->addr, p->len, region);
882 	}
883 }
884 
885 void
886 log_crypto_err(const char* str)
887 {
888 #ifdef HAVE_SSL
889 	log_crypto_err_code(str, ERR_get_error());
890 #else
891 	(void)str;
892 #endif /* HAVE_SSL */
893 }
894 
895 void log_crypto_err_code(const char* str, unsigned long err)
896 {
897 #ifdef HAVE_SSL
898 	/* error:[error code]:[library name]:[function name]:[reason string] */
899 	char buf[128];
900 	unsigned long e;
901 	ERR_error_string_n(err, buf, sizeof(buf));
902 	log_err("%s crypto %s", str, buf);
903 	while( (e=ERR_get_error()) ) {
904 		ERR_error_string_n(e, buf, sizeof(buf));
905 		log_err("and additionally crypto %s", buf);
906 	}
907 #else
908 	(void)str;
909 	(void)err;
910 #endif /* HAVE_SSL */
911 }
912 
913 #ifdef HAVE_SSL
914 /** log certificate details */
915 void
916 log_cert(unsigned level, const char* str, void* cert)
917 {
918 	BIO* bio;
919 	char nul = 0;
920 	char* pp = NULL;
921 	long len;
922 	if(verbosity < level) return;
923 	bio = BIO_new(BIO_s_mem());
924 	if(!bio) return;
925 	X509_print_ex(bio, (X509*)cert, 0, (unsigned long)-1
926 		^(X509_FLAG_NO_SUBJECT
927                         |X509_FLAG_NO_ISSUER|X509_FLAG_NO_VALIDITY
928 			|X509_FLAG_NO_EXTENSIONS|X509_FLAG_NO_AUX
929 			|X509_FLAG_NO_ATTRIBUTES));
930 	BIO_write(bio, &nul, (int)sizeof(nul));
931 	len = BIO_get_mem_data(bio, &pp);
932 	if(len != 0 && pp) {
933 		/* reduce size of cert printout */
934 		char* s;
935 		while((s=strstr(pp, "  "))!=NULL)
936 			memmove(s, s+1, strlen(s+1)+1);
937 		while((s=strstr(pp, "\t\t"))!=NULL)
938 			memmove(s, s+1, strlen(s+1)+1);
939 		verbose(level, "%s: \n%s", str, pp);
940 	}
941 	BIO_free(bio);
942 }
943 #endif /* HAVE_SSL */
944 
945 #if defined(HAVE_SSL) && defined(HAVE_NGHTTP2) && defined(HAVE_SSL_CTX_SET_ALPN_SELECT_CB)
946 static int alpn_select_cb(SSL* ATTR_UNUSED(ssl), const unsigned char** out,
947 	unsigned char* outlen, const unsigned char* in, unsigned int inlen,
948 	void* ATTR_UNUSED(arg))
949 {
950 	int rv = nghttp2_select_next_protocol((unsigned char **)out, outlen, in,
951 		inlen);
952 	if(rv == -1) {
953 		return SSL_TLSEXT_ERR_NOACK;
954 	}
955 	/* either http/1.1 or h2 selected */
956 	return SSL_TLSEXT_ERR_OK;
957 }
958 #endif
959 
960 int
961 listen_sslctx_setup(void* ctxt)
962 {
963 #ifdef HAVE_SSL
964 	SSL_CTX* ctx = (SSL_CTX*)ctxt;
965 	/* no SSLv2, SSLv3 because has defects */
966 #if SSL_OP_NO_SSLv2 != 0
967 	if((SSL_CTX_set_options(ctx, SSL_OP_NO_SSLv2) & SSL_OP_NO_SSLv2)
968 		!= SSL_OP_NO_SSLv2){
969 		log_crypto_err("could not set SSL_OP_NO_SSLv2");
970 		return 0;
971 	}
972 #endif
973 	if((SSL_CTX_set_options(ctx, SSL_OP_NO_SSLv3) & SSL_OP_NO_SSLv3)
974 		!= SSL_OP_NO_SSLv3){
975 		log_crypto_err("could not set SSL_OP_NO_SSLv3");
976 		return 0;
977 	}
978 #if defined(SSL_OP_NO_TLSv1) && defined(SSL_OP_NO_TLSv1_1)
979 	/* if we have tls 1.1 disable 1.0 */
980 	if((SSL_CTX_set_options(ctx, SSL_OP_NO_TLSv1) & SSL_OP_NO_TLSv1)
981 		!= SSL_OP_NO_TLSv1){
982 		log_crypto_err("could not set SSL_OP_NO_TLSv1");
983 		return 0;
984 	}
985 #endif
986 #if defined(SSL_OP_NO_TLSv1_1) && defined(SSL_OP_NO_TLSv1_2)
987 	/* if we have tls 1.2 disable 1.1 */
988 	if((SSL_CTX_set_options(ctx, SSL_OP_NO_TLSv1_1) & SSL_OP_NO_TLSv1_1)
989 		!= SSL_OP_NO_TLSv1_1){
990 		log_crypto_err("could not set SSL_OP_NO_TLSv1_1");
991 		return 0;
992 	}
993 #endif
994 #if defined(SSL_OP_NO_RENEGOTIATION)
995 	/* disable client renegotiation */
996 	if((SSL_CTX_set_options(ctx, SSL_OP_NO_RENEGOTIATION) &
997 		SSL_OP_NO_RENEGOTIATION) != SSL_OP_NO_RENEGOTIATION) {
998 		log_crypto_err("could not set SSL_OP_NO_RENEGOTIATION");
999 		return 0;
1000 	}
1001 #endif
1002 #if defined(SHA256_DIGEST_LENGTH) && defined(USE_ECDSA)
1003 	/* if we detect system-wide crypto policies, use those */
1004 	if (access( "/etc/crypto-policies/config", F_OK ) != 0 ) {
1005 	/* if we have sha256, set the cipher list to have no known vulns */
1006 		if(!SSL_CTX_set_cipher_list(ctx, "TLS13-CHACHA20-POLY1305-SHA256:TLS13-AES-256-GCM-SHA384:TLS13-AES-128-GCM-SHA256:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256"))
1007 			log_crypto_err("could not set cipher list with SSL_CTX_set_cipher_list");
1008 	}
1009 #endif
1010 
1011 	if((SSL_CTX_set_options(ctx, SSL_OP_CIPHER_SERVER_PREFERENCE) &
1012 		SSL_OP_CIPHER_SERVER_PREFERENCE) !=
1013 		SSL_OP_CIPHER_SERVER_PREFERENCE) {
1014 		log_crypto_err("could not set SSL_OP_CIPHER_SERVER_PREFERENCE");
1015 		return 0;
1016 	}
1017 
1018 #ifdef HAVE_SSL_CTX_SET_SECURITY_LEVEL
1019 	SSL_CTX_set_security_level(ctx, 0);
1020 #endif
1021 #if defined(HAVE_SSL_CTX_SET_ALPN_SELECT_CB) && defined(HAVE_NGHTTP2)
1022 	SSL_CTX_set_alpn_select_cb(ctx, alpn_select_cb, NULL);
1023 #endif
1024 #else
1025 	(void)ctxt;
1026 #endif /* HAVE_SSL */
1027 	return 1;
1028 }
1029 
1030 void
1031 listen_sslctx_setup_2(void* ctxt)
1032 {
1033 #ifdef HAVE_SSL
1034 	SSL_CTX* ctx = (SSL_CTX*)ctxt;
1035 	(void)ctx;
1036 #if HAVE_DECL_SSL_CTX_SET_ECDH_AUTO
1037 	if(!SSL_CTX_set_ecdh_auto(ctx,1)) {
1038 		log_crypto_err("Error in SSL_CTX_ecdh_auto, not enabling ECDHE");
1039 	}
1040 #elif defined(USE_ECDSA)
1041 	if(1) {
1042 		EC_KEY *ecdh = EC_KEY_new_by_curve_name (NID_X9_62_prime256v1);
1043 		if (!ecdh) {
1044 			log_crypto_err("could not find p256, not enabling ECDHE");
1045 		} else {
1046 			if (1 != SSL_CTX_set_tmp_ecdh (ctx, ecdh)) {
1047 				log_crypto_err("Error in SSL_CTX_set_tmp_ecdh, not enabling ECDHE");
1048 			}
1049 			EC_KEY_free (ecdh);
1050 		}
1051 	}
1052 #endif
1053 #else
1054 	(void)ctxt;
1055 #endif /* HAVE_SSL */
1056 }
1057 
1058 void* listen_sslctx_create(char* key, char* pem, char* verifypem)
1059 {
1060 #ifdef HAVE_SSL
1061 	SSL_CTX* ctx = SSL_CTX_new(SSLv23_server_method());
1062 	if(!ctx) {
1063 		log_crypto_err("could not SSL_CTX_new");
1064 		return NULL;
1065 	}
1066 	if(!key || key[0] == 0) {
1067 		log_err("error: no tls-service-key file specified");
1068 		SSL_CTX_free(ctx);
1069 		return NULL;
1070 	}
1071 	if(!pem || pem[0] == 0) {
1072 		log_err("error: no tls-service-pem file specified");
1073 		SSL_CTX_free(ctx);
1074 		return NULL;
1075 	}
1076 	if(!listen_sslctx_setup(ctx)) {
1077 		SSL_CTX_free(ctx);
1078 		return NULL;
1079 	}
1080 	if(!SSL_CTX_use_certificate_chain_file(ctx, pem)) {
1081 		log_err("error for cert file: %s", pem);
1082 		log_crypto_err("error in SSL_CTX use_certificate_chain_file");
1083 		SSL_CTX_free(ctx);
1084 		return NULL;
1085 	}
1086 	if(!SSL_CTX_use_PrivateKey_file(ctx, key, SSL_FILETYPE_PEM)) {
1087 		log_err("error for private key file: %s", key);
1088 		log_crypto_err("Error in SSL_CTX use_PrivateKey_file");
1089 		SSL_CTX_free(ctx);
1090 		return NULL;
1091 	}
1092 	if(!SSL_CTX_check_private_key(ctx)) {
1093 		log_err("error for key file: %s", key);
1094 		log_crypto_err("Error in SSL_CTX check_private_key");
1095 		SSL_CTX_free(ctx);
1096 		return NULL;
1097 	}
1098 	listen_sslctx_setup_2(ctx);
1099 	if(verifypem && verifypem[0]) {
1100 		if(!SSL_CTX_load_verify_locations(ctx, verifypem, NULL)) {
1101 			log_crypto_err("Error in SSL_CTX verify locations");
1102 			SSL_CTX_free(ctx);
1103 			return NULL;
1104 		}
1105 		SSL_CTX_set_client_CA_list(ctx, SSL_load_client_CA_file(
1106 			verifypem));
1107 		SSL_CTX_set_verify(ctx, SSL_VERIFY_PEER|SSL_VERIFY_FAIL_IF_NO_PEER_CERT, NULL);
1108 	}
1109 	return ctx;
1110 #else
1111 	(void)key; (void)pem; (void)verifypem;
1112 	return NULL;
1113 #endif
1114 }
1115 
1116 #ifdef USE_WINSOCK
1117 /* For windows, the CA trust store is not read by openssl.
1118    Add code to open the trust store using wincrypt API and add
1119    the root certs into openssl trust store */
1120 static int
1121 add_WIN_cacerts_to_openssl_store(SSL_CTX* tls_ctx)
1122 {
1123 	HCERTSTORE      hSystemStore;
1124 	PCCERT_CONTEXT  pTargetCert = NULL;
1125 	X509_STORE*	store;
1126 
1127 	verbose(VERB_ALGO, "Adding Windows certificates from system root store to CA store");
1128 
1129 	/* load just once per context lifetime for this version
1130 	   TODO: dynamically update CA trust changes as they are available */
1131 	if (!tls_ctx)
1132 		return 0;
1133 
1134 	/* Call wincrypt's CertOpenStore to open the CA root store. */
1135 
1136 	if ((hSystemStore = CertOpenStore(
1137 		CERT_STORE_PROV_SYSTEM,
1138 		0,
1139 		0,
1140 		/* NOTE: mingw does not have this const: replace with 1 << 16 from code
1141 		   CERT_SYSTEM_STORE_CURRENT_USER, */
1142 		1 << 16,
1143 		L"root")) == 0)
1144 	{
1145 		return 0;
1146 	}
1147 
1148 	store = SSL_CTX_get_cert_store(tls_ctx);
1149 	if (!store)
1150 		return 0;
1151 
1152 	/* failure if the CA store is empty or the call fails */
1153 	if ((pTargetCert = CertEnumCertificatesInStore(
1154 		hSystemStore, pTargetCert)) == 0) {
1155 		verbose(VERB_ALGO, "CA certificate store for Windows is empty.");
1156 		return 0;
1157 	}
1158 	/* iterate over the windows cert store and add to openssl store */
1159 	do
1160 	{
1161 		X509 *cert1 = d2i_X509(NULL,
1162 			(const unsigned char **)&pTargetCert->pbCertEncoded,
1163 			pTargetCert->cbCertEncoded);
1164 		if (!cert1) {
1165 			/* return error if a cert fails */
1166 			verbose(VERB_ALGO, "%s %d:%s",
1167 				"Unable to parse certificate in memory",
1168 				(int)ERR_get_error(), ERR_error_string(ERR_get_error(), NULL));
1169 			return 0;
1170 		}
1171 		else {
1172 			/* return error if a cert add to store fails */
1173 			if (X509_STORE_add_cert(store, cert1) == 0) {
1174 				unsigned long error = ERR_peek_last_error();
1175 
1176 				/* Ignore error X509_R_CERT_ALREADY_IN_HASH_TABLE which means the
1177 				* certificate is already in the store.  */
1178 				if(ERR_GET_LIB(error) != ERR_LIB_X509 ||
1179 				   ERR_GET_REASON(error) != X509_R_CERT_ALREADY_IN_HASH_TABLE) {
1180 					verbose(VERB_ALGO, "%s %d:%s\n",
1181 					    "Error adding certificate", (int)ERR_get_error(),
1182 					     ERR_error_string(ERR_get_error(), NULL));
1183 					X509_free(cert1);
1184 					return 0;
1185 				}
1186 			}
1187 			X509_free(cert1);
1188 		}
1189 	} while ((pTargetCert = CertEnumCertificatesInStore(
1190 		hSystemStore, pTargetCert)) != 0);
1191 
1192 	/* Clean up memory and quit. */
1193 	if (pTargetCert)
1194 		CertFreeCertificateContext(pTargetCert);
1195 	if (hSystemStore)
1196 	{
1197 		if (!CertCloseStore(
1198 			hSystemStore, 0))
1199 			return 0;
1200 	}
1201 	verbose(VERB_ALGO, "Completed adding Windows certificates to CA store successfully");
1202 	return 1;
1203 }
1204 #endif /* USE_WINSOCK */
1205 
1206 void* connect_sslctx_create(char* key, char* pem, char* verifypem, int wincert)
1207 {
1208 #ifdef HAVE_SSL
1209 	SSL_CTX* ctx = SSL_CTX_new(SSLv23_client_method());
1210 	if(!ctx) {
1211 		log_crypto_err("could not allocate SSL_CTX pointer");
1212 		return NULL;
1213 	}
1214 #if SSL_OP_NO_SSLv2 != 0
1215 	if((SSL_CTX_set_options(ctx, SSL_OP_NO_SSLv2) & SSL_OP_NO_SSLv2)
1216 		!= SSL_OP_NO_SSLv2) {
1217 		log_crypto_err("could not set SSL_OP_NO_SSLv2");
1218 		SSL_CTX_free(ctx);
1219 		return NULL;
1220 	}
1221 #endif
1222 	if((SSL_CTX_set_options(ctx, SSL_OP_NO_SSLv3) & SSL_OP_NO_SSLv3)
1223 		!= SSL_OP_NO_SSLv3) {
1224 		log_crypto_err("could not set SSL_OP_NO_SSLv3");
1225 		SSL_CTX_free(ctx);
1226 		return NULL;
1227 	}
1228 #if defined(SSL_OP_NO_RENEGOTIATION)
1229 	/* disable client renegotiation */
1230 	if((SSL_CTX_set_options(ctx, SSL_OP_NO_RENEGOTIATION) &
1231 		SSL_OP_NO_RENEGOTIATION) != SSL_OP_NO_RENEGOTIATION) {
1232 		log_crypto_err("could not set SSL_OP_NO_RENEGOTIATION");
1233 		SSL_CTX_free(ctx);
1234 		return 0;
1235 	}
1236 #endif
1237 	if(key && key[0]) {
1238 		if(!SSL_CTX_use_certificate_chain_file(ctx, pem)) {
1239 			log_err("error in client certificate %s", pem);
1240 			log_crypto_err("error in certificate file");
1241 			SSL_CTX_free(ctx);
1242 			return NULL;
1243 		}
1244 		if(!SSL_CTX_use_PrivateKey_file(ctx, key, SSL_FILETYPE_PEM)) {
1245 			log_err("error in client private key %s", key);
1246 			log_crypto_err("error in key file");
1247 			SSL_CTX_free(ctx);
1248 			return NULL;
1249 		}
1250 		if(!SSL_CTX_check_private_key(ctx)) {
1251 			log_err("error in client key %s", key);
1252 			log_crypto_err("error in SSL_CTX_check_private_key");
1253 			SSL_CTX_free(ctx);
1254 			return NULL;
1255 		}
1256 	}
1257 	if((verifypem && verifypem[0]) || wincert) {
1258 		if(verifypem && verifypem[0]) {
1259 			if(!SSL_CTX_load_verify_locations(ctx, verifypem, NULL)) {
1260 				log_crypto_err("error in SSL_CTX verify");
1261 				SSL_CTX_free(ctx);
1262 				return NULL;
1263 			}
1264 		}
1265 #ifdef USE_WINSOCK
1266 		if(wincert) {
1267 			if(!add_WIN_cacerts_to_openssl_store(ctx)) {
1268 				log_crypto_err("error in add_WIN_cacerts_to_openssl_store");
1269 				SSL_CTX_free(ctx);
1270 				return NULL;
1271 			}
1272 		}
1273 #else
1274 		(void)wincert;
1275 #endif
1276 		SSL_CTX_set_verify(ctx, SSL_VERIFY_PEER, NULL);
1277 	}
1278 	return ctx;
1279 #else
1280 	(void)key; (void)pem; (void)verifypem; (void)wincert;
1281 	return NULL;
1282 #endif
1283 }
1284 
1285 void* incoming_ssl_fd(void* sslctx, int fd)
1286 {
1287 #ifdef HAVE_SSL
1288 	SSL* ssl = SSL_new((SSL_CTX*)sslctx);
1289 	if(!ssl) {
1290 		log_crypto_err("could not SSL_new");
1291 		return NULL;
1292 	}
1293 	SSL_set_accept_state(ssl);
1294 	(void)SSL_set_mode(ssl, (long)SSL_MODE_AUTO_RETRY);
1295 	if(!SSL_set_fd(ssl, fd)) {
1296 		log_crypto_err("could not SSL_set_fd");
1297 		SSL_free(ssl);
1298 		return NULL;
1299 	}
1300 	return ssl;
1301 #else
1302 	(void)sslctx; (void)fd;
1303 	return NULL;
1304 #endif
1305 }
1306 
1307 void* outgoing_ssl_fd(void* sslctx, int fd)
1308 {
1309 #ifdef HAVE_SSL
1310 	SSL* ssl = SSL_new((SSL_CTX*)sslctx);
1311 	if(!ssl) {
1312 		log_crypto_err("could not SSL_new");
1313 		return NULL;
1314 	}
1315 	SSL_set_connect_state(ssl);
1316 	(void)SSL_set_mode(ssl, (long)SSL_MODE_AUTO_RETRY);
1317 	if(!SSL_set_fd(ssl, fd)) {
1318 		log_crypto_err("could not SSL_set_fd");
1319 		SSL_free(ssl);
1320 		return NULL;
1321 	}
1322 	return ssl;
1323 #else
1324 	(void)sslctx; (void)fd;
1325 	return NULL;
1326 #endif
1327 }
1328 
1329 int check_auth_name_for_ssl(char* auth_name)
1330 {
1331 	if(!auth_name) return 1;
1332 #if defined(HAVE_SSL) && !defined(HAVE_SSL_SET1_HOST) && !defined(HAVE_X509_VERIFY_PARAM_SET1_HOST)
1333 	log_err("the query has an auth_name %s, but libssl has no call to "
1334 		"perform TLS authentication.  Remove that name from config "
1335 		"or upgrade the ssl crypto library.", auth_name);
1336 	return 0;
1337 #else
1338 	return 1;
1339 #endif
1340 }
1341 
1342 /** set the authname on an SSL structure, SSL* ssl */
1343 int set_auth_name_on_ssl(void* ssl, char* auth_name, int use_sni)
1344 {
1345 	if(!auth_name) return 1;
1346 #ifdef HAVE_SSL
1347 	if(use_sni) {
1348 		(void)SSL_set_tlsext_host_name(ssl, auth_name);
1349 	}
1350 #else
1351 	(void)ssl;
1352 	(void)use_sni;
1353 #endif
1354 #ifdef HAVE_SSL_SET1_HOST
1355 	SSL_set_verify(ssl, SSL_VERIFY_PEER, NULL);
1356 	/* setting the hostname makes openssl verify the
1357 	 * host name in the x509 certificate in the
1358 	 * SSL connection*/
1359 	if(!SSL_set1_host(ssl, auth_name)) {
1360 		log_err("SSL_set1_host failed");
1361 		return 0;
1362 	}
1363 #elif defined(HAVE_X509_VERIFY_PARAM_SET1_HOST)
1364 	/* openssl 1.0.2 has this function that can be used for
1365 	 * set1_host like verification */
1366 	if(auth_name) {
1367 		X509_VERIFY_PARAM* param = SSL_get0_param(ssl);
1368 #  ifdef X509_CHECK_FLAG_NO_PARTIAL_WILDCARDS
1369 		X509_VERIFY_PARAM_set_hostflags(param, X509_CHECK_FLAG_NO_PARTIAL_WILDCARDS);
1370 #  endif
1371 		if(!X509_VERIFY_PARAM_set1_host(param, auth_name, strlen(auth_name))) {
1372 			log_err("X509_VERIFY_PARAM_set1_host failed");
1373 			return 0;
1374 		}
1375 		SSL_set_verify(ssl, SSL_VERIFY_PEER, NULL);
1376 	}
1377 #else
1378 	verbose(VERB_ALGO, "the query has an auth_name, but libssl has no call to perform TLS authentication");
1379 #endif /* HAVE_SSL_SET1_HOST */
1380 	return 1;
1381 }
1382 
1383 #if defined(HAVE_SSL) && defined(OPENSSL_THREADS) && !defined(THREADS_DISABLED) && defined(CRYPTO_LOCK) && OPENSSL_VERSION_NUMBER < 0x10100000L
1384 /** global lock list for openssl locks */
1385 static lock_basic_type *ub_openssl_locks = NULL;
1386 
1387 /** callback that gets thread id for openssl */
1388 #ifdef HAVE_CRYPTO_THREADID_SET_CALLBACK
1389 static void
1390 ub_crypto_id_cb(CRYPTO_THREADID *id)
1391 {
1392 	CRYPTO_THREADID_set_numeric(id, (unsigned long)log_thread_get());
1393 }
1394 #else
1395 static unsigned long
1396 ub_crypto_id_cb(void)
1397 {
1398 	return (unsigned long)log_thread_get();
1399 }
1400 #endif
1401 
1402 static void
1403 ub_crypto_lock_cb(int mode, int type, const char *ATTR_UNUSED(file),
1404 	int ATTR_UNUSED(line))
1405 {
1406 	if((mode&CRYPTO_LOCK)) {
1407 		lock_basic_lock(&ub_openssl_locks[type]);
1408 	} else {
1409 		lock_basic_unlock(&ub_openssl_locks[type]);
1410 	}
1411 }
1412 #endif /* OPENSSL_THREADS */
1413 
1414 int ub_openssl_lock_init(void)
1415 {
1416 #if defined(HAVE_SSL) && defined(OPENSSL_THREADS) && !defined(THREADS_DISABLED) && defined(CRYPTO_LOCK) && OPENSSL_VERSION_NUMBER < 0x10100000L
1417 	int i;
1418 	ub_openssl_locks = (lock_basic_type*)reallocarray(
1419 		NULL, (size_t)CRYPTO_num_locks(), sizeof(lock_basic_type));
1420 	if(!ub_openssl_locks)
1421 		return 0;
1422 	for(i=0; i<CRYPTO_num_locks(); i++) {
1423 		lock_basic_init(&ub_openssl_locks[i]);
1424 	}
1425 #  ifdef HAVE_CRYPTO_THREADID_SET_CALLBACK
1426 	CRYPTO_THREADID_set_callback(&ub_crypto_id_cb);
1427 #  else
1428 	CRYPTO_set_id_callback(&ub_crypto_id_cb);
1429 #  endif
1430 	CRYPTO_set_locking_callback(&ub_crypto_lock_cb);
1431 #endif /* OPENSSL_THREADS */
1432 	return 1;
1433 }
1434 
1435 void ub_openssl_lock_delete(void)
1436 {
1437 #if defined(HAVE_SSL) && defined(OPENSSL_THREADS) && !defined(THREADS_DISABLED) && defined(CRYPTO_LOCK) && OPENSSL_VERSION_NUMBER < 0x10100000L
1438 	int i;
1439 	if(!ub_openssl_locks)
1440 		return;
1441 #  ifdef HAVE_CRYPTO_THREADID_SET_CALLBACK
1442 	CRYPTO_THREADID_set_callback(NULL);
1443 #  else
1444 	CRYPTO_set_id_callback(NULL);
1445 #  endif
1446 	CRYPTO_set_locking_callback(NULL);
1447 	for(i=0; i<CRYPTO_num_locks(); i++) {
1448 		lock_basic_destroy(&ub_openssl_locks[i]);
1449 	}
1450 	free(ub_openssl_locks);
1451 #endif /* OPENSSL_THREADS */
1452 }
1453 
1454 int listen_sslctx_setup_ticket_keys(void* sslctx, struct config_strlist* tls_session_ticket_keys) {
1455 #ifdef HAVE_SSL
1456 	size_t s = 1;
1457 	struct config_strlist* p;
1458 	struct tls_session_ticket_key *keys;
1459 	for(p = tls_session_ticket_keys; p; p = p->next) {
1460 		s++;
1461 	}
1462 	keys = calloc(s, sizeof(struct tls_session_ticket_key));
1463 	if(!keys)
1464 		return 0;
1465 	memset(keys, 0, s*sizeof(*keys));
1466 	ticket_keys = keys;
1467 
1468 	for(p = tls_session_ticket_keys; p; p = p->next) {
1469 		size_t n;
1470 		unsigned char *data;
1471 		FILE *f;
1472 
1473 		data = (unsigned char *)malloc(80);
1474 		if(!data)
1475 			return 0;
1476 
1477 		f = fopen(p->str, "rb");
1478 		if(!f) {
1479 			log_err("could not read tls-session-ticket-key %s: %s", p->str, strerror(errno));
1480 			free(data);
1481 			return 0;
1482 		}
1483 		n = fread(data, 1, 80, f);
1484 		fclose(f);
1485 
1486 		if(n != 80) {
1487 			log_err("tls-session-ticket-key %s is %d bytes, must be 80 bytes", p->str, (int)n);
1488 			free(data);
1489 			return 0;
1490 		}
1491 		verbose(VERB_OPS, "read tls-session-ticket-key: %s", p->str);
1492 
1493 		keys->key_name = data;
1494 		keys->aes_key = data + 16;
1495 		keys->hmac_key = data + 48;
1496 		keys++;
1497 	}
1498 	/* terminate array with NULL key name entry */
1499 	keys->key_name = NULL;
1500 #  ifdef HAVE_SSL_CTX_SET_TLSEXT_TICKET_KEY_EVP_CB
1501 	if(SSL_CTX_set_tlsext_ticket_key_evp_cb(sslctx, tls_session_ticket_key_cb) == 0) {
1502 		log_err("no support for TLS session ticket");
1503 		return 0;
1504 	}
1505 #  else
1506 	if(SSL_CTX_set_tlsext_ticket_key_cb(sslctx, tls_session_ticket_key_cb) == 0) {
1507 		log_err("no support for TLS session ticket");
1508 		return 0;
1509 	}
1510 #  endif
1511 	return 1;
1512 #else
1513 	(void)sslctx;
1514 	(void)tls_session_ticket_keys;
1515 	return 0;
1516 #endif
1517 
1518 }
1519 
1520 #ifdef HAVE_SSL
1521 int tls_session_ticket_key_cb(SSL *ATTR_UNUSED(sslctx), unsigned char* key_name,
1522 	unsigned char* iv, EVP_CIPHER_CTX *evp_sctx,
1523 #ifdef HAVE_SSL_CTX_SET_TLSEXT_TICKET_KEY_EVP_CB
1524 	EVP_MAC_CTX *hmac_ctx,
1525 #else
1526 	HMAC_CTX* hmac_ctx,
1527 #endif
1528 	int enc)
1529 {
1530 #ifdef HAVE_SSL
1531 #  ifdef HAVE_SSL_CTX_SET_TLSEXT_TICKET_KEY_EVP_CB
1532 	OSSL_PARAM params[3];
1533 #  else
1534 	const EVP_MD *digest;
1535 #  endif
1536 	const EVP_CIPHER *cipher;
1537 	int evp_cipher_length;
1538 #  ifndef HAVE_SSL_CTX_SET_TLSEXT_TICKET_KEY_EVP_CB
1539 	digest = EVP_sha256();
1540 #  endif
1541 	cipher = EVP_aes_256_cbc();
1542 	evp_cipher_length = EVP_CIPHER_iv_length(cipher);
1543 	if( enc == 1 ) {
1544 		/* encrypt */
1545 		verbose(VERB_CLIENT, "start session encrypt");
1546 		memcpy(key_name, ticket_keys->key_name, 16);
1547 		if (RAND_bytes(iv, evp_cipher_length) != 1) {
1548 			verbose(VERB_CLIENT, "RAND_bytes failed");
1549 			return -1;
1550 		}
1551 		if (EVP_EncryptInit_ex(evp_sctx, cipher, NULL, ticket_keys->aes_key, iv) != 1) {
1552 			verbose(VERB_CLIENT, "EVP_EncryptInit_ex failed");
1553 			return -1;
1554 		}
1555 #ifdef HAVE_SSL_CTX_SET_TLSEXT_TICKET_KEY_EVP_CB
1556 		params[0] = OSSL_PARAM_construct_octet_string(OSSL_MAC_PARAM_KEY,
1557 			ticket_keys->hmac_key, 32);
1558 		params[1] = OSSL_PARAM_construct_utf8_string(OSSL_MAC_PARAM_DIGEST,
1559 			"sha256", 0);
1560 		params[2] = OSSL_PARAM_construct_end();
1561 #ifdef HAVE_EVP_MAC_CTX_SET_PARAMS
1562 		EVP_MAC_CTX_set_params(hmac_ctx, params);
1563 #else
1564 		EVP_MAC_set_ctx_params(hmac_ctx, params);
1565 #endif
1566 #elif !defined(HMAC_INIT_EX_RETURNS_VOID)
1567 		if (HMAC_Init_ex(hmac_ctx, ticket_keys->hmac_key, 32, digest, NULL) != 1) {
1568 			verbose(VERB_CLIENT, "HMAC_Init_ex failed");
1569 			return -1;
1570 		}
1571 #else
1572 		HMAC_Init_ex(hmac_ctx, ticket_keys->hmac_key, 32, digest, NULL);
1573 #endif
1574 		return 1;
1575 	} else if (enc == 0) {
1576 		/* decrypt */
1577 		struct tls_session_ticket_key *key;
1578 		verbose(VERB_CLIENT, "start session decrypt");
1579 		for(key = ticket_keys; key->key_name != NULL; key++) {
1580 			if (!memcmp(key_name, key->key_name, 16)) {
1581 				verbose(VERB_CLIENT, "Found session_key");
1582 				break;
1583 			}
1584 		}
1585 		if(key->key_name == NULL) {
1586 			verbose(VERB_CLIENT, "Not found session_key");
1587 			return 0;
1588 		}
1589 
1590 #ifdef HAVE_SSL_CTX_SET_TLSEXT_TICKET_KEY_EVP_CB
1591 		params[0] = OSSL_PARAM_construct_octet_string(OSSL_KDF_PARAM_KEY,
1592 			key->hmac_key, 32);
1593 		params[1] = OSSL_PARAM_construct_utf8_string(OSSL_MAC_PARAM_DIGEST,
1594 			"sha256", 0);
1595 		params[2] = OSSL_PARAM_construct_end();
1596 #ifdef HAVE_EVP_MAC_CTX_SET_PARAMS
1597 		EVP_MAC_CTX_set_params(hmac_ctx, params);
1598 #else
1599 		EVP_MAC_set_ctx_params(hmac_ctx, params);
1600 #endif
1601 #elif !defined(HMAC_INIT_EX_RETURNS_VOID)
1602 		if (HMAC_Init_ex(hmac_ctx, key->hmac_key, 32, digest, NULL) != 1) {
1603 			verbose(VERB_CLIENT, "HMAC_Init_ex failed");
1604 			return -1;
1605 		}
1606 #else
1607 		HMAC_Init_ex(hmac_ctx, key->hmac_key, 32, digest, NULL);
1608 #endif
1609 		if (EVP_DecryptInit_ex(evp_sctx, cipher, NULL, key->aes_key, iv) != 1) {
1610 			log_err("EVP_DecryptInit_ex failed");
1611 			return -1;
1612 		}
1613 
1614 		return (key == ticket_keys) ? 1 : 2;
1615 	}
1616 	return -1;
1617 #else
1618 	(void)key_name;
1619 	(void)iv;
1620 	(void)evp_sctx;
1621 	(void)hmac_ctx;
1622 	(void)enc;
1623 	return 0;
1624 #endif
1625 }
1626 #endif /* HAVE_SSL */
1627 
1628 void
1629 listen_sslctx_delete_ticket_keys(void)
1630 {
1631 	struct tls_session_ticket_key *key;
1632 	if(!ticket_keys) return;
1633 	for(key = ticket_keys; key->key_name != NULL; key++) {
1634 		/* wipe key data from memory*/
1635 #ifdef HAVE_EXPLICIT_BZERO
1636 		explicit_bzero(key->key_name, 80);
1637 #else
1638 		memset(key->key_name, 0xdd, 80);
1639 #endif
1640 		free(key->key_name);
1641 	}
1642 	free(ticket_keys);
1643 	ticket_keys = NULL;
1644 }
1645 
1646 #  ifndef USE_WINSOCK
1647 char*
1648 sock_strerror(int errn)
1649 {
1650 	return strerror(errn);
1651 }
1652 
1653 void
1654 sock_close(int socket)
1655 {
1656 	close(socket);
1657 }
1658 
1659 #  else
1660 char*
1661 sock_strerror(int ATTR_UNUSED(errn))
1662 {
1663 	return wsa_strerror(WSAGetLastError());
1664 }
1665 
1666 void
1667 sock_close(int socket)
1668 {
1669 	closesocket(socket);
1670 }
1671 #  endif /* USE_WINSOCK */
1672