]> git.donarmstrong.com Git - deb_pkgs/spamass-milter.git/blobdiff - debian/spamass-milter.init
and sleep before chown to allow the socket to be created
[deb_pkgs/spamass-milter.git] / debian / spamass-milter.init
index 5396f649e208fa3a2871d7c937369ed5d1dd10ab..1d7337afa2273ae4953c9e15989e9ee27d6a2498 100644 (file)
 
 PATH=/sbin:/bin:/usr/sbin:/usr/bin
 DAEMON=/usr/sbin/spamass-milter
-SOCKET=/var/run/sendmail/spamass.sock
-PIDFILE=/var/run/spamass.pid
+SOCKET=/var/run/spamass/spamass.sock
+PIDFILE=/var/run/spamass/spamass.pid
 DESC="Sendmail milter plugin for SpamAssassin"
 
 DEFAULT=/etc/default/spamass-milter
 OPTIONS=""
-RUNAS=""
+RUNAS="nobody"
 CHUID=""
+SOCKETMODE="0660"
+SOCKETOWNER="root:adm"
 
 test -x $DAEMON || exit 0
 
 # If /usr/sbin/postfix exists, set up the defaults for a postfix install
 # These can be overridden in /etc/default/spamass-milter
-if [ -x /usr/sbin/posfix ]; then
+if [ -x /usr/sbin/postfix ]; then
     SOCKET="/var/spool/postfix/spamass/spamass.sock"
-    RUNAS="postfix:postfix"
     PIDFILE="/var/spool/postfix/spamass/spamass.pid"
+    SOCKETOWNER="postfix:postfix"
 fi;
 
 if [ -r $DEFAULT ]; then
@@ -62,44 +64,59 @@ fi;
 
 set -e
 
-case "$1" in
-  start)
-       echo -n "Starting $DESC: "
-
-       if [ ! -d $(dirname $SOCKET) ]; then
-           mkdir -p $(dirname $SOCKET);
-           if [ -n "$RUNAS" ]; then
-               chown "$RUNAS" $(dirname $SOCKET);
-           fi;
+start() {
+    if [ ! -d $(dirname $SOCKET) ]; then
+       mkdir -p $(dirname $SOCKET);
+       if [ -n "$SOCKETOWNER" ]; then
+           chown "$SOCKETOWNER" $(dirname $SOCKET);
        fi;
-       if [ ! -d $(dirname $PIDFILE) ]; then
-           mkdir -p $(dirname $PIDFILE);
-           if [ -n "$RUNAS" ]; then
-               chown "$RUNAS" $(dirname $PIDFILE);
-           fi;
+    fi;
+    if [ ! -d $(dirname $PIDFILE) ]; then
+       mkdir -p $(dirname $PIDFILE);
+       if [ -n "$RUNAS" ]; then
+           chown "$RUNAS" $(dirname $PIDFILE);
        fi;
-       start-stop-daemon --start -p $PIDFILE $CHUID --exec $DAEMON -- -P $PIDFILE -f -p $SOCKET $OPTIONS
+    fi;
+    # Drop in a compatibility symlink for the old sendmail socket location
+    if [ -d /var/run/sendmail ] && [ -n "$RUNAS" ] && 
+       [ "$SOCKET" == "/var/run/spamass/spamass.sock" ] && 
+       ! [ -e /var/run/sendmail/spamass.sock ]; then
+       ln -s $SOCKET /var/run/sendmail/spamass.sock;
+    fi;
+    /bin/rm -f $SOCKET
+    start-stop-daemon --start -p $PIDFILE $CHUID --exec $DAEMON -- -P $PIDFILE -f -p $SOCKET $OPTIONS
+    sleep 1s
+    if [ -n "$SOCKETMODE" ]; then
+       chmod $SOCKETMODE $SOCKET;
+    fi;
+    if [ -n "$SOCKETOWNER" ]; then
+       chown $SOCKETOWNER $SOCKET:
+    fi;
+}
+
+stop(){
+    start-stop-daemon --stop -p $PIDFILE --signal 3 --exec $DAEMON
+    /bin/sleep 5s
+    /bin/rm -f $SOCKET
+}
 
+case "$1" in
+  start)
+       echo -n "Starting $DESC: "
+       start
        echo "${DAEMON}"
        ;;
   stop)
        echo -n "Stopping $DESC: "
-
-       start-stop-daemon --stop -p $PIDFILE --signal 3 --exec $DAEMON
-       /bin/sleep 5s
-       /bin/rm -f $SOCKET
-
+       stop
        echo "${DAEMON}"
        ;;
   force-reload | restart)
        echo -n "Restarting $DESC: "
 
-       start-stop-daemon --stop -p $PIDFILE --signal 3 --exec $DAEMON
-       /bin/sleep 5s
-       /bin/rm -f $SOCKET
-        start-stop-daemon --start -p $PIDFILE --exec $DAEMON -- -P $PIDFILE -f -p $SOCKET $OPTIONS
-
-        echo "${DAEMON}"
+       stop
+       start
+       echo "${DAEMON}"
 
        ;;
   *)