summaryrefslogtreecommitdiff
path: root/nDPIsrvd.c
diff options
context:
space:
mode:
authorToni Uhlig <matzeton@googlemail.com>2020-10-07 14:38:10 +0200
committerToni Uhlig <matzeton@googlemail.com>2020-10-07 14:38:10 +0200
commit3cfb4d9c737debfbd8d74936a33a5a0eab79ac60 (patch)
treea8aedb0d5b68a5a09ee28a765a17498dbb5d315f /nDPIsrvd.c
parent4dd45375244954e7b2e310bb2983f031f3a5a3b8 (diff)
nDPId/nDPIsrvd: change_user_group does now chown/chmod collector/distributor socket paths
Signed-off-by: Toni Uhlig <matzeton@googlemail.com>
Diffstat (limited to 'nDPIsrvd.c')
-rw-r--r--nDPIsrvd.c17
1 files changed, 9 insertions, 8 deletions
diff --git a/nDPIsrvd.c b/nDPIsrvd.c
index d2aaeb52b..ca8f2560d 100644
--- a/nDPIsrvd.c
+++ b/nDPIsrvd.c
@@ -344,7 +344,7 @@ int main(int argc, char ** argv)
if (daemonize_with_pidfile(pidfile) != 0)
{
- return 1;
+ goto error;
}
closelog();
openlog("nDPIsrvd", LOG_CONS | (log_to_stderr != 0 ? LOG_PERROR : 0), LOG_DAEMON);
@@ -354,7 +354,7 @@ int main(int argc, char ** argv)
remotes.desc = (struct remote_desc *)malloc(remotes.desc_size * sizeof(*remotes.desc));
if (remotes.desc == NULL)
{
- return 1;
+ goto error;
}
for (size_t i = 0; i < remotes.desc_size; ++i)
{
@@ -365,7 +365,7 @@ int main(int argc, char ** argv)
if (create_listen_sockets() != 0)
{
- return 1;
+ goto error;
}
syslog(LOG_DAEMON, "collector listen on %s", json_sockpath);
switch (serv_type)
@@ -387,7 +387,7 @@ int main(int argc, char ** argv)
}
errno = 0;
- if (change_user_group(user, group) != 0)
+ if (change_user_group(user, group, pidfile, json_sockpath, serv_listen_path) != 0)
{
if (errno != 0)
{
@@ -397,7 +397,7 @@ int main(int argc, char ** argv)
{
syslog(LOG_DAEMON | LOG_ERR, "Change user/group failed.");
}
- return 1;
+ goto error;
}
signal(SIGINT, sighandler);
@@ -408,7 +408,7 @@ int main(int argc, char ** argv)
if (epollfd < 0)
{
syslog(LOG_DAEMON | LOG_ERR, "Error creating epoll: %s", strerror(errno));
- return 1;
+ goto error;
}
struct epoll_event accept_event = {};
@@ -417,14 +417,14 @@ int main(int argc, char ** argv)
if (epoll_ctl(epollfd, EPOLL_CTL_ADD, json_sockfd, &accept_event) < 0)
{
syslog(LOG_DAEMON | LOG_ERR, "Error adding JSON fd to epoll: %s", strerror(errno));
- return 1;
+ goto error;
}
accept_event.data.fd = serv_sockfd;
accept_event.events = EPOLLIN;
if (epoll_ctl(epollfd, EPOLL_CTL_ADD, serv_sockfd, &accept_event) < 0)
{
syslog(LOG_DAEMON | LOG_ERR, "Error adding INET fd to epoll: %s", strerror(errno));
- return 1;
+ goto error;
}
struct epoll_event events[32];
@@ -729,6 +729,7 @@ int main(int argc, char ** argv)
}
}
+error:
close(json_sockfd);
close(serv_sockfd);