2020-09-16 12:24:38 +02:00
|
|
|
# See fedora-container-common.ks for details on how to hack on container image kickstarts
|
|
|
|
# This base is a standard Fedora-ELN image with python3 and dnf
|
|
|
|
|
2020-09-22 20:15:46 +02:00
|
|
|
text # don't use cmdline -- https://github.com/rhinstaller/anaconda/issues/931
|
|
|
|
bootloader --disabled
|
|
|
|
timezone --isUtc --nontp Etc/UTC
|
|
|
|
rootpw --lock --iscrypted locked
|
2020-09-18 12:38:44 +02:00
|
|
|
keyboard us
|
|
|
|
network --bootproto=dhcp --device=link --activate --onboot=on
|
2020-09-22 20:15:46 +02:00
|
|
|
reboot
|
2020-09-18 12:38:44 +02:00
|
|
|
|
2020-09-22 20:15:46 +02:00
|
|
|
# boot partitions are irrelevant as the final docker image is a tarball
|
2020-09-18 12:38:44 +02:00
|
|
|
zerombr
|
2020-09-22 20:15:46 +02:00
|
|
|
clearpart --all
|
|
|
|
autopart --noboot --nohome --noswap --nolvm
|
2020-09-16 12:24:38 +02:00
|
|
|
|
|
|
|
%packages --excludedocs --instLangs=en --nocore --excludeWeakdeps
|
2020-09-18 12:38:44 +02:00
|
|
|
fedora-release-container
|
|
|
|
bash
|
|
|
|
coreutils
|
|
|
|
glibc-minimal-langpack
|
|
|
|
rpm
|
|
|
|
shadow-utils
|
|
|
|
sssd-client
|
|
|
|
util-linux
|
|
|
|
-kernel
|
|
|
|
-dosfstools
|
|
|
|
-e2fsprogs
|
|
|
|
-fuse-libs
|
|
|
|
-gnupg2-smime
|
|
|
|
-libss # used by e2fsprogs
|
|
|
|
-pinentry
|
|
|
|
-shared-mime-info
|
|
|
|
-trousers
|
|
|
|
-xkeyboard-config
|
|
|
|
-grubby
|
|
|
|
|
2020-09-16 12:24:38 +02:00
|
|
|
rootfiles
|
|
|
|
# https://communityblog.fedoraproject.org/modularity-dead-long-live-modularity/
|
|
|
|
fedora-repos-modular
|
|
|
|
tar # https://bugzilla.redhat.com/show_bug.cgi?id=1409920
|
|
|
|
vim-minimal
|
|
|
|
dnf
|
|
|
|
yum # DNF compatibility with yum
|
|
|
|
sssd-client
|
|
|
|
sudo
|
|
|
|
-glibc-langpack-en
|
|
|
|
-cracklib-dicts
|
|
|
|
-langpacks-en
|
|
|
|
%end
|
|
|
|
|
|
|
|
%post --erroronfail --log=/root/anaconda-post.log
|
|
|
|
# remove some extraneous files
|
|
|
|
rm -rf /var/cache/dnf/*
|
|
|
|
rm -rf /tmp/*
|
|
|
|
|
|
|
|
# https://pagure.io/atomic-wg/issue/308
|
|
|
|
printf "tsflags=nodocs\n" >>/etc/dnf/dnf.conf
|
|
|
|
|
|
|
|
|
|
|
|
# https://bugzilla.redhat.com/show_bug.cgi?id=1343138
|
|
|
|
# Fix /run/lock breakage since it's not tmpfs in docker
|
|
|
|
# This unmounts /run (tmpfs) and then recreates the files
|
|
|
|
# in the /run directory on the root filesystem of the container
|
|
|
|
#
|
|
|
|
# We ignore the return code of the systemd-tmpfiles command because
|
|
|
|
# at this point we have already removed the /etc/machine-id and all
|
|
|
|
# tmpfiles lines with %m in them will fail and cause a bad return
|
|
|
|
# code. Example failure:
|
|
|
|
# [/usr/lib/tmpfiles.d/systemd.conf:26] Failed to replace specifiers: /run/log/journal/%m
|
|
|
|
#
|
|
|
|
umount /run
|
|
|
|
rm /run/nologin # https://pagure.io/atomic-wg/issue/316
|
|
|
|
|
|
|
|
# Final pruning
|
|
|
|
rm -rfv /var/cache/* /var/log/* /tmp/*
|
|
|
|
|
|
|
|
%end
|
|
|
|
|
|
|
|
%post --nochroot --erroronfail --log=/mnt/sysimage/root/anaconda-post-nochroot.log
|
|
|
|
set -eux
|
|
|
|
|
2020-09-18 12:38:44 +02:00
|
|
|
# Set install langs macro so that new rpms that get installed will
|
|
|
|
# only install langs that we limit it to.
|
|
|
|
LANG="en_US"
|
|
|
|
echo "%_install_langs $LANG" > /etc/rpm/macros.image-language-conf
|
|
|
|
|
|
|
|
# https://bugzilla.redhat.com/show_bug.cgi?id=1727489
|
|
|
|
echo 'LANG="C.UTF-8"' > /etc/locale.conf
|
|
|
|
|
|
|
|
# https://bugzilla.redhat.com/show_bug.cgi?id=1400682
|
|
|
|
echo "Import RPM GPG key"
|
|
|
|
rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-fedora-34-primary
|
|
|
|
|
|
|
|
echo "# fstab intentionally empty for containers" > /etc/fstab
|
|
|
|
|
|
|
|
# Remove machine-id on pre generated images
|
|
|
|
rm -f /etc/machine-id
|
|
|
|
touch /etc/machine-id
|
|
|
|
|
2020-09-16 12:24:38 +02:00
|
|
|
# See: https://bugzilla.redhat.com/show_bug.cgi?id=1051816
|
|
|
|
# NOTE: run this in nochroot because "find" does not exist in chroot
|
|
|
|
KEEPLANG=en_US
|
|
|
|
for dir in locale i18n; do
|
|
|
|
find /mnt/sysimage/usr/share/${dir} -mindepth 1 -maxdepth 1 -type d -not \( -name "${KEEPLANG}" -o -name POSIX \) -exec rm -rfv {} +
|
|
|
|
done
|
|
|
|
|
|
|
|
%end
|