]> git.pld-linux.org Git - packages/cyrus-imapd.git/blobdiff - cyrus-imapd.init
- more missing libtools
[packages/cyrus-imapd.git] / cyrus-imapd.init
index 1b952c6bb558deca85ad0012e01f84fde7c29171..e266ebf6a7bd806b41f3144841243c712f38b803 100644 (file)
@@ -1,10 +1,12 @@
 #!/bin/sh
 #
-# cyrus-imapd  cyrus-imapd IMAP & POP3 Server
+# cyrus-imapd  cyrus-imapd IMAP Daemon
 #
-# chkconfig:    345  85 15
+# chkconfig:   345 85 15
 #
 # description: cyrus-imapd
+#
+# $Id$
 
 # Source function library
 . /etc/rc.d/init.d/functions
 
 # Check that networking is up.
 if is_yes "${NETWORKING}"; then
-       if [ ! -f /var/lock/subsys/network ]; then
-               msg_network_down cyrus-imapd
+       if [ ! -f /var/lock/subsys/network -a "$1" != stop -a "$1" != status ]; then
+               msg_network_down "Cyrus IMAP Daemon"
                exit 1
        fi
 else
        exit 0
 fi
 
-
-# See how we were called.
-case "$1" in
-  start)
+start() {
        # Check if the service is already running?
        if [ ! -f /var/lock/subsys/cyrus-imapd ]; then
-               msg_starting cyrus-imapd
+               msg_starting "Cyrus IMAP Daemon"
                /usr/lib/cyrus/cyrus-master &
-               RETVAL=$?
-               [ $RETVAL -eq 0 ] && touch /var/lock/subsys/cyrus-imapd
+               if ps -C cyrus-master >/dev/null 2>&1; then
+                       RETVAL=$?
+                       [ $RETVAL -eq 0 ] && touch /var/lock/subsys/cyrus-imapd
+                       ok
+               else
+                       fail
+               fi
        else
-               # show "%s service is already running." <service>
-               msg_already_running cyrus-imapd
-               exit 1
+               msg_already_running "Cyrus IMAPD"
        fi
-        ;;
-  stop)
-        # Stop daemons.
+}
+
+stop() {
+       # Stop daemons.
        if [ -f /var/lock/subsys/cyrus-imapd ]; then
-               msg_stopping cyrus-imapd
+               msg_stopping "Cyrus IMAP Daemon"
                killproc cyrus-master
-               RETVAL=$?
                rm -f /var/lock/subsys/cyrus-imapd
        else
-               msg_not_running cyrus-imapd
-               exit 1
-       fi      
-        ;;
+               msg_not_running "Cyrus IMAP Daemon"
+       fi
+}
+
+condrestart() {
+       if [ -f /var/lock/subsys/cyrus-imapd ]; then
+               stop
+               start
+       else
+               msg_not_running "Cyrus IMAP Daemon"
+               RETVAL=$1
+       fi
+}
+
+RETVAL=0
+# See how we were called.
+case "$1" in
+  start)
+       start
+       ;;
+  stop)
+       stop
+       ;;
   restart)
-        $0 stop
-       $0 start
-        ;;
+       stop
+       start
+       ;;
+  try-restart)
+       condrestart 0
+       ;;
+  force-reload)
+       condrestart 7
+       ;;
   status)
        status cyrus-master
        RETVAL=$?
-        ;;
+       ;;
   *)
-       msg_usage "$0 {start|stop|status|restart}"
-        exit 1
+       msg_usage "$0 {start|stop|restart|try-restart|force-reload|status}"
+       exit 3
 esac
 
 exit $RETVAL
-
-# This must be last line !
-# vi:syntax=sh:tw=78:ts=8:sw=4
-
This page took 0.069522 seconds and 4 git commands to generate.