X-Git-Url: https://git.grml.org/?p=grml-debootstrap.git;a=blobdiff_plain;f=grml-debootstrap;h=9b0574ce1bba67b136dbc28517b5974a8e135b4d;hp=f31680200945f617a864eb62d5993470861b4380;hb=a33020b8087c2663ec37835fb47a0039ea6a41c1;hpb=3b8197edc1b836dff40d7d067cb7fc05f7c572fa diff --git a/grml-debootstrap b/grml-debootstrap index f316802..9b0574c 100644 --- a/grml-debootstrap +++ b/grml-debootstrap @@ -4,21 +4,25 @@ # Authors: grml-team (grml.org), (c) Michael Prokop # Bug-Reports: see http://grml.org/bugs/ # License: This file is licensed under the GPL v2. -# Latest change: Mon Apr 09 14:35:18 CEST 2007 [mika] +# Latest change: Mon Apr 16 13:21:01 CEST 2007 [mika] ################################################################################ -# http://www.debian.org/releases/stable/i386/apcs04.html.en +# http://www.debian.org/releases/stable/i386/index.html.en set -e # exit on any error +VERSION='0.8' + +# source core functions {{{ . /etc/grml/lsb-functions . /etc/grml/script-functions +# }}} -# inside the chroot system the locales might not be available, so use minimum: -export LANG=C -export LC_ALL=C - -VERSION='0.6' +# make sure we have what we need {{{ +check4progs debootstrap || exit 1 +check4root || exit 1 +# }}} +# cmdline handling {{{ case $* in -h*|--h*) einfo "$0 - wrapper around debootstrap for installing plain Debian via grml" @@ -33,37 +37,34 @@ case $* in exit 0 ;; esac +# }}} -check4progs debootstrap || exit 1 -check4root || exit 1 - -# without config file it won't work +# without config file it won't work {{{ if [ -r /etc/debootstrap/config ] ; then . /etc/debootstrap/config else - echo "/etc/debootstrap/config could not be read, exiting." + eerror "/etc/debootstrap/config could not be read, exiting." ; eend 1 exit 1 fi +# }}} -# make sure at least $TARGET is set [the partition for the new system] -if [ -z "$TARGET" ] ; then - eerror "Please adjust /etc/debootstrap/config before running ${0}" ; eend 1 - exit 1 -fi +# set/check variables {{{ -function bailout(){ - # make sure $TARGET is not mounted when exiting grml-debootstrap - if [ -n "$TARGET" ] ; then - if grep -q $TARGET /proc/mounts ; then - echo "Unmounting $TARGET" - umount "$TARGET" - fi - fi - [ -n "$1" ] && EXIT="$1" || EXIT="1" - exit "$EXIT" -} +# inside the chroot system the locales might not be available, so use minimum: +export LANG=C +export LC_ALL=C -trap bailout 1 2 3 15 +if [ -z "$STAGES" ] ; then + STAGES='/etc/debootstrap/stages' + [ -d "$STAGES" ] || mkdir -p "$STAGES" +fi + +if [ -r $STAGES/grml-debootstrap ] ; then + if grep -q done $STAGES/grml-debootstrap ; then + eerror "Error: grml-debootstrap has been executed already, won't continue therefore." + eerror "If you want to re-execute grml-debootstrap just manually remove ${STAGES}" ; eend 1 + fi +fi PARTITION='' DIRECTORY='' @@ -84,7 +85,60 @@ case $TARGET in ;; esac -# user should recheck his configuration +if [ -n "$ARCH" ] ; then + ARCHCMD="--arch $ARCH" + ARCHINFO=" (${ARCH})" +else + ARCH="$(dpkg --print-architecture)" + ARCHCMD="--arch $ARCH" + ARCHINFO=" (${ARCH})" +fi + +# provide variables to chroot system +echo " +ARCH=$ARCH +" > /etc/debootstrap/variables + +# make sure at least $TARGET is set [the partition for the new system] +if [ -z "$TARGET" ] ; then + eerror "Please adjust /etc/debootstrap/config before running ${0}" ; eend 1 + exit 1 +fi +# }}} + +# helper functions {{{ +# we want to exit smoothly and clean: +bailout(){ + # make sure $TARGET is not mounted when exiting grml-debootstrap + if [ -n "$MNTPOINT" ] ; then + if grep -q $MNTPOINT /proc/mounts ; then + # make sure nothing is left inside chroot so we can unmount it + [ -x "$MNTPOINT"/etc/init.d/ssh ] && "$MNTPOINT"/etc/init.d/ssh stop + [ -x "$MNTPOINT"/etc/init.d/mdadm ] && "$MNTPOINT"/etc/init.d/mdadm stop + [ -x "$MNTPOINT"/bin/umount ] && chroot "$MNTPOINT" umount /sys + [ -x "$MNTPOINT"/bin/umount ] && chroot "$MNTPOINT" umount /proc + echo "Unmounting $MNTPOINT" ; umount "$MNTPOINT" + fi + fi + [ -n "$1" ] && EXIT="$1" || EXIT="1" + [ -n "$3" ] && einfo "Notice: just remove $STAGES/$3 to reexecute the stage" + exit "$EXIT" +} +trap bailout 1 2 3 15 + +# we want to execute all the functions only once, simple check for it: +stage() { + if [ -n "$2" ] ; then + echo "$2" > "$STAGES/$1" + return 0 + elif grep -q done "$STAGES/$1" 2>/dev/null ; then + ewarn "Notice: stage $1 has been executed already, skipping execution therefore." ; eend 0 + return 1 + fi +} +# }}} + +# user should recheck his configuration {{{ einfo "$0 - Please recheck configuration before execution:" echo " Target: $TARGET" @@ -99,52 +153,65 @@ if ! [ "$a" = 'y' -o "$a" = 'Y' ] ; then eerror "Exiting as requested." ; eend 1 exit 1 fi +# }}} -if [ -n "$MKFS" ] ; then - einfo "Running $MKFS on $TARGET" - $MKFS $TARGET - eend $? -fi - -if [ -n "$TUNE2FS" ] ; then - einfo "Disabling automatic filesystem check on $TARGET via tune2fs" - $TUNE2FS $TARGET - eend $? -fi - +# create filesystem {{{ +mkfs() { + if [ -n "$MKFS" ] ; then + einfo "Running $MKFS on $TARGET" + $MKFS $TARGET + eend $? + fi +} +# }}} -# now mount the new partition or if it's a directory do nothing at all -if [ -n "$DIRECTORY" ] ; then - einfo "Running grml-debootstrap on a directory, nothing to mount." -else - if grep -q $TARGET /proc/mounts ; then - eerror "$TARGET already mounted, exiting." - else - [ -n "$MNTPOINT" ] || MNTPOINT='/mnt/test' - [ -d "$MNTPOINT" ] || mkdir -p "$MNTPOINT" - einfo "Mounting $TARGET to $MNTPOINT" - mount -o rw,suid,dev $TARGET $MNTPOINT +# modify filesystem settings {{{ +tunefs() { + if [ -n "$TUNE2FS" ] ; then + einfo "Disabling automatic filesystem check on $TARGET via tune2fs" + $TUNE2FS $TARGET eend $? - fi -fi + fi +} +# }}} -# get main packages from a debian-mirror -if [ -n "$ARCH" ] ; then - ARCHCMD="--arch $ARCH" - ARCHINFO=" (${ARCH})" -fi -einfo "Running $DEBOOTSTRAP for release ${RELEASE}${ARCHINFO} using mirror $MIRROR" -$DEBOOTSTRAP $ARCHCMD $RELEASE $MNTPOINT $MIRROR -eend $? +# mount the new partition or if it's a directory do nothing at all {{{ +mount_target() { + if [ -n "$DIRECTORY" ] ; then + einfo "Running grml-debootstrap on a directory, nothing to mount." + else + if grep -q $TARGET /proc/mounts ; then + eerror "$TARGET already mounted, exiting." + else + [ -n "$MNTPOINT" ] || MNTPOINT='/mnt/test' + [ -d "$MNTPOINT" ] || mkdir -p "$MNTPOINT" + einfo "Mounting $TARGET to $MNTPOINT" + mount -o rw,suid,dev $TARGET $MNTPOINT + eend $? + fi + fi +} +# }}} -einfo "Preparing chroot system" +# install main chroot {{{ +debootstrap_system() { + einfo "Running $DEBOOTSTRAP for release ${RELEASE}${ARCHINFO} using mirror $MIRROR" + $DEBOOTSTRAP $ARCHCMD $RELEASE $MNTPOINT $MIRROR + eend $? +} +# }}} + +# prepare chroot via chroot-script {{{ +preparechroot() { + einfo "Preparing chroot system" cp $CONFFILES/chroot-script $MNTPOINT/bin/chroot-script chmod 755 $MNTPOINT/bin/chroot-script mkdir $MNTPOINT/etc/debootstrap/ # make sure we have our files for later use via chroot-script - cp /etc/debootstrap/config $MNTPOINT/etc/debootstrap/ - cp /etc/debootstrap/packages $MNTPOINT/etc/debootstrap/packages + cp /etc/debootstrap/config $MNTPOINT/etc/debootstrap/ + cp /etc/debootstrap/packages $MNTPOINT/etc/debootstrap/packages + cp /etc/debootstrap/variables $MNTPOINT/etc/debootstrap/variables # make sure we can access network [relevant for cdebootstrap] [ -f "$MNTPOINT/etc/resolv.conf" ] || cp /etc/resolv.conf $MNTPOINT/etc/resolv.conf @@ -158,38 +225,73 @@ einfo "Preparing chroot system" [ -d /etc/debootstrap/share ] && cp -a /etc/debootstrap/share/* $MNTPOINT/share/ [ -d /etc/debootstrap/usr ] && cp -a /etc/debootstrap/usr/* $MNTPOINT/usr/ [ -d /etc/debootstrap/var ] && cp -a /etc/debootstrap/var/* $MNTPOINT/var/ -eend 0 + eend 0 +} +# }}} -einfo "Executing chroot-script now" -chroot "$MNTPOINT" /bin/chroot-script -eend $? +# execute chroot-script {{{ +chrootscript() { + if ! [ -r "$MNTPOINT/bin/chroot-script" ] ; then + mount_target + fi + if [ -x "$MNTPOINT/bin/chroot-script" ] ; then + einfo "Executing chroot-script now" + chroot "$MNTPOINT" /bin/chroot-script + eend $? + else + eerror "Fatal: $MNTPOINT/bin/chroot-script could not be found." + eend 1 + fi +} +# }}} + +# install booloader grub {{{ +grub_install() { + if [ -z "$GRUB" -o -z "$GROOT" ] ; then + echo "Notice: \$GRUB or \$GROOT not defined, will not install grub therefor." + else + einfo "Installing grub on ${GRUB}:" + grub-install --root-directory="$MNTPOINT" "(${GRUB})" + eend $? + fi +} +# }}} -# einfo "Removing chroot-script" -# rm -f $MNTPOINT/bin/chroot-script -# rm -rf $MNTPOINT/etc/debootstrap/ -# eend $? +# unmount $MNTPOINRT {{{ +umount_chroot() { + if [ -n "$PARTITION" ] ; then + einfo "Unmount $MNTPOINT" + umount $MNTPOINT + eend $? + fi +} +# }}} -if [ -z "$GRUB" -o -z "$GROOT" ] ; then - echo "Notice: \$GRUB or \$GROOT not defined, will not install grub therefor." -else - einfo "Installing grub on ${GRUB}:" - grub-install --root-directory="$MNTPOINT" "(${GRUB})" - eend $? -fi +# execute filesystem check {{{ +fscktool() { + if [ "$FSCK" = 'yes' ] ; then + [ -n "$FSCKTOOL" ] || FSCKTOOL="fsck.${MKFS#mkfs.}" + einfo "Checking filesystem on $TARGET using $FSCKTOOL" + $FSCKTOOL $TARGET + eend $? + fi +} +# }}} -if [ -n "$PARTITION" ] ; then - einfo "Unmount $MNTPOINT" - umount $MNTPOINT - eend $? -fi +# now execute all the functions {{{ +for i in mkfs tunefs mount_target debootstrap_system preparechroot \ + chrootscript grub_install umount_chroot fscktool ; do + if stage $i ; then + $i && stage $i done || bailout 2 "i" + fi +done +# }}} -if [ "$FSCK" = 'yes' ] ; then - [ -n "$FSCKTOOL" ] || FSCKTOOL="fsck.${MKFS#mkfs.}" - einfo "Checking filesystem on $TARGET using $FSCKTOOL" - $FSCKTOOL $TARGET - eend $? -fi +# stages {{{ + echo done > $STAGES/grml-debootstrap +# }}} -einfo "Finished execution of $0 - enjoy your Debian system." ; eend 0 + einfo "Finished execution of $0 - enjoy your Debian system." ; eend 0 ## END OF FILE ################################################################# +# vim: ai tw=100 expandtab foldmethod=marker