summaryrefslogtreecommitdiff
path: root/programs/_plutoload/_plutoload.in
diff options
context:
space:
mode:
authorRene Mayrhofer <rene@mayrhofer.eu.org>2006-05-22 05:12:18 +0000
committerRene Mayrhofer <rene@mayrhofer.eu.org>2006-05-22 05:12:18 +0000
commitaa0f5b38aec14428b4b80e06f90ff781f8bca5f1 (patch)
tree95f3d0c8cb0d59d88900dbbd72110d7ab6e15b2a /programs/_plutoload/_plutoload.in
parent7c383bc22113b23718be89fe18eeb251942d7356 (diff)
downloadvyos-strongswan-aa0f5b38aec14428b4b80e06f90ff781f8bca5f1.tar.gz
vyos-strongswan-aa0f5b38aec14428b4b80e06f90ff781f8bca5f1.zip
Import initial strongswan 2.7.0 version into SVN.
Diffstat (limited to 'programs/_plutoload/_plutoload.in')
-rwxr-xr-xprograms/_plutoload/_plutoload.in164
1 files changed, 164 insertions, 0 deletions
diff --git a/programs/_plutoload/_plutoload.in b/programs/_plutoload/_plutoload.in
new file mode 100755
index 000000000..73841197d
--- /dev/null
+++ b/programs/_plutoload/_plutoload.in
@@ -0,0 +1,164 @@
+#!/bin/sh
+# Pluto database-loading script
+# Copyright (C) 1998, 1999, 2001 Henry Spencer.
+#
+# This program is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by the
+# Free Software Foundation; either version 2 of the License, or (at your
+# option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
+#
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+# for more details.
+#
+# RCSID $Id: _plutoload.in,v 1.2 2004/03/31 16:15:10 as Exp $
+#
+# exit status is 13 for protocol violation, that of Pluto otherwise
+
+me='ipsec _plutoload' # for messages
+
+for dummy
+do
+ case "$1" in
+ --load) plutoload="$2" ; shift ;;
+ --start) plutostart="$2" ; shift ;;
+ --wait) plutowait="$2" ; shift ;;
+ --post) postpluto="$2" ; shift ;;
+ --) shift ; break ;;
+ -*) echo "$me: unknown option \`$1'" >&2 ; exit 2 ;;
+ *) break ;;
+ esac
+ shift
+done
+
+# load ca information
+eval `ipsec _confread --varprefix PLUTO --type ca --search auto add start`
+if test " $PLUTO_confreadstatus" != " "
+then
+ echo "auto=add/start search: $PLUTO_confreadstatus"
+ echo "unable to determine what ca information to add -- adding none"
+ caload=
+else
+ caload="$PLUTO_confreadnames"
+fi
+
+# searches, if needed
+# the way the searches were done ensures plutoload >= plutoroute >= plutostart
+
+# search for things to "ipsec auto --add": auto in "add" "route" "start"
+eval `ipsec _confread --varprefix PLUTO --search auto add route start`
+if test " $PLUTO_confreadstatus" != " "
+then
+ echo "auto=add/route/start search: $PLUTO_confreadstatus"
+ echo "unable to determine what conns to add -- adding none"
+ plutoload=
+else
+ plutoload="$PLUTO_confreadnames"
+fi
+
+# search for things to "ipsec auto --route": auto in "route" "start"
+eval `ipsec _confread --varprefix PLUTO --search auto route start`
+if test " $PLUTO_confreadstatus" != " "
+then
+ echo "auto=route/start search: $PLUTO_confreadstatus"
+ echo "unable to determine what conns to route -- routing none"
+ plutoroute=
+else
+ plutoroute="$PLUTO_confreadnames"
+fi
+
+# search for things to "ipsec auto --up": auto in "start"
+eval `ipsec _confread --varprefix PLUTO --search auto start`
+if test " $PLUTO_confreadstatus" != " "
+then
+ echo "auto=start search: $PLUTO_confreadstatus"
+ echo "unable to determine what conns to start -- starting none"
+ plutostart=
+else
+ plutostart="$PLUTO_confreadnames"
+fi
+
+# await Pluto's readiness (not likely to be an issue, but...)
+eofed=y
+while read saying
+do
+ case "$saying" in
+ 'Pluto initialized') eofed= ; break ;; # NOTE BREAK OUT
+ *) echo "pluto unexpectedly said \`$saying'" ;;
+ esac
+done
+if test "$eofed"
+then
+ echo "pluto died unexpectedly!?!"
+ exit 13
+fi
+
+# ca database load
+for tu in $caload
+do
+ ipsec auto --type ca --add $tu ||
+ echo "...could not add ca \"$tu\""
+done
+
+# conn database load
+for tu in $plutoload
+do
+ ipsec auto --add $tu ||
+ echo "...could not add conn \"$tu\""
+done
+
+# enable listening
+ipsec auto --ready
+
+# execute any post-startup cleanup
+if test " $postpluto" != " "
+then
+ $postpluto
+ st=$?
+ if test " $st" -ne 0
+ then
+ echo "...postpluto command exited with status $st"
+ fi
+fi
+
+# quickly establish routing
+for tu in $plutoroute
+do
+ ipsec auto --route $tu ||
+ echo "...could not route conn \"$tu\""
+done
+
+# tunnel initiation, which may take a while
+async=
+if test " $plutowait" = " no"
+then
+ async="--asynchronous"
+fi
+for tu in $plutostart
+do
+ ipsec auto --up $async $tu ||
+ echo "...could not start conn \"$tu\""
+done
+
+# report any further utterances, and watch for exit status
+eofed=y
+while read saying
+do
+ case "$saying" in
+ exit) eofed= ; break ;; # NOTE BREAK OUT
+ *) echo "pluto unexpectedly says \`$saying'" ;;
+ esac
+done
+if test "$eofed"
+then
+ echo "pluto died without exit status!?!"
+ exit 13
+fi
+if read status
+then
+ exit $status
+else
+ echo "pluto yielded no exit status!?!"
+ exit 13
+fi