2 # Filename: /etc/debootstrap/chroot-script
3 # Purpose: script executed in chroot when installing Debian via grml-debootstrap
4 # Authors: grml-team (grml.org), (c) Michael Prokop <mika@grml.org>
5 # Bug-Reports: see http://grml.org/bugs/
6 # License: This file is licensed under the GPL v2.
7 # Latest change: Mon Nov 06 15:33:28 CET 2006 [mika]
8 ################################################################################
10 set -e # exit on any error
12 . /etc/debootstrap/config || exit 1
14 [ -r /proc/1 ] || mount -t proc none /proc
16 if [ -n "$CHROOTMIRROR" ] ; then
17 echo "deb $CHROOTMIRROR $RELEASE main contrib non-free" > /etc/apt/sources.list
20 if ! [ -r /etc/kernel-img.conf ] ; then
21 echo "Setting up /etc/kernel-img.conf"
22 cat > /etc/kernel-img.conf << EOF
23 # Kernel Image management overrides
24 # See kernel-img.conf(5) for details
30 # create default devices
31 if ! [ -r /dev/hda20 ] ; then
32 echo "Creating generic devices in /dev - this might take a while..."
33 cd /dev && MAKEDEV generic
36 # install additional packages
37 if [ "$PACKAGES" = 'yes' ] ; then
38 if ! [ -r /etc/debootstrap/packages ] ; then
39 echo "Error: /etc/debootstrap/packages not found, exiting."
43 apt-get --force-yes -y install $(cat /etc/debootstrap/packages)
47 # sarge specific stuff
48 if [ "$RELEASE" = 'sarge' ] ; then
49 sed -i "s#ROOT=probe#ROOT=$TARGET#" /etc/mkinitrd/mkinitrd.conf
52 if [ -n "$KERNEL" ] ; then
54 if [ "$RELEASE" = 'sarge' ] ; then
55 KERNELPACKAGES="kernel-image-$KERNEL kernel-headers-$KERNEL"
57 KERNELPACKAGES="linux-image-$KERNEL linux-headers-$KERNEL"
59 apt-get --force-yes -y install $KERNELPACKAGES
62 if [ -n "$RECONFIGURE" ] ; then
63 for package in $RECONFIGURE ; do
64 dpkg --list $package 1>/dev/null 2>/dev/null && dpkg-reconfigure $package || echo "Warning: $package does not exist, can not reconfigure it."
68 # set password of user root
69 echo "Activating shadow passwords."
71 echo "Setting password for user root:"
72 set +e # do not exit if passwd returns error due to missmatching passwords
75 set -e # restore default behaviour again
77 if ! [ -f /etc/hosts ] ; then
78 echo "Setting up /etc/hosts"
79 echo "127.0.0.1 localhost $HOSTNAME" > /etc/hosts
82 if ! [ -f /etc/network/interfaces ] ; then
83 echo "Setting up /etc/network/interfaces"
84 cat >> /etc/network/interfaces << EOF
85 iface lo inet loopback
93 if [ -n "$TIMEZONE" ] ; then
94 echo "Adjusting /etc/localtime"
95 ln -sf /usr/share/zoneinfo/$TIMEZONE /etc/localtime
98 function createfstab(){
99 echo "Setting up /etc/fstab"
100 cat > /etc/fstab << EOF
101 $TARGET / auto defaults,errors=remount-ro 0 1
102 /sys /sys sysfs rw,nosuid,nodev,noexec 0 0
103 proc /proc proc defaults 0 0
104 /dev/cdrom /mnt/cdrom0 iso9660 ro,user,noauto 0 0
105 # some other examples:
106 # /dev/sda2 none swap sw 0 0
107 # /dev/hda1 /Grml ext3 dev,suid,user,noauto 0 2
108 # //1.2.3.4/pub /smb/pub smbfs defaults,user,noauto,uid=grml,gid=grml 0 0
109 # linux:/pub /beer nfs defaults 0 0
110 # tmpfs /tmp tmpfs size=300M 0 0
114 # set up /etc/fstab if file is not present (cdebootstrap)
115 if [ ! -f /etc/fstab ] ; then
119 # set up /etc/fstab if file is UNCONFIGURED (debootstrap)
120 if grep -q UNCONFIGURED /etc/fstab ; then
125 if [ -n "$HOSTNAME" ] ; then
126 echo "Setting hostname to ${HOSTNAME}."
127 echo "$HOSTNAME" > /etc/hostname
130 # assume the first available kernel as our main kernel
131 KERNELIMG=$(ls -1 /boot/vmlinuz-* | head -1)
132 KERNELVER=${KERNELIMG#/boot/vmlinuz-}
135 if [ -n "$INITRD" ] ; then
136 if [ "$RELEASE" = 'sarge' ] ; then
137 echo "Release sarge detected, will not create an initrd."
139 echo "Generating initrd."
140 update-initramfs -c -t -k $KERNELVER
141 if [ -f "/boot/initrd.img-$KERNELVER" ] ; then
142 GRUBINITRD="initrd /boot/initrd.img-$KERNELVER"
143 LILOINITRD=" initrd=/boot/initrd.img-$KERNELVER"
148 if [ -n "$GROOT" ] ; then
149 echo "Installing grub"
151 # copy stage-files to /boot/grub/
152 [ -d /boot/grub/ ] || mkdir /boot/grub
153 if [ -d /usr/lib/grub/i386-pc/ ] ; then
154 cp /usr/lib/grub/i386-pc/* /boot/grub/
156 # sarge ships grub files in another directory
157 cp /lib/grub/i386-pc/* /boot/grub/
160 # finally install grub
162 sed -i "s/^# groot=.*/# groot=(${GROOT})/g" /boot/grub/menu.lst
163 sed -i "s|^# kopt=root=.*|# kopt=root=${TARGET} ro|g" /boot/grub/menu.lst
164 # not sure why savedefault does not work for me; any ideas?
165 sed -i "s/^savedefault.*/# &/g" /boot/grub/menu.lst
169 # make sure we don't have any running processes left
170 for service in ssh mdadm mdadm-raid ; do
171 [ -x "/etc/init.d/$service" ] && "/etc/init.d/$service" stop
174 # unmount all filesystems in chroot, make sure nothing is left...
175 umount -a 1>/dev/null 2>/dev/null || true
176 umount /proc 1>/dev/null 2>/dev/null || true
177 umount /proc 1>/dev/null 2>/dev/null || true
178 umount -a 1>/dev/null 2>/dev/null || true
180 # finally exit the chroot
181 echo "Finished chroot installation, exiting."
184 ## END OF FILE #################################################################