X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=vserver-reference.spec;h=897b8a0e475640ac9548da1c7b2da0d435b9739d;hb=c9f6863aedfca503474371136e412dca8d06150f;hp=9a4298cfa2ce51d33608641ca9fd7cf47a9c7c31;hpb=208e5be30349820ab251c3e9ba0d806f63543c83;p=vserver-reference.git diff --git a/vserver-reference.spec b/vserver-reference.spec index 9a4298c..897b8a0 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,58 +28,59 @@ 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} 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} /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 %changelog * Tue Sep 1 2005 Mark Huang 3.1-1.planetlab