1 1.1 itojun #!/bin/sh 2 1.1 itojun # 3 1.3 itojun # $NetBSD: ipsec,v 1.3 2000/06/14 03:24:16 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.3 itojun echo "Clearing ipsec 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