#
# config: /etc/samba/smb.conf
# config: /etc/samba/lmhosts
-
-export PATH=/bin:/sbin:/usr/bin:/usr/sbin
+# processname: nmbd
+# processname: smbd
# Source function library.
. /etc/rc.d/init.d/functions
# Source networking configuration.
. /etc/sysconfig/network
+# Set default config
+CFGFILE="/etc/samba/smb.conf"
+smbd_pidfile="/var/run/smbd.pid"
+nmbd_pidfile="/var/run/nmbd.pid"
+lockname=smb
+
# Demon specified configuration.
. /etc/sysconfig/samba
# Check that networking is up.
if is_yes "${NETWORKING}"; then
- if [ ! -f /var/lock/subsys/network -a != stop -a != status ]; then
- msg_network_down smb
+ if [ ! -f /var/lock/subsys/network -a "$1" != stop -a "$1" != status ]; then
+ msg_network_down "Samba SMB/CIFS Server"
exit 1
fi
else
fi
TMPDIR="/tmp"; export TMPDIR
+unset TMP || :
-# Check that smb.conf exists.
-[ -f /etc/samba/smb.conf ] || exit 0
-
-RETVAL=0
-# See how we were called.
-case "$1" in
- start)
+start() {
# Check if the service is already running?
- if [ ! -f /var/lock/subsys/smb ]; then
- msg_starting smbd
- daemon $NICELEVEL smbd -D
- RETVAL=$?
- msg_starting nmbd
- daemon $NICELEVEL nmbd -D
- [ $RETVAL -eq 0 ] && RETVAL=$?
- if [ "$WINBINDD" = "yes" ]; then
- msg_starting winbindd
- daemon $NICELEVEL winbindd
- RET=$?
- [ $RETVAL -eq 0 ] && RETVAL=$RET
- fi
- [ $RETVAL -eq 0 ] && touch /var/lock/subsys/smb
- else
- msg_already_running smb
+ if [ -f /var/lock/subsys/$lockname ]; then
+ msg_already_running "Samba SMB/CIFS Server"
+ return
fi
- ;;
- stop)
+
+ msg_starting "Samba SMB/CIFS Server"
+ daemon /usr/sbin/smbd -D -s $CFGFILE
+ RETVAL=$?
+ msg_starting "Samba NetBIOS Name Server"
+ daemon /usr/sbin/nmbd -D $CFGFILE
+ [ $RETVAL -eq 0 ] && RETVAL=$?
+ if [ $RETVAL -eq 0 ]; then
+ touch /var/lock/subsys/$lockname
+ fi
+}
+
+stop() {
# Stop daemons.
- if [ -f /var/lock/subsys/smb ]; then
- msg_stopping smbd
- killproc smbd
- msg_stopping nmbd
- killproc nmbd
- if [ "$WINBINDD" = "yes" ]; then
- msg_stopping winbindd
- killproc winbindd
- fi
- rm -f /var/lock/subsys/smb >/dev/null 2>&1
- else
- msg_not_running smb
+ if [ ! -f /var/lock/subsys/$lockname ]; then
+ msg_not_running "Samba SMB/CIFS Server"
+ return
fi
- ;;
- status)
+
+ msg_stopping "Samba SMB/CIFS Server"
+ killproc --pidfile $smbd_pidfile smbd
+
+ msg_stopping "Samba NetBIOS Name Server"
+ killproc --pidfile $nmbd_pidfile nmbd
+ rm -f /var/lock/subsys/$lockname >/dev/null 2>&1
+}
+
+reload() {
+ if [ ! -f /var/lock/subsys/$lockname ]; then
+ msg_not_running "Samba SMB/CIFS Server"
+ RETVAL=7
+ return
+ fi
+
+ msg_reloading "Samba SMB/CIFS Server"
+ killproc --pidfile $smbd_pidfile smbd -HUP
+ RETVAL=$?
+}
+
+condrestart() {
+ if [ ! -f /var/lock/subsys/$lockname ]; then
+ msg_not_running "Samba SMB/CIFS Server"
+ RETVAL=$1
+ return
+ fi
+
+ stop
+ start
+}
+
+rc_status() {
status smbd
- RETVAL=$?
+ RETVAL=$?
status nmbd
RET=$?
[ $RETVAL -eq 0 ] && RETVAL=$RET
- status winbindd
- RET=$?
- [ $RETVAL -eq 0 ] && RETVAL=$RET
- smbstatus
+}
+
+RETVAL=0
+# See how we were called.
+case "$1" in
+ start)
+ start
+ ;;
+ stop)
+ stop
;;
restart)
- $0 stop
- $0 start
- exit $?
+ stop
+ start
+ ;;
+ try-restart)
+ condrestart 0
;;
reload|force-reload)
- if [ -f /var/lock/subsys/smb ]; then
- msg_reloading smb
- killproc smbd -HUP
- RETVAL=$?
- else
- msg_not_running smb >&2
- exit 7
- fi
+ reload
+ ;;
+ status)
+ rc_status
;;
*)
- msg_usage "$0 {start|stop|restart|reload|force-reload|status}"
+ msg_usage "$0 {start|stop|restart|try-restart|reload|force-reload|status}"
exit 3
esac