X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=build.sh;h=41d92f5f227174152b48c439389f452356f99a3c;hb=04eef922e2badb6085beb461bd4a2c492a50516c;hp=c4c117e61e1c78269147f84a2147925e64b45a09;hpb=ea0f8131c3a4fd50c7c72d0a506533167ac51648;p=vserver-reference.git diff --git a/build.sh b/build.sh index c4c117e..41d92f5 100755 --- a/build.sh +++ b/build.sh @@ -37,22 +37,21 @@ pl_process_fedora_options $@ shiftcount=$? shift $shiftcount -# pldistro expected as $1 - defaults to planetlab +# pldistro expected as $1 pldistro=$1 ; shift +# The vserver reference name - this comes from spec's slicefamily +slicefamily=$1; shift # Do not tolerate errors set -e # Path's to the vserver references images and stubs vrefdir=$PWD/vservers/.vref -vstubdir=$PWD/vservers/.vstub - -# XXX: The vserver reference name should be passed in as an argument -# rather than being hardcoded. -vrefname=default +vref=${vrefdir}/${slicefamily} +# stubs are created in a subdir per slicefamily +vstubdir=$PWD/vservers/.vstub/${slicefamily} # Make /vservers and default vserver reference image -vref=${vrefdir}/${vrefname} install -d -m 755 ${vref} # Some of the PlanetLab RPMs attempt to (re)start themselves in %post, @@ -86,11 +85,11 @@ systemvserver_count=$(ls ../build/config.${pldistro}/vserver-*.pkgs 2> /dev/null rm -f ${vdir}/var/lib/rpm/__db* # Communicate to the initialization script from which vref this stub was cloned - echo ${vrefname} > ${vdir}.cloned + echo ${slicefamily} > ${vdir}.cloned # Install the system vserver specific packages - [ -n "$systempackages" ] && yum -c ${vdir}/etc/yum.conf --installroot=${vdir} -y install $systempackages - [ -n "$systemgroups" ] && yum -c ${vdir}/etc/yum.conf --installroot=${vdir} -y groupinstall $systemgroups + [ -n "$systempackages" ] && yum -c ${vdir}/etc/mkfedora-yum.conf --installroot=${vdir} -y install $systempackages + [ -n "$systemgroups" ] && yum -c ${vdir}/etc/mkfedora-yum.conf --installroot=${vdir} -y groupinstall $systemgroups pkgsdir=$(dirname $pkgsfile) pkgsname=$(basename $pkgsfile .pkgs) @@ -101,9 +100,7 @@ systemvserver_count=$(ls ../build/config.${pldistro}/vserver-*.pkgs 2> /dev/null # This is a three step process: # step 1: clean out yum cache to reduce space requirements - yum -c ${vdir}/etc/yum.conf --installroot=${vdir} -y clean all - - [ -f ${vdir}/etc/yum.conf.rpmnew ] && mv -f ${vdir}/etc/yum.conf.rpmnew ${vdir}/etc/yum.conf + yum -c ${vdir}/etc/mkfedora-yum.conf --installroot=${vdir} -y clean all # step 2: figure out the new/changed files in ${vdir} vs. ${vref} and compute ${vdir}.changes rsync -anv ${vdir}/ ${vref}/ > ${vdir}.changes @@ -133,7 +130,7 @@ pkgsname=$(basename $pkgsfile .pkgs) postfile="${pkgsdir}/${pkgsname}.post" [ -f $postfile ] && /bin/bash $postfile ${vref} || : -# switch the vserver reference /etc/yum.conf to the new one from the yum package -[ -f ${vref}/etc/yum.conf.rpmnew ] && mv -f ${vref}/etc/yum.conf.rpmnew ${vref}/etc/yum.conf +# fix sudoers config +[ -f ${vref}/etc/sudoers ] && echo -e "\nDefaults\tlogfile=/var/log/sudo\n" >> ${vref}/etc/sudoers exit 0