2007-09-23 08:04:46 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
# lh_chroot_hacks(1) - execute hacks in chroot
|
2008-03-06 14:43:00 -01:00
|
|
|
# Copyright (C) 2006-2008 Daniel Baumann <daniel@debian.org>
|
2007-09-23 08:04:48 +00:00
|
|
|
#
|
|
|
|
# live-helper comes with ABSOLUTELY NO WARRANTY; for details see COPYING.
|
|
|
|
# This is free software, and you are welcome to redistribute it
|
|
|
|
# under certain conditions; see COPYING for details.
|
2007-09-23 08:04:46 +00:00
|
|
|
|
|
|
|
set -e
|
|
|
|
|
2007-09-23 08:05:11 +00:00
|
|
|
# Including common functions
|
|
|
|
LH_BASE="${LH_BASE:-/usr/share/live-helper}"
|
|
|
|
|
|
|
|
for FUNCTION in "${LH_BASE}"/functions/*.sh
|
2007-09-23 08:04:46 +00:00
|
|
|
do
|
2007-09-23 08:05:11 +00:00
|
|
|
. "${FUNCTION}"
|
2007-09-23 08:04:46 +00:00
|
|
|
done
|
|
|
|
|
2007-09-23 08:05:11 +00:00
|
|
|
# Setting static variables
|
2007-09-23 08:04:48 +00:00
|
|
|
DESCRIPTION="execute hacks in chroot"
|
|
|
|
HELP=""
|
|
|
|
USAGE="${PROGRAM} [--force]"
|
|
|
|
|
|
|
|
Arguments "${@}"
|
|
|
|
|
2007-09-23 08:04:46 +00:00
|
|
|
# Reading configuration files
|
2008-04-07 10:10:21 +00:00
|
|
|
Read_conffile config/all config/common config/bootstrap config/chroot config/binary config/source
|
2007-09-23 08:04:46 +00:00
|
|
|
Set_defaults
|
|
|
|
|
2007-09-23 08:05:11 +00:00
|
|
|
Echo_message "Begin executing hacks..."
|
2007-09-23 08:04:49 +00:00
|
|
|
|
2007-09-23 08:04:46 +00:00
|
|
|
# Requiring stage file
|
2007-09-23 08:04:47 +00:00
|
|
|
Require_stagefile .stage/bootstrap
|
2007-09-23 08:04:46 +00:00
|
|
|
|
|
|
|
# Checking stage file
|
2007-09-23 08:04:47 +00:00
|
|
|
Check_stagefile .stage/chroot_hacks
|
2007-09-23 08:04:46 +00:00
|
|
|
|
|
|
|
# Checking lock file
|
2007-09-23 08:04:47 +00:00
|
|
|
Check_lockfile .lock
|
2007-09-23 08:04:46 +00:00
|
|
|
|
|
|
|
# Creating lock file
|
2007-09-23 08:04:47 +00:00
|
|
|
Create_lockfile .lock
|
2007-09-23 08:04:46 +00:00
|
|
|
|
2007-09-23 08:04:47 +00:00
|
|
|
# Removing udev mac caching rule
|
2008-08-27 16:08:51 +00:00
|
|
|
rm -f chroot/etc/udev/rules.d/*persistent-net.rules
|
2007-09-23 08:04:47 +00:00
|
|
|
|
2007-09-23 08:05:17 +00:00
|
|
|
case "${LH_BINARY_IMAGES}" in
|
2007-09-23 08:04:46 +00:00
|
|
|
net)
|
2007-09-23 08:04:48 +00:00
|
|
|
if [ ! -f chroot/usr/bin/smbmount ]
|
|
|
|
then
|
2008-02-21 18:03:57 -01:00
|
|
|
Apt install smbfs
|
2007-09-23 08:04:48 +00:00
|
|
|
fi
|
2007-09-23 08:04:46 +00:00
|
|
|
|
2007-09-23 08:04:47 +00:00
|
|
|
if [ ! -d chroot/etc/initramfs-tools ]
|
2007-09-23 08:04:46 +00:00
|
|
|
then
|
2007-09-23 08:04:47 +00:00
|
|
|
mkdir chroot/etc/initramfs-tools
|
2007-09-23 08:04:46 +00:00
|
|
|
fi
|
2007-09-24 06:47:42 +00:00
|
|
|
if [ ! "$(grep 'MODULES=netboot' chroot/etc/initramfs-tools/initramfs.conf)" ]
|
2007-09-23 08:04:48 +00:00
|
|
|
then
|
|
|
|
# Configuring initramfs for NFS
|
2007-09-23 08:04:47 +00:00
|
|
|
cat >> chroot/etc/initramfs-tools/initramfs.conf << EOF
|
2007-09-23 08:04:46 +00:00
|
|
|
MODULES=netboot
|
|
|
|
BOOT=nfs
|
|
|
|
NFSROOT=auto
|
|
|
|
EOF
|
2007-09-23 08:04:48 +00:00
|
|
|
fi
|
2007-09-23 08:04:46 +00:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2007-09-23 08:05:17 +00:00
|
|
|
# Remove resume
|
|
|
|
if [ "${LH_DISTRIBUTION}" = "etch" ] && [ -e /etc/initramfs-tools/conf.d/resume ]
|
|
|
|
then
|
|
|
|
rm -f /etc/initramfs-tools/conf.d/resume
|
|
|
|
fi
|
|
|
|
|
2008-03-23 03:27:21 -01:00
|
|
|
# Ensure readable permissions on initramfs. loop-aes-utils sets umask to
|
|
|
|
# protect GPG keys, which live-helper does not support.
|
|
|
|
chmod go+r chroot/boot/initrd*
|
|
|
|
|
2007-09-23 08:05:14 +00:00
|
|
|
# Remove build systems clock drift
|
|
|
|
echo "0.0 0 0.0" > chroot/etc/adjtime
|
|
|
|
|
|
|
|
# Remove cruft
|
|
|
|
rm -f chroot/boot/initrd*bak*
|
2007-11-11 21:00:43 -01:00
|
|
|
rm -f chroot/etc/apt/trusted.gpg~
|
2007-09-23 08:05:14 +00:00
|
|
|
rm -f chroot/etc/group- chroot/etc/passwd-
|
|
|
|
rm -f chroot/etc/gshadow- chroot/etc/shadow-
|
|
|
|
rm -f chroot/var/cache/debconf/*-old
|
2007-11-20 09:23:26 -01:00
|
|
|
rm -f chroot/var/cache/man/index.db
|
2007-09-23 08:05:14 +00:00
|
|
|
rm -f chroot/var/lib/dpkg/*-old
|
|
|
|
|
2007-09-23 08:04:51 +00:00
|
|
|
if [ -n "${LH_ROOT_COMMAND}" ]
|
|
|
|
then
|
2007-09-24 06:47:42 +00:00
|
|
|
${LH_ROOT_COMMAND} chown -R --quiet $(whoami):$(whoami) chroot
|
2007-09-23 08:04:51 +00:00
|
|
|
fi
|
|
|
|
|
2008-08-25 11:04:03 +00:00
|
|
|
if [ "${LH_INITRAMFS}" = "casper" ] && [ -d chroot/home/${LH_USERNAME} ]
|
2007-09-23 08:05:14 +00:00
|
|
|
then
|
2007-09-23 08:05:17 +00:00
|
|
|
chown -R --quiet 999:999 chroot/home/${LH_USERNAME}
|
2007-09-23 08:05:14 +00:00
|
|
|
fi
|
|
|
|
|
2008-03-01 12:43:47 -01:00
|
|
|
# This is a temporary hack to get rid of fstab;
|
|
|
|
# needs cleanup in live-initramfs first to proper fix.
|
|
|
|
if [ "${LH_DEBIAN_INSTALLER}" = "live" ]
|
|
|
|
then
|
|
|
|
rm -f chroot/etc/fstab
|
|
|
|
fi
|
|
|
|
|
2007-10-23 20:56:43 +00:00
|
|
|
if [ "${LH_EXPOSED_ROOT}" = "enabled" ]
|
|
|
|
then
|
|
|
|
# Make sure RW dirs exist so that the initramfs script has
|
|
|
|
# a directory in which to bind the tmpfs filesystems
|
2007-11-11 11:57:11 -01:00
|
|
|
COW_DIRECTORIES="/home /live /tmp /var/lib/live /var/lock /var/log /var/run /var/tmp /var/spool"
|
|
|
|
|
|
|
|
for DIRECTORY in ${COW_DIRECTORIES}
|
|
|
|
do
|
|
|
|
mkdir -p chroot/"${DIRECTORY}"
|
2007-10-23 20:56:43 +00:00
|
|
|
done
|
|
|
|
|
|
|
|
# Config files which need to be RW
|
2008-08-15 21:19:33 +00:00
|
|
|
COW_FILES="/etc/adjtime /etc/fstab /etc/hostname /etc/hosts /etc/live.conf /etc/network/interfaces /etc/resolv.conf /etc/udev/rules.d/*persistent-net.rules /etc/udev/rules.d/*persistent-cd.rules /etc/X11/xorg.conf"
|
2007-10-23 20:56:43 +00:00
|
|
|
|
|
|
|
# Where we will store RW config files
|
2007-11-11 11:57:11 -01:00
|
|
|
RW_DIRECTORY="/var/lib/live"
|
2007-10-23 20:56:43 +00:00
|
|
|
|
2007-11-11 11:57:11 -01:00
|
|
|
for FILE in ${COW_FILES}
|
2007-10-23 20:56:43 +00:00
|
|
|
do
|
2007-11-11 11:57:11 -01:00
|
|
|
DIRECTORY="$(dirname ${FILE})"
|
|
|
|
FILE="$(basename ${FILE})"
|
2008-01-15 06:25:29 -01:00
|
|
|
RELATIVE_PATH="$(echo ${DIRECTORY} | sed 's|[^/]\+|..|g; s|^/||g')"
|
2007-11-11 11:57:11 -01:00
|
|
|
|
2007-10-23 20:56:43 +00:00
|
|
|
# Touch files in case they don't yet exist
|
2007-11-11 11:57:11 -01:00
|
|
|
mkdir -p chroot/${DIRECTORY}
|
|
|
|
touch chroot/${DIRECTORY}/${FILE}
|
|
|
|
|
|
|
|
# Move files to the read-write directory
|
|
|
|
mkdir -p chroot/${RW_DIRECTORY}/${DIRECTORY}
|
|
|
|
mv chroot/${DIRECTORY}/${FILE} chroot/${RW_DIRECTORY}/${DIRECTORY}
|
|
|
|
|
2007-10-23 20:56:43 +00:00
|
|
|
# Create a symbolic link to RW config file
|
2007-11-11 11:57:11 -01:00
|
|
|
ln -s ${RELATIVE_PATH}/${RW_DIRECTORY}/${DIRECTORY}/${FILE} chroot/${DIRECTORY}/${FILE}
|
2007-10-23 20:56:43 +00:00
|
|
|
done
|
|
|
|
|
|
|
|
# Mount doesn't write to a symlink so use /proc/mounts instead,
|
|
|
|
# see debian bug #154438 for more info
|
2007-10-30 20:03:44 -01:00
|
|
|
rm -f chroot/etc/mtab
|
2007-10-23 20:56:43 +00:00
|
|
|
ln -s /proc/mounts chroot/etc/mtab
|
|
|
|
fi
|
|
|
|
|
2007-09-23 08:04:46 +00:00
|
|
|
# Creating stage file
|
2007-09-23 08:04:47 +00:00
|
|
|
Create_stagefile .stage/chroot_hacks
|