mirror of
https://git.launchpad.net/livecd-rootfs
synced 2025-10-23 21:14:09 +00:00
Import patches-unapplied version 2.491 to ubuntu/bionic-proposed
Imported using git-ubuntu import. Changelog parent: 5afe03acbb5cdd2bd7a63f64d17574940ce6d298 New changelog entries: * Support seeding of snaps, as emitted by germinate >= 2.27.
This commit is contained in:
parent
5afe03acbb
commit
f6d60551d8
6
debian/changelog
vendored
6
debian/changelog
vendored
@ -1,3 +1,9 @@
|
|||||||
|
livecd-rootfs (2.491) bionic; urgency=medium
|
||||||
|
|
||||||
|
* Support seeding of snaps, as emitted by germinate >= 2.27.
|
||||||
|
|
||||||
|
-- Iain Lane <iain.lane@canonical.com> Tue, 30 Jan 2018 11:20:28 +0000
|
||||||
|
|
||||||
livecd-rootfs (2.490) bionic; urgency=medium
|
livecd-rootfs (2.490) bionic; urgency=medium
|
||||||
|
|
||||||
* ubuntu-cpc: Initramfs compression should match default for
|
* ubuntu-cpc: Initramfs compression should match default for
|
||||||
|
@ -43,7 +43,7 @@ preinstall_snaps() {
|
|||||||
chroot chroot sh -c "
|
chroot chroot sh -c "
|
||||||
set -x;
|
set -x;
|
||||||
cd /var/lib/snapd/seed;
|
cd /var/lib/snapd/seed;
|
||||||
SNAPPY_STORE_NO_CDN=1 snap download \"$snap\""
|
SNAPPY_STORE_NO_CDN=1 snap download \"${snap%/*}\""
|
||||||
done
|
done
|
||||||
lb chroot_resolv remove
|
lb chroot_resolv remove
|
||||||
|
|
||||||
@ -56,12 +56,14 @@ snaps:
|
|||||||
file: ${CORE_SNAP}
|
file: ${CORE_SNAP}
|
||||||
EOF
|
EOF
|
||||||
for snap in "$@"; do
|
for snap in "$@"; do
|
||||||
|
snap_name=${snap%/*}
|
||||||
cat <<EOF >> chroot/var/lib/snapd/seed/seed.yaml
|
cat <<EOF >> chroot/var/lib/snapd/seed/seed.yaml
|
||||||
- name: $snap
|
- name: ${snap_name}
|
||||||
channel: stable
|
channel: stable
|
||||||
EOF
|
EOF
|
||||||
|
case ${snap} in */classic) echo " classic: true" >> chroot/var/lib/snapd/seed/seed.yaml;; esac
|
||||||
echo -n " file: " >> chroot/var/lib/snapd/seed/seed.yaml
|
echo -n " file: " >> chroot/var/lib/snapd/seed/seed.yaml
|
||||||
(cd chroot/var/lib/snapd/seed; ls -1 ${snap}_*.snap) \
|
(cd chroot/var/lib/snapd/seed; ls -1 ${snap_name}_*.snap) \
|
||||||
>> chroot/var/lib/snapd/seed/seed.yaml
|
>> chroot/var/lib/snapd/seed/seed.yaml
|
||||||
done
|
done
|
||||||
|
|
||||||
@ -368,41 +370,34 @@ deb file:/var/lib/preinstalled-pool/ $LB_DISTRIBUTION $LB_PARENT_ARCHIVE_AREAS
|
|||||||
rm chroot/etc/apt/sources.list.preinstall chroot/etc/apt/sources.list.orig
|
rm chroot/etc/apt/sources.list.preinstall chroot/etc/apt/sources.list.orig
|
||||||
fi
|
fi
|
||||||
case $PROJECT:$SUBPROJECT in
|
case $PROJECT:$SUBPROJECT in
|
||||||
ubuntu-server:live|ubuntu-mate:*)
|
*)
|
||||||
assertions_dir="chroot/var/lib/snapd/seed/assertions"
|
if [ -e "config/seeded-snaps" ]; then
|
||||||
model_assertion="$assertions_dir/generic-classic.model"
|
assertions_dir="chroot/var/lib/snapd/seed/assertions"
|
||||||
account_key_assertion="$assertions_dir/generic.account-key"
|
model_assertion="$assertions_dir/generic-classic.model"
|
||||||
account_assertion="$assertions_dir/generic.account"
|
account_key_assertion="$assertions_dir/generic.account-key"
|
||||||
|
account_assertion="$assertions_dir/generic.account"
|
||||||
|
|
||||||
mkdir -p "$assertions_dir"
|
mkdir -p "$assertions_dir"
|
||||||
snap known --remote model series=16 \
|
snap known --remote model series=16 \
|
||||||
model=generic-classic brand-id=generic \
|
model=generic-classic brand-id=generic \
|
||||||
> "$model_assertion"
|
> "$model_assertion"
|
||||||
account_key=$(sed -n -e's/sign-key-sha3-384: //p' \
|
account_key=$(sed -n -e's/sign-key-sha3-384: //p' \
|
||||||
< "$model_assertion")
|
< "$model_assertion")
|
||||||
|
|
||||||
snap known --remote account-key \
|
snap known --remote account-key \
|
||||||
public-key-sha3-384="$account_key" \
|
public-key-sha3-384="$account_key" \
|
||||||
> "$account_key_assertion"
|
> "$account_key_assertion"
|
||||||
account=$(sed -n -e's/account-id: //p' \
|
account=$(sed -n -e's/account-id: //p' \
|
||||||
< "$account_key_assertion")
|
< "$account_key_assertion")
|
||||||
|
|
||||||
snap known --remote account account-id=generic \
|
snap known --remote account account-id=generic \
|
||||||
> "$account_assertion"
|
> "$account_assertion"
|
||||||
|
snap_list=$(cat config/seeded-snaps)
|
||||||
|
preinstall_snaps $snap_list
|
||||||
|
fi
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# FIXME: this should not be a hard-coded list in this script; this
|
|
||||||
# is an interim solution for 17.10.
|
|
||||||
case $PROJECT:$SUBPROJECT in
|
|
||||||
ubuntu-mate:*)
|
|
||||||
SNAP_LIST=pulsemixer
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
if [ -n "$SNAP_LIST" ]; then
|
|
||||||
preinstall_snaps $SNAP_LIST
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$PROJECT" = "ubuntu-touch" ] || [ "$PROJECT" = "ubuntu-touch-custom" ]; then
|
if [ "$PROJECT" = "ubuntu-touch" ] || [ "$PROJECT" = "ubuntu-touch-custom" ]; then
|
||||||
if [ "$ARCH" = "armhf" ]; then
|
if [ "$ARCH" = "armhf" ]; then
|
||||||
INFO_DESC="$(lsb_release -d -s)"
|
INFO_DESC="$(lsb_release -d -s)"
|
||||||
|
@ -5,7 +5,8 @@ rm -rf config
|
|||||||
|
|
||||||
echo "Building on $(hostname --fqdn)"
|
echo "Building on $(hostname --fqdn)"
|
||||||
|
|
||||||
SEEDMIRROR=http://people.canonical.com/~ubuntu-archive/seeds/
|
SEEDMIRROR=http://people.canonical.com/~ubuntu-archive/~laney/seeds/
|
||||||
|
MIRROR=http://raleigh/mirrors/ubuntu/
|
||||||
if [ -z "$MIRROR" ]; then
|
if [ -z "$MIRROR" ]; then
|
||||||
case $(hostname --fqdn) in
|
case $(hostname --fqdn) in
|
||||||
bld-*.mmjgroup.com) ;;
|
bld-*.mmjgroup.com) ;;
|
||||||
@ -254,6 +255,68 @@ if [ "${SUBPROJECT:-}" = minimized ]; then
|
|||||||
OPTS="${OPTS:+$OPTS }--bootstrap-flavour=minimal --linux-packages=linux-image"
|
OPTS="${OPTS:+$OPTS }--bootstrap-flavour=minimal --linux-packages=linux-image"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# cribbed from cdimage, perhaps this should be a small helper script in germinate?
|
||||||
|
add_inheritance () {
|
||||||
|
case " $inherit " in
|
||||||
|
*" $1 "*)
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
inherit="${inherit:+$inherit }$1"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
expand_inheritance () {
|
||||||
|
for seed in $(grep "^$1:" config/germinate-output/structure | cut -d: -f2); do
|
||||||
|
expand_inheritance "$seed"
|
||||||
|
done
|
||||||
|
add_inheritance "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
inheritance () {
|
||||||
|
inherit=
|
||||||
|
expand_inheritance "$1"
|
||||||
|
echo "$inherit"
|
||||||
|
}
|
||||||
|
|
||||||
|
mkdir -p config/germinate-output
|
||||||
|
case $PROJECT in
|
||||||
|
kubuntu-active*)
|
||||||
|
SEED=kubuntu-active.$SUITE
|
||||||
|
;;
|
||||||
|
kubuntu*)
|
||||||
|
SEED=kubuntu.$SUITE
|
||||||
|
;;
|
||||||
|
xubuntu*)
|
||||||
|
SEED=xubuntu.$SUITE
|
||||||
|
;;
|
||||||
|
ubuntu-mate*)
|
||||||
|
SEED=ubuntu-mate.$SUITE
|
||||||
|
;;
|
||||||
|
lubuntu*)
|
||||||
|
SEED=lubuntu.$SUITE
|
||||||
|
;;
|
||||||
|
ubuntu-budgie*)
|
||||||
|
SEED=ubuntu-budgie.$SUITE
|
||||||
|
;;
|
||||||
|
ubuntukylin*)
|
||||||
|
SEED=ubuntukylin.$SUITE
|
||||||
|
;;
|
||||||
|
ubuntustudio*)
|
||||||
|
SEED=ubuntustudio.$SUITE
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
SEED=ubuntu.$SUITE
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if ! [ -e config/germinate-output/structure ]; then
|
||||||
|
echo "Running germinate..."
|
||||||
|
(cd config/germinate-output && germinate --no-rdepends --no-installer \
|
||||||
|
-S $SEEDMIRROR -m $MIRROR -d $SUITE -s $SEED \
|
||||||
|
${COMPONENTS:+-c "$COMPONENTS"} -a $ARCH)
|
||||||
|
fi
|
||||||
|
|
||||||
case $PROJECT in
|
case $PROJECT in
|
||||||
ubuntu|ubuntu-dvd)
|
ubuntu|ubuntu-dvd)
|
||||||
add_task install minimal standard ubuntu-desktop
|
add_task install minimal standard ubuntu-desktop
|
||||||
@ -593,6 +656,32 @@ case $PROJECT in
|
|||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
# we'll expand the base seed given here according to the STRUCTURE file, and
|
||||||
|
# then look in all of the seeds found to see which snaps are seeded
|
||||||
|
case $PROJECT in
|
||||||
|
ubuntu|kubuntu*|lubuntu*|xubuntu*|ubuntu-mate*|ubuntustudio*|ubuntukylin*|ubuntu-budgie*)
|
||||||
|
BASE_SEED='desktop'
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if [ -n "${BASE_SEED}" ]; then
|
||||||
|
SEEDS_EXPANDED=$(inheritance ${BASE_SEED})
|
||||||
|
for seed in ${SEEDS_EXPANDED}; do
|
||||||
|
echo "snap: considering ${seed}"
|
||||||
|
file=config/germinate-output/${seed}.snaps
|
||||||
|
[ -e "${file}" ] || continue
|
||||||
|
# extract the first column (snap package name) from germinate's output
|
||||||
|
# translate the human-readable "foo (classic)" into a
|
||||||
|
# more machine readable "foo/classic"
|
||||||
|
seed_snaps=$(sed -rn '1,/-----/d;/-----/,$d; s/(.*) \|.*/\1/; s, \(classic\),/classic,; p' "${file}")
|
||||||
|
for snap in ${seed_snaps}; do
|
||||||
|
echo "snap: found ${snap}"
|
||||||
|
ALL_SNAPS="${ALL_SNAPS:+${ALL_SNAPS} }${snap}"
|
||||||
|
done
|
||||||
|
done
|
||||||
|
echo "${ALL_SNAPS}" > config/seeded-snaps
|
||||||
|
fi
|
||||||
|
|
||||||
export APT_OPTIONS
|
export APT_OPTIONS
|
||||||
|
|
||||||
if [ "$PREINSTALLED" != "true" ] && [ "$LIVE_TASK" ]; then
|
if [ "$PREINSTALLED" != "true" ] && [ "$LIVE_TASK" ]; then
|
||||||
@ -926,51 +1015,8 @@ case ${SUBPROJECT:-} in
|
|||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# cribbed from cdimage, perhaps this should be a small helper script in germinate?
|
|
||||||
add_inheritance () {
|
|
||||||
case " $inherit " in
|
|
||||||
*" $1 "*)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
inherit="${inherit:+$inherit }$1"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
expand_inheritance () {
|
|
||||||
for seed in $(grep "^$1:" config/germinate-output/structure | cut -d: -f2); do
|
|
||||||
expand_inheritance "$seed"
|
|
||||||
done
|
|
||||||
add_inheritance "$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
inheritance () {
|
|
||||||
inherit=
|
|
||||||
expand_inheritance "$1"
|
|
||||||
echo "$inherit"
|
|
||||||
}
|
|
||||||
|
|
||||||
if [ "$PREINSTALLED" = "true" ]; then
|
if [ "$PREINSTALLED" = "true" ]; then
|
||||||
if [ -n "$PREINSTALL_POOL_SEEDS" ]; then
|
if [ -n "$PREINSTALL_POOL_SEEDS" ]; then
|
||||||
mkdir -p config/germinate-output
|
|
||||||
case $PROJECT in
|
|
||||||
kubuntu-active*)
|
|
||||||
SEED=kubuntu-active.$SUITE
|
|
||||||
;;
|
|
||||||
kubuntu*)
|
|
||||||
SEED=kubuntu.$SUITE
|
|
||||||
;;
|
|
||||||
xubuntu*)
|
|
||||||
SEED=xubuntu.$SUITE
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
SEED=ubuntu.$SUITE
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
(cd config/germinate-output && germinate --no-rdepends --no-installer \
|
|
||||||
-S $SEEDMIRROR -m $MIRROR -d $SUITE -s $SEED \
|
|
||||||
${COMPONENTS:+-c "$COMPONENTS"} -a $ARCH)
|
|
||||||
|
|
||||||
UNWANTED_SEEDS="${LIVE_TASK:+$LIVE_TASK }boot installer required"
|
UNWANTED_SEEDS="${LIVE_TASK:+$LIVE_TASK }boot installer required"
|
||||||
for i in $UNWANTED_SEEDS; do
|
for i in $UNWANTED_SEEDS; do
|
||||||
UNWANTED_SEEDS="${UNWANTED_SEEDS:+$UNWANTED_SEEDS }$(inheritance $i)"
|
UNWANTED_SEEDS="${UNWANTED_SEEDS:+$UNWANTED_SEEDS }$(inheritance $i)"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user