forked from henryk/tinydnssec
-
Notifications
You must be signed in to change notification settings - Fork 0
/
droproot.c
33 lines (29 loc) · 773 Bytes
/
droproot.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#include <unistd.h>
#include "env.h"
#include "scan.h"
#include "prot.h"
#include "strerr.h"
void droproot(const char *fatal)
{
char *x;
unsigned long id;
x = env_get("ROOT");
if (!x)
strerr_die2x(111,fatal,"$ROOT not set");
if (chdir(x) == -1)
strerr_die4sys(111,fatal,"unable to chdir to ",x,": ");
if (chroot(".") == -1)
strerr_die4sys(111,fatal,"unable to chroot to ",x,": ");
x = env_get("GID");
if (!x)
strerr_die2x(111,fatal,"$GID not set");
scan_ulong(x,&id);
if (prot_gid((int) id) == -1)
strerr_die2sys(111,fatal,"unable to setgid: ");
x = env_get("UID");
if (!x)
strerr_die2x(111,fatal,"$UID not set");
scan_ulong(x,&id);
if (prot_uid((int) id) == -1)
strerr_die2sys(111,fatal,"unable to setuid: ");
}