X-Git-Url: https://git.grml.org/?p=grml-debootstrap.git;a=blobdiff_plain;f=grml-debootstrap;h=277c3ac79bb6fc89280ba2c3d83c581b87c1a2f8;hp=7ca8a70c74e9192be2c00781f4ff5bf46aee808a;hb=139f1a82802a0cbef7f231b0fae51f9357a7f518;hpb=a8fd9efa83f4963b552c3ddc90864677d90dfb05;ds=sidebyside diff --git a/grml-debootstrap b/grml-debootstrap index 7ca8a70..277c3ac 100755 --- a/grml-debootstrap +++ b/grml-debootstrap @@ -4,13 +4,13 @@ # 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 16 14:14:54 CEST 2007 [mika] +# Latest change: Mon Apr 16 20:39:13 CEST 2007 [mika] ################################################################################ # http://www.debian.org/releases/stable/i386/index.html.en set -e # exit on any error -VERSION='0.8' +VERSION='0.7' # source core functions {{{ . /etc/grml/lsb-functions @@ -33,14 +33,33 @@ fi # cmdline handling {{{ usage() { - einfo "$0 - wrapper around debootstrap for installing plain Debian via grml" - einfo "Adjust /etc/debootstrap/config and invoke $0 afterwards." + einfo "$0 - version $VERSION" + echo " A wrapper around debootstrap for installing plain Debian via grml" + echo + einfo "Usage: $0 [options]" + echo " Adjust /etc/debootstrap/config and invoke $0 afterwards or use the cmdline option:" + echo + einfo "Valid options:" + echo " + -h|--help Print this usage information and exit. + -v|--version Show summary of options and exit. + + -t|--target Target partition (/dev/...) or directory. + -r|--release Specify release of new Debian system. Supported relases: sarge, etch, lenny and sid. + -m|--mirror Specify mirror which should be used for apt-get/aptitude. + -p|--mntpoint Specify mountpoint that should be used for mounting the target system. + --groot Specify root device for usage in grub (corresponds with \$TARGET). + --grub Where do you want to install grub to? Use grub syntax for specifying. + --password Use specified password as password for user root. Use with caution. + --boot_append Add specified appendline to kernel whilst booting + +" } while [ "$#" -gt "0" ] ; do case $1 in -v|--version) - einfo "$0 version $VERSION" + einfo "$0 - version $VERSION" einfo "Send bug reports to Michael Prokop ." eend 0 exit 0 @@ -65,6 +84,10 @@ while [ "$#" -gt "0" ] ; do shift MNTPOINT=$1 ;; + --password) + shift + ROOTPASSWORD=$1 + ;; -m|--mirror) shift MIRROR=$1 @@ -132,12 +155,15 @@ else fi # provide variables to chroot system -[ -n "$ARCH" ] && echo "ARCH=$ARCH" > /etc/debootstrap/variables +touch /etc/debootstrap/variables +chmod 600 /etc/debootstrap/variables # make sure nobody except root can read it +[ -n "$ARCH" ] && echo "ARCH=$ARCH" > /etc/debootstrap/variables [ -n "$GRUB" ] && echo "GRUB=$GRUB" >> /etc/debootstrap/variables [ -n "$GROOT" ] && echo "GROOT=$GROOT" >> /etc/debootstrap/variables [ -n "$TARGET" ] && echo "TARGET=$TARGET" >> /etc/debootstrap/variables [ -n "$MIRROR" ] && echo "MIRROR=$MIRROR" >> /etc/debootstrap/variables -[ -n "$CHROOTMIRROR" ] && echo "CHROOTMIRROR=$CHROOTMIRROR" >> /etc/debootstrap/variables +[ -n "$MIRROR" ] && echo "CHROOTMIRROR=$MIRROR" >> /etc/debootstrap/variables +[ -n "$ROOTPASSWORD" ] && echo "ROOTPASSWORD=$ROOTPASSWORD" >> /etc/debootstrap/variables # make sure at least $TARGET is set [the partition for the new system] if [ -z "$TARGET" ] ; then @@ -182,20 +208,38 @@ stage() { # }}} # user should recheck his configuration {{{ -einfo "$0 - Please recheck configuration before execution:" -echo " - Target: $TARGET" - case "$MNTPOINT" in "$TARGET") ;; *) echo " Mount-point: $MNTPOINT" ;; esac - [ -n "$GRUB" ] && echo " Install grub to: $GROOT / $GRUB" - [ -n "$MIRROR" ] && echo " Using mirror: $MIRROR" - case "$MNTPOINT" in "$TARGET") ;; *) echo " Important! Continuing will delete all data from ${TARGET}!" ;; esac - echo -einfon "Is this ok for you? [y/N] " +# support full automatic installation: +checkforrun() { + dialog --timeout 10 --title "$0" \ + --yesno "Do you want to stop at this stage? -read a -if ! [ "$a" = 'y' -o "$a" = 'Y' ] ; then - eerror "Exiting as requested." ; eend 1 - exit 1 +Notice: you are running grml-debootstrap in non-interactive mode. +grml-debootstrap will install Debian ${RELEASE} on ${TARGET}. +Last chance to quit. Timeout of 10 seconds running.... + +Do you want to stop now?" 0 0 2>/dev/null +} + +if [ -n "$AUTOINSTALL" ] ; then + if checkforrun ; then + eerror "Exiting as requested" ; eend 0 + exit 1 + fi +else # if not running automatic installation display configuration and prompt for execution: + einfo "$0 - Please recheck configuration before execution:" + echo + echo " Target: $TARGET" + case "$MNTPOINT" in "$TARGET") ;; *) echo " Mount-point: $MNTPOINT" ;; esac + [ -n "$GRUB" ] && echo " Install grub to: $GROOT / $GRUB" + [ -n "$MIRROR" ] && echo " Using mirror: $MIRROR" + case "$MNTPOINT" in "$TARGET") ;; *) echo " Important! Continuing will delete all data from ${TARGET}!" ;; esac + echo + 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 fi # }}} @@ -265,6 +309,8 @@ preparechroot() { cp /etc/debootstrap/packages $MNTPOINT/etc/debootstrap/packages cp /etc/debootstrap/variables $MNTPOINT/etc/debootstrap/variables + cp -a /etc/debootstrap/extrapackages/ $MNTPOINT/etc/debootstrap/ + # make sure we can access network [relevant for cdebootstrap] [ -f "$MNTPOINT/etc/resolv.conf" ] || cp /etc/resolv.conf $MNTPOINT/etc/resolv.conf @@ -303,7 +349,8 @@ grub_install() { echo "Notice: \$GRUB or \$GROOT not defined, will not install grub therefor." else einfo "Installing grub on ${GRUB}:" - grub-install --root-directory="$MNTPOINT" "(${GRUB})" + [ -x /usr/sbin/grub-install ] && GRUBINSTALL=/usr/sbin/grub-install || GRUBINSTALL=/sbin/grub-install + $GRUBINSTALL --root-directory="$MNTPOINT" "(${GRUB})" eend $? fi } @@ -343,7 +390,13 @@ done echo done > $STAGES/grml-debootstrap # }}} - einfo "Finished execution of $0 - enjoy your Debian system." ; eend 0 +if [ -n "$AUTOINSTALL" ] ; then + dialog --title "$0" --msgbox \ + "Finished execution of ${0}. +Enjoy your Debian system." 6 60 +else + einfo "Finished execution of $0 - enjoy your Debian system." ; eend 0 +fi ## END OF FILE ################################################################# # vim: ai tw=100 expandtab foldmethod=marker