2004-09-09 09:27:26 +00:00
|
|
|
#!/bin/bash
|
|
|
|
#
|
|
|
|
# rpcgssd Start up and shut down RPCSEC GSS daemon
|
|
|
|
#
|
2007-07-30 10:10:07 +00:00
|
|
|
# chkconfig: 345 19 85
|
2004-09-09 09:27:26 +00:00
|
|
|
# description: Starts user-level daemon that manages RPCSEC GSS contexts \
|
2009-06-10 16:14:13 +00:00
|
|
|
# for the NFS client.
|
|
|
|
|
|
|
|
### BEGIN INIT INFO
|
|
|
|
# Provides: rpcgssd
|
|
|
|
# Required-Start: $network $syslog
|
|
|
|
# Required-Stop: $network $syslog
|
|
|
|
# Default-Start: 2 3 4 5
|
|
|
|
# Default-Stop: 0 1 6
|
|
|
|
# Short-Description: Starts the RPCSEC GSS client daemon
|
|
|
|
# Description: NFS is a popular protocol for file sharing across \
|
|
|
|
# networks. This deamon manages RPCSEC GSS contexts on the
|
|
|
|
# client used by secure NFS mounts
|
|
|
|
### END INIT INFO
|
2004-09-09 09:27:26 +00:00
|
|
|
|
|
|
|
# Source function library.
|
|
|
|
. /etc/init.d/functions
|
|
|
|
|
|
|
|
# Source networking configuration.
|
2008-09-16 20:29:11 +00:00
|
|
|
[ -f /etc/sysconfig/network ]&& . /etc/sysconfig/network
|
2004-09-09 09:27:26 +00:00
|
|
|
|
|
|
|
# Check for and source configuration file otherwise set defaults
|
|
|
|
[ -f /etc/sysconfig/nfs ] && . /etc/sysconfig/nfs
|
2005-02-14 19:29:31 +00:00
|
|
|
|
2008-09-16 20:29:11 +00:00
|
|
|
# See if we are configured to start
|
|
|
|
[ "${SECURE_NFS}" != "yes" ] && exit 6
|
2004-09-09 09:27:26 +00:00
|
|
|
|
|
|
|
# Try to use machine credentials by default
|
|
|
|
RETVAL=0
|
2006-01-11 21:55:51 +00:00
|
|
|
LOCKFILE=/var/lock/subsys/rpcgssd
|
2004-09-09 09:27:26 +00:00
|
|
|
prog="rpc.gssd"
|
|
|
|
|
|
|
|
case "$1" in
|
|
|
|
start|condstart)
|
2008-09-16 20:29:11 +00:00
|
|
|
# Check that networking is up.
|
|
|
|
[ "${NETWORKING}" != "yes" ] && exit 6
|
|
|
|
[ ! -x /usr/sbin/rpc.gssd ] && exit 5
|
|
|
|
|
2004-09-09 09:27:26 +00:00
|
|
|
# Make sure the daemon is not already running.
|
|
|
|
if status $prog > /dev/null ; then
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
2008-09-16 20:29:11 +00:00
|
|
|
# During condstart need to check again to see
|
|
|
|
# if we are configured to start
|
|
|
|
[ "${SECURE_NFS}" != "yes" ] && exit 6
|
|
|
|
|
|
|
|
rm -f $LOCKFILE
|
2005-02-14 19:29:31 +00:00
|
|
|
echo -n $"Starting RPC gssd: "
|
2004-09-09 09:27:26 +00:00
|
|
|
|
2008-09-16 20:29:11 +00:00
|
|
|
# List of kernel modules to load
|
|
|
|
[ -z "${SECURE_NFS_MODS}" ] && SECURE_NFS_MODS="des rpcsec_gss_krb5"
|
|
|
|
|
2007-07-30 10:10:07 +00:00
|
|
|
# Make sure the rpc_pipefs filesystem is available
|
|
|
|
[ "${RPCMTAB}" != "noload" ] && {
|
|
|
|
RPCMTAB=`grep -v '^#' /proc/mounts | \
|
|
|
|
awk '{ if ($3 ~ /^rpc_pipefs$/ ) print $2}'`
|
|
|
|
[ -z "${RPCMTAB}" ] && {
|
|
|
|
[ -x /sbin/lsmod -a -x /sbin/modprobe ] && {
|
|
|
|
if ! /sbin/lsmod | grep sunrpc > /dev/null ; then
|
|
|
|
/sbin/modprobe sunrpc
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
RPCMTAB=`grep -v '^#' /proc/mounts | \
|
|
|
|
awk '{ if ($3 ~ /^rpc_pipefs$/ ) print $2}'`
|
|
|
|
[ -z "${RPCMTAB}" ] && { \
|
|
|
|
echo "Error: RPC MTAB does not exist."
|
|
|
|
exit 6
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
[ "${SECURE_NFS_MODS}" != "noload" ] && {
|
|
|
|
[ -x /sbin/lsmod -a -x /sbin/modprobe ] && {
|
|
|
|
for i in ${SECURE_NFS_MODS}; do
|
|
|
|
if ! /sbin/lsmod | grep $i > /dev/null ; then
|
|
|
|
/sbin/modprobe $i || {
|
|
|
|
echo "Error: Unable to load '$i' security module."
|
|
|
|
exit 6;
|
|
|
|
}
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
}
|
2004-09-09 09:27:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# Start daemon.
|
2007-05-15 15:03:52 +00:00
|
|
|
daemon $prog ${RPCGSSDARGS}
|
2004-09-09 09:27:26 +00:00
|
|
|
RETVAL=$?
|
|
|
|
echo
|
2006-01-11 21:55:51 +00:00
|
|
|
[ $RETVAL -eq 0 ] && touch $LOCKFILE
|
2004-09-09 09:27:26 +00:00
|
|
|
;;
|
|
|
|
stop)
|
|
|
|
# Stop daemon.
|
2007-07-30 10:10:07 +00:00
|
|
|
echo -n $"Stopping RPC gssd: "
|
2004-09-09 09:27:26 +00:00
|
|
|
killproc $prog
|
|
|
|
RETVAL=$?
|
|
|
|
echo
|
2007-08-02 15:54:05 +00:00
|
|
|
rm -f $LOCKFILE
|
2004-09-09 09:27:26 +00:00
|
|
|
;;
|
|
|
|
status)
|
|
|
|
status rpc.gssd
|
|
|
|
RETVAL=$?
|
|
|
|
;;
|
|
|
|
restart|reload)
|
|
|
|
$0 stop
|
|
|
|
$0 start
|
|
|
|
RETVAL=$?
|
|
|
|
;;
|
|
|
|
condrestart)
|
2006-01-11 21:55:51 +00:00
|
|
|
if [ -f $LOCKFILE ]; then
|
2004-09-09 09:27:26 +00:00
|
|
|
$0 restart
|
|
|
|
RETVAL=$?
|
|
|
|
fi
|
|
|
|
;;
|
2008-07-02 23:35:53 +00:00
|
|
|
condstop)
|
|
|
|
if [ -f $LOCKFILE ]; then
|
|
|
|
$0 stop
|
|
|
|
RETVAL=$?
|
|
|
|
fi
|
|
|
|
;;
|
2004-09-09 09:27:26 +00:00
|
|
|
*)
|
2008-07-02 23:35:53 +00:00
|
|
|
echo $"Usage: $0 {start|stop|restart|condstart|condrestart|status|condstop}"
|
2007-07-30 10:10:07 +00:00
|
|
|
RETVAL=3
|
|
|
|
;;
|
2004-09-09 09:27:26 +00:00
|
|
|
esac
|
|
|
|
|
|
|
|
exit $RETVAL
|