From f6cbbf01e1c27bfd9a7fa43fef14f5fd5c9e5c9c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C5=81ukasz=20=27sil2100=27=20Zemczak?= Date: Thu, 8 Aug 2019 12:22:33 +0200 Subject: [PATCH] Add a new u-i specific chroot hook, move the NoCloud system-boot cloud-init datasource configuration there to make sure all u-i built ship with it. --- live-build/auto/config | 3 +++ .../hooks.d/chroot/999-cpc-fixes.chroot | 27 ++----------------- .../999-ubuntu-image-customization.chroot | 18 +++++++++++++ 3 files changed, 23 insertions(+), 25 deletions(-) create mode 100755 live-build/ubuntu-cpc/hooks.d/chroot/999-ubuntu-image-customization.chroot diff --git a/live-build/auto/config b/live-build/auto/config index 83a6f791..e163995f 100755 --- a/live-build/auto/config +++ b/live-build/auto/config @@ -394,6 +394,9 @@ case $IMAGEFORMAT in echo "Configured ubuntu-image for the following gadget model: $MODEL" fi + + # Save the model name used for building, mostly for any model-specific hook execution + echo "MODEL=$MODEL" >> config/common # Fake finished configuration for lb build mkdir -p .build touch .build/config diff --git a/live-build/ubuntu-cpc/hooks.d/chroot/999-cpc-fixes.chroot b/live-build/ubuntu-cpc/hooks.d/chroot/999-cpc-fixes.chroot index 561b4473..bc516092 100755 --- a/live-build/ubuntu-cpc/hooks.d/chroot/999-cpc-fixes.chroot +++ b/live-build/ubuntu-cpc/hooks.d/chroot/999-cpc-fixes.chroot @@ -22,18 +22,6 @@ _xchroot() { #### COMMON architecture independent functions arch=$(_xchroot "${rootd}" dpkg --print-architecture) -fake_cloud_init() { - # If the cloud does not provide a meta-data service this should be run - # This will setup a nocloud datasource on the boot partition. - cat << EOF > ${rootd}/etc/cloud/cloud.cfg.d/99-fake_cloud.cfg -# configure cloud-init for NoCloud -datasource_list: [ NoCloud, None ] -datasource: - NoCloud: - fs_label: system-boot -EOF -} - ## -------------- # remove 127.0.1.1 entry (LP: #440757) _xchroot "${rootd}" sh -c 'sed -i "/^127.0.1.1/d" /etc/hosts' @@ -128,19 +116,8 @@ fi case $arch in - # ARM images are special - armhf|arm64) - # Dirty hack because SUBARCH doesn't exist when running chroot hooks, - # and we don't want raspi2 images to depend on a cloud data source: - if _xchroot "${rootd}" dpkg -l linux-image-raspi2 2>/dev/null | grep -q '^.i'; then - fake_cloud_init - fi - - echo "Image architecture is ARM. Existing vmbuilder-fixups" - - exit 0 - ;; - powerpc|ppc64el|s390x) + # ARM, ppc and s390 images are special + armhf|arm64|powerpc|ppc64el|s390x) exit 0 ;; esac diff --git a/live-build/ubuntu-cpc/hooks.d/chroot/999-ubuntu-image-customization.chroot b/live-build/ubuntu-cpc/hooks.d/chroot/999-ubuntu-image-customization.chroot new file mode 100755 index 00000000..d1e89bae --- /dev/null +++ b/live-build/ubuntu-cpc/hooks.d/chroot/999-ubuntu-image-customization.chroot @@ -0,0 +1,18 @@ +#!/bin/bash -ex + +. /root/config/common + +# Specific ubuntu-image chroot configuration goes here. +if [ "$IMAGEFORMAT" == "ubuntu-image" ]; do + # If the cloud does not provide a meta-data service this should be run + # This will setup a nocloud datasource on the boot partition. + # This is the default behavior for our ubuntu-image built preinstalled + # images. + cat << EOF > /etc/cloud/cloud.cfg.d/99-fake_cloud.cfg +# configure cloud-init for NoCloud +datasource_list: [ NoCloud, None ] +datasource: + NoCloud: + fs_label: system-boot +EOF +fi