aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rambler-co.ru>2009-03-06 13:09:32 +0300
committerVsevolod Stakhov <vsevolod@rambler-co.ru>2009-03-06 13:09:32 +0300
commit514d83c13d1f22263c9662154e7459cdbff51c97 (patch)
tree2f2b4823f4fca3c20439ebe28efc14f570378a44
parent8c09632127fb53347239f5f35c0049d8d316a607 (diff)
downloadrspamd-514d83c13d1f22263c9662154e7459cdbff51c97.tar.gz
rspamd-514d83c13d1f22263c9662154e7459cdbff51c97.zip
* Fix initialization procedure of redirector
* Do not write to log file if we cannot open it
-rw-r--r--src/util.c2
-rwxr-xr-xutils/redirector.pl.in15
2 files changed, 8 insertions, 9 deletions
diff --git a/src/util.c b/src/util.c
index 589d5b5d9..4ca9a437b 100644
--- a/src/util.c
+++ b/src/util.c
@@ -813,7 +813,7 @@ open_log (struct config_file *cfg)
case RSPAMD_LOG_FILE:
cfg->log_fd = open (cfg->log_file, O_CREAT | O_WRONLY | O_APPEND, S_IWUSR | S_IRUSR | S_IRGRP | S_IROTH);
if (cfg->log_fd == -1) {
- msg_err ("open_log: cannot open desired log file: %s, %s", cfg->log_file, strerror (errno));
+ fprintf (stderr, "open_log: cannot open desired log file: %s, %s", cfg->log_file, strerror (errno));
return -1;
}
return 0;
diff --git a/utils/redirector.pl.in b/utils/redirector.pl.in
index da3451580..c406b48a3 100755
--- a/utils/redirector.pl.in
+++ b/utils/redirector.pl.in
@@ -40,7 +40,7 @@ my %cfg = (
max_rec => 5,
pidfile => '/var/run/rspamd/redirector.pid',
logfile => '/var/log/rspamd-redirector.log',
- do_log => 1,
+ do_log => 0,
debug => 0,
digest_bits => 256,
cache_expire => 3600,
@@ -50,6 +50,11 @@ my %cfg = (
our $do_reopen_log = 0;
+die "Process is already started, check $cfg{pidfile}" if Proc::PidUtil::is_running($cfg{pidfile});
+
+# Do daemonization
+Proc::Daemon::Init if !$cfg{debug};
+
# Drop privilleges
if ($> == 0) {
my $uid = getpwnam($cfg{user}) or die "user $cfg{user} unknown";
@@ -58,15 +63,10 @@ if ($> == 0) {
$) = $gid;
}
-die "Process is already started, check $cfg{pidfile}" if Proc::PidUtil::is_running($cfg{pidfile});
-
die "Cannot write to pidfile $cfg{pidfile}" if ! open(PID, "> $cfg{pidfile}");
close(PID);
-$cfg{do_log} = 0 if ! open(LOG, ">> $cfg{logfile}");
-
-# Do daemonization
-Proc::Daemon::Init if !$cfg{debug};
+$cfg{do_log} = 1 if open(LOG, ">> $cfg{logfile}");
Proc::PidUtil::make_pidfile($cfg{pidfile}, $$) or die "Cannot write pidfile $cfg{pidfile}";
@@ -443,7 +443,6 @@ POE::Kernel->run();
exit 0;
END {
- unlink($cfg{pidfile});
if ($cfg{do_log}) {
write_log ("", "Stopping URL resolver");
close (LOG);