lod plugins for scepclient
[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 DIR=`dirname $0`
18
19 source $DIR/function.sh
20
21 [ -f $DIR/../testing.conf ] || die "!! Configuration file 'testing.conf' not found"
22 [ -d $DIR/../hosts ]        || die "!! Directory 'hosts' not found"
23
24 source $DIR/../testing.conf
25
26 if [ ! -d $BUILDDIR ]
27 then
28     cecho " * Creating directory '$BUILDDIR'"
29     mkdir $BUILDDIR
30 fi
31
32 LOGFILE=${BUILDDIR}/testing.log
33
34 if [ ! -f $LOGFILE ]
35 then
36     cecho-n " * Logfile '$LOGFILE' does not exist..creating.."
37     touch $LOGFILE
38     cgecho "done"
39 fi
40
41 if [ ! -d ~/.ssh ]
42 then
43     cecho-n " * Creating directory '~/.ssh'.."
44     mkdir ~/.ssh
45     cgecho "done"
46 fi
47
48 if [ -f ~/.ssh/known_hosts ]
49 then
50     cecho-n " * Backing up ~/.ssh/known_hosts to '~/.ssh/known_hosts.before_uml'.."
51     cp -fp ~/.ssh/known_hosts ~/.ssh/known_hosts.before_uml
52     cgecho "done"
53 else
54     cecho-n " * Creating '~/.ssh/known_hosts'"
55     touch ~/.ssh/known_hosts
56     cgecho "done"
57 fi
58
59 for host in $HOSTNAMEIPV4
60 do
61     HOSTNAME=`echo $host | awk -F, '{ print $1 }'`
62     IP=`echo $host | awk -F, '{ print $2 }'`
63     if [ `grep "$IP " ~/.ssh/known_hosts | wc -l` != "0" ]
64     then
65         cecho "!! Warning: An entry exists for the following IP address: $IP"
66     else
67         cecho-n " * Adding uml host $HOSTNAME ($IP) to '~/.ssh/known_hosts'.."
68         echo "$HOSTNAME,$IP `cat $DIR/../hosts/ssh_host_rsa_key.pub`" >> ~/.ssh/known_hosts
69         cgecho "done"
70     fi
71 done
72
73 #####################################
74 # preparing ssh for PK authentication
75 #
76
77 cecho-n " * Checking for ssh rsa key '~/.ssh/id_rsa.pub'.."
78 if [ -f ~/.ssh/id_rsa.pub ]
79 then
80     cecho "already exists"
81 else
82     cecho "not found"
83     cecho-n " * Generating ssh rsa key pair.."
84     echo "" | ssh-keygen -N "" -t rsa -f ~/.ssh/id_rsa >> $LOGFILE 2>&1
85     cgecho "done"
86 fi