5 # Sample init script for Debian GNU/Linux
7 # Copyright (c) 2002 Georg C. F. Greve <greve@gnu.org>,
8 # all rights maintained by FSF Europe e.V.,
9 # Villa Vogelsang, Antonienallee 1, 45279 Essen, Germany
11 # This program is free software; you can redistribute it and/or modify
12 # it under the terms of the GNU General Public License as published by
13 # the Free Software Foundation; either version 2 of the License, or
14 # (at your option) any later version.
16 # This program is distributed in the hope that it will be useful,
17 # but WITHOUT ANY WARRANTY; without even the implied warranty of
18 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 # GNU General Public License for more details.
21 # You should have received a copy of the GNU General Public License
22 # along with this program; if not, write to the Free Software
23 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
26 # Michael Brown <michaelb@opentext.com>
28 # This init script was modified on Thu, 30 Jan 2003 02:06:04 -0500 by
29 # Don Armstrong <don@donarmstrong.com> from contrib/spamass-milter to
30 # allow force-reload and options specified in
31 # /etc/default/spamass-milter necessary for inclusion in debian.
34 PATH=/sbin:/bin:/usr/sbin:/usr/bin
36 DAEMON=/usr/sbin/spamass-milter
37 SOCKET=/var/run/spamass/spamass.sock
38 PIDFILE=/var/run/spamass/spamass.pid
39 DESC="Sendmail milter plugin for SpamAssassin"
41 DEFAULT=/etc/default/spamass-milter
46 SOCKETOWNER="root:root"
48 test -x $DAEMON || exit 0
50 if [ -e /etc/mail/sendmail.cf ] && egrep -q 'X.+S=local:/var/run/sendmail/spamass\.sock' /etc/mail/sendmail.cf; then
51 SOCKET=/var/run/sendmail/spamass.sock
55 echo "WARNING: You are using the old location of spamass.sock. Change your input filter to use";
56 echo "/var/run/spamass/spamass.sock so spamass-milter can run as nobody";
59 # If /usr/sbin/postfix exists, set up the defaults for a postfix install
60 # These can be overridden in /etc/default/spamass-milter
61 if [ -x /usr/sbin/postfix ]; then
62 SOCKET="/var/spool/postfix/spamass/spamass.sock"
63 SOCKETOWNER="postfix:postfix"
67 if [ -r $DEFAULT ]; then
71 if [ -n "$RUNAS" ]; then
72 CHUID="--chuid $RUNAS";
78 if [ ! -d $(dirname $SOCKET) ]; then
79 mkdir -p $(dirname $SOCKET);
80 if [ -n "$SOCKETOWNER" ]; then
81 chown "$SOCKETOWNER" $(dirname $SOCKET);
84 if [ ! -d $(dirname $PIDFILE) ]; then
85 mkdir -p $(dirname $PIDFILE);
86 if [ -d $(dirname $PIDFILE) ] && [ -n "$RUNAS" ]; then
87 chown "$RUNAS" $(dirname $PIDFILE);
90 if [ -n "$RUNAS" ] && [ -d $(dirname $PIDFILE) ] && [ "$(stat -c '%U' $(dirname $PIDFILE))" != "$RUNAS" ]; then
91 echo "WARNING: $NAME will run as user $RUNAS but $(dirname $PIDFILE) is not owned by $RUNAS";
92 echo "Either delete this directory or chown it appropriately. Startup attempts may fail.";
95 start-stop-daemon --start -p $PIDFILE $CHUID --exec $DAEMON -- -P $PIDFILE -f -p $SOCKET $OPTIONS
97 if [ -n "$SOCKETMODE" ]; then
98 chmod $SOCKETMODE $SOCKET;
100 if [ -n "$SOCKETOWNER" ]; then
101 chown $SOCKETOWNER $SOCKET;
106 start-stop-daemon --stop -p $PIDFILE --signal 3 --exec $DAEMON
113 echo -n "Starting $DESC: "
118 echo -n "Stopping $DESC: "
122 force-reload | restart)
123 echo -n "Restarting $DESC: "
132 echo "Usage: $N {start|stop|restart}" >&2