]> git.pld-linux.org Git - packages/sendmail.git/blobdiff - sendmail.init
- fixed previous change
[packages/sendmail.git] / sendmail.init
index b72637bfefaebb5f6632e0926ccbc9997671e39d..34127ced3ce41acd355e75167836ac34afc25914 100644 (file)
@@ -1,62 +1,88 @@
-#!/bin/sh
+#! /bin/sh
 #
-# sendmail      This shell script takes care of starting and stopping
-#               sendmail.
+# sendmail     This shell script takes care of starting and stopping
+#              sendmail.
 #
-# chkconfig: 2345 80 30
-# description: Sendmail is a Mail Transport Agent, which is the program \
-#              that moves mail from one machine to another.
-# processname: sendmail
-# config: /etc/sendmail.cf
-# pidfile: /var/run/sendmail.pid
+# chkconfig:   2345 80 30
+# description: Sendmail is a Mail Transport Agent, which is the program \
+#              that moves mail from one machine to another.
+# pidfile:     /var/run/sendmail.pid
 
-# Source function library.
+
+# Source function library
 . /etc/rc.d/init.d/functions
 
-# Source networking configuration.
+# Get network config
 . /etc/sysconfig/network
 
-# Source sendmail configureation.
-if [ -f /etc/sysconfig/sendmail ] ; then
+# Get service config
+if [ -f /etc/sysconfig/sendmail ]; then
        . /etc/sysconfig/sendmail
 else
        DAEMON=yes
        QUEUE=1h
+       ENABLE_IPV6=yes
 fi
 
 # Check that networking is up.
-[ ${NETWORKING} = "no" ] && exit 0
-
-[ -f /usr/sbin/sendmail ] || exit 0
+if is_yes "${NETWORKING}"; then
+       if [ ! -f /var/lock/subsys/network -a "$1" != stop -a "$1" != status ]; then
+               msg_network_down Sendmail
+               exit 1
+       fi
+else
+       exit 0
+fi
 
+RETVAL=0
 # See how we were called.
 case "$1" in
   start)
-       # Start daemons.
-       echo -n "Starting sendmail: "
-       daemon /usr/sbin/sendmail $([ "$DAEMON" = yes ] && echo -bd) \
-                                  $([ -n "$QUEUE" ] && echo -q$QUEUE)
-       echo
-       touch /var/lock/subsys/sendmail
+       # Check if the service is already running?
+       if [ ! -f /var/lock/subsys/sendmail ]; then
+               show "Prepare sendmail db"
+               busy
+               /usr/bin/newaliases >/dev/null 2>&1
+               for i in virtusertable access domaintable mailertable; do
+                       if [ -f /etc/mail/$i ]; then
+                               makemap -v hash /etc/mail/$i < /etc/mail/$i >/dev/null 2>&1
+                               [ $RETVAL -eq 0 ] && RETVAL=$?
+                       fi
+               done 
+               [ $RETVAL -eq 0 ] && ok || fail
+               msg_starting sendmail
+               daemon /usr/sbin/sendmail $([ "$DAEMON" = "yes" ] && echo -bd) \
+                                       $([ -n "$QUEUE" ] && echo -q$QUEUE) \
+                                       $([ "$ENABLE_IPV6" = "yes" ] && 
+                                               echo -ODaemonPortOptions=Family=inet6 )
+               RETVAL=$?
+               [ $RETVAL -eq 0 ] && touch /var/lock/subsys/sendmail
+       else
+               msg_already_running sendmail
+       fi
        ;;
   stop)
-       # Stop daemons.
-       echo -n "Shutting down sendmail: "
-       killproc sendmail
-       echo
-       rm -f /var/lock/subsys/sendmail
+       if [ -f /var/lock/subsys/sendmail ]; then
+               # Stop daemons.
+               msg_stopping sendmail
+               killproc sendmail
+               rm -f /var/lock/subsys/sendmail
+       else
+               msg_not_running sendmail
+       fi
        ;;
-  restart)
+  restart|force-reload)
        $0 stop
        $0 start
+       exit $?
        ;;
   status)
        status sendmail
+       exit $?
        ;;
   *)
-       echo "Usage: sendmail {start|stop|restart|status}"
-       exit 1
+       msg_usage "$0 {start|stop|restart|force-reload|status}"
+       exit 3
 esac
 
-exit 0
-
+exit $RETVAL
This page took 0.069394 seconds and 4 git commands to generate.