NetBSD/etc/rc.d/pf
apb 31edfc6f0f * Add a stop_boot() function in rc.subr, to terminate a multi-user boot
by killing the parent process.  The parent's PID is saved in $RC_PID.
* In all rc.d/* scripts that previously tried to stop the boot,
  replace in-line code with "stop_boot".
* Document this.

This should fix PR 29822.
2007-04-06 14:20:08 +00:00

71 lines
1.1 KiB
Bash

#!/bin/sh
#
# $NetBSD: pf,v 1.7 2007/04/06 14:20:18 apb Exp $
#
# PROVIDE: pf
# REQUIRE: root beforenetlkm mountcritlocal tty network dhclient
# BEFORE: NETWORKING
$_rc_subr_loaded . /etc/rc.subr
name="pf"
rcvar=$name
start_precmd="pf_prestart"
start_cmd="pf_start"
stop_cmd="pf_stop"
reload_cmd="pf_reload"
status_cmd="pf_status"
extra_commands="reload status"
pf_prestart()
{
if [ ! -f ${pf_rules} ]; then
warn "${pf_rules} not readable; pf start aborted."
stop_boot
return 1
fi
return 0
}
pf_start()
{
echo "Enabling pf firewall."
# The pf_boot script has enabled pf already.
if [ "$autoboot" != yes ]; then
/sbin/pfctl -q -e
fi
if [ -f ${pf_rules} ]; then
/sbin/pfctl -q -f ${pf_rules}
else
warn "${pf_rules} not found; no pf rules loaded."
fi
}
pf_stop()
{
echo "Disabling pf firewall."
/sbin/pfctl -q -Fa -d
}
pf_reload()
{
echo "Reloading pf rules."
if [ -f ${pf_rules} ]; then
/sbin/pfctl -q -f ${pf_rules}
else
warn "${pf_rules} not found; no pf rules loaded."
fi
}
pf_status()
{
/sbin/pfctl -s info
}
load_rc_config $name
run_rc_command "$1"