}
}
+void create_needed_dir(const char *dir, uid_t uid, gid_t gid)
+{
+ if(mkdir(dir, 0755) == -1 && errno != EEXIST)
+ error("Cannot create directory '%s'", dir);
+
+ if(chown(dir, uid, gid) == -1)
+ error("Cannot chown directory '%s' to %u:%u", dir, (unsigned int)uid, (unsigned int)gid);
+}
+
int become_user(const char *username, int pid_fd)
{
struct passwd *pw = getpwnam(username);
uid_t uid = pw->pw_uid;
gid_t gid = pw->pw_gid;
+ create_needed_dir(CACHE_DIR, uid, gid);
+ create_needed_dir(VARLIB_DIR, uid, gid);
+
int ngroups = (int)sysconf(_SC_NGROUPS_MAX);
gid_t *supplementary_groups = NULL;
if(ngroups) {
}
else debug(D_SYSTEM, "Successfully became user '%s'.", user);
}
+ else {
+ create_needed_dir(CACHE_DIR, getuid(), getgid());
+ create_needed_dir(VARLIB_DIR, getuid(), getgid());
+ }
if(pidfd != -1) {
close(pidfd);
// fork, switch user, create pid file, set process priority
if(become_daemon(dont_fork, user) == -1)
- fatal("Cannot demonize myself.");
+ fatal("Cannot daemonize myself.");
info("NetData started on pid %d", getpid());