Various improvements for Gentoo install script

This commit is contained in:
Stefan Reimer 2012-04-11 10:14:38 -07:00
parent eae044126d
commit 053a4d9b25

View File

@ -9,10 +9,13 @@
#=============================================================================== #===============================================================================
GENTOO_MIRROR="http://gentoo.arcticnetwork.ca" GENTOO_MIRROR="http://gentoo.arcticnetwork.ca"
LOCAL_CACHE=/var/tmp LOCAL_CACHE=/var/tmp
IMAGE_ROOT=/opt/gentoo IMAGE_ROOT=/mnt/gentoo
# Import certain values from host config
_PORTDIR=$(. /etc/make.conf && echo $PORTDIR)
PORTDIR=${_PORTDIR:-/usr/portage}
set -o nounset set -o nounset
set -x
die() { die() {
echo $@ echo $@
@ -91,26 +94,21 @@ bootstrap() {
fi fi
STAGE_TARBALL=${GENTOO_MIRROR}/releases/${STAGE_ARCH}/autobuilds/$(curl -s ${LATEST_STAGE_FILE} | grep -v "^#" | head -n 1) STAGE_TARBALL=${GENTOO_MIRROR}/releases/${STAGE_ARCH}/autobuilds/$(curl -s ${LATEST_STAGE_FILE} | grep -v "^#" | head -n 1)
PORTAGE_SNAPSHOT="${GENTOO_MIRROR}/snapshots/portage-latest.tar.bz2"
[ -d ${ROOT_FS} ] || die "${ROOT_FS} does not exists" [ -d ${ROOT_FS} ] || die "${ROOT_FS} does not exists"
[ -w ${ROOT_FS} ] || die "${ROOT_FS} isn't writable" [ -w ${ROOT_FS} ] || die "${ROOT_FS} isn't writable"
# install stage 3 # install stage 3
cd ${ROOT_FS} cd ${ROOT_FS}
if [ ! -d "usr" ] ; then if [ -d "usr" ] ; then
echo "There seems to be already files in ${ROOT_FS} !"
echo "Press Ctrl+c to abort..."
read
fi
fetch_file "${STAGE_TARBALL}" "${STAGE_TARBALL}.DIGESTS" fetch_file "${STAGE_TARBALL}" "${STAGE_TARBALL}.DIGESTS"
tar jxpf stage3*.bz2 || die "Extracting stage file failed" tar jxpf $(basename ${STAGE_TARBALL}) || die "Extracting stage file failed"
rm -f stage3*.bz2 rm -f $(basename ${STAGE_TARBALL})
fi
# TODO - bind ro mount local portage tree
# install latest portage snapshot
if [ ! -d "usr/portage" ] ; then
fetch_file "${PORTAGE_SNAPSHOT}" "${PORTAGE_SNAPSHOT}.md5sum"
tar jxf portage-latest.tar.bz2 -C "${ROOT_FS}/usr" || die "Extracting portage snapshot failed"
rm -f portage-latest.tar.bz2
fi
} }
@ -118,6 +116,19 @@ bootstrap() {
setup_chroot() { setup_chroot() {
local ROOT_FS=$1 local ROOT_FS=$1
PORTAGE_SNAPSHOT="${GENTOO_MIRROR}/snapshots/portage-latest.tar.bz2"
if [ ${BIND_PORTAGE} = 1 ]; then
mkdir -p usr/portage
mount --bind ${PORTDIR} ${ROOT_FS}/usr/portage || die "Error mounting ${PORTDIR}"
else
# install latest portage snapshot
if [ ! -d "usr/portage" ] ; then
fetch_file "${PORTAGE_SNAPSHOT}" "${PORTAGE_SNAPSHOT}.md5sum"
tar jxf portage-latest.tar.bz2 -C "${ROOT_FS}/usr" || die "Extracting portage snapshot failed"
rm -f portage-latest.tar.bz2
fi
fi
# resolve.conf # resolve.conf
cp -L /etc/resolv.conf ${ROOT_FS}/etc/resolv.conf || die "Can't copy resolv.conf" cp -L /etc/resolv.conf ${ROOT_FS}/etc/resolv.conf || die "Can't copy resolv.conf"
@ -132,6 +143,8 @@ setup_chroot() {
# make.conf # make.conf
# etc/portage/* # etc/portage/*
echo "Done :D ... take a look around, any key to end"
read
} }
@ -139,6 +152,10 @@ setup_chroot() {
cleanup() { cleanup() {
local ROOT_FS=$1 local ROOT_FS=$1
umount ${ROOT_FS}/dev ${ROOT_FS}/sys ${ROOT_FS}/proc umount ${ROOT_FS}/dev ${ROOT_FS}/sys ${ROOT_FS}/proc
if [ ${BIND_PORTAGE} = 1 ]; then
umount ${ROOT_FS}/usr/portage
fi
} }
@ -154,6 +171,9 @@ OPTIONS:
-a arch, either i686 or x86_64, defaults to uname -m -a arch, either i686 or x86_64, defaults to uname -m
-p profile, either hardened or hardened-no-multilib or server(default) -p profile, either hardened or hardened-no-multilib or server(default)
-t The timezone to use, default to GMT -t The timezone to use, default to GMT
-r chroot location, default /mnt/gentoo
-c local cache, default /var/tmp
-b bind mount host portage tree instead of installing portage inside chroot
-v Verbose -v Verbose
EOF EOF
} }
@ -161,15 +181,20 @@ EOF
# Do some sanity checks first # Do some sanity checks first
if [ "$(id -u)" != "0" ]; then if [ "$(id -u)" != "0" ]; then
die "Sorry, but we need root permissions!" die "Sorry, but we need root permissions to create DEVICE nodes etc.!"
fi fi
while getopts ":a:p:t:vh" OPTIONS; do VERBOSE=0
BIND_PORTAGE=0
while getopts ":a:p:t:r:c:bvh" OPTIONS; do
case $OPTIONS in case $OPTIONS in
a ) ARCH=$OPTARG;; a ) ARCH=$OPTARG;;
p ) PROFILE=$OPTARG;; p ) PROFILE=$OPTARG;;
t ) TIMEZONE=$OPTARG;; t ) TIMEZONE=$OPTARG;;
v ) VERBOSE=1;; v ) VERBOSE=1;;
b ) BIND_PORTAGE=1;;
r ) IMAGE_ROOT=$OPTARG;;
c ) LOCAL_CACHE=$OPTARG;;
? ) ? )
usage usage
exit exit
@ -181,6 +206,10 @@ ARCH=${ARCH-"$(uname -m)"}
PROFILE=${PROFILE="server"} PROFILE=${PROFILE="server"}
TIMEZONE=${TIMEZONE-"GMT"} TIMEZONE=${TIMEZONE-"GMT"}
if [ ${VERBOSE} = 1 ]; then
set -x
fi
bootstrap ${IMAGE_ROOT} ${PROFILE} ${ARCH} bootstrap ${IMAGE_ROOT} ${PROFILE} ${ARCH}
# From here make sure we don't leave stuff around # From here make sure we don't leave stuff around