DESC="Citadel Groupware "
NAME=citserver
DAEMON=/usr/sbin/$NAME
-PIDFILE=$RUNDIR/$NAME.pid
-DAEMON_ARGS=" -D${PIDFILE} -x3 -lmail -t/dev/null"
+PIDFILE=$RUNDIR/citadel.pid
+DAEMON_ARGS=" -d -x3 -lmail -t/dev/null"
SCRIPTNAME=/etc/init.d/citadel
SENDCOMMAND=/usr/sbin/sendcommand
# 2 if daemon could not be stopped
# other if a failure occurred
if $SENDCOMMAND "DOWN" >/dev/null 2>&1 ; then
+ PID=`cat $PIDFILE`
rm -f $PIDFILE
-
- while test -S /var/run/citadel/citadel.socket; do
+ count=0;
+ while test -S /var/run/citadel/citadel.socket -o -d /proc/$PID; do
+ count=$(($count+1))
sleep 1
echo -n "."
+ if test "$count" = "10"; then
+ kill $PID
+ fi
+ if test "$count" = "20"; then
+ kill -9 $PID
+ rm -rf /var/run/citadel/*
+ fi
done
return 0
else
# Function that sends a SIGHUP to the daemon/service
#
do_reload() {
- do_stop
- do_start
+ # Return
+ # 0 if daemon could not be restarted
+ # 1 if daemon has been restarted
+ # other if a failure occurred
+ if $SENDCOMMAND "DOWN 1" 2>&1|grep '200 Restarting'>/dev/null ; then
+ return 1
+ fi
return 0
}
echo "Restarting $DESC" "$NAME"
fi
- do_stop
+ do_reload
if test -n "$MODERN"; then
case "$?" in
- 0|1)
- do_start
- case "$?" in
- 0) log_end_msg 0 ;;
- 1) log_end_msg 1 ;; # Old process is still running
- *) log_end_msg 1 ;; # Failed to start
- esac
+ 0)
+ log_end_msg 0
;;
- *)
+ 1)
# Failed to stop
log_end_msg 1
;;
esac
- else
- do_start
fi
;;
*)