* Add (extra-)override parsing to the preinstalled pool to make sure

we get task headers in the local pool for tasksel (LP: #819899)
* Move temp directories under config so they get cleaned properly
* Invoke apt-get update once with only the sources.list fragment
  for the local archive, so our package/task selection more closely
  mimics the CD experience (LP: #985258, #985737, #985280, #819900)
* Write out a standard sources.list entry for preinstalled systems
  that's similar to the one generated by installers (LP: #985291)
ubuntu/precise 2.65
Adam Conrad 13 years ago
parent b83c095cf4
commit b0b6e0d9e5

13
debian/changelog vendored

@ -1,3 +1,16 @@
livecd-rootfs (2.65) precise; urgency=low
* Add (extra-)override parsing to the preinstalled pool to make sure
we get task headers in the local pool for tasksel (LP: #819899)
* Move temp directories under config so they get cleaned properly
* Invoke apt-get update once with only the sources.list fragment
for the local archive, so our package/task selection more closely
mimics the CD experience (LP: #985258, #985737, #985280, #819900)
* Write out a standard sources.list entry for preinstalled systems
that's similar to the one generated by installers (LP: #985291)
-- Adam Conrad <adconrad@ubuntu.com> Fri, 20 Apr 2012 00:29:38 -0600
livecd-rootfs (2.64) precise; urgency=low livecd-rootfs (2.64) precise; urgency=low
* Add minimal and standard tasks to Ubuntu Studio images (LP: #962585). * Add minimal and standard tasks to Ubuntu Studio images (LP: #962585).

@ -12,16 +12,17 @@ Read_conffiles config/all config/common config/bootstrap config/chroot config/bi
Set_defaults Set_defaults
( (
if [ -d gnupg ]; then if [ -d config/gnupg ]; then
cat << @@EOF > gnupg/NEWKEY cat << @@EOF > config/gnupg/NEWKEY
Key-Type: DSA Key-Type: DSA
Key-Length: 1024 Key-Length: 1024
Key-Usage: sign
Name-Real: Ubuntu Local Archive One-Time Signing Key Name-Real: Ubuntu Local Archive One-Time Signing Key
Name-Email: cdimage@ubuntu.com Name-Email: cdimage@ubuntu.com
Expire-Date: 0 Expire-Date: 0
@@EOF @@EOF
gpg --home gnupg --gen-key --batch < gnupg/NEWKEY \ gpg --home config/gnupg --gen-key --batch < config/gnupg/NEWKEY \
> gnupg/generate.log 2>&1 & > config/gnupg/generate.log 2>&1 &
GPG_PROCESS=$! GPG_PROCESS=$!
fi fi
@ -49,10 +50,147 @@ EOF
lb chroot "$@" lb chroot "$@"
if [ -f config/oem-config-preinstalled ]; then
# This is cargo-culted almost verbatim (with some syntax changes for
# preinstalled being slightly different in what it doesn't ask) from
# debian-installer's apt-setup:
codename=$LB_DISTRIBUTION
file="chroot/etc/apt/sources.list"
dists="main"
alldists="main"
if echo "$LB_PARENT_ARCHIVE_AREAS" | grep -q restricted; then
dists="$dists restricted"
alldists="$alldists restricted"
fi
if echo "$LB_PARENT_ARCHIVE_AREAS" | grep -q universe; then
UNIVERSE=true
else
UNIVERSE=false
fi
if echo "$LB_PARENT_ARCHIVE_AREAS" | grep -q multiverse; then
MULTIVERSE=true
else
MULTIVERSE=false
fi
cat > $file <<EOF
# See http://help.ubuntu.com/community/UpgradeNotes for how to upgrade to
# newer versions of the distribution.
deb $LB_PARENT_MIRROR_BINARY $codename $dists
deb-src $LB_PARENT_MIRROR_BINARY $codename $dists
## Major bug fix updates produced after the final release of the
## distribution.
deb $LB_PARENT_MIRROR_BINARY $codename-updates $dists
deb-src $LB_PARENT_MIRROR_BINARY $codename-updates $dists
EOF
# Even if universe isn't enabled, we write example lines for it.
echo >> $file
if [ "$UNIVERSE" = true ]; then
alldists="$alldists universe"
COMMENT=
else
cat >> $file <<EOF
## Uncomment the following two lines to add software from the 'universe'
## repository.
EOF
COMMENT='# '
fi
cat >> $file <<EOF
## N.B. software from this repository is ENTIRELY UNSUPPORTED by the Ubuntu
## team. Also, please note that software in universe WILL NOT receive any
## review or updates from the Ubuntu security team.
${COMMENT}deb $LB_PARENT_MIRROR_BINARY $codename universe
${COMMENT}deb-src $LB_PARENT_MIRROR_BINARY $codename universe
${COMMENT}deb $LB_PARENT_MIRROR_BINARY $codename-updates universe
${COMMENT}deb-src $LB_PARENT_MIRROR_BINARY $codename-updates universe
EOF
# Multiverse is different, don't write anything unless enabled.
if [ "$MULTIVERSE" = true ]; then
alldists="$alldists multiverse"
cat >> $file <<EOF
## N.B. software from this repository is ENTIRELY UNSUPPORTED by the Ubuntu
## team, and may not be under a free licence. Please satisfy yourself as to
## your rights to use the software. Also, please note that software in
## multiverse WILL NOT receive any review or updates from the Ubuntu
## security team.
deb $LB_PARENT_MIRROR_BINARY $codename multiverse
deb-src $LB_PARENT_MIRROR_BINARY $codename multiverse
deb $LB_PARENT_MIRROR_BINARY $codename-updates multiverse
deb-src $LB_PARENT_MIRROR_BINARY $codename-updates multiverse
EOF
fi
cat >> $file <<EOF
## N.B. software from this repository may not have been tested as
## extensively as that contained in the main release, although it includes
## newer versions of some applications which may provide useful features.
## Also, please note that software in backports WILL NOT receive any review
## or updates from the Ubuntu security team.
# deb $LB_PARENT_MIRROR_BINARY $codename-backports $alldists
# deb-src $LB_PARENT_MIRROR_BINARY $codename-backports $alldists
EOF
cat >> $file <<EOF
deb $LB_PARENT_MIRROR_BINARY $codename-security $dists
deb-src $LB_PARENT_MIRROR_BINARY $codename-security $dists
EOF
# Security sources for Ubuntu universe; not used much, but e.g. unsupported
# binary packages from a supported source package will end up here.
if [ "$UNIVERSE" = true ]; then
COMMENT=
else
COMMENT='# '
fi
cat >> $file <<EOF
${COMMENT}deb $LB_PARENT_MIRROR_BINARY $codename-security universe
${COMMENT}deb-src $LB_PARENT_MIRROR_BINARY $codename-security universe
EOF
# Security sources for Ubuntu multiverse, with the same caveats as for
# universe.
if [ "$MULTIVERSE" = true ]; then
COMMENT=
else
COMMENT='# '
fi
cat >> $file <<EOF
${COMMENT}deb $LB_PARENT_MIRROR_BINARY $codename-security multiverse
${COMMENT}deb-src $LB_PARENT_MIRROR_BINARY $codename-security multiverse
EOF
fi
if [ -d chroot/var/lib/preinstalled-pool ]; then if [ -d chroot/var/lib/preinstalled-pool ]; then
(cd chroot/var/lib/preinstalled-pool/ && apt-ftparchive packages . > Packages) cat > config/indices/apt.conf <<-EOF
bzip2 -9 -c chroot/var/lib/preinstalled-pool/Packages \ Dir {
> chroot/var/lib/preinstalled-pool/Packages.bz2 ArchiveDir "chroot/var/lib/preinstalled-pool";
OverrideDir "config/indices";
CacheDir "config/indices";
}
Default { Packages::Compress ". bzip2"; }
TreeDefault { Directory "pool"; }
Tree "dists/$LB_DISTRIBUTION"
{
Sections "$LB_PARENT_ARCHIVE_AREAS";
Architectures "$LB_ARCHITECTURES";
BinOverride "override.$LB_DISTRIBUTION.\$(SECTION)";
ExtraOverride "override.$LB_DISTRIBUTION.extra.\$(SECTION)";
Contents " ";
}
EOF
for component in $LB_PARENT_ARCHIVE_AREAS; do
mkdir -p chroot/var/lib/preinstalled-pool/dists/$LB_DISTRIBUTION/$component/binary-$LB_ARCHITECTURES
done
apt-ftparchive generate config/indices/apt.conf
cat << @@EOF > chroot/etc/apt/sources.list.preinstall cat << @@EOF > chroot/etc/apt/sources.list.preinstall
# This is a sources.list entry for a small pool of packages # This is a sources.list entry for a small pool of packages
# provided on your preinstalled filesystem for your convenience. # provided on your preinstalled filesystem for your convenience.
@ -61,14 +199,12 @@ EOF
# it references, should you want to save disk space and fetch the # it references, should you want to save disk space and fetch the
# packages remotely instead. # packages remotely instead.
# #
deb file:/var/lib/preinstalled-pool/ ./ deb file:/var/lib/preinstalled-pool/ $LB_DISTRIBUTION $LB_PARENT_ARCHIVE_AREAS
# #
@@EOF @@EOF
cat chroot/etc/apt/sources.list.preinstall chroot/etc/apt/sources.list \ cp chroot/etc/apt/sources.list chroot/etc/apt/sources.list.orig
> chroot/etc/apt/sources.list.new cp chroot/etc/apt/sources.list.preinstall chroot/etc/apt/sources.list
mv chroot/etc/apt/sources.list.new chroot/etc/apt/sources.list
rm chroot/etc/apt/sources.list.preinstall
echo "Waiting on gnupg ("$GPG_PROCESS") to finish generating a key." echo "Waiting on gnupg ("$GPG_PROCESS") to finish generating a key."
wait $GPG_PROCESS wait $GPG_PROCESS
@ -84,13 +220,21 @@ deb file:/var/lib/preinstalled-pool/ ./
-o APT::FTPArchive::Release::Version=$R_VERSION \ -o APT::FTPArchive::Release::Version=$R_VERSION \
-o APT::FTPArchive::Release::Codename=$R_CODENAME \ -o APT::FTPArchive::Release::Codename=$R_CODENAME \
-o APT::FTPArchive::Release::Description="$R_ORIGIN $R_PRETTYNAME Local" \ -o APT::FTPArchive::Release::Description="$R_ORIGIN $R_PRETTYNAME Local" \
release chroot/var/lib/preinstalled-pool/ > gnupg/Release release chroot/var/lib/preinstalled-pool/dists/$R_CODENAME/ \
> config/gnupg/Release
gpg --home gnupg --detach-sign --armor gnupg/Release
mv gnupg/Release chroot/var/lib/preinstalled-pool/Release gpg --home config/gnupg --detach-sign --armor config/gnupg/Release
mv gnupg/Release.asc chroot/var/lib/preinstalled-pool/Release.gpg mv config/gnupg/Release \
apt-key --keyring chroot/etc/apt/trusted.gpg add gnupg/pubring.gpg chroot/var/lib/preinstalled-pool/dists/$R_CODENAME/Release
rm chroot/var/lib/preinstalled-pool/Packages mv config/gnupg/Release.asc \
chroot/var/lib/preinstalled-pool/dists/$R_CODENAME/Release.gpg
apt-key --keyring chroot/etc/apt/trusted.gpg add config/gnupg/pubring.gpg
find chroot/var/lib/preinstalled-pool/ -name Packages | xargs rm
Chroot chroot "apt-get update"
cat chroot/etc/apt/sources.list.preinstall chroot/etc/apt/sources.list.orig \
> chroot/etc/apt/sources.list
rm chroot/etc/apt/sources.list.preinstall chroot/etc/apt/sources.list.orig
fi fi
echo "===== Checking size of /usr/share/doc =====" echo "===== Checking size of /usr/share/doc ====="

@ -95,6 +95,9 @@ case $IMAGEFORMAT in
esac esac
if [ "$PREINSTALLED" = "true" ] && [ "$SUBPROJECT" != "wubi" ]; then if [ "$PREINSTALLED" = "true" ] && [ "$SUBPROJECT" != "wubi" ]; then
# This is an oem-config preinstalled image, touch a random file that
# we can refer back to during build, cause that's wildly hackish
touch config/oem-config-preinstalled
case $PROJECT in case $PROJECT in
kubuntu*) kubuntu*)
add_package live oem-config-kde ubiquity-frontend-kde add_package live oem-config-kde ubiquity-frontend-kde
@ -192,6 +195,7 @@ case $PROJECT in
ubuntu-server) ubuntu-server)
add_task install minimal standard add_task install minimal standard
COMPONENTS='main'
PREINSTALL_POOL_SEEDS='server-ship' PREINSTALL_POOL_SEEDS='server-ship'
;; ;;
@ -249,7 +253,6 @@ case $ARCH in
add_package install zram-config add_package install zram-config
add_package live ac100-tarball-installer add_package live ac100-tarball-installer
BINARY_REMOVE_LINUX=false BINARY_REMOVE_LINUX=false
PREINSTALL_POOL_SEEDS=""
;; ;;
esac esac
;; ;;
@ -317,7 +320,7 @@ add_inheritance () {
} }
expand_inheritance () { expand_inheritance () {
for seed in $(grep "^$1:" germinate-output/structure | cut -d: -f2); do for seed in $(grep "^$1:" config/germinate-output/structure | cut -d: -f2); do
expand_inheritance "$seed" expand_inheritance "$seed"
done done
add_inheritance "$1" add_inheritance "$1"
@ -331,7 +334,7 @@ inheritance () {
if [ "$PREINSTALLED" = "true" ]; then if [ "$PREINSTALLED" = "true" ]; then
if [ -n "$PREINSTALL_POOL_SEEDS" ]; then if [ -n "$PREINSTALL_POOL_SEEDS" ]; then
rm -rf germinate-output && mkdir germinate-output mkdir -p config/germinate-output
case $PROJECT in case $PROJECT in
kubuntu-active*) kubuntu-active*)
SEED=kubuntu-active.$SUITE SEED=kubuntu-active.$SUITE
@ -346,7 +349,7 @@ if [ "$PREINSTALLED" = "true" ]; then
SEED=ubuntu.$SUITE SEED=ubuntu.$SUITE
;; ;;
esac esac
(cd germinate-output && germinate --no-rdepends --no-installer \ (cd config/germinate-output && germinate --no-rdepends --no-installer \
-S $SEEDMIRROR -m $MIRROR -d $SUITE -s $SEED \ -S $SEEDMIRROR -m $MIRROR -d $SUITE -s $SEED \
${COMPONENTS:+-c "$COMPONENTS"} -a $ARCH) ${COMPONENTS:+-c "$COMPONENTS"} -a $ARCH)
@ -371,15 +374,22 @@ if [ "$PREINSTALLED" = "true" ]; then
for i in $PPS_EXP; do for i in $PPS_EXP; do
PREINSTALL_POOL="$PREINSTALL_POOL $(awk '{print $1}' \ PREINSTALL_POOL="$PREINSTALL_POOL $(awk '{print $1}' \
germinate-output/$i | egrep -v '^-|^Package|^\|' | tr '\n' ' ')" config/germinate-output/$i | egrep -v '^-|^Package|^\|' | tr '\n' ' ')"
done done
fi fi
if [ -n "$PREINSTALL_POOL" ]; then if [ -n "$PREINSTALL_POOL" ]; then
rm -rf gnupg && mkdir gnupg mkdir -p config/gnupg
mkdir -p config/indices
for component in $COMPONENTS; do
(cd config/indices && \
wget $MIRROR/indices/override.$SUITE.$component && \
wget $MIRROR/indices/override.$SUITE.extra.$component \
)
done
PREINSTALL_POOL_HOOK=config/chroot_local-hooks/preinstall-pool.sh PREINSTALL_POOL_HOOK=config/chroot_local-hooks/preinstall-pool.sh
echo "#! /bin/sh" > $PREINSTALL_POOL_HOOK echo "#! /bin/sh" > $PREINSTALL_POOL_HOOK
echo "mkdir -p /var/lib/preinstalled-pool/" >> $PREINSTALL_POOL_HOOK echo "mkdir -p /var/lib/preinstalled-pool/pool/" >> $PREINSTALL_POOL_HOOK
echo "cd /var/lib/preinstalled-pool/" >> $PREINSTALL_POOL_HOOK echo "cd /var/lib/preinstalled-pool/pool/" >> $PREINSTALL_POOL_HOOK
echo "apt-get -y download $PREINSTALL_POOL" >> $PREINSTALL_POOL_HOOK echo "apt-get -y download $PREINSTALL_POOL" >> $PREINSTALL_POOL_HOOK
fi fi
fi fi

Loading…
Cancel
Save