#!/bin/sh
#
# mailman	mailman qrunner daemon
#
# chkconfig:	345 85 15
# description:	mailman is mailing lists server
#
# processname:	mailman
# pidfile:	/var/run/mailman/master-qrunner.pid
# config:	/etc/webapps/mailman/mm_cfg.py

# Source function library
. /etc/rc.d/init.d/functions

# Source networking configuration.
. /etc/sysconfig/network

# Check that networking is up.
if is_yes "${NETWORKING}"; then
	if [ ! -f /var/lock/subsys/network -a "$1" != stop -a "$1" != status ]; then
		msg_network_down "Mailman Qrunner Daemon"
		exit 1
	fi
else
	exit 0
fi

# Get service config
[ -f /etc/sysconfig/mailman ] && . /etc/sysconfig/mailman

start() {
	# Check if the service is already running?
	if [ -f /var/lock/subsys/mailman ]; then
		msg_already_running "Mailman Qrunner Daemon"
		return
	fi

	msg_starting "Mailman Qrunner Daemon"
	daemon --user mailman /usr/lib64/mailman/bin/mailmanctl -q -s -u start
	RETVAL=$?
	[ $RETVAL -eq 0 ] && touch /var/lock/subsys/mailman
}

stop() {
	# Stop daemons.
	if [ ! -f /var/lock/subsys/mailman ]; then
		msg_not_running "Mailman Qrunner Daemon"
		return
	fi

	msg_stopping "Mailman Qrunner Daemon"
	daemon --user mailman /usr/lib64/mailman/bin/mailmanctl -u stop
	rm -f /var/lock/subsys/mailman /var/run/mailman.pid
}

condrestart() {
	if [ -f /var/lock/subsys/mailman ]; then
		stop
		start
	else
		msg_not_running "Mailman Qrunner Daemon"
		RETVAL=$1
	fi
}

flushlogs() {
    if [ -f /var/lock/subsys/mailman ]; then
                daemon --user mailman /usr/lib64/mailman/bin/mailmanctl -u reopen > /dev/null
                RETVAL=$?
    else
                msg_not_running "Mailman Qrunner Daemon"
                RETVAL=1
    fi
}

RETVAL=0
# See how we were called.
case "$1" in
  start)
  	start
	;;
  stop)
  	stop
	;;
  restart)
	stop
	start
	;;
  try-restart)
	condrestart 0
	;;
  force-reload)
	condrestart 7
	;;
  flush-logs)
        flushlogs
        ;;
  status)
	/usr/lib64/mailman/bin/mailmanctl status
	exit $?
	;;
  *)
	msg_usage "$0 {start|stop|restart|try-restart|force-reload|status|flush-logs}"
	exit 3
esac

exit $RETVAL
