1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-17 14:07:03 +01:00

common: Add keyword sysconfdir to the optional gpgconf.ctl file.

* common/homedir.c (unix_rootdir): Add arg want_sysconfdir.
(gnupg_sysconfdir): Return it.
--

Our regression test suite has the problem that we can't disable the
use of the global config files or test them using the regualr
binaries.  This new keyword will allow us to overcome the problem.
This commit is contained in:
Werner Koch 2021-09-29 12:05:30 +02:00
parent ca54d3f148
commit ec847cf17f
No known key found for this signature in database
GPG Key ID: E3FDFF218E45B72B

View File

@ -457,12 +457,14 @@ w32_rootdir (void)
* root directory. There is no solid standard on Unix to locate the * root directory. There is no solid standard on Unix to locate the
* binary used to create the process, thus we support this currently * binary used to create the process, thus we support this currently
* only on Linux where we can look this info up using the proc file * only on Linux where we can look this info up using the proc file
* system. */ * system. If WANT_SYSCONFDIR is true the optional sysconfdir entry
* is returned. */
static const char * static const char *
unix_rootdir (void) unix_rootdir (int want_sysconfdir)
{ {
static int checked; static int checked;
static char *dir; static char *dir; /* for the rootdir */
static char *sdir; /* for the sysconfdir */
if (!checked) if (!checked)
{ {
@ -476,6 +478,8 @@ unix_rootdir (void)
ssize_t length; ssize_t length;
estream_t fp; estream_t fp;
char *rootdir; char *rootdir;
char *sysconfdir;
const char *name;
for (;;) for (;;)
{ {
@ -557,6 +561,7 @@ unix_rootdir (void)
line = NULL; line = NULL;
linelen = 0; linelen = 0;
rootdir = NULL; rootdir = NULL;
sysconfdir = NULL;
while ((length = es_read_line (fp, &line, &linelen, NULL)) > 0) while ((length = es_read_line (fp, &line, &linelen, NULL)) > 0)
{ {
/* Strip NL and CR, if present. */ /* Strip NL and CR, if present. */
@ -565,22 +570,47 @@ unix_rootdir (void)
line[--length] = 0; line[--length] = 0;
trim_spaces (line); trim_spaces (line);
if (!strncmp (line, "rootdir=", 8)) if (!strncmp (line, "rootdir=", 8))
p = line + 8; {
name = "rootdir";
p = line + 8;
}
else if (!strncmp (line, "rootdir =", 9)) /* (What a kludge) */ else if (!strncmp (line, "rootdir =", 9)) /* (What a kludge) */
p = line + 9; {
name = "rootdir";
p = line + 9;
}
else if (!strncmp (line, "sysconfdir=", 11))
{
name = "sysconfdir";
p = line + 11;
}
else if (!strncmp (line, "sysconfdir =", 12)) /* (What a kludge) */
{
name = "sysconfdir";
p = line + 12;
}
else else
continue; continue;
trim_spaces (p); trim_spaces (p);
rootdir = substitute_envvars (p); p = substitute_envvars (p);
if (!rootdir) if (!p)
{ {
err = gpg_error_from_syserror (); err = gpg_error_from_syserror ();
log_info ("error getting rootdir from gpgconf.ctl: %s\n", log_info ("error getting %s from gpgconf.ctl: %s\n",
gpg_strerror (err)); name, gpg_strerror (err));
}
else if (!strcmp (name, "sysconfdir"))
{
xfree (sysconfdir);
sysconfdir = p;
}
else
{
xfree (rootdir);
rootdir = p;
} }
break;
} }
if (length < 0 || es_ferror (fp)) if (es_ferror (fp))
{ {
err = gpg_error_from_syserror (); err = gpg_error_from_syserror ();
log_info ("error reading '%s': %s\n", buffer, gpg_strerror (err)); log_info ("error reading '%s': %s\n", buffer, gpg_strerror (err));
@ -598,6 +628,15 @@ unix_rootdir (void)
{ {
log_info ("invalid rootdir '%s' specified in gpgconf.ctl\n", rootdir); log_info ("invalid rootdir '%s' specified in gpgconf.ctl\n", rootdir);
xfree (rootdir); xfree (rootdir);
xfree (sysconfdir);
dir = NULL;
}
else if (sysconfdir && (!*sysconfdir || *sysconfdir != '/'))
{
log_info ("invalid sysconfdir '%s' specified in gpgconf.ctl\n",
sysconfdir);
xfree (rootdir);
xfree (sysconfdir);
dir = NULL; dir = NULL;
} }
else else
@ -607,11 +646,19 @@ unix_rootdir (void)
dir = rootdir; dir = rootdir;
gpgrt_annotate_leaked_object (dir); gpgrt_annotate_leaked_object (dir);
/* log_info ("want rootdir '%s'\n", dir); */ /* log_info ("want rootdir '%s'\n", dir); */
if (sysconfdir)
{
while (*sysconfdir && sysconfdir[strlen (sysconfdir)-1] == '/')
sysconfdir[strlen (sysconfdir)-1] = 0;
sdir = sysconfdir;
gpgrt_annotate_leaked_object (sdir);
/* log_info ("want sysconfdir '%s'\n", sdir); */
}
} }
checked = 1; checked = 1;
} }
return dir; return want_sysconfdir? sdir : dir;
} }
#endif /* Unix */ #endif /* Unix */
@ -1121,7 +1168,11 @@ gnupg_sysconfdir (void)
} }
return name; return name;
#else /*!HAVE_W32_SYSTEM*/ #else /*!HAVE_W32_SYSTEM*/
return GNUPG_SYSCONFDIR; const char *dir = unix_rootdir (1);
if (dir)
return dir;
else
return GNUPG_SYSCONFDIR;
#endif /*!HAVE_W32_SYSTEM*/ #endif /*!HAVE_W32_SYSTEM*/
} }
@ -1146,7 +1197,7 @@ gnupg_bindir (void)
else else
return rdir; return rdir;
#else /*!HAVE_W32_SYSTEM*/ #else /*!HAVE_W32_SYSTEM*/
rdir = unix_rootdir (); rdir = unix_rootdir (0);
if (rdir) if (rdir)
{ {
if (!name) if (!name)
@ -1173,7 +1224,7 @@ gnupg_libexecdir (void)
static char *name; static char *name;
const char *rdir; const char *rdir;
rdir = unix_rootdir (); rdir = unix_rootdir (0);
if (rdir) if (rdir)
{ {
if (!name) if (!name)
@ -1203,7 +1254,7 @@ gnupg_libdir (void)
#else /*!HAVE_W32_SYSTEM*/ #else /*!HAVE_W32_SYSTEM*/
const char *rdir; const char *rdir;
rdir = unix_rootdir (); rdir = unix_rootdir (0);
if (rdir) if (rdir)
{ {
if (!name) if (!name)
@ -1234,7 +1285,7 @@ gnupg_datadir (void)
#else /*!HAVE_W32_SYSTEM*/ #else /*!HAVE_W32_SYSTEM*/
const char *rdir; const char *rdir;
rdir = unix_rootdir (); rdir = unix_rootdir (0);
if (rdir) if (rdir)
{ {
if (!name) if (!name)
@ -1266,7 +1317,7 @@ gnupg_localedir (void)
#else /*!HAVE_W32_SYSTEM*/ #else /*!HAVE_W32_SYSTEM*/
const char *rdir; const char *rdir;
rdir = unix_rootdir (); rdir = unix_rootdir (0);
if (rdir) if (rdir)
{ {
if (!name) if (!name)