#!/bin/sh
#
-# syslog Starts syslog-ng (syslogd replacment).
+# syslog Starts syslog-ng (syslogd replacement).
#
# chkconfig: 2345 30 70
# description: Syslog is the facility by which many daemons use to log \
. /etc/sysconfig/syslog-ng
fi
+checkconfig() {
+ syslog-ng $OPTIONS -F -s -p /var/run/syslog-ng-syntaxcheck.pid
+ RETVAL=$?
+ return $RETVAL
+}
+
configtest() {
- syslog-ng $OPTIONS -s || exit 1
+ checkconfig 2>/dev/null
+ RETVAL=$?
+ if [ $RETVAL != 0 ]; then
+ show "Checking syslog-ng config syntax"
+ fail
+ echo >&2 "Configuration file syntax test failed. Run $0 configtest to see errors."
+ exit $RETVAL
+ fi
}
start() {
# Check if the service is already running?
if [ ! -f /var/lock/subsys/syslog-ng ]; then
msg_starting "syslog-ng"
- daemon /usr/sbin/syslog-ng $OPTIONS
+ emit starting JOB=syslog-ng SERVICE=syslog
+ daemon /usr/sbin/syslog-ng -f /etc/syslog-ng/syslog-ng.conf $OPTIONS
+ emit --no-wait started JOB=syslog-ng SERVICE=syslog
RETVAL=$?
[ $RETVAL -eq 0 ] && touch /var/lock/subsys/syslog-ng
else
stop() {
if [ -f /var/lock/subsys/syslog-ng ]; then
msg_stopping "syslog-ng"
+ emit stopping JOB=syslog-ng SERVICE=syslog
killproc syslog-ng
+ emit --no-wait stopped JOB=syslog-ng SERVICE=syslog
rm -f /var/lock/subsys/syslog-ng >/dev/null 2>&1
else
- msg_not_running syslog-ng
+ msg_not_running "syslog-ng"
fi
}
condrestart() {
if [ -f /var/lock/subsys/syslog-ng ]; then
+ configtest
stop
start
else
- msg_not_running syslog-ng
+ msg_not_running "syslog-ng"
RETVAL=$1
fi
}
+reload() {
+ if [ -f /var/lock/subsys/syslog-ng ]; then
+ configtest
+ msg_reloading "syslog-ng"
+ killproc syslog-ng -HUP
+ RETVAL=$?
+ else
+ msg_not_running "syslog-ng"
+ exit 7
+ fi
+}
+
+flush_logs() {
+ if use_upstart && [ -f /etc/init/syslog-ng.conf ] ; then
+ /sbin/initctl reload syslog-ng
+ elif [ -f /var/lock/subsys/syslog-ng ]; then
+ configtest
+ msg_reloading "syslog-ng"
+ killproc syslog-ng -HUP
+ RETVAL=$?
+ else
+ msg_not_running "syslog-ng"
+ exit 7
+ fi
+}
+
+upstart_controlled --except configtest flush-logs
+
RETVAL=0
# See how we were called.
case "$1" in
start)
+ configtest
start
;;
stop)
stop
;;
restart)
- configtest
+ configtest
stop
start
;;
try-restart)
- configtest
condrestart 0
;;
reload|force-reload)
- if [ -f /var/lock/subsys/syslog-ng ]; then
- msg_reloading "syslog-ng"
- configtest
- RETVAL=$?
- if [ $RETVAL -eq 0 ]; then
- killproc syslog-ng -HUP
- RETVAL=$?
- else
- fail
- echo >&2 "Configuration file syntax test failed."
- fi
- else
- msg_not_running syslog-ng
- exit 7
- fi
+ reload
;;
flush-logs)
- if [ -f /var/lock/subsys/syslog-ng ]; then
- msg_reloading "syslog-ng"
- configtest
- RETVAL=$?
- if [ $RETVAL -eq 0 ]; then
- killproc syslog-ng -HUP
- RETVAL=$?
- else
- fail
- echo >&2 "Configuration file syntax test failed."
- fi
- fi
+ flush_logs
;;
configtest)
- configtest
- exit $?
+ show "Checking syslog-ng config syntax"
+ res=$(checkconfig 2>&1)
+ RETVAL=$?
+ [ $RETVAL = 0 ] && ok || fail
+ echo >&2 "$res"
;;
status)
status syslog-ng