1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-03 12:11:33 +01:00

dirmngr: Re-init libdns resolver on towel change of resolv.conf

* dirmngr/dns-stuff.c: Include sys/stat.h.
(RESOLV_CONF_NAME): New macro to replace a string.
(resolv_conf_changed_p): New.
(libdns_init): Call new function
(libdns_res_open): Ditto.
--

Don't panic.  This is a simple change
Suggested-by: Stefan Bühler <stbuehler@web.de>
to avoid complicated if-up.d hooks to reload resolv.conf.

Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
Werner Koch 2017-05-25 11:33:07 +02:00
parent 525f2c482a
commit b5f356e9fb
No known key found for this signature in database
GPG Key ID: E3FDFF218E45B72B

View File

@ -45,6 +45,9 @@
# endif # endif
# include <netdb.h> # include <netdb.h>
#endif #endif
#ifdef HAVE_STAT
# include <sys/stat.h>
#endif
#include <string.h> #include <string.h>
#include <unistd.h> #include <unistd.h>
@ -111,6 +114,8 @@
#define DEFAULT_TIMEOUT 30 #define DEFAULT_TIMEOUT 30
#define RESOLV_CONF_NAME "/etc/resolv.conf"
/* Two flags to enable verbose and debug mode. */ /* Two flags to enable verbose and debug mode. */
static int opt_verbose; static int opt_verbose;
static int opt_debug; static int opt_debug;
@ -391,6 +396,37 @@ libdns_error_to_gpg_error (int serr)
#endif /*USE_LIBDNS*/ #endif /*USE_LIBDNS*/
/* Return true if resolve.conf changed since it was last loaded. */
#ifdef USE_LIBDNS
static int
resolv_conf_changed_p (void)
{
#if defined(HAVE_W32_SYSTEM) || !defined(HAVE_STAT)
return 0;
#else
static time_t last_mtime;
const char *fname = RESOLV_CONF_NAME;
struct stat statbuf;
int changed;
if (stat (fname, &statbuf))
{
log_error ("stat'ing '%s' failed: %s\n",
fname, gpg_strerror (gpg_error_from_syserror ()));
changed = 0;
last_mtime = 1; /* Force a "changed" result the next time stat
* works. */
}
else
{
changed = last_mtime && (last_mtime != statbuf.st_mtime);
last_mtime = statbuf.st_mtime;
}
return changed;
#endif
}
#endif /*USE_LIBDNS*/
#ifdef USE_LIBDNS #ifdef USE_LIBDNS
/* Initialize libdns. Returns 0 on success; prints a diagnostic and /* Initialize libdns. Returns 0 on success; prints a diagnostic and
* returns an error code on failure. */ * returns an error code on failure. */
@ -496,7 +532,8 @@ libdns_init (void)
#else /* Unix */ #else /* Unix */
const char *fname; const char *fname;
fname = "/etc/resolv.conf"; fname = RESOLV_CONF_NAME;
resolv_conf_changed_p (); /* Reset timestamp. */
err = libdns_error_to_gpg_error err = libdns_error_to_gpg_error
(dns_resconf_loadpath (ld.resolv_conf, fname)); (dns_resconf_loadpath (ld.resolv_conf, fname));
if (err) if (err)
@ -653,6 +690,14 @@ libdns_res_open (struct dns_resolver **r_res)
*r_res = NULL; *r_res = NULL;
/* Force a reload if resolv.conf has changed. */
if (resolv_conf_changed_p ())
{
if (opt_debug)
log_debug ("dns: resolv.conf changed - forcing reload\n");
libdns_reinit_pending = 1;
}
if (libdns_reinit_pending) if (libdns_reinit_pending)
{ {
libdns_reinit_pending = 0; libdns_reinit_pending = 0;