Conty/create-arch-bootstrap.sh

444 lines
14 KiB
Bash
Raw Normal View History

2021-03-26 18:03:50 +01:00
#!/usr/bin/env bash
# Dependencies: curl tar gzip grep coreutils
2021-03-26 18:03:50 +01:00
# Root rights are required
########################################################################
# Package groups
audio_pkgs="alsa-lib lib32-alsa-lib alsa-plugins lib32-alsa-plugins libpulse \
lib32-libpulse alsa-tools alsa-utils pipewire lib32-pipewire pipewire-pulse pipewire-jack lib32-pipewire-jack"
core_pkgs="xorg-xwayland qt6-wayland wayland \
lib32-wayland qt5-wayland xorg-server-xephyr gamescope"
video_pkgs="mesa lib32-mesa vulkan-radeon lib32-vulkan-radeon \
vulkan-intel lib32-vulkan-intel \
vulkan-icd-loader lib32-vulkan-icd-loader vulkan-mesa-layers \
lib32-vulkan-mesa-layers libva-mesa-driver lib32-libva-mesa-driver \
libva-intel-driver lib32-libva-intel-driver intel-media-driver \
mesa-utils vulkan-tools libva-utils lib32-mesa-utils"
wine_pkgs="wine-staging winetricks-git wine-nine wineasio \
freetype2 lib32-freetype2 libxft lib32-libxft \
flex lib32-flex fluidsynth lib32-fluidsynth \
libxrandr lib32-libxrandr xorg-xrandr libldap lib32-libldap \
mpg123 lib32-mpg123 libxcomposite lib32-libxcomposite \
libxi lib32-libxi libxinerama lib32-libxinerama libxss lib32-libxss \
libxslt lib32-libxslt openal lib32-openal \
krb5 lib32-krb5 libpulse lib32-libpulse alsa-plugins \
lib32-alsa-plugins alsa-lib lib32-alsa-lib gnutls lib32-gnutls \
giflib lib32-giflib gst-libav gst-plugin-pipewire gst-plugins-ugly \
gst-plugins-bad gst-plugins-bad-libs \
gst-plugins-base-libs lib32-gst-plugins-base-libs gst-plugins-base lib32-gst-plugins-base \
gst-plugins-good lib32-gst-plugins-good gstreamer lib32-gstreamer \
libpng lib32-libpng v4l-utils lib32-v4l-utils \
libgpg-error lib32-libgpg-error libjpeg-turbo lib32-libjpeg-turbo \
libgcrypt lib32-libgcrypt ncurses lib32-ncurses ocl-icd lib32-ocl-icd
libxcrypt-compat lib32-libxcrypt-compat libva lib32-libva sqlite lib32-sqlite \
gtk3 lib32-gtk3 vulkan-icd-loader lib32-vulkan-icd-loader \
sdl2 lib32-sdl2 vkd3d lib32-vkd3d libgphoto2 \
openssl-1.1 lib32-openssl-1.1 libnm lib32-libnm \
cabextract wget gamemode lib32-gamemode mangohud lib32-mangohud"
devel_pkgs="base-devel git meson mingw-w64-gcc cmake"
gaming_pkgs="lutris steam steam-native-runtime steamtinkerlaunch minigalaxy \
gamehub legendary prismlauncher bottles playonlinux obs-studio \
retroarch retroarch-assets-ozone libretro-beetle-psx-hw sunshine \
libretro-blastem libretro-bsnes libretro-dolphin duckstation \
libretro-gambatte libretro-melonds libretro-mgba libretro-nestopia \
libretro-parallel-n64 libretro-pcsx2 libretro-picodrive libretro-ppsspp \
libretro-retrodream libretro-yabause"
extra_pkgs="nano ttf-dejavu ttf-liberation firefox mpv geany pcmanfm \
htop qbittorrent speedcrunch gpicview file-roller openbox lxterminal \
yt-dlp minizip nautilus genymotion jre17-openjdk"
# Packages to install
# You can add packages that you want and remove packages that you don't need
# Apart from packages from the official Arch repos, you can also specify
# packages from the Chaotic-AUR repo
export packagelist="${audio_pkgs} ${core_pkgs} ${video_pkgs} ${wine_pkgs} ${devel_pkgs} ${gaming_pkgs} ${extra_pkgs}"
# If you want to install AUR packages, specify them in this variable
export aur_packagelist=""
# ALHP is a repository containing packages from the official Arch Linux
# repos recompiled with -O3, LTO and optimizations for modern CPUs for
# better performance
#
# When this repository is enabled, most of the packages from the official
# Arch Linux repos will be replaced with their optimized versions from ALHP
#
# Set this variable to true, if you want to enable this repository
enable_alhp_repo="false"
# Feature levels for ALHP. Available feature levels are 2 and 3
# For level 2 you need a CPU with SSE4.2 instructions
# For level 3 you need a CPU with AVX2 instructions
alhp_feature_level="2"
########################################################################
2021-03-26 18:03:50 +01:00
if [ $EUID != 0 ]; then
echo "Root rights are required!"
2021-03-26 18:03:50 +01:00
exit 1
fi
2023-02-16 11:48:21 +01:00
if ! command -v curl 1>/dev/null; then
echo "curl is required!"
2021-05-27 22:16:50 +02:00
exit 1
fi
if ! command -v gzip 1>/dev/null; then
echo "gzip is required!"
exit 1
fi
2022-04-11 12:08:42 +02:00
if ! command -v grep 1>/dev/null; then
echo "grep is required!"
exit 1
fi
if ! command -v sha256sum 1>/dev/null; then
echo "sha256sum is required!"
exit 1
fi
2021-03-26 18:03:50 +01:00
script_dir="$(dirname "$(readlink -f "${BASH_SOURCE[0]}")")"
mount_chroot () {
# First unmount just in case
umount -Rl "${bootstrap}"
2021-03-26 18:03:50 +01:00
mount --bind "${bootstrap}" "${bootstrap}"
2021-05-27 22:07:34 +02:00
mount -t proc /proc "${bootstrap}"/proc
mount --bind /sys "${bootstrap}"/sys
mount --make-rslave "${bootstrap}"/sys
mount --bind /dev "${bootstrap}"/dev
mount --bind /dev/pts "${bootstrap}"/dev/pts
mount --bind /dev/shm "${bootstrap}"/dev/shm
mount --make-rslave "${bootstrap}"/dev
2021-05-27 22:07:34 +02:00
rm -f "${bootstrap}"/etc/resolv.conf
cp /etc/resolv.conf "${bootstrap}"/etc/resolv.conf
mkdir -p "${bootstrap}"/run/shm
2021-03-26 18:03:50 +01:00
}
unmount_chroot () {
umount -l "${bootstrap}"
umount "${bootstrap}"/proc
umount "${bootstrap}"/sys
umount "${bootstrap}"/dev/pts
umount "${bootstrap}"/dev/shm
umount "${bootstrap}"/dev
2021-03-26 18:03:50 +01:00
}
run_in_chroot () {
if [ -n "${CHROOT_AUR}" ]; then
chroot --userspec=aur:aur "${bootstrap}" /usr/bin/env LANG=en_US.UTF-8 TERM=xterm PATH="/bin:/sbin:/usr/bin:/usr/sbin" "$@"
else
chroot "${bootstrap}" /usr/bin/env LANG=en_US.UTF-8 TERM=xterm PATH="/bin:/sbin:/usr/bin:/usr/sbin" "$@"
fi
2021-03-26 18:03:50 +01:00
}
install_packages () {
echo "Checking if packages are present in the repos, please wait..."
for p in ${packagelist}; do
if pacman -Sp "${p}" &>/dev/null; then
good_pkglist="${good_pkglist} ${p}"
else
bad_pkglist="${bad_pkglist} ${p}"
fi
done
if [ -n "${bad_pkglist}" ]; then
echo ${bad_pkglist} > /opt/bad_pkglist.txt
fi
for i in {1..10}; do
if pacman --noconfirm --needed -S ${good_pkglist}; then
good_install=1
break
fi
done
if [ -z "${good_install}" ]; then
echo > /opt/pacman_failed.txt
fi
}
install_aur_packages () {
cd /home/aur
echo "Checking if packages are present in the AUR, please wait..."
for p in ${aur_pkgs}; do
if ! yay -a -G "${p}" &>/dev/null; then
bad_aur_pkglist="${bad_aur_pkglist} ${p}"
fi
done
if [ -n "${bad_aur_pkglist}" ]; then
echo ${bad_aur_pkglist} > /home/aur/bad_aur_pkglist.txt
fi
for i in {1..10}; do
if yes | yay --needed --removemake --builddir /home/aur -a -S ${aur_pkgs}; then
break
fi
done
}
generate_pkg_licenses_file () {
for p in $(pacman -Q | cut -d' ' -f1); do
echo -n $(pacman -Qi "${p}" | grep -E 'Name|Licenses' | cut -d ":" -f 2) >>/pkglicenses.txt
echo >>/pkglicenses.txt
done
}
2021-03-26 18:03:50 +01:00
generate_localegen () {
cat <<EOF > locale.gen
ar_EG.UTF-8 UTF-8
en_US.UTF-8 UTF-8
2021-05-27 15:19:07 +02:00
en_GB.UTF-8 UTF-8
en_CA.UTF-8 UTF-8
en_SG.UTF-8 UTF-8
es_MX.UTF-8 UTF-8
2021-05-27 15:19:07 +02:00
zh_CN.UTF-8 UTF-8
fr_FR.UTF-8 UTF-8
2021-05-27 15:19:07 +02:00
ru_RU.UTF-8 UTF-8
ru_UA.UTF-8 UTF-8
es_ES.UTF-8 UTF-8
de_DE.UTF-8 UTF-8
pt_BR.UTF-8 UTF-8
it_IT.UTF-8 UTF-8
id_ID.UTF-8 UTF-8
ja_JP.UTF-8 UTF-8
2021-05-27 15:19:07 +02:00
bg_BG.UTF-8 UTF-8
pl_PL.UTF-8 UTF-8
2021-05-27 15:19:07 +02:00
da_DK.UTF-8 UTF-8
ko_KR.UTF-8 UTF-8
tr_TR.UTF-8 UTF-8
2021-05-27 15:19:07 +02:00
hu_HU.UTF-8 UTF-8
cs_CZ.UTF-8 UTF-8
bn_IN UTF-8
hi_IN UTF-8
2021-03-26 18:03:50 +01:00
EOF
}
generate_mirrorlist () {
cat <<EOF > mirrorlist
2024-06-12 20:56:25 +02:00
Server = https://mirror1.sl-chat.ru/archlinux/\$repo/os/\$arch
2023-12-29 12:14:40 +01:00
Server = https://mirror3.sl-chat.ru/archlinux/\$repo/os/\$arch
2024-06-12 20:56:25 +02:00
Server = https://us.mirrors.cicku.me/archlinux/\$repo/os/\$arch
2023-07-02 09:31:11 +02:00
Server = https://mirror.osbeck.com/archlinux/\$repo/os/\$arch
2023-12-29 12:14:40 +01:00
Server = https://md.mirrors.hacktegic.com/archlinux/\$repo/os/\$arch
Server = https://geo.mirror.pkgbuild.com/\$repo/os/\$arch
2024-06-12 20:56:25 +02:00
Server = https://mirror.qctronics.com/archlinux/\$repo/os/\$arch
Server = https://arch.mirror.constant.com/\$repo/os/\$arch
Server = https://america.mirror.pkgbuild.com/\$repo/os/\$arch
Server = https://mirror.tmmworkshop.com/archlinux/\$repo/os/\$arch
2021-03-26 18:03:50 +01:00
EOF
}
cd "${script_dir}" || exit 1
bootstrap="${script_dir}"/root.x86_64
2023-02-16 11:48:21 +01:00
curl -#LO 'https://cdn-mirror.chaotic.cx/chaotic-aur/chaotic-keyring.pkg.tar.zst'
curl -#LO 'https://cdn-mirror.chaotic.cx/chaotic-aur/chaotic-mirrorlist.pkg.tar.zst'
if [ ! -s chaotic-keyring.pkg.tar.zst ] || [ ! -s chaotic-mirrorlist.pkg.tar.zst ]; then
2022-07-17 16:02:39 +02:00
echo "Seems like Chaotic-AUR keyring or mirrorlist is currently unavailable"
echo "Please try again later"
exit 1
fi
bootstrap_urls=("arch.hu.fo" \
"mirror.cyberbits.eu" \
"mirror.osbeck.com" \
"mirror.lcarilla.de" \
"mirror.moson.org" \
"mirror.f4st.host")
echo "Downloading Arch Linux bootstrap"
for link in "${bootstrap_urls[@]}"; do
curl -#LO "https://${link}/archlinux/iso/latest/archlinux-bootstrap-x86_64.tar.zst"
2023-02-16 11:48:21 +01:00
curl -#LO "https://${link}/archlinux/iso/latest/sha256sums.txt"
if [ -s sha256sums.txt ]; then
grep bootstrap-x86_64 sha256sums.txt > sha256.txt
echo "Verifying the integrity of the bootstrap"
if sha256sum -c sha256.txt &>/dev/null; then
bootstrap_is_good=1
break
fi
fi
echo "Download failed, trying again with different mirror"
done
if [ -z "${bootstrap_is_good}" ]; then
echo "Bootstrap download failed or its checksum is incorrect"
exit 1
fi
rm -rf "${bootstrap}"
tar xf archlinux-bootstrap-x86_64.tar.zst
rm archlinux-bootstrap-x86_64.tar.zst sha256sums.txt sha256.txt
2021-03-26 18:03:50 +01:00
mount_chroot
generate_localegen
if command -v reflector 1>/dev/null; then
echo "Generating mirrorlist..."
reflector --connection-timeout 10 --download-timeout 10 --protocol https --score 10 --sort rate --save mirrorlist
reflector_used=1
else
generate_mirrorlist
fi
2021-03-26 18:03:50 +01:00
rm "${bootstrap}"/etc/locale.gen
mv locale.gen "${bootstrap}"/etc/locale.gen
2021-03-26 18:03:50 +01:00
rm "${bootstrap}"/etc/pacman.d/mirrorlist
mv mirrorlist "${bootstrap}"/etc/pacman.d/mirrorlist
2021-03-26 18:03:50 +01:00
{
echo
echo "[multilib]"
echo "Include = /etc/pacman.d/mirrorlist"
} >> "${bootstrap}"/etc/pacman.conf
2021-03-26 18:03:50 +01:00
run_in_chroot pacman-key --init
2021-06-23 10:23:43 +02:00
echo "keyserver hkps://keyserver.ubuntu.com" >> "${bootstrap}"/etc/pacman.d/gnupg/gpg.conf
2021-03-26 18:03:50 +01:00
run_in_chroot pacman-key --populate archlinux
# Add Chaotic-AUR repo
2023-07-16 09:27:06 +02:00
run_in_chroot pacman-key --recv-key 3056513887B78AEB
run_in_chroot pacman-key --lsign-key 3056513887B78AEB
mv chaotic-keyring.pkg.tar.zst chaotic-mirrorlist.pkg.tar.zst "${bootstrap}"/opt
run_in_chroot pacman --noconfirm -U /opt/chaotic-keyring.pkg.tar.zst /opt/chaotic-mirrorlist.pkg.tar.zst
rm "${bootstrap}"/opt/chaotic-keyring.pkg.tar.zst "${bootstrap}"/opt/chaotic-mirrorlist.pkg.tar.zst
{
echo
echo "[chaotic-aur]"
echo "Include = /etc/pacman.d/chaotic-mirrorlist"
} >> "${bootstrap}"/etc/pacman.conf
# The ParallelDownloads feature of pacman
# Speeds up packages installation, especially when there are many small packages to install
sed -i 's/#ParallelDownloads = 5/ParallelDownloads = 3/g' "${bootstrap}"/etc/pacman.conf
# Do not install unneeded files (man pages and Nvidia firmwares)
sed -i 's/#NoExtract =/NoExtract = usr\/lib\/firmware\/nvidia\/\* usr\/share\/man\/\*/' "${bootstrap}"/etc/pacman.conf
run_in_chroot pacman -Sy archlinux-keyring --noconfirm
run_in_chroot pacman -Su --noconfirm
if [ "${enable_alhp_repo}" = "true" ]; then
if [ "${alhp_feature_level}" -gt 2 ]; then
alhp_feature_level=3
else
alhp_feature_level=2
fi
run_in_chroot pacman --noconfirm --needed -S alhp-keyring alhp-mirrorlist
sed -i "s/#\[multilib\]/#/" "${bootstrap}"/etc/pacman.conf
sed -i "s/\[core\]/\[core-x86-64-v${alhp_feature_level}\]\nInclude = \/etc\/pacman.d\/alhp-mirrorlist\n\n\[extra-x86-64-v${alhp_feature_level}\]\nInclude = \/etc\/pacman.d\/alhp-mirrorlist\n\n\[core\]/" "${bootstrap}"/etc/pacman.conf
sed -i "s/\[multilib\]/\[multilib-x86-64-v${alhp_feature_level}\]\nInclude = \/etc\/pacman.d\/alhp-mirrorlist\n\n\[multilib\]/" "${bootstrap}"/etc/pacman.conf
run_in_chroot pacman -Syu --noconfirm
fi
date -u +"%d-%m-%Y %H:%M (DMY UTC)" > "${bootstrap}"/version
# These packages are required for the self-update feature to work properly
2021-05-27 16:21:37 +02:00
run_in_chroot pacman --noconfirm --needed -S base reflector squashfs-tools fakeroot
# Regenerate the mirrorlist with reflector if reflector was not used before
if [ -z "${reflector_used}" ]; then
echo "Generating mirrorlist..."
run_in_chroot reflector --connection-timeout 10 --download-timeout 10 --protocol https --score 10 --sort rate --save /etc/pacman.d/mirrorlist
run_in_chroot pacman -Syu --noconfirm
fi
export -f install_packages
run_in_chroot bash -c install_packages
2021-03-26 18:03:50 +01:00
if [ -f "${bootstrap}"/opt/pacman_failed.txt ]; then
unmount_chroot
echo "Pacman failed to install some packages"
exit 1
fi
if [ -n "${aur_packagelist}" ]; then
run_in_chroot pacman --noconfirm --needed -S base-devel yay
run_in_chroot useradd -m -G wheel aur
echo "%wheel ALL=(ALL:ALL) NOPASSWD: ALL" >> "${bootstrap}"/etc/sudoers
for p in ${aur_packagelist}; do
aur_pkgs="${aur_pkgs} aur/${p}"
done
export aur_pkgs
export -f install_aur_packages
CHROOT_AUR=1 HOME=/home/aur run_in_chroot bash -c install_aur_packages
mv "${bootstrap}"/home/aur/bad_aur_pkglist.txt "${bootstrap}"/opt
rm -rf "${bootstrap}"/home/aur
fi
run_in_chroot locale-gen
echo "Generating package info, please wait..."
# Generate a list of installed packages
run_in_chroot pacman -Q > "${bootstrap}"/pkglist.x86_64.txt
# Generate a list of licenses of installed packages
export -f generate_pkg_licenses_file
run_in_chroot bash -c generate_pkg_licenses_file
unmount_chroot
2021-05-22 11:54:24 +02:00
# Clear pacman package cache
rm -f "${bootstrap}"/var/cache/pacman/pkg/*
2021-05-22 11:54:24 +02:00
# Create some empty files and directories
# This is needed for bubblewrap to be able to bind real files/dirs to them
# later in the conty-start.sh script
2021-03-27 12:59:35 +01:00
mkdir "${bootstrap}"/media
mkdir -p "${bootstrap}"/usr/share/steam/compatibilitytools.d
touch "${bootstrap}"/etc/asound.conf
2021-05-22 11:54:24 +02:00
touch "${bootstrap}"/etc/localtime
2021-05-28 13:36:11 +02:00
chmod 755 "${bootstrap}"/root
2021-03-26 18:03:50 +01:00
# Enable full font hinting
rm -f "${bootstrap}"/etc/fonts/conf.d/10-hinting-slight.conf
ln -s /usr/share/fontconfig/conf.avail/10-hinting-full.conf "${bootstrap}"/etc/fonts/conf.d
2021-03-26 18:03:50 +01:00
clear
echo "Done"
if [ -f "${bootstrap}"/opt/bad_pkglist.txt ]; then
echo
echo "These packages are not in the repos and have not been installed:"
cat "${bootstrap}"/opt/bad_pkglist.txt
rm "${bootstrap}"/opt/bad_pkglist.txt
fi
if [ -f "${bootstrap}"/opt/bad_aur_pkglist.txt ]; then
echo
echo "These packages are either not in the AUR or yay failed to download their"
echo "PKGBUILDs:"
cat "${bootstrap}"/opt/bad_aur_pkglist.txt
rm "${bootstrap}"/opt/bad_aur_pkglist.txt
fi