724e4bd0b0
Reviewed by: hrs MFC after: 3 days
73 lines
1.6 KiB
Bash
Executable File
73 lines
1.6 KiB
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# $FreeBSD$
|
|
#
|
|
|
|
# PROVIDE: rtadvd
|
|
# REQUIRE: DAEMON
|
|
# BEFORE: LOGIN
|
|
# KEYWORD: nojail shutdown
|
|
|
|
. /etc/rc.subr
|
|
. /etc/network.subr
|
|
|
|
name="rtadvd"
|
|
rcvar="rtadvd_enable"
|
|
command="/usr/sbin/${name}"
|
|
extra_commands="reload"
|
|
reload_cmd="rtadvd_reload"
|
|
start_precmd="rtadvd_precmd"
|
|
|
|
rtadvd_precmd()
|
|
{
|
|
# This should be enabled with a great care.
|
|
# You may want to fine-tune /etc/rtadvd.conf.
|
|
#
|
|
# And if you wish your rtadvd to receive and process
|
|
# router renumbering messages, specify your Router Renumbering
|
|
# security policy by -R option.
|
|
#
|
|
# See `man 3 ipsec_set_policy` for IPsec policy specification
|
|
# details.
|
|
# (CAUTION: This enables your routers prefix renumbering
|
|
# from another machine, so if you enable this, do it with
|
|
# enough care.)
|
|
#
|
|
# If specific interfaces haven't been specified,
|
|
# get a list of interfaces and enable it on them
|
|
#
|
|
case ${rtadvd_interfaces} in
|
|
[Aa][Uu][Tt][Oo]|'')
|
|
command_args=
|
|
for i in `list_net_interfaces`; do
|
|
case $i in
|
|
lo0) continue ;;
|
|
esac
|
|
if ipv6if $i; then
|
|
command_args="${command_args} ${i}"
|
|
fi
|
|
done
|
|
;;
|
|
[Nn][Oo][Nn][Ee])
|
|
;;
|
|
*)
|
|
command_args="${rtadvd_interfaces}"
|
|
;;
|
|
esac
|
|
|
|
# Enable Router Renumbering, unicast case
|
|
# (use correct src/dst addr)
|
|
# rtadvd -R "in ipsec ah/transport/fec0:0:0:1::1-fec0:0:0:10::1/require" ${ipv6_network_interfaces}
|
|
# Enable Router Renumbering, multicast case
|
|
# (use correct src addr)
|
|
# rtadvd -R "in ipsec ah/transport/ff05::2-fec0:0:0:10::1/require" ${ipv6_network_interfaces}
|
|
return 0
|
|
}
|
|
|
|
rtadvd_reload() {
|
|
/usr/sbin/rtadvctl reload
|
|
}
|
|
|
|
load_rc_config $name
|
|
run_rc_command "$1"
|