Add proper startup/shutdown script for the CAcert CommModule processes.

Add separate commdaemon script to control looping of basic script, and
allow orderly shutdown.
Add hook to client.pl script to interact properly with the new commmodule
and commdaemon scripts.
This commit is contained in:
Wytze van der Raay 2009-12-28 15:09:24 +00:00
parent 2fbd0b09b6
commit 4885a78c1c
3 changed files with 212 additions and 1 deletions

View file

@ -1120,7 +1120,7 @@ sub HandleGPG()
my $crlcheck=0;
while(1)
while ( -f "./client.pl-active" )
{
SysLog("Handling GPG database ...\n");
HandleGPG();

45
CommModule/commdaemon Executable file
View file

@ -0,0 +1,45 @@
#! /bin/bash
# @(#)(CAcert) $Id: commdaemon,v 1.1 2009/12/28 15:09:24 wytze Exp $
# commdaemon - script to run CommModule script in a loop,
# while checking for removal of activation by external script
NAME=CommModule/commdaemon
PID=$$
TAG=${NAME}\[${PID}]
case $# in
1) SCRIPT=$1
ACTIVE=${SCRIPT}-active
;;
*) echo "Usage: $0 <script>" 1>&2
exit 1
;;
esac
syslog_error()
{
logger -t ${TAG} -p user.err $1
}
syslog_notice()
{
logger -t ${TAG} -p user.notice $1
}
if [ ! -x ${SCRIPT} ]
then
syslog_error "${SCRIPT} not found or not executable"
exit 1
fi
(echo -n "${TAG}: "; date) >${ACTIVE}
syslog_notice "main loop started"
while [ -f ${ACTIVE} ]
do
syslog_notice "${SCRIPT} started"
${SCRIPT} >nohup.out 2>&1
syslog_notice "${SCRIPT} ended"
sleep 1
done
syslog_notice "main loop stopped"

166
CommModule/commmodule Executable file
View file

@ -0,0 +1,166 @@
#! /bin/sh
# @(#)(CAcert) $Id: commmodule,v 1.1 2009/12/28 15:09:24 wytze Exp $
### BEGIN INIT INFO
# Provides: commmodule
# Required-Start: $local_fs $remote_fs $syslog mysql
# Required-Stop: $local_fs $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Start and stop the CAcert CommModule processes
# Description: This file should be used to start and stop the CAcert
# CommModule processes from /etc/init.d.
### END INIT INFO
# Author: Wytze van der Raay <wytze@cacert.org>
#
# Please remove the "Author" lines above and replace them
# with your own name if you copy and modify this script.
# Do NOT "set -e"
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="CAcert CommModule processes start/stop"
NAME=commmodule
PIDFILE=/var/run/$NAME.pid
SCRIPTNAME=/etc/init.d/$NAME
# Read configuration variable file if it is present
[ -r /etc/default/$NAME ] && . /etc/default/$NAME
# Load the VERBOSE setting and other rcS variables
. /lib/init/vars.sh
# Define LSB log_* functions.
# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
. /lib/lsb/init-functions
if [ "$1" != "setup" ]
then
if [ "${COMMROOT}" = "" ]
then
echo "$0: COMMROOT not set"
exit 1
fi
if [ "${COMMROLE}" = "" ]
then
echo "$0: COMMROLE not set"
exit 1
fi
if [ ! -d ${COMMROOT} ]
then
echo "$0: ${COMMROOT} is not a directory"
exit 1
fi
if [ ! -x ${COMMROOT}/commdaemon ]
then
echo "$0: ${COMMROOT}/commdaemon not present or non-executable"
exit 1
fi
if [ ! -x ${COMMROOT}/${COMMROLE}.pl ]
then
echo "$0: ${COMMROOT}/${COMMROLE}.pl not present or non executable"
exit 1
fi
DAEMON=${COMMROOT}/commdaemon
DAEMON_ARGS="${COMMROOT}/${COMMROLE}.pl"
ACTIVE=${COMMROOT}/${COMMROLE}.pl-active
fi
# Load usbserial module with proper parameters
/sbin/modprobe usbserial vendor=0x067b product=0x2501
#
# Function that starts the daemon/service
#
do_start()
{
# Return
# 0 if daemon has been started
# 1 if daemon was already running
# 2 if daemon could not be started
start-stop-daemon --start --quiet --pidfile $PIDFILE \
--chdir ${COMMROOT} --background --exec $DAEMON --test \
> /dev/null \
|| return 1
start-stop-daemon --start --quiet --pidfile $PIDFILE \
--chdir ${COMMROOT} --background --exec $DAEMON -- \
$DAEMON_ARGS \
|| return 2
# Add code here, if necessary, that waits for the process to be ready
# to handle requests from services started subsequently which depend
# on this one. As a last resort, sleep for some time.
}
#
# Function that stops the daemon/service
#
do_stop()
{
# Return
# 0 if daemon has been stopped
# 1 if daemon was already stopped
# 2 if daemon could not be stopped
# other if a failure occurred
rm -f ${ACTIVE}
sleep 5
start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME
RETVAL="$?"
[ "$RETVAL" = 2 ] && return 2
# Many daemons don't delete their pidfiles when they exit.
rm -f $PIDFILE
return "$RETVAL"
}
case "$1" in
start)
[ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
do_start
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
stop)
[ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
do_stop
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
restart|force-reload)
log_daemon_msg "Restarting $DESC" "$NAME"
do_stop
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
;;
*)
# Failed to stop
log_end_msg 1
;;
esac
;;
setup)
# setup default installation of commmodule scripts
cp ${NAME} /etc/init.d
chown root.root /etc/init.d/${NAME}
update-rc.d -f ${NAME} remove
update-rc.d ${NAME} defaults 90 20
(echo "COMMROOT=/home/cacert/www/CommModule";
echo "COMMROLE=client") >/etc/default/${NAME}
;;
*)
echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload|setup}" >&2
exit 3
;;
esac
: