projects
/
grml-debootstrap.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fix use of chrootmirror
[grml-debootstrap.git]
/
chroot-script
diff --git
a/chroot-script
b/chroot-script
index
fc35e95
..
4a505ac
100644
(file)
--- a/
chroot-script
+++ b/
chroot-script
@@
-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
15:24:53
CET 2006 [mika]
+# Latest change: Fre Nov 03
23:19:29
CET 2006 [mika]
################################################################################
set -e # exit on any error
################################################################################
set -e # exit on any error
@@
-14,12
+14,18
@@
set -e # exit on any error
[ -r /proc/1 ] || mount -t proc none /proc
if [ -n "$CHROOTMIRROR" ] ; then
[ -r /proc/1 ] || mount -t proc none /proc
if [ -n "$CHROOTMIRROR" ] ; then
- echo "
$CHROOTMIRROR" >
/etc/apt/sources.list
+ echo "
deb $CHROOTMIRROR $RELEASE main contrib non-free"
/etc/apt/sources.list
fi
fi
-#if ! [ -n /etc/kernel-img.conf ] ; then
-# echo "do_initrd = Yes" > /etc/kernel-img.conf
-#fi
+if ! [ -r /etc/kernel-img.conf ] ; then
+ echo "Setting up /etc/kernel-img.conf"
+ cat > /etc/kernel-img.conf << EOF
+# Kernel Image management overrides
+# See kernel-img.conf(5) for details
+do_initrd = Yes
+do_symlinks = Yes
+EOF
+fi
# install additional packages
if [ "$PACKAGES" = 'yes' ] ; then
# install additional packages
if [ "$PACKAGES" = 'yes' ] ; then
@@
-28,7
+34,7
@@
if [ "$PACKAGES" = 'yes' ] ; then
exit 1
else
apt-get update
exit 1
else
apt-get update
- apt-get -y install $(cat /etc/debootstrap/packages)
+ apt-get -
-force-yes -
y install $(cat /etc/debootstrap/packages)
fi
fi
fi
fi
@@
-66,16
+72,36
@@
if [ -n "$TIMEZONE" ] ; then
ln -sf /usr/share/zoneinfo/$TIMEZONE /etc/localtime
fi
ln -sf /usr/share/zoneinfo/$TIMEZONE /etc/localtime
fi
-# set up /etc/fstab if file is UNCONFIGURED
-if grep -q UNCONFIGURED /etc/fstab ; then
+function createfstab(){
echo "Setting up /etc/fstab"
cat > /etc/fstab << EOF
$TARGET / auto defaults,errors=remount-ro 0 1
echo "Setting up /etc/fstab"
cat > /etc/fstab << EOF
$TARGET / auto defaults,errors=remount-ro 0 1
-
sysfs /sys sysfs auto
0 0
+
/sys /sys sysfs rw,nosuid,nodev,noexec
0 0
proc /proc proc defaults 0 0
proc /proc proc defaults 0 0
-# /dev/sda2 none swap sw 0 0
/dev/cdrom /mnt/cdrom0 iso9660 ro,user,noauto 0 0
/dev/cdrom /mnt/cdrom0 iso9660 ro,user,noauto 0 0
+# some other examples:
+# /dev/sda2 none swap sw 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
EOF
EOF
+}
+
+# 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
+if [ -n "$HOSTNAME" ] ; then
+ echo "Setting hostname to ${HOSTNAME}."
+ echo "$HOSTNAME" > /etc/hostname
fi
# create default devices
fi
# create default devices
@@
-112,8
+138,18
@@
if [ -n "$GROOT" ] ; then
sed -i "s/^savedefault.*/# &/g" /boot/grub/menu.lst
update-grub -y
sed -i "s/^savedefault.*/# &/g" /boot/grub/menu.lst
update-grub -y
+ if [ -z "$MBR" ] ; then
+ echo "Notice: \$MBR not set, will not install grub therefor."
+ else
+ cp /proc/mounts /etc/mtab
+ grub-install "$MBR"
+ rm /etc/mtab
+ fi
fi
fi
+# make sure we don't have any running processes left
+[ -x /etc/init.d/ssh ] && /etc/init.d/ssh stop
+
# unmount all filesystems in chroot, make sure nothing is left...
umount -a 1>/dev/null 2>/dev/null || true
umount /proc 1>/dev/null 2>/dev/null || true
# unmount all filesystems in chroot, make sure nothing is left...
umount -a 1>/dev/null 2>/dev/null || true
umount /proc 1>/dev/null 2>/dev/null || true