X-Git-Url: http://git.grml.org/?a=blobdiff_plain;f=etc%2Fgrml%2Ffai%2Fconfig%2Fhooks%2Fupdatebase.GRMLBASE;h=b49b180b065f9a16be63928b1e22b2242cec6d89;hb=1cef31a85e18484353f05dc851ed101001f9c07c;hp=359c7ba60a4abb7baaf7427489080d75832e8d30;hpb=338bbb2a14b9680e6eab3578220b1ab6e9a5d2cc;p=grml-live.git diff --git a/etc/grml/fai/config/hooks/updatebase.GRMLBASE b/etc/grml/fai/config/hooks/updatebase.GRMLBASE index 359c7ba..b49b180 100755 --- a/etc/grml/fai/config/hooks/updatebase.GRMLBASE +++ b/etc/grml/fai/config/hooks/updatebase.GRMLBASE @@ -1,18 +1,73 @@ -#!/bin/sh -# Filename: /etc/grml/fai/config/hooks/updatebase.GRMLBASE -# Purpose: skip task updatebase of FAI when running softupdate +#!/bin/bash +# Filename: ${GRML_FAI_CONFIG}/hooks/updatebase.GRMLBASE +# Purpose: Updates the base packages of the system, prepare chroot for instsoft # Authors: grml-team (grml.org), (c) Michael Prokop # Bug-Reports: see http://grml.org/bugs/ # License: This file is licensed under the GPL v2 or any later version. -# Latest change: Sun Dec 16 13:56:58 CET 2007 [mika] ################################################################################ +set -u +set -e + +# visualize chroot inside zsh: +echo grml_chroot > $target/etc/debian_chroot + +HOSTNAME='' +[ -r /etc/grml/grml-live.conf ] && . /etc/grml/grml-live.conf +[ -r /etc/grml/grml-live.local ] && . /etc/grml/grml-live.local +[ -n "$HOSTNAME" ] || HOSTNAME=grml +echo "$HOSTNAME" > $target/etc/hostname + if [ "$FAI_ACTION" = "softupdate" ] ; then - # we want to use our own sources.list: + echo "Action $FAI_ACTION of FAI (hooks/updatebase.GRMLBASE) via grml-live running" + + ## we want to use our own sources.list: skiptask updatebase - # skip the task if we want to build a new ISO only: - [ -n "$BUILD_ONLY" ] && skiptask instsoft + + ## based on FAI's lib/updatebase: + # some packages must access /proc even in chroot environment + if ! [ -d $FAI_ROOT/proc/1 ] ; then + mount -t proc proc $FAI_ROOT/proc || true + fi + # some packages must access /sys even in chroot environment + if ! [ -d $FAI_ROOT/sys/kernel ] ; then + mount -t sysfs sysfs $FAI_ROOT/sys + fi + # if we are using udev, also mount it into $FAI_ROOT + if [ -f /etc/init.d/udev ] ; then + mount --bind /dev $FAI_ROOT/dev || true + fi + + mount -t devpts devpts $FAI_ROOT/dev/pts || true + + # skip the task if we want to build a new ISO only, + # this means we do NOT update any packages + if [ -n "$BUILD_ONLY" ] ; then + skiptask instsoft || true + fi + + exit # make sure we don't continue behind the following "fi" fi +if [ -n "$BOOTSTRAP_ONLY" ] ; then + echo "Skipping task configure in hooks/updatebase.GRMLBASE as BOOTSTRAP_ONLY environment is set." + skiptask configure +fi + +# no softupdate but updating chroot e.g. based on ${GRML_FAI_CONFIG}/basefiles/* +echo "Action $FAI_ACTION of FAI (hooks/updatebase.GRMLBASE) via grml-live running" + +# work around #632624: udev fails to install on systems with old kernel versions +if ! [ -e ${target}/etc/udev/kernel-upgrade ] ; then + echo "Working around udev package bug, creating /etc/udev/kernel-upgrade" + echo "# installed via updatebase.GRMLBASE" > ${target}/etc/udev/kernel-upgrade +fi + +# install all apt related files +fcopy -r /etc/apt + +# install Grml gpg key: +$ROOTCMD apt-key add /etc/apt/grml.key + ## END OF FILE ################################################################# -# vim:ft=sh expandtab ai tw=80 tabstop=4 shiftwidth=3 +# vim:ft=sh expandtab ai tw=80 tabstop=4 shiftwidth=2