2004-06-29 08:48:28 +04:00
|
|
|
#!/bin/sh
|
|
|
|
#
|
2008-11-22 23:23:33 +03:00
|
|
|
# $NetBSD: pf,v 1.9 2008/11/22 20:23:33 tsutsui Exp $
|
2004-06-29 08:48:28 +04:00
|
|
|
#
|
|
|
|
|
|
|
|
# PROVIDE: pf
|
2008-11-22 23:23:33 +03:00
|
|
|
# REQUIRE: root bootconf mountcritlocal tty network dhclient
|
2005-08-23 16:12:56 +04:00
|
|
|
# BEFORE: NETWORKING
|
2004-06-29 08:48:28 +04:00
|
|
|
|
2004-08-13 22:08:03 +04:00
|
|
|
$_rc_subr_loaded . /etc/rc.subr
|
2004-06-29 08:48:28 +04:00
|
|
|
|
|
|
|
name="pf"
|
|
|
|
rcvar=$name
|
2005-08-10 17:52:05 +04:00
|
|
|
start_precmd="pf_prestart"
|
2004-06-29 08:48:28 +04:00
|
|
|
start_cmd="pf_start"
|
|
|
|
stop_cmd="pf_stop"
|
|
|
|
reload_cmd="pf_reload"
|
|
|
|
status_cmd="pf_status"
|
|
|
|
extra_commands="reload status"
|
|
|
|
|
2005-08-10 17:52:05 +04:00
|
|
|
pf_prestart()
|
|
|
|
{
|
|
|
|
if [ ! -f ${pf_rules} ]; then
|
|
|
|
warn "${pf_rules} not readable; pf start aborted."
|
|
|
|
|
2007-04-06 18:20:08 +04:00
|
|
|
stop_boot
|
2005-08-10 17:52:05 +04:00
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2004-06-29 08:48:28 +04:00
|
|
|
pf_start()
|
|
|
|
{
|
|
|
|
echo "Enabling pf firewall."
|
2005-08-23 16:12:56 +04:00
|
|
|
|
|
|
|
# The pf_boot script has enabled pf already.
|
|
|
|
if [ "$autoboot" != yes ]; then
|
|
|
|
/sbin/pfctl -q -e
|
|
|
|
fi
|
|
|
|
|
2005-08-07 05:03:39 +04:00
|
|
|
if [ -f ${pf_rules} ]; then
|
|
|
|
/sbin/pfctl -q -f ${pf_rules}
|
2004-06-29 08:48:28 +04:00
|
|
|
else
|
2005-08-07 05:03:39 +04:00
|
|
|
warn "${pf_rules} not found; no pf rules loaded."
|
2004-06-29 08:48:28 +04:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
pf_stop()
|
|
|
|
{
|
|
|
|
echo "Disabling pf firewall."
|
2005-03-15 21:22:03 +03:00
|
|
|
/sbin/pfctl -q -Fa -d
|
2004-06-29 08:48:28 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
pf_reload()
|
|
|
|
{
|
|
|
|
echo "Reloading pf rules."
|
2005-08-07 05:03:39 +04:00
|
|
|
if [ -f ${pf_rules} ]; then
|
|
|
|
/sbin/pfctl -q -f ${pf_rules}
|
2004-06-29 08:48:28 +04:00
|
|
|
else
|
2005-08-07 05:03:39 +04:00
|
|
|
warn "${pf_rules} not found; no pf rules loaded."
|
2004-06-29 08:48:28 +04:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
pf_status()
|
|
|
|
{
|
|
|
|
/sbin/pfctl -s info
|
|
|
|
}
|
|
|
|
|
|
|
|
load_rc_config $name
|
|
|
|
run_rc_command "$1"
|