Regard GNUPGHOME

This commit is contained in:
Moritz Luedecke 2018-02-02 12:20:17 +01:00
parent a9cba79ff9
commit e1904c2196

View file

@ -25,7 +25,8 @@
#include "pinentry/pinentry.h" #include "pinentry/pinentry.h"
#include "pinentry/memory.h" #include "pinentry/memory.h"
#define CONFIG "/.gnupg/pinentry-dmenu.conf" #define CONFIG_DIR "/.gnupg"
#define CONFIG_FILE "/pinentry-dmenu.conf"
#define INTERSECT(x, y, w, h, r) \ #define INTERSECT(x, y, w, h, r) \
(MAX(0, MIN((x)+(w),(r).x_org+(r).width) - MAX((x),(r).x_org)) \ (MAX(0, MIN((x)+(w),(r).x_org+(r).width) - MAX((x),(r).x_org)) \
&& MAX(0, MIN((y)+(h),(r).y_org+(r).height) - MAX((y),(r).y_org))) && MAX(0, MIN((y)+(h),(r).y_org+(r).height) - MAX((y),(r).y_org)))
@ -707,8 +708,13 @@ main(int argc, char *argv[]) {
char path[PATH_MAX]; char path[PATH_MAX];
char *sudo_uid = getenv("SUDO_UID"); char *sudo_uid = getenv("SUDO_UID");
char *home = getenv("HOME"); char *home = getenv("HOME");
char *gnupghome = getenv("GNUPGHOME");
config_t cfg; config_t cfg;
if (gnupghome) {
i = strlen(gnupghome);
strcpy(path, gnupghome);
} else {
/* Get the home dir even if the user used sudo or logged in as root */ /* Get the home dir even if the user used sudo or logged in as root */
if (sudo_uid) { if (sudo_uid) {
i = atoi(sudo_uid); i = atoi(sudo_uid);
@ -716,12 +722,17 @@ main(int argc, char *argv[]) {
home = pw->pw_dir; home = pw->pw_dir;
} }
config_init(&cfg);
i = strlen(home); i = strlen(home);
strcpy(path, home); strcpy(path, home);
strcpy(&path[i], CONFIG); strcpy(&path[i], CONFIG_DIR);
i += strlen(CONFIG_DIR);
}
strcpy(&path[i], CONFIG_FILE);
endpwent(); endpwent();
config_init(&cfg);
/* Read the file. If there is an error, report it and exit. */ /* Read the file. If there is an error, report it and exit. */
if (config_read_file(&cfg, path)) { if (config_read_file(&cfg, path)) {
if (config_lookup_string(&cfg, "asterisk", &str)) { if (config_lookup_string(&cfg, "asterisk", &str)) {