Changeset View
Changeset View
Standalone View
Standalone View
contrib/blacklist/etc/rc.d/blacklistd
- This file was added.
#!/bin/sh | |||||
# | |||||
# $NetBSD: blacklistd,v 1.1 2015/01/22 17:49:41 christos Exp $ | |||||
# | |||||
# PROVIDE: blacklistd | |||||
# REQUIRE: npf | |||||
# BEFORE: SERVERS | |||||
$_rc_subr_loaded . /etc/rc.subr | |||||
name="blacklistd" | |||||
rcvar=$name | |||||
command="/sbin/${name}" | |||||
pidfile="/var/run/${name}.pid" | |||||
required_files="/etc/${name}.conf" | |||||
start_precmd="${name}_precmd" | |||||
extra_commands="reload" | |||||
_sockfile="/var/run/${name}.sockets" | |||||
_sockname="blsock" | |||||
blacklistd_precmd() | |||||
{ | |||||
# Create default list of blacklistd sockets to watch | |||||
# | |||||
( umask 022 ; > $_sockfile ) | |||||
# Find /etc/rc.d scripts with "chrootdir" rcorder(8) keyword, | |||||
# and if $${app}_chrootdir is a directory, add appropriate | |||||
# blacklistd socket to list of sockets to watch. | |||||
# | |||||
for _lr in $(rcorder -k chrootdir /etc/rc.d/*); do | |||||
( | |||||
_l=${_lr##*/} | |||||
load_rc_config ${_l} | |||||
eval _ldir=\$${_l}_chrootdir | |||||
if checkyesno $_l && [ -n "$_ldir" ]; then | |||||
echo "${_ldir}/var/run/${_sockname}" >> $_sockfile | |||||
fi | |||||
) | |||||
done | |||||
# If other sockets have been provided, change run_rc_command()'s | |||||
# internal copy of $blacklistd_flags to force use of specific | |||||
# blacklistd sockets. | |||||
# | |||||
if [ -s $_sockfile ]; then | |||||
echo "/var/run/${_sockname}" >> $_sockfile | |||||
rc_flags="-P $_sockfile $rc_flags" | |||||
fi | |||||
return 0 | |||||
} | |||||
load_rc_config $name | |||||
run_rc_command "$1" |