123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- #!/bin/bash
- DIR=$(dirname `readlink -f $0`)
- . $DIR/../testing.conf
- . $DIR/function.sh
- SWANDIR=${1:+$(readlink -f $1)}
- : ${SWANDIR:=$(readlink -f $DIR/../..)}
- [ `id -u` -eq 0 ] || die "You must be root to run $0"
- [ -f "$BASEIMG" ] || die "Base image $BASEIMG not found"
- [ -f "$ROOTIMG" ] || die "Root image $ROOTIMG not found"
- running_any $STRONGSWANHOSTS && die "Please stop test environment before running $0"
- [ -f $SWANDIR/src/libstrongswan/asn1/oid.txt ] || die "strongSwan not found in $SWANDIR"
- SRCUID=${SUDO_UID:-$(id -u)}
- SRCGID=${SUDO_GID:-$(id -g)}
- check_commands partprobe qemu-img qemu-nbd bindfs
- load_qemu_nbd
- mkdir -p $LOOPDIR
- mkdir -p $IMGDIR
- case "$2" in
- "")
- log_action "Connecting root image to NBD device $NBDEV"
- execute "qemu-nbd -c $NBDEV $ROOTIMG"
- ;;
- *)
- echo $STRONGSWANHOSTS | grep -q "\b$2\b" || die "Guest $2 not found"
- GUESTIMG="$IMGDIR/$2.$IMGEXT"
- [ -f "$GUESTIMG" ] || die "Guest image $GUESTIMG not found"
- log_action "Connecting guest image to NBD device $NBDEV"
- execute "qemu-nbd -c $NBDEV $GUESTIMG"
- ;;
- esac
- do_on_exit qemu-nbd -d $NBDEV
- partprobe $NBDEV
- log_action "Mounting $NBDPARTITION to $LOOPDIR"
- execute "mount $NBDPARTITION $LOOPDIR"
- do_on_exit umount $LOOPDIR
- log_action "Mounting proc filesystem to $LOOPDIR/proc"
- execute "mount -t proc none $LOOPDIR/proc"
- do_on_exit umount $LOOPDIR/proc
- mkdir -p $LOOPDIR/root/shared
- log_action "Mounting $SHAREDDIR as /root/shared"
- execute "mount -o bind $SHAREDDIR $LOOPDIR/root/shared"
- do_on_exit umount $LOOPDIR/root/shared
- mkdir -p $LOOPDIR/root/strongswan
- log_action "Mounting $SWANDIR as /root/strongswan"
- execute "bindfs -u $SRCUID -g $SRCGID --create-for-user=$SRCUID --create-for-group=$SRCGID $SWANDIR $LOOPDIR/root/strongswan"
- do_on_exit umount $LOOPDIR/root/strongswan
- log_action "Copy /etc/resolv.conf"
- execute "cp /etc/resolv.conf $LOOPDIR/etc/resolv.conf"
- do_on_exit rm $LOOPDIR/etc/resolv.conf
- log_action "Remove SWID tags of previous versions"
- execute_chroot "find /usr/local/share -path '*strongswan*' -name *.swidtag -delete"
- echo "Building and installing strongSwan"
- log_action "Determine strongSwan version"
- desc=`git -C $SWANDIR describe --dirty`
- if [ $? -eq 0 ]; then
- SWANVERSION="$desc (`git -C $SWANDIR rev-parse --abbrev-ref HEAD`)"
- else
- SWANVERSION="`cat $SWANDIR/configure.ac | sed -n '/^AC_INIT/{ s/.*,\[\(.*\)\])$/\1/p }'`"
- fi
- echo "$SWANVERSION" > $SHAREDDIR/.strongswan-version
- log_status 0
- log_action "Preparing source tree"
- execute_chroot 'autoreconf -i /root/strongswan'
- RECPDIR=$DIR/recipes
- RECIPE=`ls $RECPDIR/*strongswan.mk | xargs -n1 basename`
- mkdir -p $SHAREDDIR/build-strongswan
- cp $RECPDIR/$RECIPE $SHAREDDIR/build-strongswan
- log_action "Installing from recipe $RECIPE"
- execute_chroot "make SRCDIR=/root/strongswan BUILDDIR=/root/shared/build-strongswan -f /root/shared/build-strongswan/$RECIPE"
- # rebuild the guest images after we modified the root image
- if [ -z "$2" ]; then
- # cleanup before mounting guest images
- on_exit
- # building the guest images without certificates fails on winnetou
- if [ ! -f "$DIR/../hosts/winnetou/etc/ca/strongswanCert.pem" ]; then
- # this also re-builds the guest images
- $DIR/build-certs
- else
- $DIR/build-guestimages
- fi
- fi
|