summaryrefslogtreecommitdiff
path: root/src/tls/s6tls_clean_and_exec.c
diff options
context:
space:
mode:
authorLaurent Bercot <ska-skaware@skarnet.org>2021-06-02 08:54:17 +0000
committerLaurent Bercot <ska-skaware@skarnet.org>2021-06-02 08:54:17 +0000
commit9cfe27834a3014235526c60c52652399411993de (patch)
treef548574d0090d14b73d102822c8fe8c052fa32c9 /src/tls/s6tls_clean_and_exec.c
parenta6c4fb25b60cbc83a4b8bdb756fcf9c69310e6ae (diff)
downloads6-networking-9cfe27834a3014235526c60c52652399411993de.tar.xz
Correctly clean up the environment for -z
Diffstat (limited to 'src/tls/s6tls_clean_and_exec.c')
-rw-r--r--src/tls/s6tls_clean_and_exec.c43
1 files changed, 43 insertions, 0 deletions
diff --git a/src/tls/s6tls_clean_and_exec.c b/src/tls/s6tls_clean_and_exec.c
new file mode 100644
index 0000000..9432e3a
--- /dev/null
+++ b/src/tls/s6tls_clean_and_exec.c
@@ -0,0 +1,43 @@
+/* ISC license. */
+
+#include <stddef.h>
+
+#include <skalibs/posixplz.h>
+#include <skalibs/bytestr.h>
+#include <skalibs/env.h>
+#include <skalibs/exec.h>
+
+#include "s6tls-internal.h"
+
+void s6tls_clean_and_exec (char const *const *argv, uint32_t options, char const *modif, size_t modiflen)
+{
+ if (options & 1)
+ {
+ static char const *const toclean[] =
+ {
+ "CADIR=",
+ "CAFILE=",
+ "KEYFILE=",
+ "CERTFILE=",
+ "TLS_UID=",
+ "TLS_GID=",
+ "KEYFILE:",
+ "CERTFILE:",
+ 0
+ } ;
+ char const *const *envp = (char const *const *)environ ;
+ size_t m = 0 ;
+ size_t n = env_len(envp) ;
+ char const *newenvp[n + 1] ;
+ for (; *envp ; envp++)
+ {
+ char const *const *var = toclean ;
+ for (; *var ; var++)
+ if (str_start(*envp, *var)) break ;
+ if (!*var) newenvp[m++] = *envp ;
+ }
+ newenvp[m] = 0 ;
+ xmexec_fm(argv, newenvp, m, modif, modiflen) ;
+ }
+ else xmexec_m(argv, modif, modiflen) ;
+}