mirror of
https://git.FreeBSD.org/ports.git
synced 2025-01-01 05:45:45 +00:00
4bef4dd3c2
Most significant improvement is the support of SMB2 protocol.
169 lines
5.0 KiB
Bash
169 lines
5.0 KiB
Bash
#!/bin/sh
|
|
#
|
|
# $FreeBSD$
|
|
#
|
|
|
|
# PROVIDE: nmbd smbd
|
|
%%WINBIND%%# PROVIDE: winbindd
|
|
# REQUIRE: NETWORKING SERVERS DAEMON ldconfig resolv
|
|
%%CUPS%%# REQUIRE: cupsd
|
|
# BEFORE: LOGIN
|
|
# KEYWORD: shutdown
|
|
#
|
|
# Add the following lines to /etc/rc.conf.local or /etc/rc.conf
|
|
# to enable this service:
|
|
#
|
|
#samba_enable="YES"
|
|
# or, for fine grain control:
|
|
#nmbd_enable="YES"
|
|
#smbd_enable="YES"
|
|
%%WINBIND%%# You need to enable winbindd separately, by adding:
|
|
%%WINBIND%%#winbindd_enable="YES"
|
|
#
|
|
# Configuration file can be set with:
|
|
#samba_config="%%SAMBA_CONFDIR%%/%%SAMBA_CONFIG%%"
|
|
#
|
|
|
|
. /etc/rc.subr
|
|
|
|
name="samba"
|
|
rcvar=$(set_rcvar)
|
|
set_rcvar ${rcvar} "NO" "Samba service" > /dev/null
|
|
# Defaults
|
|
eval ${rcvar}=\${${rcvar}:=NO}
|
|
samba_config_default="%%SAMBA_CONFDIR%%/%%SAMBA_CONFIG%%"
|
|
samba_config=${samba_config="${samba_config_default}"}
|
|
command_args=${samba_config:+-s "${samba_config}"}
|
|
# Fetch parameters from configuration file
|
|
testparm_command="%%PREFIX%%/bin/testparm"
|
|
smbcontrol_command="%%PREFIX%%/bin/smbcontrol"
|
|
samba_parm="${testparm_command} -s -v --parameter-name"
|
|
samba_idmap=$(${samba_parm} 'idmap uid' "${samba_config}" 2>/dev/null)
|
|
samba_lockdir=$(${samba_parm} 'lock directory' "${samba_config}" 2>/dev/null)
|
|
# Load configuration
|
|
load_rc_config "${name}"
|
|
# Setup dependent variables
|
|
if [ -n "${rcvar}" ] && checkyesno "${rcvar}"; then
|
|
nmbd_enable=${nmbd_enable=YES}
|
|
smbd_enable=${smbd_enable=YES}
|
|
%%WINBIND%% # Check that winbindd is actually configured
|
|
%%WINBIND%% if [ -n "${samba_idmap}" ]; then
|
|
%%WINBIND%% winbindd_enable=${winbindd_enable=YES}
|
|
%%WINBIND%% fi
|
|
fi
|
|
# XXX: Hack to enable check of the dependent variables
|
|
eval real_${rcvar}="\${${rcvar}:=NO}" ${rcvar}=YES
|
|
# nmbd
|
|
nmbd_enable=${nmbd_enable:=NO}
|
|
nmbd_flags=${nmbd_flags="-D"}
|
|
set_rcvar nmbd_enable "NO" "nmb daemon" >/dev/null
|
|
# smbd
|
|
smbd_enable=${smbd_enable:=NO}
|
|
smbd_flags=${smbd_flags="-D"}
|
|
set_rcvar smbd_enable "NO" "smb daemon" >/dev/null
|
|
%%WINBIND%%# winbindd
|
|
%%WINBIND%%winbindd_enable=${winbindd_enable:=NO}
|
|
%%WINBIND%%winbindd_flags=${winbindd_flags=''}
|
|
%%WINBIND%%set_rcvar winbindd_enable "NO" "winbind daemon" >/dev/null
|
|
# Custom commands
|
|
extra_commands="reload status"
|
|
start_precmd="samba_start_precmd"
|
|
start_cmd="samba_cmd"
|
|
stop_cmd="samba_cmd"
|
|
status_cmd="samba_cmd"
|
|
restart_precmd="samba_checkconfig"
|
|
reload_precmd="samba_checkconfig"
|
|
reload_cmd="samba_reload_cmd"
|
|
rcvar_cmd="samba_rcvar_cmd"
|
|
#
|
|
samba_daemons="nmbd smbd"
|
|
%%WINBIND%%samba_daemons="${samba_daemons} winbindd"
|
|
# Requirements
|
|
required_files="${samba_config}"
|
|
required_dirs="${samba_lockdir}"
|
|
|
|
samba_checkconfig() {
|
|
echo -n "Performing sanity check on Samba configuration: "
|
|
if ${testparm_command} -s ${samba_config:+"${samba_config}"} >/dev/null 2>&1; then
|
|
echo "OK"
|
|
else
|
|
echo "FAILED"
|
|
return 1
|
|
fi
|
|
return 0
|
|
}
|
|
|
|
samba_start_precmd() {
|
|
# XXX: Never delete winbindd_idmap, winbindd_cache and group_mapping
|
|
if [ -n "${samba_lockdir}" -a -d "${samba_lockdir}" ]; then
|
|
echo -n "Removing stale Samba tdb files: "
|
|
for file in brlock.tdb browse.dat connections.tdb gencache.tdb \
|
|
locking.tdb messages.tdb namelist.debug sessionid.tdb \
|
|
unexpected.tdb
|
|
do
|
|
rm "${samba_lockdir}/${file}" </dev/null 2>/dev/null && echo -n '.'
|
|
done
|
|
echo " done"
|
|
fi
|
|
}
|
|
|
|
samba_rcvar_cmd() {
|
|
local rcvar
|
|
rcvar=$(set_rcvar ${name})
|
|
eval ${rcvar}=\${real_${rcvar}}
|
|
# Prevent recursive calling
|
|
unset "${rc_arg}_cmd" "${rc_arg}_precmd" "${rc_arg}_postcmd"
|
|
# Check master variable
|
|
run_rc_command "${_rc_prefix}${rc_arg}" ${rc_extra_args}
|
|
}
|
|
|
|
samba_reload_cmd() {
|
|
local name rcvar command pidfile
|
|
# Prevent recursive calling
|
|
unset "${rc_arg}_cmd" "${rc_arg}_precmd" "${rc_arg}_postcmd"
|
|
# Apply to all daemons
|
|
for name in ${samba_daemons}; do
|
|
rcvar=$(set_rcvar ${name})
|
|
command="%%PREFIX%%/sbin/${name}"
|
|
pidfile="%%SAMBA_RUNDIR%%/${name}${pid_extra}.pid"
|
|
# Daemon should be enabled and running
|
|
if [ -n "${rcvar}" ] && checkyesno "${rcvar}"; then
|
|
if [ -n "$(check_pidfile "${pidfile}" "${command}")" ]; then
|
|
debug "reloading ${name} configuration"
|
|
echo "Reloading ${name}."
|
|
# XXX: Hack with pid_extra
|
|
${smbcontrol_command} "${name}${pid_extra}" 'reload-config' ${command_args} >/dev/null 2>&1
|
|
fi
|
|
fi
|
|
done
|
|
}
|
|
|
|
samba_cmd() {
|
|
local name rcvar rcvars v command pidfile samba_daemons result
|
|
# Prevent recursive calling
|
|
unset "${rc_arg}_cmd" "${rc_arg}_precmd" "${rc_arg}_postcmd"
|
|
# Stop processes in the reverse order
|
|
if [ "${rc_arg}" = "stop" ] ; then
|
|
samba_daemons=$(reverse_list ${samba_daemons})
|
|
fi
|
|
# Assume success
|
|
result=0
|
|
# Apply to all daemons
|
|
for name in ${samba_daemons}; do
|
|
rcvar=$(set_rcvar ${name})
|
|
# XXX
|
|
rcvars=''; v=''
|
|
command="%%PREFIX%%/sbin/${name}"
|
|
pidfile="%%SAMBA_RUNDIR%%/${name}${pid_extra}.pid"
|
|
# Daemon should be enabled and running
|
|
if [ -n "${rcvar}" ] && checkyesno "${rcvar}"; then
|
|
run_rc_command "${_rc_prefix}${rc_arg}" ${rc_extra_args}
|
|
# If any of the of the commands failed, take it as a total result
|
|
result=$((${result} || $?))
|
|
fi
|
|
done
|
|
return ${result}
|
|
}
|
|
|
|
run_rc_command "$1"
|