summaryrefslogtreecommitdiff
path: root/src/tipideed/harden.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/tipideed/harden.c')
-rw-r--r--src/tipideed/harden.c50
1 files changed, 50 insertions, 0 deletions
diff --git a/src/tipideed/harden.c b/src/tipideed/harden.c
new file mode 100644
index 0000000..5c925f2
--- /dev/null
+++ b/src/tipideed/harden.c
@@ -0,0 +1,50 @@
+/* ISC license. */
+
+#include <skalibs/sysdeps.h>
+#include <skalibs/nonposix.h>
+
+#include <unistd.h>
+#include <errno.h>
+#include <stdlib.h>
+
+#include <skalibs/types.h>
+#include <skalibs/strerr.h>
+
+#include "tipideed-internal.h"
+
+static inline void tipideed_chroot (void)
+{
+#ifdef SKALIBS_HASCHROOT
+ if (chroot(".") == -1) strerr_diefu1sys(111, "chroot") ;
+#else
+ errno = ENOSYS ;
+ strerr_warnwu1sys("chroot") ;
+#endif
+}
+
+static inline void tipideed_dropuidgid (void)
+{
+ uid_t uid = 0 ;
+ gid_t gid = 0 ;
+ char const *gidfmt = getenv("GID") ;
+ char const *uidfmt = getenv("UID") ;
+ if (!uidfmt) strerr_dienotset(100, "UID") ;
+ if (!uid0_scan(uidfmt, &uid)) strerr_dieinvalid(100, "UID") ;
+ if (!gidfmt) strerr_dienotset(100, "GID") ;
+ if (!gid0_scan(gidfmt, &gid)) strerr_dieinvalid(100, "GID") ;
+ if (gid)
+ {
+#ifdef SKALIBS_HASSETGROUPS
+ if (setgroups(1, &gid) == -1) strerr_diefu2sys(111, "setgroups to ", gidfmt) ;
+#endif
+ if (setgid(gid) == -1) strerr_diefu2sys(111, "setgid to ", gidfmt) ;
+ }
+ if (uid)
+ if (setuid(uid) == -1) strerr_diefu2sys(111, "setuid to ", uidfmt) ;
+}
+
+void tipideed_harden (unsigned int h)
+{
+ if (h & 2) tipideed_chroot() ;
+ if (h & 1) tipideed_dropuidgid() ;
+}