version bump to 4.2.13
[strongswan.git] / testing / scripts / build-sshkeys
1 #!/bin/bash
2 # build the hosts configuration directory with the actual IP addresses
3 #
4 # Copyright (C) 2004  Eric Marchionni, Patrik Rayo
5 # Zuercher Hochschule Winterthur
6 #
7 # This program is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by the
9 # Free Software Foundation; either version 2 of the License, or (at your
10 # option) any later version.  See <http://www.fsf.org/copyleft/gpl.txt>.
11 #
12 # This program is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
14 # or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
15 # for more details.
16 #
17 # RCSID $Id$
18
19 DIR=`dirname $0`
20
21 source $DIR/function.sh
22
23 [ -f $DIR/../testing.conf ] || die "!! Configuration file 'testing.conf' not found"
24 [ -d $DIR/../hosts ]        || die "!! Directory 'hosts' not found"
25
26 source $DIR/../testing.conf
27
28 if [ ! -d $BUILDDIR ]
29 then
30     cecho " * Creating directory '$BUILDDIR'"
31     mkdir $BUILDDIR
32 fi
33
34 LOGFILE=${BUILDDIR}/testing.log
35
36 if [ ! -f $LOGFILE ]
37 then
38     cecho-n " * Logfile '$LOGFILE' does not exist..creating.."
39     touch $LOGFILE
40     cgecho "done"
41 fi
42
43 if [ ! -d ~/.ssh ]
44 then
45     cecho-n " * Creating directory '~/.ssh'.."
46     mkdir ~/.ssh
47     cgecho "done"
48 fi
49
50 if [ -f ~/.ssh/known_hosts ]
51 then
52     cecho-n " * Backing up ~/.ssh/known_hosts to '~/.ssh/known_hosts.before_uml'.."
53     cp -fp ~/.ssh/known_hosts ~/.ssh/known_hosts.before_uml
54     cgecho "done"
55 else
56     cecho-n " * Creating '~/.ssh/known_hosts'"
57     touch ~/.ssh/known_hosts
58     cgecho "done"
59 fi
60
61 for host in $HOSTNAMEIPV4
62 do
63     HOSTNAME=`echo $host | awk -F, '{ print $1 }'`
64     IP=`echo $host | awk -F, '{ print $2 }'`
65     if [ `grep "$IP " ~/.ssh/known_hosts | wc -l` != "0" ]
66     then
67         cecho "!! Warning: An entry exists for the following IP address: $IP"
68     else
69         cecho-n " * Adding uml host $HOSTNAME ($IP) to '~/.ssh/known_hosts'.."
70         echo "$HOSTNAME,$IP `cat $DIR/../hosts/ssh_host_rsa_key.pub`" >> ~/.ssh/known_hosts
71         cgecho "done"
72     fi
73 done
74
75 #####################################
76 # preparing ssh for PK authentication
77 #
78
79 cecho-n " * Checking for ssh rsa key '~/.ssh/id_rsa.pub'.."
80 if [ -f ~/.ssh/id_rsa.pub ]
81 then
82     cecho "already exists"
83 else
84     cecho "not found"
85     cecho-n " * Generating ssh rsa key pair.."
86     echo "" | ssh-keygen -N "" -t rsa -f ~/.ssh/id_rsa >> $LOGFILE 2>&1
87     cgecho "done"
88 fi