updated TODO
[grml-debootstrap.git] / grml-debootstrap
index bea4922..dea48b7 100644 (file)
@@ -4,7 +4,7 @@
 # Authors:       grml-team (grml.org), (c) Michael Prokop <mika@grml.org>
 # Bug-Reports:   see http://grml.org/bugs/
 # License:       This file is licensed under the GPL v2.
 # Authors:       grml-team (grml.org), (c) Michael Prokop <mika@grml.org>
 # Bug-Reports:   see http://grml.org/bugs/
 # License:       This file is licensed under the GPL v2.
-# Latest change: Fre Nov 03 17:49:46 CET 2006 [mika]
+# Latest change: Mon Nov 06 15:57:52 CET 2006 [mika]
 ################################################################################
 # http://www.debian.org/releases/stable/i386/apcs04.html.en
 
 ################################################################################
 # http://www.debian.org/releases/stable/i386/apcs04.html.en
 
@@ -13,7 +13,7 @@ set -e # exit on any error
 . /etc/grml/lsb-functions
 . /etc/grml/script-functions
 
 . /etc/grml/lsb-functions
 . /etc/grml/script-functions
 
-VERSION='0.1'
+VERSION='0.2'
 
 case $* in
    -h*|--h*)
 
 case $* in
    -h*|--h*)
@@ -33,6 +33,7 @@ esac
 check4progs debootstrap || exit 1
 check4root || exit 1
 
 check4progs debootstrap || exit 1
 check4root || exit 1
 
+# without config file it won't work
 if [ -r /etc/debootstrap/config ] ; then
    . /etc/debootstrap/config
 else
 if [ -r /etc/debootstrap/config ] ; then
    . /etc/debootstrap/config
 else
@@ -40,11 +41,29 @@ else
    exit 1
 fi
 
    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
 
 if [ -z "$TARGET" ] ; then
    eerror "Please adjust /etc/debootstrap/config before running ${0}" ; eend 1
    exit 1
 fi
 
+# user should recheck his configuration
+einfo "$0 - Please recheck configuration before execution:"
+echo "
+   Target partition: $TARGET
+   Mount-point:      $MNTPOINT
+   Install grub to:  $GROOT / $GRUB  [if empty grub will not be installed]
+
+   Important! Continuing will delete all data from ${TARGET}!
+"
+einfon "Is this ok for you? [y/N] "
+
+read a
+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
 if [ -n "$MKFS" ] ; then
    einfo "Running $MKFS on $TARGET"
    $MKFS $TARGET
@@ -59,9 +78,11 @@ fi
 
 # now mount the new partition
 if grep -q $TARGET /proc/mounts ; then
 
 # now mount the new partition
 if grep -q $TARGET /proc/mounts ; then
-   eerror "$TARGEt already mounted, exiting."
+   eerror "$TARGET already mounted, exiting."
 else
 else
+  [ -n "$MNTPOINT" ] || MNTPOINT='/mnt/test'
   einfo "Mounting $TARGET to $MNTPOINT"
   einfo "Mounting $TARGET to $MNTPOINT"
+  [ -d "$MNTPOINT" ] || mkdir -p "$MNTPOINT"
   mount -o rw,suid,dev $TARGET $MNTPOINT
   eend $?
 fi
   mount -o rw,suid,dev $TARGET $MNTPOINT
   eend $?
 fi
@@ -80,6 +101,12 @@ einfo "Preparing chroot system"
   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
 
+  # make sure we can access network [relevant for cdebootstrap]
+  [ -f "$MNTPOINT/etc/resolv.conf" ] || cp /etc/resolv.conf $MNTPOINT/etc/resolv.conf
+
+  # setup default locales
+  [ -n "$LOCALES" ] && cp /etc/debootstrap/locale.gen  $MNTPOINT/etc/locale.gen
+
   # copy any existing existing files to chroot
   [ -d /etc/debootstrap/boot  ] && cp -a /etc/debootstrap/boot/*  $MNTPOINT/boot/
   [ -d /etc/debootstrap/etc   ] && cp -a /etc/debootstrap/etc/*   $MNTPOINT/etc/
   # copy any existing existing files to chroot
   [ -d /etc/debootstrap/boot  ] && cp -a /etc/debootstrap/boot/*  $MNTPOINT/boot/
   [ -d /etc/debootstrap/etc   ] && cp -a /etc/debootstrap/etc/*   $MNTPOINT/etc/
@@ -92,6 +119,19 @@ einfo "Executing chroot-script now"
 chroot $MNTPOINT /bin/chroot-script
 eend $?
 
 chroot $MNTPOINT /bin/chroot-script
 eend $?
 
+# einfo "Removing chroot-script"
+# rm -f  $MNTPOINT/bin/chroot-script
+# rm -rf $MNTPOINT/etc/debootstrap/
+# eend $?
+
+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 "Unmount $MNTPOINT"
 umount $MNTPOINT
 eend $?
 einfo "Unmount $MNTPOINT"
 umount $MNTPOINT
 eend $?