X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=vserver-reference.spec;h=8c53b5de1bcbf137cca2f29aea5087da2dc72d59;hb=refs%2Fheads%2Fplanetlab-3_3-branch;hp=c7ba4cd3ef627044aeb46532d3f0dbb3f7dd1108;hpb=311f1f92344b4a9e950649b134b11debbec6ae71;p=sliceimage.git diff --git a/vserver-reference.spec b/vserver-reference.spec index c7ba4cd..8c53b5d 100644 --- a/vserver-reference.spec +++ b/vserver-reference.spec @@ -1,6 +1,6 @@ %define name vserver-reference %define version 3.1 -%define release 1.planetlab%{?date:.%{date}} +%define release 2%{?pldistro:.%{pldistro}}%{?date:.%{date}} Vendor: PlanetLab Packager: PlanetLab Central @@ -28,53 +28,66 @@ as the installation base for new PlanetLab slivers. %setup -q %build -RPM_BUILD_DIR=$RPM_BUILD_DIR ./%{name}.init +RPM_BUILD_DIR=$RPM_BUILD_DIR ./build.sh %install rm -rf $RPM_BUILD_ROOT +install -D -m 755 %{name}.init $RPM_BUILD_ROOT/%{_initrddir}/%{name} +install -D -m 644 vserver-reference.cron $RPM_BUILD_ROOT/%{_sysconfdir}/cron.d/vserver-reference find vservers/vserver-reference | cpio -p -d -u $RPM_BUILD_ROOT/ +# If run under sudo, allow user to delete the build directory +if [ -n "$SUDO_USER" ] ; then + chown -R $SUDO_USER . + # Some temporary cdroot files like /var/empty/sshd and + # /usr/bin/sudo get created with non-readable permissions. + find . -not -perm +0600 -exec chmod u+rw {} \; +fi + %clean rm -rf $RPM_BUILD_ROOT +# If run under sudo, allow user to delete the built RPM +if [ -n "$SUDO_USER" ] ; then + chown $SUDO_USER %{_rpmdir}/%{_arch}/%{name}-%{version}-%{release}.%{_arch}.rpm +fi + %files %defattr(-,root,root) +%{_initrddir}/%{name} +%{_sysconfdir}/cron.d/vserver-reference /vservers/vserver-reference -%post -VROOT=/vservers/vserver-reference - -# Make sure the barrier bit is set -setattr --barrier /vservers - -# Copy configuration files from host to reference image -for file in /etc/hosts /etc/resolv.conf /etc/yum.conf ; do - if [ -f $file ] ; then - echo $file | cpio -p -d -u $VROOT - fi -done - -# Install and parse Management Authority (MA) configuration -if [ -r /etc/planetlab/primary_ma ] ; then - . /etc/planetlab/primary_ma - install -D -m 644 /etc/planetlab/primary_ma $VROOT/etc/planetlab/primary_ma -elif [ -d /mnt/cdrom/bootme/cacert ] ; then - MA_NAME="PlanetLab Central" - MA_BOOT_SERVER=$(head -1 /mnt/cdrom/bootme/BOOTSERVER) - MA_BOOT_SERVER_CACERT=/mnt/cdrom/bootme/cacert/$MA_BOOT_SERVER/cacert.pem - cat > $VROOT/etc/planetlab/primary_ma < %{vcached_pid} -# Install boot server certificate -install -D -m 644 $MA_BOOT_SERVER_CACERT $VROOT/$MA_BOOT_SERVER_CACERT +# vcached will clean up .vtmp later +mkdir -p /vservers/.vtmp +if [ -d /vservers/vserver-reference ] ; then + mv /vservers/vserver-reference /vservers/.vtmp/vserver-reference.$RANDOM +fi +if [ -d /vservers/.vcache ] ; then + mv /vservers/.vcache /vservers/.vtmp/.vcache.$RANDOM +fi -# Also install in /mnt/cdrom/bootme for backward compatibility -install -D -m 644 $MA_BOOT_SERVER_CACERT $VROOT/mnt/cdrom/bootme/cacert/$MA_BOOT_SERVER/cacert.pem -echo $MA_BOOT_SERVER > $VROOT/mnt/cdrom/bootme/BOOTSERVER +# Allow vcached to run again +rm -f %{vcached_pid} + +%post +chkconfig --add %{name} +chkconfig %{name} on +[ "$PL_BOOTCD" = "1" ] || service vserver-reference start + +# Randomize daily run time +M=$((60 * $RANDOM / 32768)) +H=$((24 * $RANDOM / 32768)) +sed -i -e "s/@M@/$M/" -e "s/@H@/$H/" %{_sysconfdir}/cron.d/vserver-reference %changelog * Tue Sep 1 2005 Mark Huang 3.1-1.planetlab