#!/bin/sh
# courier-imaps		Courier IMAP-SSL daemon
#
# chkconfig: 35 71 29
# description: Courier IMAP daemon with SSL/TLS support. This \
#              daemon is running via Courier own tcpd daemon - couriertcpd
# processname: courier-imaps
# config: /etc/courier-imap/imapd
# config: /etc/courier-imap/imapd-ssl
# config: /etc/courier-imap/imapd.cnf
# pidfile: /var/run/courier-imaps.pid

# Do not load RH compatibility interface.
WITHOUT_RC_COMPAT=1

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

# System-wide Courier-IMAP configuration
. /etc/sysconfig/courier-imap

# IMAP daemon configuration
. /etc/courier-imap/imapd-ssl
. /etc/courier-imap/imapd

SBIN_DIR=/usr/sbin
LIBEXEC_DIR=/usr/lib/courier-imap

IMAPD_BIN=/usr/sbin/imapd
IMAPLOGIN_BIN=/usr/sbin/imaplogin
DAEMON=$SBIN_DIR/courier-imaps
LOGGER_BIN=$SBIN_DIR/courierlogger

LOCKFILE=/var/lock/subsys/courier-imaps

[ "$IMAPDSSLSTART" != "NO" ] || exit;
[ -x $IMAPD_BIN -a -x $IMAPLOGIN_BIN ] || exit;
[ -x $DAEMON -a -x $LOGGER_BIN ] || exit;
[ -x $COURIERTLS ] || exit;

RETVAL=0

start()
{

	LIBAUTHMODULES=""
	for f in `echo $AUTHMODULES`; do
		LIBAUTHMODULES="$LIBAUTHMODULES $LIBEXEC_DIR/authlib/$f"
	done

	if test "$TLS_CACHEFILE" != ""; then
		rm -f $TLS_CACHEFILE
	fi

	msg_starting $"Courier IMAP-SSL daemon"

	ulimit -v $IMAP_ULIMITD
	/usr/bin/env - /bin/sh -c " set -a ; \
		. /etc/courier-imap/imapd ; \
		. /etc/courier-imap/imapd-ssl ; \
		IMAP_TLS=1; export IMAP_TLS; \
		$DAEMON -address=$SSLADDRESS \
		    -stderrlogger=$LOGGER_BIN \
		    -stderrloggername=imapd-ssl \
		    -maxprocs=$MAXDAEMONS \
		    -maxperip=$MAXPERIP \
		    -pid=$SSLPIDFILE \
			-lock=$LOCKFILE \
		    $TCPDOPTS $SSLPORT $COURIERTLS -server -tcpd \
		    $IMAPLOGIN_BIN $LIBAUTHMODULES \
		    $IMAPD_BIN Maildir"
	
	RETVAL=$?
	if [ $RETVAL -eq 0 ]; then
	    success "courier-imaps startup"
	else
		failure "courier-imaps startup"
	fi
	
	return $RETVAL
}	

stop()
{
	msg_stopping $"Courier IMAP-SSL daemon"
	stop_daemon --pidfile "$SSLPIDFILE" --lockfile "$LOCKLFILE" \
				--no-announce --expect-user root -- \
				$DAEMON -pid=$SSLPIDFILE -lock=$LOCKFILE -stop

	RETVAL=$?
	return $RETVAL
}

restart()
{
	stop
	start
}

# See how we were called.
case "$1" in
	start)
		start
		;;
	stop)
		stop
		;;
	reload)
		echo "Reload not implemented. Please, use restart instead."
		;;
	restart)
		restart
		;;
	condstop)
		if [ -e "$LOCKFILE" ]; then
			stop
		fi
		;;
	condrestart)
		if [ -e "$LOCKFILE" ]; then
			restart
		fi
		;;
	status)
		status --pidfile "$SSLPIDFILE" courier-imaps
		RETVAL=$?
		;;
	*)
		msg_usage "${0##*/} {start|stop|restart|condstop|condrestart|status}"
		RETVAL=1
esac

exit $RETVAL
