### BEGIN INIT INFO
# Provides: spamass-milter
-# Required-Start: $syslog $local_fs
-# Required-Stop: $syslog $local_fs
+# Required-Start: $syslog $local_fs $remote_fs
+# Required-Stop: $syslog $local_fs $remote_fs
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: milter for spamassassin
set -e
start() {
+ if status; then
+ echo "$NAME is already running";
+ exit 1;
+ fi;
# Because the default socket is in the same location as the
# pidfile, we create them in this order.
- if [ ! -d $(dirname $PIDFILE) ]; then
- mkdir -p $(dirname $PIDFILE);
- if [ -d $(dirname $PIDFILE) ] && [ -n "$RUNAS" ]; then
- chown "$RUNAS" $(dirname $PIDFILE);
- fi;
- fi;
- if [ ! -d $(dirname $SOCKET) ]; then
- mkdir -p $(dirname $SOCKET);
- if [ -n "$SOCKETOWNER" ]; then
- chown "$RUNAS" $(dirname $SOCKET);
+ for DIR in "$(dirname $PIDFILE)" "$(dirname $SOCKET)"; do
+ # if the dirname is '.', then it's some kind of odd socket, like
+ # an inet socket. Don't create the directory in such a case
+ if [ "$DIR" != "." ] && [ ! -d "$DIR" ]; then
+ mkdir -p "$DIR";
+ if [ -x /sbin/restorecon ]; then
+ /sbin/restorecon "$DIR";
+ fi;
+ if [ -n "$RUNAS" ]; then
+ chown "$RUNAS" "$DIR";
+ fi;
fi;
- fi;
- if [ -n "$RUNAS" ] && [ -d $(dirname $PIDFILE) ] && [ "$(stat -c '%U' $(dirname $PIDFILE))" != "$RUNAS" ]; then
+ done;
+ if [ -n "$RUNAS" ] && [ -d $(dirname $PIDFILE) ] &&
+ [ "$(stat -c '%U' $(dirname $PIDFILE))" != "$RUNAS" ]; then
echo "WARNING: $NAME will run as user $RUNAS but $(dirname $PIDFILE) is not owned by $RUNAS";
echo "Either delete this directory or chown it appropriately. Startup attempts may fail.";
fi;
- if [ -n "$RUNAS" ] && [ -d $(dirname $SOCKET) ] && [ "$(stat -c '%U' $(dirname $SOCKET))" != "$RUNAS" ]; then
+ if [ -n "$RUNAS" ] && [ $(dirname $SOCKET) != "." ] &&
+ [ -d $(dirname $SOCKET) ] &&
+ [ "$(stat -c '%U' $(dirname $SOCKET))" != "$RUNAS" ]; then
echo "WARNING: $NAME will run as user $RUNAS but $(dirname $SOCKET) is not owned by $RUNAS";
echo "Either delete this directory or chown it appropriately. Startup attempts may fail.";
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;
+ if [ $(dirname $SOCKET) != "." ]; then
+ /bin/rm -f $SOCKET
fi;
- if [ -n "$SOCKETOWNER" ]; then
- chown $SOCKETOWNER $SOCKET;
+ start-stop-daemon --start -p $PIDFILE $CHUID --exec $DAEMON -- -P $PIDFILE -f -p $SOCKET $OPTIONS
+ sleep 1
+ if [ $(dirname $SOCKET) != "." ];
+ if [ -n "$SOCKETMODE" ]; then
+ chmod $SOCKETMODE $SOCKET;
+ fi;
+ if [ -n "$SOCKETOWNER" ]; then
+ chown $SOCKETOWNER $SOCKET;
+ fi;
fi;
}
stop(){
start-stop-daemon --oknodo --stop -p $PIDFILE --signal 3 --exec $DAEMON
- /bin/sleep 5s
- /bin/rm -f $SOCKET
+ /bin/sleep 5
+ if [ $(dirname $SOCKET) != "." ]; then
+ /bin/rm -f $SOCKET
+ fi;
/bin/rm -f $PIDFILE
}