Home | History | Annotate | Line # | Download | only in rc.d
ipsec revision 1.2
      1  1.1  itojun #!/bin/sh
      2  1.1  itojun #
      3  1.2  itojun # $NetBSD: ipsec,v 1.2 2000/06/13 18:17:13 itojun Exp $
      4  1.1  itojun #
      5  1.1  itojun 
      6  1.1  itojun # PROVIDE: ipsec
      7  1.1  itojun # REQUIRE: root beforenetlkm mountcritlocal tty
      8  1.1  itojun 
      9  1.1  itojun #	it does not really require beforenetlkm.
     10  1.1  itojun 
     11  1.1  itojun . /etc/rc.subr
     12  1.1  itojun 
     13  1.1  itojun name="ipsec"
     14  1.1  itojun start_cmd="ipsec_start"
     15  1.1  itojun stop_precmd="checkyesno ipsec && [ -f /etc/ipsec.conf ]"
     16  1.1  itojun stop_cmd="ipsec_stop"
     17  1.1  itojun reload_precmd="$stop_precmd"
     18  1.1  itojun reload_cmd="ipsec_reload"
     19  1.1  itojun extra_commands="reload"
     20  1.1  itojun 
     21  1.1  itojun ipsec_start()
     22  1.1  itojun {
     23  1.1  itojun 	if ! checkyesno ipsec; then
     24  1.1  itojun 		return 0
     25  1.1  itojun 	fi
     26  1.1  itojun 
     27  1.1  itojun 	# if /etc/ipsec.conf isn't readable, abort the boot rather
     28  1.1  itojun 	# than risk a security problem
     29  1.1  itojun 	#
     30  1.1  itojun 	if [ ! -f /etc/ipsec.conf ]; then
     31  1.1  itojun 		err 1 "/etc/ipsec.conf not readable; ipsec start aborted."
     32  1.1  itojun 	fi
     33  1.2  itojun 	# XXX should check if ipsec.conf is secure enough
     34  1.2  itojun 	#
     35  1.1  itojun 	echo "Installing ipsec manual keys/policies."
     36  1.1  itojun 	/sbin/setkey -f /etc/ipsec.conf
     37  1.1  itojun }
     38  1.1  itojun 
     39  1.1  itojun ipsec_stop()
     40  1.1  itojun {
     41  1.1  itojun 	echo "Clearing ipesc manual keys/policies."
     42  1.1  itojun 
     43  1.1  itojun 	# still not 100% sure if we would like to do this.
     44  1.1  itojun 	# it is very questionable to do this during shutdown session, since
     45  1.1  itojun 	# it can hang any of remaining IPv4/v6 session.
     46  1.1  itojun 	#
     47  1.1  itojun 	/sbin/setkey -F
     48  1.1  itojun 	/sbin/setkey -FP
     49  1.1  itojun }
     50  1.1  itojun 
     51  1.1  itojun ipsec_reload()
     52  1.1  itojun {
     53  1.1  itojun 	echo "Reloading ipsec manual keys/policies."
     54  1.1  itojun 	/sbin/setkey -F
     55  1.1  itojun 	/sbin/setkey -FP
     56  1.1  itojun 	/sbin/setkey -f /etc/ipsec.conf
     57  1.1  itojun }
     58  1.1  itojun 
     59  1.1  itojun load_rc_config $name
     60  1.1  itojun run_rc_command "$1"
     61