#!/bin/sh # # $FreeBSD$ # # PROVIDE: rtadvd # REQUIRE: DAEMON # BEFORE: LOGIN # KEYWORD: nojail shutdown . /etc/rc.subr name="rtadvd" rcvar=`set_rcvar` command="/usr/sbin/${name}" start_precmd="rtadvd_precmd" rtadvd_precmd() { if ! checkyesno ipv6_gateway_enable ; then warn \ "${name} cannot be used on IPv6 host, only on an IPv6 router." return 1 fi # 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]|'') for i in `ifconfig -l` ; do case $i in lo0|\ stf[0-9]*|\ faith[0-9]*|\ lp[0-9]*|\ sl[0-9]*|\ pflog[0-9]*|\ pfsync[0-9]*|\ an[0-9]*|\ ath[0-9]*|\ ipw[0-9]*|\ iwi[0-9]*|\ iwn[0-9]*|\ ral[0-9]*|\ wi[0-9]*|\ wl[0-9]*|\ wpi[0-9]*) continue ;; *) rtadvd_interfaces="${rtadvd_interfaces} ${i}" ;; esac done ;; esac command_args="${rtadvd_interfaces}" # 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 } load_rc_config $name run_rc_command "$1"