From e77b924fec1082faae48cdd2ff8474874a22bdf7 Mon Sep 17 00:00:00 2001 From: Werner Koch Date: Sat, 17 Dec 2016 21:54:45 +0100 Subject: dirmngr: Fix setup of libdns for W32. * configure.ac (DNSLIB) {W32]: Add -liphlpapi. * dirmngr/dns-stuff.c [W32]: Include iphlpapi.h and define WIN32_LEAN_AND_MEAN. (libdns_init) [W32]: Use GetNetworkParams to get the nameserver. * dirmngr/t-dns-stuff.c (init_sockets): New. (main): Call it. Signed-off-by: Werner Koch --- dirmngr/dns-stuff.c | 51 +++++++++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 49 insertions(+), 2 deletions(-) (limited to 'dirmngr/dns-stuff.c') diff --git a/dirmngr/dns-stuff.c b/dirmngr/dns-stuff.c index 1fc81b27a..eae674f5a 100644 --- a/dirmngr/dns-stuff.c +++ b/dirmngr/dns-stuff.c @@ -31,10 +31,12 @@ #include #include #ifdef HAVE_W32_SYSTEM +# define WIN32_LEAN_AND_MEAN # ifdef HAVE_WINSOCK2_H # include # endif # include +# include #else # if HAVE_SYSTEM_RESOLVER # include @@ -46,6 +48,7 @@ #include #include + /* William Ahern's DNS library, included as a source copy. */ #ifdef USE_LIBDNS # include "dns.h" @@ -229,6 +232,8 @@ free_dns_addrinfo (dns_addrinfo_t ai) } } + +#ifndef HAVE_W32_SYSTEM /* Return H_ERRNO mapped to a gpg-error code. Will never return 0. */ static gpg_error_t get_h_errno_as_gpg_error (void) @@ -245,7 +250,7 @@ get_h_errno_as_gpg_error (void) } return gpg_error (ec); } - +#endif /*!HAVE_W32_SYSTEM*/ static gpg_error_t map_eai_to_gpg_error (int ec) @@ -323,7 +328,6 @@ libdns_init (void) gpg_error_t err; struct libdns_s ld; int derr; - const char *fname; char *cfgstr = NULL; if (libdns.resolv_conf) @@ -378,6 +382,47 @@ libdns_init (void) } else { +#ifdef HAVE_W32_SYSTEM + ULONG ninfo_len; + PFIXED_INFO ninfo; + PIP_ADDR_STRING pip; + int idx; + + ninfo_len = 2048; + ninfo = xtrymalloc (ninfo_len); + if (!ninfo) + { + err = gpg_error_from_syserror (); + goto leave; + } + + if (GetNetworkParams (ninfo, &ninfo_len)) + { + log_error ("GetNetworkParms failed: %s\n", w32_strerror (-1)); + err = gpg_error (GPG_ERR_GENERAL); + xfree (ninfo); + goto leave; + } + + for (idx=0, pip = &(ninfo->DnsServerList); + pip && idx < DIM (ld.resolv_conf->nameserver); + pip = pip->Next) + { + log_debug ("ninfo->dnsserver[%d] '%s'\n", idx, pip->IpAddress.String); + err = libdns_error_to_gpg_error + (dns_resconf_pton (&ld.resolv_conf->nameserver[idx], + pip->IpAddress.String)); + if (err) + log_error ("failed to set nameserver[%d] '%s': %s\n", + idx, pip->IpAddress.String, gpg_strerror (err)); + else + idx++; + } + xfree (ninfo); + +#else /* Unix */ + const char *fname; + fname = "/etc/resolv.conf"; err = libdns_error_to_gpg_error (dns_resconf_loadpath (ld.resolv_conf, fname)); @@ -395,6 +440,8 @@ libdns_init (void) log_error ("failed to load '%s': %s\n", fname, gpg_strerror (err)); goto leave; } + +#endif /* Unix */ } ld.hosts = dns_hosts_open (&derr); -- cgit v1.2.3