2021-01-17 12:36:34 +00:00
|
|
|
diff --git a/usr.sbin/smtpd/smtpd.c b/usr.sbin/smtpd/smtpd.c
|
2018-05-18 22:15:07 +01:00
|
|
|
index e049f07c..a1bd03a0 100644
|
2021-01-17 12:36:34 +00:00
|
|
|
--- a/usr.sbin/smtpd/smtpd.c
|
|
|
|
+++ b/usr.sbin/smtpd/smtpd.c
|
2018-05-18 22:15:07 +01:00
|
|
|
@@ -1157,6 +1157,7 @@ fork_proc_backend(const char *key, const char *conf, const char *procname)
|
2015-11-14 20:32:51 +00:00
|
|
|
char path[PATH_MAX];
|
|
|
|
char name[PATH_MAX];
|
|
|
|
char *arg;
|
2016-05-22 21:22:39 +01:00
|
|
|
+ char *proc_path;
|
2015-11-14 20:32:51 +00:00
|
|
|
|
|
|
|
if (strlcpy(name, conf, sizeof(name)) >= sizeof(name)) {
|
|
|
|
log_warnx("warn: %s-proc: conf too long", key);
|
2018-05-18 22:15:07 +01:00
|
|
|
@@ -1167,7 +1168,12 @@ fork_proc_backend(const char *key, const char *conf, const char *procname)
|
2015-11-14 20:32:51 +00:00
|
|
|
if (arg)
|
|
|
|
*arg++ = '\0';
|
|
|
|
|
|
|
|
- if (snprintf(path, sizeof(path), PATH_LIBEXEC "/%s-%s", key, name) >=
|
2016-05-22 21:22:39 +01:00
|
|
|
+ proc_path = getenv("OPENSMTPD_PROC_PATH");
|
|
|
|
+ if (proc_path == NULL) {
|
|
|
|
+ proc_path = PATH_LIBEXEC;
|
|
|
|
+ }
|
2015-11-14 20:32:51 +00:00
|
|
|
+
|
|
|
|
+ if (snprintf(path, sizeof(path), "%s/%s-%s", proc_path, key, name) >=
|
|
|
|
(ssize_t)sizeof(path)) {
|
|
|
|
log_warn("warn: %s-proc: exec path too long", key);
|
|
|
|
return (-1);
|
2021-01-17 12:36:34 +00:00
|
|
|
diff --git a/usr.sbin/smtpd/table.c b/usr.sbin/smtpd/table.c
|
2018-05-18 22:15:07 +01:00
|
|
|
index 9cfdfb99..24dfcca4 100644
|
2021-01-17 12:36:34 +00:00
|
|
|
--- a/usr.sbin/smtpd/table.c
|
|
|
|
+++ b/usr.sbin/smtpd/table.c
|
2018-05-18 22:15:07 +01:00
|
|
|
@@ -201,6 +201,7 @@ table_create(const char *backend, const char *name, const char *tag,
|
2015-11-14 20:32:51 +00:00
|
|
|
struct table_backend *tb;
|
|
|
|
char buf[LINE_MAX];
|
|
|
|
char path[LINE_MAX];
|
2016-05-22 21:22:39 +01:00
|
|
|
+ const char *proc_path;
|
2015-11-14 20:32:51 +00:00
|
|
|
size_t n;
|
|
|
|
struct stat sb;
|
|
|
|
|
2018-05-18 22:15:07 +01:00
|
|
|
@@ -215,11 +216,16 @@ table_create(const char *backend, const char *name, const char *tag,
|
2015-11-14 20:32:51 +00:00
|
|
|
if (name && table_find(name, NULL))
|
|
|
|
fatalx("table_create: table \"%s\" already defined", name);
|
|
|
|
|
2016-05-22 21:22:39 +01:00
|
|
|
+ proc_path = getenv("OPENSMTPD_PROC_PATH");
|
|
|
|
+ if (proc_path == NULL) {
|
|
|
|
+ proc_path = PATH_LIBEXEC;
|
|
|
|
+ }
|
2015-11-14 20:32:51 +00:00
|
|
|
+
|
|
|
|
if ((tb = table_backend_lookup(backend)) == NULL) {
|
2016-05-22 21:22:39 +01:00
|
|
|
- if ((size_t)snprintf(path, sizeof(path), PATH_LIBEXEC"/table-%s",
|
|
|
|
- backend) >= sizeof(path)) {
|
|
|
|
- fatalx("table_create: path too long \""
|
|
|
|
- PATH_LIBEXEC"/table-%s\"", backend);
|
2015-11-14 20:32:51 +00:00
|
|
|
+ if ((size_t)snprintf(path, sizeof(path), "%s/table-%s",
|
2016-05-22 21:22:39 +01:00
|
|
|
+ proc_path, backend) >= sizeof(path)) {
|
|
|
|
+ fatalx("table_create: path too long \"%s/table-%s\"",
|
|
|
|
+ proc_path, backend);
|
|
|
|
}
|
|
|
|
if (stat(path, &sb) == 0) {
|
|
|
|
tb = table_backend_lookup("proc");
|