Commit a23de6ea authored by Daniel Henninger's avatar Daniel Henninger Committed by dhenninger

[JM-872] Modifications for improvements towards more thorough init scripts

and such.  Still work to be done.



git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/trunk@7980 b35dd754-fafc-0310-a699-88a17e54d16e
parent 83a7680b
#!/bin/bash #!/bin/sh
# #
# openfired Stops and starts the Openfire XMPP service. # openfired Stops and starts the Openfire XMPP service.
# #
...@@ -6,7 +6,8 @@ ...@@ -6,7 +6,8 @@
# description: Openfire is an XMPP server, which is a server that facilitates \ # description: Openfire is an XMPP server, which is a server that facilitates \
# XML based communication, such as chat. # XML based communication, such as chat.
# config: /opt/openfire/conf/openfire.xml # config: /opt/openfire/conf/openfire.xml
# pidfile: /var/run/openfired.pid # config: /etc/sysconfig/openfire
# pidfile: /var/run/openfire.pid
# #
# This script has currently been tested on Redhat and CentOS based systems, # This script has currently been tested on Redhat and CentOS based systems,
# but should theoretically work on most UNIX like systems # but should theoretically work on most UNIX like systems
...@@ -25,19 +26,26 @@ ...@@ -25,19 +26,26 @@
# ln -s ../init.d/openfired S99openfired # ln -s ../init.d/openfired S99openfired
# #
PATH=/sbin:/bin:/usr/bin:/usr/sbin
RETVAL=0
PROG="openfire"
# Check that we are root ... so non-root users stop here
[ "`id -u`" = 0 ] || exit 1
# Get config. # Get config.
[ -f /etc/sysconfig/openfire ] && . /etc/sysconfig/openfire [ -f "/etc/sysconfig/$PROG" ] && . /etc/sysconfig/$PROG
# If openfire user is not set in sysconfig, set to jive. # If openfire user is not set in sysconfig, set to jive.
[ -z "$OPENFIRE_USER" ] && OPENFIRE_USER=jive [ -z "$OPENFIRE_USER" ] && OPENFIRE_USER=jive
# If pid file path is not set in sysconfig, set to /var/run/openfired.pid. # If pid file path is not set in sysconfig, set to /var/run/openfired.pid.
[ -z "$OPENFIRE_PIDFILE" ] && OPENFIRE_PIDFILE=/var/run/openfired.pid [ -z "$OPENFIRE_PIDFILE" ] && OPENFIRE_PIDFILE=/var/run/$PROG.pid
# ----------------------------------------------------------------- # -----------------------------------------------------------------
# If a openfire home variable has not been specified, try to determine it # If a openfire home variable has not been specified, try to determine it
if [ ! $OPENFIRE_HOME ]; then if [ -z "$OPENFIRE_HOME" ]; then
if [ -d "/opt/openfire" ]; then if [ -d "/opt/openfire" ]; then
OPENFIRE_HOME="/opt/openfire" OPENFIRE_HOME="/opt/openfire"
elif [ -d "/usr/local/openfire" ]; then elif [ -d "/usr/local/openfire" ]; then
...@@ -49,18 +57,19 @@ if [ ! $OPENFIRE_HOME ]; then ...@@ -49,18 +57,19 @@ if [ ! $OPENFIRE_HOME ]; then
fi fi
fi fi
RETVAL=0 [ -z "$OPENFIRE_LOGDIR" ] && OPENFIRE_LOGDIR=$OPENFIRE_HOME/logs
prog="openfired"
OPENFIRE_CMD="$OPENFIRE_HOME/bin/openfire.sh"
[ -f "$OPENFIRE_CMD" ] || exit 1
start() { start() {
OLD_PWD=`pwd` OLD_PWD=`pwd`
cd $OPENFIRE_HOME/bin cd $OPENFIRE_LOGDIR
# Start daemons. # Start daemons.
echo -n $"Starting $prog: " echo -n "Starting $PROG: "
CMD=./openfire.sh su -s /bin/sh -c "$OPENFIRE_CMD" $OPENFIRE_USER > nohup.out 2>&1 &
su -s /bin/bash -c "$CMD" $OPENFIRE_USER &
RETVAL=$? RETVAL=$?
if [ $RETVAL -eq 0 -a ! -z "$OPENFIRE_PIDFILE" ]; then if [ $RETVAL -eq 0 -a ! -z "$OPENFIRE_PIDFILE" ]; then
...@@ -69,7 +78,7 @@ start() { ...@@ -69,7 +78,7 @@ start() {
echo echo
[ $RETVAL -eq 0 ] && touch /var/lock/subsys/openfired [ $RETVAL -eq 0 -a -d /var/lock/subsys ] && touch /var/lock/subsys/$PROG
sleep 1 # allows prompt to return sleep 1 # allows prompt to return
cd $OLD_PWD cd $OLD_PWD
...@@ -77,17 +86,46 @@ start() { ...@@ -77,17 +86,46 @@ start() {
stop() { stop() {
# Stop daemons. # Stop daemons.
echo -n $"Shutting down $prog: " echo -n "Shutting down $PROG: "
[ -f $OPENFILE_PIDFILE ] && kill `cat $OPENFIRE_PIDFILE` [ -f "$OPENFILE_PIDFILE" ] && kill `cat $OPENFIRE_PIDFILE`
RETVAL=$? RETVAL=$?
echo echo
[ $RETVAL -eq 0 -a -f $OPENFIRE_PIDFILE ] && rm -f $OPENFIRE_PIDFILE [ $RETVAL -eq 0 -a -f "$OPENFIRE_PIDFILE" ] && rm -f $OPENFIRE_PIDFILE
[ $RETVAL -eq 0 -a -f /var/lock/subsys/openfired ] && rm -f /var/lock/subsys/openfired [ $RETVAL -eq 0 -a -f "/var/lock/subsys/$PROG" ] && rm -f /var/lock/subsys/$PROG
}
restart() {
stop
sleep 10 # give it a few moments to shut down
start
}
condrestart() {
[ -e "/var/lock/subsys/$PROG" ] && restart
return 0
}
status() {
pid=`cat $OPENFIRE_PIDFILE 2>&1`
if [ "$?" = "1" ]; then
echo "openfire is not running"
RETVAL=0
else
ps -p $pid > /dev/null 2>&1
if [ "$?" = "0" ]; then
echo "openfire is running"
RETVAL=0
else
echo "openfire is not running"
RETVAL=0
fi
fi
} }
# Handle how we were called.
case "$1" in case "$1" in
start) start)
start start
...@@ -96,23 +134,17 @@ case "$1" in ...@@ -96,23 +134,17 @@ case "$1" in
stop stop
;; ;;
restart) restart)
stop restart
sleep 10 # since stop is backgrounded ;;
start condrestart)
condrestart
;; ;;
status) status)
retval=$(pgrep -u $OPENFIRE_USER -f $OPENFIRE_HOME/bin/openfire.sh > /dev/null ; echo $?) status
if [ "$retval" = "0" ] ; then
echo "openfire is running"
exit 0
else
echo "openfire is not running"
exit 0
fi
;; ;;
*) *)
echo "Usage $0 {start|stop|restart|status}" echo "Usage $0 {start|stop|restart|status|condrestart}"
exit 1 RETVAL=1
esac esac
exit 0 exit $RETVAL
...@@ -83,6 +83,11 @@ fi ...@@ -83,6 +83,11 @@ fi
OPENFIRE_LIB="${OPENFIRE_HOME}/lib" OPENFIRE_LIB="${OPENFIRE_HOME}/lib"
OPENFIRE_OPTS="${OPENFIRE_OPTS} -Dopenfire.lib.dir=${OPENFIRE_LIB}" OPENFIRE_OPTS="${OPENFIRE_OPTS} -Dopenfire.lib.dir=${OPENFIRE_LIB}"
# Override with bundled jre if it exists.
if [ -f "$OPENFIRE_HOME/jre/bin/java" ]; then
JAVA_HOME="$OPENFIRE_HOME/jre"
JAVACMD="$OPENFIRE_HOME/jre/bin/java"
fi
if [ -z "$JAVACMD" ] ; then if [ -z "$JAVACMD" ] ; then
if [ -n "$JAVA_HOME" ] ; then if [ -n "$JAVA_HOME" ] ; then
...@@ -153,5 +158,5 @@ if $cygwin; then ...@@ -153,5 +158,5 @@ if $cygwin; then
esac esac
fi fi
openfire_exec_command="exec \"$JAVACMD\" -server $OPENFIRE_OPTS -classpath \"$LOCALCLASSPATH\" -jar \"$OPENFIRE_LIB\"/startup.jar" openfire_exec_command="exec $JAVACMD -server $OPENFIRE_OPTS -classpath \"$LOCALCLASSPATH\" -jar \"$OPENFIRE_LIB/startup.jar\""
eval $openfire_exec_command eval $openfire_exec_command
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment