+cat >> /etc/fstab << EOF
+proc /proc proc defaults 0 0
+/sys /sys sysfs noauto,rw,nosuid,nodev,noexec 0 0
+/dev/cdrom /mnt/cdrom0 iso9660 ro,user,noauto 0 0
+# some other examples:
+# /dev/sda2 none swap sw,pri=0 0 0
+# /dev/hda1 /Grml ext3 dev,suid,user,noauto 0 2
+# //1.2.3.4/pub /smb/pub smbfs defaults,user,noauto,uid=grml,gid=grml 0 0
+# linux:/pub /beer nfs defaults 0 0
+# tmpfs /tmp tmpfs size=300M 0 0
+# /dev/sda5 none swap sw 0 0
+EOF
+}
+# }}}
+
+# generate /etc/fstab {{{
+fstab() {
+ # set up /etc/fstab if file is not present (cdebootstrap)
+ if [ ! -f /etc/fstab ] ; then
+ createfstab
+ fi
+
+ # set up /etc/fstab if file is UNCONFIGURED (debootstrap)
+ if grep -q UNCONFIGURED /etc/fstab ; then
+ createfstab
+ fi
+}
+# }}}
+
+# set up hostname {{{
+hostname() {
+ if [ -n "$HOSTNAME" ] ; then
+ echo "Setting hostname to ${HOSTNAME}."
+ echo "$HOSTNAME" > /etc/hostname
+
+ # adjust postfix configuration
+ if [ -r /etc/postfix/main.cf ] ; then
+ # adjust hostname related options:
+ sed -i "s/grml/$HOSTNAME/g" /etc/postfix/main.cf
+
+ # listen on loopback interface only:
+ sed -i "s/^inet_interfaces = .*/inet_interfaces = loopback-only/" /etc/postfix/main.cf
+ grep -q inet_interfaces /etc/postfix/main.cf || echo 'inet_interfaces = loopback-only' >> /etc/postfix/main.cf
+ fi
+ fi
+}
+# }}}
+
+# generate initrd/initramfs {{{
+initrd() {
+ # assume the first available kernel as our main kernel
+ KERNELIMG=$(ls -1 /boot/vmlinuz-* 2>/dev/null | head -1)
+ if [ -z "$KERNELIMG" ] ; then
+ echo 'No kernel image found, skipping initrd stuff.'>&2
+ return
+ fi
+
+ KERNELVER=${KERNELIMG#/boot/vmlinuz-}
+
+ # generate initrd
+ if [ -n "$INITRD" ] ; then
+ echo "Generating initrd."
+ update-initramfs -c -t -k $KERNELVER
+ fi
+}
+# }}}
+
+# grub configuration/installation {{{
+grub_install() {
+
+ if [ -z "$GRUB" ] ; then
+ echo "Notice: \$GRUB not defined, will not install grub therefore."
+ return 0
+ fi
+
+ if ! dpkg --list grub-pc 2>/dev/null | grep -q '^ii' ; then
+ echo "Notice: grub option set but no grub-pc package, installing it therefore."
+ DEBIAN_FRONTEND=$DEBIAN_FRONTEND $APTINSTALL grub-pc
+ fi
+
+ if ! [ -x "$(which grub-install)" ] ; then
+ echo "Error: grub-install not available. (Error while installing grub package?)" >&2
+ return 1
+ fi
+
+ if [ -n "$SELECTED_PARTITIONS" ] ; then # using sw-raid
+ for device in $SELECTED_PARTITIONS ; do
+ GRUB="${device%%[0-9]}"
+ echo "Installing grub on ${GRUB}:"
+ grub-install --no-floppy "$GRUB"
+ done
+ else
+ echo "Installing grub on ${GRUB}:"
+ grub-install --no-floppy "$GRUB"
+ fi
+
+ echo "Adjusting grub configuration for use on ${GRUB}."
+
+ # finally install grub
+ if [ -x /usr/sbin/update-grub ] ; then
+ UPDATEGRUB='/usr/sbin/update-grub'
+ elif [ -x /sbin/update-grub ] ; then
+ UPDATEGRUB='/sbin/update-grub'
+ else
+ echo "Error: update-grub not available, can not execute it." >&2
+ return 1
+ fi
+
+ $UPDATEGRUB
+}
+# }}}
+
+# execute all scripts present in /etc/debootstrap/chroot-scripts/ {{{
+custom_scripts() {
+ [ -d /etc/debootstrap/chroot-scripts/ ] || return 0
+
+ for script in /etc/debootstrap/chroot-scripts/* ; do
+ echo "Executing script $script"
+ $script && echo "done" || echo "failed"
+ done
+}
+# }}}
+
+# make sure we don't have any running processes left {{{
+services() {
+ for service in ssh mdadm mdadm-raid ; do
+ if [ -x /etc/init.d/"$service" ] ; then
+ /etc/init.d/"$service" stop || true
+ fi
+ done
+}
+# }}}
+
+# unmount /proc and make sure nothing is left {{{
+finalize() {
+ # make sure we don't leave any sensible data
+ rm -f /etc/debootstrap/variables
+
+ [ -n "$POLICYRCD" ] && rm -f /usr/sbin/policy-rc.d
+
+ umount /proc >/dev/null 2>/dev/null || true
+}
+# }}}
+
+# signal handler {{{
+signal_handler() {
+ finalize
+ [ -n "$1" ] && EXIT="$1" || EXIT="1"
+ exit "$EXIT"
+}
+# }}}
+
+# set signal handler {{{
+trap signal_handler HUP INT QUIT TERM
+# }}}
+
+# execute the functions {{{
+
+ # always execute install_policy_rcd
+ install_policy_rcd
+
+ for i in chrootmirror grmlrepos kernelimg_conf \
+ kernel packages extrapackages reconfigure hosts interfaces \
+ timezone fstab hostname initrd grub_install passwords \
+ custom_scripts remove_apt_cache services ; do
+ if stage $i ; then
+ $i && stage $i done || exit 1
+ fi
+ done
+ # always execute the finalize stage:
+ finalize
+# }}}
+
+# finally exit the chroot {{{
+ echo "Finished chroot installation, exiting."
+ exit 0
+# }}}