From 1aacb9fa39f38e07a8992e730be850710de4d7da Mon Sep 17 00:00:00 2001 From: rhpidfyre Date: Tue, 27 May 2025 01:42:27 -0400 Subject: [PATCH] init commit --- .gitignore | 1 + releng/airootfs/etc/gshadow | 2 + releng/airootfs/etc/hostname | 1 + releng/airootfs/etc/locale.conf | 1 + releng/airootfs/etc/localtime | 1 + .../etc/mkinitcpio.conf.d/archiso.conf | 3 + releng/airootfs/etc/mkinitcpio.d/linux.preset | 8 + .../airootfs/etc/modprobe.d/broadcom-wl.conf | 7 + releng/airootfs/etc/motd | 11 + releng/airootfs/etc/os-release | 11 + .../etc/pacman.d/hooks/uncomment-mirrors.hook | 13 + ...z99-remove-custom-hooks-from-airootfs.hook | 18 + releng/airootfs/etc/passwd | 2 + releng/airootfs/etc/resolv.conf | 1 + releng/airootfs/etc/shadow | 2 + releng/airootfs/etc/skel/.config/breezerc | 0 .../etc/skel/.config/fish/config.fish | 12 + .../airootfs/etc/skel/.config/ghostty/config | 44 ++ .../.config/gtk-3.0/assets/close-active.svg | 28 + .../gtk-3.0/assets/close-backdrop-active.svg | 28 + .../gtk-3.0/assets/close-backdrop-hover.svg | 28 + .../gtk-3.0/assets/close-backdrop-normal.svg | 22 + .../.config/gtk-3.0/assets/close-hover.svg | 28 + .../.config/gtk-3.0/assets/close-normal.svg | 22 + .../gtk-3.0/assets/maximize-active.svg | 27 + .../assets/maximize-backdrop-active.svg | 27 + .../assets/maximize-backdrop-hover.svg | 27 + .../assets/maximize-backdrop-normal.svg | 21 + .../.config/gtk-3.0/assets/maximize-hover.svg | 27 + .../gtk-3.0/assets/maximize-normal.svg | 21 + .../gtk-3.0/assets/maximized-active.svg | 27 + .../assets/maximized-backdrop-active.svg | 27 + .../assets/maximized-backdrop-hover.svg | 27 + .../assets/maximized-backdrop-normal.svg | 21 + .../gtk-3.0/assets/maximized-hover.svg | 27 + .../gtk-3.0/assets/maximized-normal.svg | 21 + .../gtk-3.0/assets/minimize-active.svg | 27 + .../assets/minimize-backdrop-active.svg | 27 + .../assets/minimize-backdrop-hover.svg | 27 + .../assets/minimize-backdrop-normal.svg | 21 + .../.config/gtk-3.0/assets/minimize-hover.svg | 27 + .../gtk-3.0/assets/minimize-normal.svg | 21 + .../etc/skel/.config/gtk-3.0/colors.css | 84 +++ .../airootfs/etc/skel/.config/gtk-3.0/gtk.css | 1 + .../etc/skel/.config/gtk-3.0/settings.ini | 23 + .../etc/skel/.config/gtk-4.0/colors.css | 84 +++ .../airootfs/etc/skel/.config/gtk-4.0/gtk.css | 1 + .../etc/skel/.config/gtk-4.0/settings.ini | 13 + releng/airootfs/etc/skel/.config/gtkrc | 6 + releng/airootfs/etc/skel/.config/gtkrc-2.0 | 5 + releng/airootfs/etc/skel/.config/katerc | 164 ++++++ releng/airootfs/etc/skel/.config/kcminputrc | 2 + releng/airootfs/etc/skel/.config/kdeglobals | 149 +++++ .../etc/skel/.config/kglobalshortcutsrc | 284 +++++++++ .../airootfs/etc/skel/.config/kscreenlockerrc | 3 + releng/airootfs/etc/skel/.config/ksmserverrc | 8 + releng/airootfs/etc/skel/.config/ksplashrc | 2 + releng/airootfs/etc/skel/.config/kwinrc | 37 ++ .../airootfs/etc/skel/.config/paru/paru.conf | 2 + .../plasma-org.kde.plasma.desktop-appletsrc | 245 ++++++++ releng/airootfs/etc/skel/.config/plasmarc | 2 + .../airootfs/etc/skel/.config/plasmashellrc | 10 + .../etc/ssh/sshd_config.d/10-archiso.conf | 3 + .../journald.conf.d/volatile-storage.conf | 2 + .../systemd/logind.conf.d/do-not-suspend.conf | 4 + .../ipv6-privacy-extensions.conf | 2 + .../etc/systemd/network/20-ethernet.network | 24 + .../etc/systemd/network/20-wlan.network | 20 + .../etc/systemd/network/20-wwan.network | 19 + .../etc/systemd/resolved.conf.d/archiso.conf | 4 + .../systemd-gpt-auto-generator | 1 + .../etc/systemd/system/choose-mirror.service | 10 + .../cloud-config.service | 1 + .../cloud-final.service | 1 + .../cloud-init-local.service | 1 + .../cloud-init-main.service | 1 + .../cloud-init-network.service | 1 + ...dbus-org.freedesktop.ModemManager1.service | 1 + .../dbus-org.freedesktop.network1.service | 1 + .../dbus-org.freedesktop.resolve1.service | 1 + .../dbus-org.freedesktop.timesync1.service | 1 + .../systemd/system/display-manager.service | 1 + .../systemd/system/etc-pacman.d-gnupg.mount | 8 + .../getty@tty1.service.d/autologin.conf | 3 + .../system/livecd-alsa-unmuter.service | 13 + .../etc/systemd/system/livecd-talk.service | 20 + .../ModemManager.service | 1 + .../choose-mirror.service | 1 + .../hv_fcopy_daemon.service | 1 + .../hv_kvp_daemon.service | 1 + .../hv_vss_daemon.service | 1 + .../multi-user.target.wants/iwd.service | 1 + .../livecd-talk.service | 1 + .../pacman-init.service | 1 + .../multi-user.target.wants/reflector.service | 1 + .../multi-user.target.wants/sshd.service | 1 + .../systemd-networkd.service | 1 + .../systemd-resolved.service | 1 + .../vboxservice.service | 1 + .../multi-user.target.wants/vmtoolsd.service | 1 + .../vmware-vmblock-fuse.service | 1 + .../systemd-networkd-wait-online.service | 1 + .../etc/systemd/system/pacman-init.service | 15 + .../system/reflector.service.d/archiso.conf | 6 + .../system/sockets.target.wants/pcscd.socket | 1 + .../systemd-networkd.socket | 1 + .../livecd-alsa-unmuter.service | 1 + .../systemd-time-wait-sync.service | 1 + .../systemd-timesyncd.service | 1 + .../wait-for-only-one-interface.conf | 6 + .../airootfs/etc/xdg/reflector/reflector.conf | 8 + releng/airootfs/root/.automated_script.sh | 44 ++ releng/airootfs/root/.gnupg/scdaemon.conf | 4 + releng/airootfs/root/.zlogin | 6 + .../airootfs/usr/local/bin/Installation_guide | 5 + releng/airootfs/usr/local/bin/choose-mirror | 29 + releng/airootfs/usr/local/bin/livecd-sound | 239 ++++++++ .../local/share/livecd-sound/asound.conf.in | 3 + .../usr/share/pacman/keyrings/chaotic-revoked | 3 + .../usr/share/pacman/keyrings/chaotic-trusted | 6 + .../usr/share/pacman/keyrings/chaotic.gpg | 542 ++++++++++++++++++ releng/bootstrap_packages.x86_64 | 2 + .../entries/01-archiso-x86_64-linux.conf | 5 + .../02-archiso-x86_64-speech-linux.conf | 5 + .../entries/03-archiso-x86_64-memtest86+.conf | 3 + releng/efiboot/loader/loader.conf | 3 + releng/grub/grub.cfg | 107 ++++ releng/grub/loopback.cfg | 80 +++ releng/packages.x86_64 | 161 ++++++ releng/pacman.conf | 103 ++++ releng/profiledef.sh | 28 + releng/syslinux/archiso_head.cfg | 28 + releng/syslinux/archiso_pxe-linux.cfg | 32 ++ releng/syslinux/archiso_pxe.cfg | 5 + releng/syslinux/archiso_sys-linux.cfg | 20 + releng/syslinux/archiso_sys.cfg | 8 + releng/syslinux/archiso_tail.cfg | 35 ++ releng/syslinux/splash.png | Bin 0 -> 45400 bytes releng/syslinux/syslinux.cfg | 11 + 139 files changed, 3585 insertions(+) create mode 100644 .gitignore create mode 100644 releng/airootfs/etc/gshadow create mode 100644 releng/airootfs/etc/hostname create mode 100644 releng/airootfs/etc/locale.conf create mode 120000 releng/airootfs/etc/localtime create mode 100644 releng/airootfs/etc/mkinitcpio.conf.d/archiso.conf create mode 100644 releng/airootfs/etc/mkinitcpio.d/linux.preset create mode 100644 releng/airootfs/etc/modprobe.d/broadcom-wl.conf create mode 100644 releng/airootfs/etc/motd create mode 100644 releng/airootfs/etc/os-release create mode 100644 releng/airootfs/etc/pacman.d/hooks/uncomment-mirrors.hook create mode 100644 releng/airootfs/etc/pacman.d/hooks/zzzz99-remove-custom-hooks-from-airootfs.hook create mode 100644 releng/airootfs/etc/passwd create mode 120000 releng/airootfs/etc/resolv.conf create mode 100644 releng/airootfs/etc/shadow create mode 100644 releng/airootfs/etc/skel/.config/breezerc create mode 100644 releng/airootfs/etc/skel/.config/fish/config.fish create mode 100644 releng/airootfs/etc/skel/.config/ghostty/config create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-active.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-backdrop-active.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-backdrop-hover.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-backdrop-normal.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-hover.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-normal.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-active.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-backdrop-active.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-backdrop-hover.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-backdrop-normal.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-hover.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-normal.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-active.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-backdrop-active.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-backdrop-hover.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-backdrop-normal.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-hover.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-normal.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-active.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-backdrop-active.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-backdrop-hover.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-backdrop-normal.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-hover.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-normal.svg create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/colors.css create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/gtk.css create mode 100644 releng/airootfs/etc/skel/.config/gtk-3.0/settings.ini create mode 100644 releng/airootfs/etc/skel/.config/gtk-4.0/colors.css create mode 100644 releng/airootfs/etc/skel/.config/gtk-4.0/gtk.css create mode 100644 releng/airootfs/etc/skel/.config/gtk-4.0/settings.ini create mode 100644 releng/airootfs/etc/skel/.config/gtkrc create mode 100644 releng/airootfs/etc/skel/.config/gtkrc-2.0 create mode 100644 releng/airootfs/etc/skel/.config/katerc create mode 100644 releng/airootfs/etc/skel/.config/kcminputrc create mode 100644 releng/airootfs/etc/skel/.config/kdeglobals create mode 100644 releng/airootfs/etc/skel/.config/kglobalshortcutsrc create mode 100644 releng/airootfs/etc/skel/.config/kscreenlockerrc create mode 100644 releng/airootfs/etc/skel/.config/ksmserverrc create mode 100644 releng/airootfs/etc/skel/.config/ksplashrc create mode 100644 releng/airootfs/etc/skel/.config/kwinrc create mode 100644 releng/airootfs/etc/skel/.config/paru/paru.conf create mode 100644 releng/airootfs/etc/skel/.config/plasma-org.kde.plasma.desktop-appletsrc create mode 100644 releng/airootfs/etc/skel/.config/plasmarc create mode 100644 releng/airootfs/etc/skel/.config/plasmashellrc create mode 100644 releng/airootfs/etc/ssh/sshd_config.d/10-archiso.conf create mode 100644 releng/airootfs/etc/systemd/journald.conf.d/volatile-storage.conf create mode 100644 releng/airootfs/etc/systemd/logind.conf.d/do-not-suspend.conf create mode 100644 releng/airootfs/etc/systemd/network.conf.d/ipv6-privacy-extensions.conf create mode 100644 releng/airootfs/etc/systemd/network/20-ethernet.network create mode 100644 releng/airootfs/etc/systemd/network/20-wlan.network create mode 100644 releng/airootfs/etc/systemd/network/20-wwan.network create mode 100644 releng/airootfs/etc/systemd/resolved.conf.d/archiso.conf create mode 120000 releng/airootfs/etc/systemd/system-generators/systemd-gpt-auto-generator create mode 100644 releng/airootfs/etc/systemd/system/choose-mirror.service create mode 120000 releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-config.service create mode 120000 releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-final.service create mode 120000 releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-init-local.service create mode 120000 releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-init-main.service create mode 120000 releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-init-network.service create mode 120000 releng/airootfs/etc/systemd/system/dbus-org.freedesktop.ModemManager1.service create mode 120000 releng/airootfs/etc/systemd/system/dbus-org.freedesktop.network1.service create mode 120000 releng/airootfs/etc/systemd/system/dbus-org.freedesktop.resolve1.service create mode 120000 releng/airootfs/etc/systemd/system/dbus-org.freedesktop.timesync1.service create mode 120000 releng/airootfs/etc/systemd/system/display-manager.service create mode 100644 releng/airootfs/etc/systemd/system/etc-pacman.d-gnupg.mount create mode 100644 releng/airootfs/etc/systemd/system/getty@tty1.service.d/autologin.conf create mode 100644 releng/airootfs/etc/systemd/system/livecd-alsa-unmuter.service create mode 100644 releng/airootfs/etc/systemd/system/livecd-talk.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/ModemManager.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/choose-mirror.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/hv_fcopy_daemon.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/hv_kvp_daemon.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/hv_vss_daemon.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/iwd.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/livecd-talk.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/pacman-init.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/reflector.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/sshd.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/systemd-networkd.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/systemd-resolved.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/vboxservice.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/vmtoolsd.service create mode 120000 releng/airootfs/etc/systemd/system/multi-user.target.wants/vmware-vmblock-fuse.service create mode 120000 releng/airootfs/etc/systemd/system/network-online.target.wants/systemd-networkd-wait-online.service create mode 100644 releng/airootfs/etc/systemd/system/pacman-init.service create mode 100644 releng/airootfs/etc/systemd/system/reflector.service.d/archiso.conf create mode 120000 releng/airootfs/etc/systemd/system/sockets.target.wants/pcscd.socket create mode 120000 releng/airootfs/etc/systemd/system/sockets.target.wants/systemd-networkd.socket create mode 120000 releng/airootfs/etc/systemd/system/sound.target.wants/livecd-alsa-unmuter.service create mode 120000 releng/airootfs/etc/systemd/system/sysinit.target.wants/systemd-time-wait-sync.service create mode 120000 releng/airootfs/etc/systemd/system/sysinit.target.wants/systemd-timesyncd.service create mode 100644 releng/airootfs/etc/systemd/system/systemd-networkd-wait-online.service.d/wait-for-only-one-interface.conf create mode 100644 releng/airootfs/etc/xdg/reflector/reflector.conf create mode 100755 releng/airootfs/root/.automated_script.sh create mode 100644 releng/airootfs/root/.gnupg/scdaemon.conf create mode 100644 releng/airootfs/root/.zlogin create mode 100755 releng/airootfs/usr/local/bin/Installation_guide create mode 100755 releng/airootfs/usr/local/bin/choose-mirror create mode 100755 releng/airootfs/usr/local/bin/livecd-sound create mode 100644 releng/airootfs/usr/local/share/livecd-sound/asound.conf.in create mode 100644 releng/airootfs/usr/share/pacman/keyrings/chaotic-revoked create mode 100644 releng/airootfs/usr/share/pacman/keyrings/chaotic-trusted create mode 100644 releng/airootfs/usr/share/pacman/keyrings/chaotic.gpg create mode 100644 releng/bootstrap_packages.x86_64 create mode 100644 releng/efiboot/loader/entries/01-archiso-x86_64-linux.conf create mode 100644 releng/efiboot/loader/entries/02-archiso-x86_64-speech-linux.conf create mode 100644 releng/efiboot/loader/entries/03-archiso-x86_64-memtest86+.conf create mode 100644 releng/efiboot/loader/loader.conf create mode 100644 releng/grub/grub.cfg create mode 100644 releng/grub/loopback.cfg create mode 100644 releng/packages.x86_64 create mode 100644 releng/pacman.conf create mode 100644 releng/profiledef.sh create mode 100644 releng/syslinux/archiso_head.cfg create mode 100644 releng/syslinux/archiso_pxe-linux.cfg create mode 100644 releng/syslinux/archiso_pxe.cfg create mode 100644 releng/syslinux/archiso_sys-linux.cfg create mode 100644 releng/syslinux/archiso_sys.cfg create mode 100644 releng/syslinux/archiso_tail.cfg create mode 100644 releng/syslinux/splash.png create mode 100644 releng/syslinux/syslinux.cfg diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..1fcb152 --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +out diff --git a/releng/airootfs/etc/gshadow b/releng/airootfs/etc/gshadow new file mode 100644 index 0000000..44b795b --- /dev/null +++ b/releng/airootfs/etc/gshadow @@ -0,0 +1,2 @@ +root:!*::root +rhpidfyre:!*:: diff --git a/releng/airootfs/etc/hostname b/releng/airootfs/etc/hostname new file mode 100644 index 0000000..83fc876 --- /dev/null +++ b/releng/airootfs/etc/hostname @@ -0,0 +1 @@ +rhpidfyre-iso diff --git a/releng/airootfs/etc/locale.conf b/releng/airootfs/etc/locale.conf new file mode 100644 index 0000000..f9c983c --- /dev/null +++ b/releng/airootfs/etc/locale.conf @@ -0,0 +1 @@ +LANG=C.UTF-8 diff --git a/releng/airootfs/etc/localtime b/releng/airootfs/etc/localtime new file mode 120000 index 0000000..0e35b57 --- /dev/null +++ b/releng/airootfs/etc/localtime @@ -0,0 +1 @@ +/usr/share/zoneinfo/UTC \ No newline at end of file diff --git a/releng/airootfs/etc/mkinitcpio.conf.d/archiso.conf b/releng/airootfs/etc/mkinitcpio.conf.d/archiso.conf new file mode 100644 index 0000000..5c008e5 --- /dev/null +++ b/releng/airootfs/etc/mkinitcpio.conf.d/archiso.conf @@ -0,0 +1,3 @@ +HOOKS=(base udev microcode modconf kms memdisk archiso archiso_loop_mnt archiso_pxe_common archiso_pxe_nbd archiso_pxe_http archiso_pxe_nfs block filesystems keyboard) +COMPRESSION="xz" +COMPRESSION_OPTIONS=(-9e) diff --git a/releng/airootfs/etc/mkinitcpio.d/linux.preset b/releng/airootfs/etc/mkinitcpio.d/linux.preset new file mode 100644 index 0000000..8e85205 --- /dev/null +++ b/releng/airootfs/etc/mkinitcpio.d/linux.preset @@ -0,0 +1,8 @@ +# mkinitcpio preset file for the 'linux' package on archiso + +PRESETS=('archiso') + +ALL_kver='/boot/vmlinuz-linux' +archiso_config='/etc/mkinitcpio.conf.d/archiso.conf' + +archiso_image="/boot/initramfs-linux.img" diff --git a/releng/airootfs/etc/modprobe.d/broadcom-wl.conf b/releng/airootfs/etc/modprobe.d/broadcom-wl.conf new file mode 100644 index 0000000..0eae70c --- /dev/null +++ b/releng/airootfs/etc/modprobe.d/broadcom-wl.conf @@ -0,0 +1,7 @@ +# The broadcom-wl package requires some modules to be disabled in order to use +# wl. Since the ISO image needs to cover many hardware cases, this file +# overrides the default blacklist in /usr/lib/modprobe.d/ +# +# If you need to use wl, you may need to delete this file, then `rmmod` any +# already-loaded modules that are now blacklisted before proceeding to modprobe +# wl itself. diff --git a/releng/airootfs/etc/motd b/releng/airootfs/etc/motd new file mode 100644 index 0000000..1fa2d18 --- /dev/null +++ b/releng/airootfs/etc/motd @@ -0,0 +1,11 @@ +To install rhpidfyre Linux follow the installation guide: +https://wiki.archlinux.org/title/Installation_guide + +For Wi-Fi, authenticate to the wireless network using the iwctl utility. +For mobile broadband (WWAN) modems, connect with the mmcli utility. +Ethernet, WLAN and WWAN interfaces using DHCP should work automatically. + +After connecting to the internet, the installation guide can be accessed +via the convenience script Installation_guide. + +                                           diff --git a/releng/airootfs/etc/os-release b/releng/airootfs/etc/os-release new file mode 100644 index 0000000..23143aa --- /dev/null +++ b/releng/airootfs/etc/os-release @@ -0,0 +1,11 @@ +NAME="rhpidfyre Linux" +PRETTY_NAME="rhpidfyre Linux" +ID=arch +BUILD_ID=rolling +ANSI_COLOR="38;2;1;49;255" +HOME_URL="https://git.rhpidfyre.io/rhpidfyre-Linux" +DOCUMENTATION_URL="https://wiki.archlinux.org/" +SUPPORT_URL="https://git.rhpidfyre.io/rhpidfyre-Linux/Linux" +BUG_REPORT_URL="https://git.rhpidfyre.io/rhpidfyre-Linux/Linux/issues" +PRIVACY_POLICY_URL="https://terms.archlinux.org/docs/privacy-policy/" +LOGO=rhpidfyre-linux-logo diff --git a/releng/airootfs/etc/pacman.d/hooks/uncomment-mirrors.hook b/releng/airootfs/etc/pacman.d/hooks/uncomment-mirrors.hook new file mode 100644 index 0000000..342aa95 --- /dev/null +++ b/releng/airootfs/etc/pacman.d/hooks/uncomment-mirrors.hook @@ -0,0 +1,13 @@ +# remove from airootfs! +[Trigger] +Operation = Install +Operation = Upgrade +Type = Package +Target = pacman-mirrorlist + +[Action] +Description = Uncommenting all mirrors in /etc/pacman.d/mirrorlist... +When = PostTransaction +Depends = pacman-mirrorlist +Depends = sed +Exec = /usr/bin/sed -i "s/#Server/Server/g" /etc/pacman.d/mirrorlist diff --git a/releng/airootfs/etc/pacman.d/hooks/zzzz99-remove-custom-hooks-from-airootfs.hook b/releng/airootfs/etc/pacman.d/hooks/zzzz99-remove-custom-hooks-from-airootfs.hook new file mode 100644 index 0000000..8dfb943 --- /dev/null +++ b/releng/airootfs/etc/pacman.d/hooks/zzzz99-remove-custom-hooks-from-airootfs.hook @@ -0,0 +1,18 @@ +# remove from airootfs! +# As a workaround for https://bugs.archlinux.org/task/49347 , remove pacman hooks specific to the ISO build process. +# If not, they would be used when pacstrap is run in the live environment. + +[Trigger] +Operation = Install +Operation = Upgrade +Operation = Remove +Type = Package +Target = * + +[Action] +Description = Work around FS#49347 by removing custom pacman hooks that are only required during ISO build... +When = PostTransaction +Depends = sh +Depends = coreutils +Depends = grep +Exec = /bin/sh -c "rm -- $(grep -Frl 'remove from airootfs' /etc/pacman.d/hooks/)" diff --git a/releng/airootfs/etc/passwd b/releng/airootfs/etc/passwd new file mode 100644 index 0000000..588d1c4 --- /dev/null +++ b/releng/airootfs/etc/passwd @@ -0,0 +1,2 @@ +root:x:0:0:root:/root:/usr/bin/fish +rhpidfyre:x:1000:1000::/home/rhpidfyre:/usr/bin/fish diff --git a/releng/airootfs/etc/resolv.conf b/releng/airootfs/etc/resolv.conf new file mode 120000 index 0000000..3639662 --- /dev/null +++ b/releng/airootfs/etc/resolv.conf @@ -0,0 +1 @@ +/run/systemd/resolve/stub-resolv.conf \ No newline at end of file diff --git a/releng/airootfs/etc/shadow b/releng/airootfs/etc/shadow new file mode 100644 index 0000000..a811101 --- /dev/null +++ b/releng/airootfs/etc/shadow @@ -0,0 +1,2 @@ +root::14871:::::: +rhpidfyre:$6$Sv.SKft9siOAAN6U$6OSC1PKGwxwxnrzfAVnxWhdESKS5DVM4tjLqmk4P3IKxx6sKX3wPW9Y1o/0e5eIloqWv5v9jBbhjfyzVQGLoh0:14871:::::: diff --git a/releng/airootfs/etc/skel/.config/breezerc b/releng/airootfs/etc/skel/.config/breezerc new file mode 100644 index 0000000..e69de29 diff --git a/releng/airootfs/etc/skel/.config/fish/config.fish b/releng/airootfs/etc/skel/.config/fish/config.fish new file mode 100644 index 0000000..78ce5c5 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/fish/config.fish @@ -0,0 +1,12 @@ +if status is-interactive + alias pacman-mirrors="sudo reflector --protocol https --country US --age 24 --verbose --sort rate -l 100 --save /etc/pacman.d/mirrorlist" + alias arch-news="paru -Pww" + alias fastfetch="fastfetch --logo linux" + alias neofetch="fastfetch" + alias grep="grep --color=auto" + alias ccd="cd && c" + alias man="batman" + alias ls="ls -l --color" + alias la="ls -a" + alias c="clear" +end diff --git a/releng/airootfs/etc/skel/.config/ghostty/config b/releng/airootfs/etc/skel/.config/ghostty/config new file mode 100644 index 0000000..6e6cf7a --- /dev/null +++ b/releng/airootfs/etc/skel/.config/ghostty/config @@ -0,0 +1,44 @@ +# This is the configuration file for Ghostty. +# +# This template file has been automatically created at the following +# path since Ghostty couldn't find any existing config files on your system: +# +# /home/rhpidfyre/.config/ghostty/config +# +# The template does not set any default options, since Ghostty ships +# with sensible defaults for all options. Users should only need to set +# options that they want to change from the default. +# +# Run `ghostty +show-config --default --docs` to view a list of +# all available config options and their default values. +# +# Additionally, each config option is also explained in detail +# on Ghostty's website, at https://ghostty.org/docs/config. + +# Config syntax crash course +# ========================== +# # The config file consists of simple key-value pairs, +# # separated by equals signs. +# font-family = Iosevka +# window-padding-x = 2 +# +# # Spacing around the equals sign does not matter. +# # All of these are identical: +# key=value +# key= value +# key =value +# key = value +# +# # Any line beginning with a # is a comment. It's not possible to put +# # a comment after a config option, since it would be interpreted as a +# # part of the value. For example, this will have a value of "#123abc": +# background = #123abc +# +# # Empty values are used to reset config keys to default. +# key = +# +# # Some config options have unique syntaxes for their value, +# # which is explained in the docs for that config option. +# # Just for example: +# resize-overlay-duration = 4s 200ms +theme = "iTerm2 Default" diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-active.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-active.svg new file mode 100644 index 0000000..2bf7f22 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-active.svg @@ -0,0 +1,28 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-backdrop-active.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-backdrop-active.svg new file mode 100644 index 0000000..bce609a --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-backdrop-active.svg @@ -0,0 +1,28 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-backdrop-hover.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-backdrop-hover.svg new file mode 100644 index 0000000..3cd0579 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-backdrop-hover.svg @@ -0,0 +1,28 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-backdrop-normal.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-backdrop-normal.svg new file mode 100644 index 0000000..d91808d --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-backdrop-normal.svg @@ -0,0 +1,22 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-hover.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-hover.svg new file mode 100644 index 0000000..117e90c --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-hover.svg @@ -0,0 +1,28 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-normal.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-normal.svg new file mode 100644 index 0000000..cee9d47 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/close-normal.svg @@ -0,0 +1,22 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-active.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-active.svg new file mode 100644 index 0000000..0bcfca7 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-active.svg @@ -0,0 +1,27 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-backdrop-active.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-backdrop-active.svg new file mode 100644 index 0000000..fd41e9b --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-backdrop-active.svg @@ -0,0 +1,27 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-backdrop-hover.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-backdrop-hover.svg new file mode 100644 index 0000000..f2a2e53 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-backdrop-hover.svg @@ -0,0 +1,27 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-backdrop-normal.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-backdrop-normal.svg new file mode 100644 index 0000000..6f539fd --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-backdrop-normal.svg @@ -0,0 +1,21 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-hover.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-hover.svg new file mode 100644 index 0000000..4d462dd --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-hover.svg @@ -0,0 +1,27 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-normal.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-normal.svg new file mode 100644 index 0000000..5c4d988 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximize-normal.svg @@ -0,0 +1,21 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-active.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-active.svg new file mode 100644 index 0000000..5f5dd5c --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-active.svg @@ -0,0 +1,27 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-backdrop-active.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-backdrop-active.svg new file mode 100644 index 0000000..756c328 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-backdrop-active.svg @@ -0,0 +1,27 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-backdrop-hover.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-backdrop-hover.svg new file mode 100644 index 0000000..9de4548 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-backdrop-hover.svg @@ -0,0 +1,27 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-backdrop-normal.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-backdrop-normal.svg new file mode 100644 index 0000000..4cff76c --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-backdrop-normal.svg @@ -0,0 +1,21 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-hover.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-hover.svg new file mode 100644 index 0000000..12593f4 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-hover.svg @@ -0,0 +1,27 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-normal.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-normal.svg new file mode 100644 index 0000000..6033505 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/maximized-normal.svg @@ -0,0 +1,21 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-active.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-active.svg new file mode 100644 index 0000000..5e16e9a --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-active.svg @@ -0,0 +1,27 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-backdrop-active.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-backdrop-active.svg new file mode 100644 index 0000000..e52bdd2 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-backdrop-active.svg @@ -0,0 +1,27 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-backdrop-hover.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-backdrop-hover.svg new file mode 100644 index 0000000..73f4363 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-backdrop-hover.svg @@ -0,0 +1,27 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-backdrop-normal.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-backdrop-normal.svg new file mode 100644 index 0000000..b1814de --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-backdrop-normal.svg @@ -0,0 +1,21 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-hover.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-hover.svg new file mode 100644 index 0000000..99bc0ff --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-hover.svg @@ -0,0 +1,27 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-normal.svg b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-normal.svg new file mode 100644 index 0000000..84c557f --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/assets/minimize-normal.svg @@ -0,0 +1,21 @@ + + +Qt SVG Document +Generated with Qt + + + + + + + + + + + + diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/colors.css b/releng/airootfs/etc/skel/.config/gtk-3.0/colors.css new file mode 100644 index 0000000..c2f0c20 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/colors.css @@ -0,0 +1,84 @@ +@define-color borders_breeze #454545; +@define-color content_view_bg_breeze #1e1e1e; +@define-color error_color_backdrop_breeze #f44336; +@define-color error_color_breeze #f44336; +@define-color error_color_insensitive_backdrop_breeze #642925; +@define-color error_color_insensitive_breeze #642925; +@define-color insensitive_base_color_breeze #1d1d1d; +@define-color insensitive_base_fg_color_breeze #5d5d5d; +@define-color insensitive_bg_color_breeze #111111; +@define-color insensitive_borders_breeze #222222; +@define-color insensitive_fg_color_breeze #565656; +@define-color insensitive_selected_bg_color_breeze #111111; +@define-color insensitive_selected_fg_color_breeze #565656; +@define-color insensitive_unfocused_bg_color_breeze #111111; +@define-color insensitive_unfocused_fg_color_breeze #565656; +@define-color insensitive_unfocused_selected_bg_color_breeze #111111; +@define-color insensitive_unfocused_selected_fg_color_breeze #565656; +@define-color link_color_breeze #1a73e8; +@define-color link_visited_color_breeze #ad65af; +@define-color success_color_backdrop_breeze #4caf50; +@define-color success_color_breeze #4caf50; +@define-color success_color_insensitive_backdrop_breeze #2c4d2d; +@define-color success_color_insensitive_breeze #2c4d2d; +@define-color theme_base_color_breeze #1e1e1e; +@define-color theme_bg_color_breeze #121212; +@define-color theme_button_background_backdrop_breeze #2e2e2e; +@define-color theme_button_background_backdrop_insensitive_breeze #2c2c2c; +@define-color theme_button_background_insensitive_breeze #2c2c2c; +@define-color theme_button_background_normal_breeze #2e2e2e; +@define-color theme_button_decoration_focus_backdrop_breeze #8ab4f8; +@define-color theme_button_decoration_focus_backdrop_insensitive_breeze #4b596f; +@define-color theme_button_decoration_focus_breeze #8ab4f8; +@define-color theme_button_decoration_focus_insensitive_breeze #4b596f; +@define-color theme_button_decoration_hover_backdrop_breeze #495363; +@define-color theme_button_decoration_hover_backdrop_insensitive_breeze #35383e; +@define-color theme_button_decoration_hover_breeze #495363; +@define-color theme_button_decoration_hover_insensitive_breeze #35383e; +@define-color theme_button_foreground_active_backdrop_breeze #dfdfdf; +@define-color theme_button_foreground_active_backdrop_insensitive_breeze #565656; +@define-color theme_button_foreground_active_breeze #ffffff; +@define-color theme_button_foreground_active_insensitive_breeze #565656; +@define-color theme_button_foreground_backdrop_breeze #ffffff; +@define-color theme_button_foreground_backdrop_insensitive_breeze #727272; +@define-color theme_button_foreground_insensitive_breeze #727272; +@define-color theme_button_foreground_normal_breeze #ffffff; +@define-color theme_fg_color_breeze #dfdfdf; +@define-color theme_header_background_backdrop_breeze #121212; +@define-color theme_header_background_breeze #121212; +@define-color theme_header_background_light_breeze #121212; +@define-color theme_header_foreground_backdrop_breeze #dfdfdf; +@define-color theme_header_foreground_breeze #dfdfdf; +@define-color theme_header_foreground_insensitive_backdrop_breeze #dfdfdf; +@define-color theme_header_foreground_insensitive_breeze #dfdfdf; +@define-color theme_hovering_selected_bg_color_breeze #495363; +@define-color theme_selected_bg_color_breeze #8ab4f8; +@define-color theme_selected_fg_color_breeze #ffffff; +@define-color theme_text_color_breeze #dfdfdf; +@define-color theme_titlebar_background_backdrop_breeze #1e1e1e; +@define-color theme_titlebar_background_breeze #272727; +@define-color theme_titlebar_background_light_breeze #121212; +@define-color theme_titlebar_foreground_backdrop_breeze #8b8b8b; +@define-color theme_titlebar_foreground_breeze #dfdfdf; +@define-color theme_titlebar_foreground_insensitive_backdrop_breeze #8b8b8b; +@define-color theme_titlebar_foreground_insensitive_breeze #8b8b8b; +@define-color theme_unfocused_base_color_breeze #1e1e1e; +@define-color theme_unfocused_bg_color_breeze #121212; +@define-color theme_unfocused_fg_color_breeze #dfdfdf; +@define-color theme_unfocused_selected_bg_color_alt_breeze #2e3b50; +@define-color theme_unfocused_selected_bg_color_breeze #2e3b50; +@define-color theme_unfocused_selected_fg_color_breeze #dfdfdf; +@define-color theme_unfocused_text_color_breeze #dfdfdf; +@define-color theme_unfocused_view_bg_color_breeze #1d1d1d; +@define-color theme_unfocused_view_text_color_breeze #5d5d5d; +@define-color theme_view_active_decoration_color_breeze #495363; +@define-color theme_view_hover_decoration_color_breeze #495363; +@define-color tooltip_background_breeze #616161; +@define-color tooltip_border_breeze #818181; +@define-color tooltip_text_breeze #dfdfdf; +@define-color unfocused_borders_breeze #454545; +@define-color unfocused_insensitive_borders_breeze #222222; +@define-color warning_color_backdrop_breeze #ff9800; +@define-color warning_color_breeze #ff9800; +@define-color warning_color_insensitive_backdrop_breeze #684513; +@define-color warning_color_insensitive_breeze #684513; diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/gtk.css b/releng/airootfs/etc/skel/.config/gtk-3.0/gtk.css new file mode 100644 index 0000000..c9763f7 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/gtk.css @@ -0,0 +1 @@ +@import 'colors.css'; \ No newline at end of file diff --git a/releng/airootfs/etc/skel/.config/gtk-3.0/settings.ini b/releng/airootfs/etc/skel/.config/gtk-3.0/settings.ini new file mode 100644 index 0000000..902a936 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-3.0/settings.ini @@ -0,0 +1,23 @@ +[Settings] +gtk-application-prefer-dark-theme=true +gtk-button-images=true +gtk-cursor-theme-name=default +gtk-cursor-theme-size=24 +gtk-decoration-layout=icon:minimize,maximize,close +gtk-enable-animations=true +gtk-enable-event-sounds=1 +gtk-enable-input-feedback-sounds=0 +gtk-font-name=Noto Sans, 10 +gtk-icon-theme-name=Papirus-Dark +gtk-menu-images=true +gtk-modules=colorreload-gtk-module:window-decorations-gtk-module +gtk-primary-button-warps-slider=true +gtk-sound-theme-name=ocean +gtk-theme-name=Materia-dark +gtk-toolbar-icon-size=GTK_ICON_SIZE_LARGE_TOOLBAR +gtk-toolbar-style=3 +gtk-xft-antialias=1 +gtk-xft-dpi=98304 +gtk-xft-hinting=1 +gtk-xft-hintstyle=hintslight +gtk-xft-rgba=rgb diff --git a/releng/airootfs/etc/skel/.config/gtk-4.0/colors.css b/releng/airootfs/etc/skel/.config/gtk-4.0/colors.css new file mode 100644 index 0000000..c2f0c20 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-4.0/colors.css @@ -0,0 +1,84 @@ +@define-color borders_breeze #454545; +@define-color content_view_bg_breeze #1e1e1e; +@define-color error_color_backdrop_breeze #f44336; +@define-color error_color_breeze #f44336; +@define-color error_color_insensitive_backdrop_breeze #642925; +@define-color error_color_insensitive_breeze #642925; +@define-color insensitive_base_color_breeze #1d1d1d; +@define-color insensitive_base_fg_color_breeze #5d5d5d; +@define-color insensitive_bg_color_breeze #111111; +@define-color insensitive_borders_breeze #222222; +@define-color insensitive_fg_color_breeze #565656; +@define-color insensitive_selected_bg_color_breeze #111111; +@define-color insensitive_selected_fg_color_breeze #565656; +@define-color insensitive_unfocused_bg_color_breeze #111111; +@define-color insensitive_unfocused_fg_color_breeze #565656; +@define-color insensitive_unfocused_selected_bg_color_breeze #111111; +@define-color insensitive_unfocused_selected_fg_color_breeze #565656; +@define-color link_color_breeze #1a73e8; +@define-color link_visited_color_breeze #ad65af; +@define-color success_color_backdrop_breeze #4caf50; +@define-color success_color_breeze #4caf50; +@define-color success_color_insensitive_backdrop_breeze #2c4d2d; +@define-color success_color_insensitive_breeze #2c4d2d; +@define-color theme_base_color_breeze #1e1e1e; +@define-color theme_bg_color_breeze #121212; +@define-color theme_button_background_backdrop_breeze #2e2e2e; +@define-color theme_button_background_backdrop_insensitive_breeze #2c2c2c; +@define-color theme_button_background_insensitive_breeze #2c2c2c; +@define-color theme_button_background_normal_breeze #2e2e2e; +@define-color theme_button_decoration_focus_backdrop_breeze #8ab4f8; +@define-color theme_button_decoration_focus_backdrop_insensitive_breeze #4b596f; +@define-color theme_button_decoration_focus_breeze #8ab4f8; +@define-color theme_button_decoration_focus_insensitive_breeze #4b596f; +@define-color theme_button_decoration_hover_backdrop_breeze #495363; +@define-color theme_button_decoration_hover_backdrop_insensitive_breeze #35383e; +@define-color theme_button_decoration_hover_breeze #495363; +@define-color theme_button_decoration_hover_insensitive_breeze #35383e; +@define-color theme_button_foreground_active_backdrop_breeze #dfdfdf; +@define-color theme_button_foreground_active_backdrop_insensitive_breeze #565656; +@define-color theme_button_foreground_active_breeze #ffffff; +@define-color theme_button_foreground_active_insensitive_breeze #565656; +@define-color theme_button_foreground_backdrop_breeze #ffffff; +@define-color theme_button_foreground_backdrop_insensitive_breeze #727272; +@define-color theme_button_foreground_insensitive_breeze #727272; +@define-color theme_button_foreground_normal_breeze #ffffff; +@define-color theme_fg_color_breeze #dfdfdf; +@define-color theme_header_background_backdrop_breeze #121212; +@define-color theme_header_background_breeze #121212; +@define-color theme_header_background_light_breeze #121212; +@define-color theme_header_foreground_backdrop_breeze #dfdfdf; +@define-color theme_header_foreground_breeze #dfdfdf; +@define-color theme_header_foreground_insensitive_backdrop_breeze #dfdfdf; +@define-color theme_header_foreground_insensitive_breeze #dfdfdf; +@define-color theme_hovering_selected_bg_color_breeze #495363; +@define-color theme_selected_bg_color_breeze #8ab4f8; +@define-color theme_selected_fg_color_breeze #ffffff; +@define-color theme_text_color_breeze #dfdfdf; +@define-color theme_titlebar_background_backdrop_breeze #1e1e1e; +@define-color theme_titlebar_background_breeze #272727; +@define-color theme_titlebar_background_light_breeze #121212; +@define-color theme_titlebar_foreground_backdrop_breeze #8b8b8b; +@define-color theme_titlebar_foreground_breeze #dfdfdf; +@define-color theme_titlebar_foreground_insensitive_backdrop_breeze #8b8b8b; +@define-color theme_titlebar_foreground_insensitive_breeze #8b8b8b; +@define-color theme_unfocused_base_color_breeze #1e1e1e; +@define-color theme_unfocused_bg_color_breeze #121212; +@define-color theme_unfocused_fg_color_breeze #dfdfdf; +@define-color theme_unfocused_selected_bg_color_alt_breeze #2e3b50; +@define-color theme_unfocused_selected_bg_color_breeze #2e3b50; +@define-color theme_unfocused_selected_fg_color_breeze #dfdfdf; +@define-color theme_unfocused_text_color_breeze #dfdfdf; +@define-color theme_unfocused_view_bg_color_breeze #1d1d1d; +@define-color theme_unfocused_view_text_color_breeze #5d5d5d; +@define-color theme_view_active_decoration_color_breeze #495363; +@define-color theme_view_hover_decoration_color_breeze #495363; +@define-color tooltip_background_breeze #616161; +@define-color tooltip_border_breeze #818181; +@define-color tooltip_text_breeze #dfdfdf; +@define-color unfocused_borders_breeze #454545; +@define-color unfocused_insensitive_borders_breeze #222222; +@define-color warning_color_backdrop_breeze #ff9800; +@define-color warning_color_breeze #ff9800; +@define-color warning_color_insensitive_backdrop_breeze #684513; +@define-color warning_color_insensitive_breeze #684513; diff --git a/releng/airootfs/etc/skel/.config/gtk-4.0/gtk.css b/releng/airootfs/etc/skel/.config/gtk-4.0/gtk.css new file mode 100644 index 0000000..c9763f7 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-4.0/gtk.css @@ -0,0 +1 @@ +@import 'colors.css'; \ No newline at end of file diff --git a/releng/airootfs/etc/skel/.config/gtk-4.0/settings.ini b/releng/airootfs/etc/skel/.config/gtk-4.0/settings.ini new file mode 100644 index 0000000..8afd8cf --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtk-4.0/settings.ini @@ -0,0 +1,13 @@ +[Settings] +gtk-application-prefer-dark-theme=true +gtk-cursor-theme-name=default +gtk-cursor-theme-size=24 +gtk-decoration-layout=icon:minimize,maximize,close +gtk-enable-animations=true +gtk-font-name=Noto Sans, 10 +gtk-icon-theme-name=Papirus-Dark +gtk-modules=colorreload-gtk-module:window-decorations-gtk-module +gtk-primary-button-warps-slider=true +gtk-sound-theme-name=ocean +gtk-theme-name=Materia-dark +gtk-xft-dpi=98304 diff --git a/releng/airootfs/etc/skel/.config/gtkrc b/releng/airootfs/etc/skel/.config/gtkrc new file mode 100644 index 0000000..6711a7c --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtkrc @@ -0,0 +1,6 @@ +# created by KDE Plasma, Mon May 26 22:38:26 2025 +# +include "/usr/share/themes/Breeze/gtk-2.0/gtkrc" + +gtk-theme-name="Breeze" + diff --git a/releng/airootfs/etc/skel/.config/gtkrc-2.0 b/releng/airootfs/etc/skel/.config/gtkrc-2.0 new file mode 100644 index 0000000..5510ec5 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/gtkrc-2.0 @@ -0,0 +1,5 @@ +# created by KDE Plasma, Mon May 26 22:38:26 2025 +# + +gtk-alternative-button-order = 1 + diff --git a/releng/airootfs/etc/skel/.config/katerc b/releng/airootfs/etc/skel/.config/katerc new file mode 100644 index 0000000..c5fc85b --- /dev/null +++ b/releng/airootfs/etc/skel/.config/katerc @@ -0,0 +1,164 @@ +[FileDialogSize] +2 screens: Height=720 +2 screens: Width=1280 + +[General] +Allow Tab Scrolling=true +Auto Hide Tabs=false +Close After Last=false +Close documents with window=true +Cycle To First Tab=true +Days Meta Infos=30 +Diagnostics Limit=12000 +Diff Show Style=0 +Elide Tab Text=false +Enable Context ToolView=false +Expand Tabs=false +Icon size for left and right sidebar buttons=32 +Modified Notification=false +Mouse back button action=0 +Mouse forward button action=0 +Open New Tab To The Right Of Current=false +Output History Limit=100 +Output With Date=false +Recent File List Entry Count=10 +Restore Window Configuration=true +SDI Mode=false +Save Meta Infos=true +Show Full Path in Title=false +Show Menu Bar=true +Show Status Bar=true +Show Symbol In Navigation Bar=true +Show Tab Bar=true +Show Tabs Close Button=true +Show Url Nav Bar=true +Show output view for message type=1 +Show text for left and right sidebar=false +Show welcome view for new window=true +Startup Session=manual +Stash new unsaved files=true +Stash unsaved file changes=false +Sync section size with tab positions=false +Tab Double Click New Document=true +Tab Middle Click Close Document=true +Tabbar Tab Limit=0 + +[KTextEditor Renderer] +Animate Bracket Matching=false +Auto Color Theme Selection=false +Color Theme=gruvbox Dark +Line Height Multiplier=1 +Show Indentation Lines=false +Show Whole Bracket Expression=false +Text Font=Intel One Mono,13,-1,5,400,0,0,0,0,0,0,0,0,0,0,1 +Text Font Features= +Word Wrap Marker=false + +[KTextEditor View] +Allow Mark Menu=true +Auto Brackets=true +Auto Center Lines=0 +Auto Completion=true +Auto Completion Preselect First Entry=true +Backspace Remove Composed Characters=false +Bookmark Menu Sorting=0 +Bracket Match Preview=false +Chars To Enclose Selection=<>(){}[]'" +Cycle Through Bookmarks=true +Default Mark Type=1 +Dynamic Word Wrap=true +Dynamic Word Wrap Align Indent=80 +Dynamic Word Wrap At Static Marker=false +Dynamic Word Wrap Indicators=1 +Dynamic Wrap not at word boundaries=false +Enable Accessibility=true +Enable Tab completion=false +Enter To Insert Completion=true +Fold First Line=false +Folding Bar=true +Folding Preview=true +Icon Bar=false +Input Mode=0 +Keyword Completion=true +Line Modification=true +Line Numbers=true +Max Clipboard History Entries=20 +Maximum Search History Size=100 +Mouse Paste At Cursor Position=false +Multiple Cursor Modifier=134217728 +Persistent Selection=false +Scroll Bar Marks=false +Scroll Bar Mini Map All=true +Scroll Bar Mini Map Width=60 +Scroll Bar MiniMap=true +Scroll Bar Preview=true +Scroll Past End=false +Search/Replace Flags=140 +Shoe Line Ending Type in Statusbar=false +Show Documentation With Completion=true +Show File Encoding=true +Show Folding Icons On Hover Only=true +Show Line Count=false +Show Scrollbars=0 +Show Statusbar Dictionary=true +Show Statusbar Highlighting Mode=true +Show Statusbar Input Mode=true +Show Statusbar Line Column=true +Show Statusbar Tab Settings=true +Show Word Count=false +Smart Copy Cut=true +Statusbar Line Column Compact Mode=true +Text Drag And Drop=true +User Sets Of Chars To Enclose Selection= +Vi Input Mode Steal Keys=false +Vi Relative Line Numbers=false +Word Completion=true +Word Completion Minimal Word Length=3 +Word Completion Remove Tail=true + +[Konsole] +AutoSyncronizeMode=0 +KonsoleEscKeyBehaviour=true +KonsoleEscKeyExceptions=vi,vim,nvim,git +RemoveExtension=false +RunPrefix= +SetEditor=false + +[MainWindow] +2 screens: Height=1190 +2 screens: Width=1907 + +[filetree] +editShade=91,44,100 +listMode=false +middleClickToClose=false +shadingEnabled=true +showCloseButton=false +showFullPathOnRoots=false +showToolbar=true +sortRole=0 +viewShade=81,49,95 + +[lspclient] +AllowedServerCommandLines= +AutoHover=true +AutoImport=true +BlockedServerCommandLines= +CompletionDocumentation=true +CompletionParens=true +Diagnostics=true +FormatOnSave=false +HighlightGoto=true +IncrementalSync=false +InlayHints=false +Messages=true +ReferencesDeclaration=true +SemanticHighlighting=true +ServerConfiguration= +ShowCompletions=true +SignatureHelp=true +SymbolDetails=false +SymbolExpand=true +SymbolSort=false +SymbolTree=true +TypeFormatting=false diff --git a/releng/airootfs/etc/skel/.config/kcminputrc b/releng/airootfs/etc/skel/.config/kcminputrc new file mode 100644 index 0000000..3e72a00 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/kcminputrc @@ -0,0 +1,2 @@ +[Mouse] +cursorTheme=default diff --git a/releng/airootfs/etc/skel/.config/kdeglobals b/releng/airootfs/etc/skel/.config/kdeglobals new file mode 100644 index 0000000..806738b --- /dev/null +++ b/releng/airootfs/etc/skel/.config/kdeglobals @@ -0,0 +1,149 @@ +[ColorEffects:Disabled] +ChangeSelectionColor= +Color=56,56,56 +ColorAmount=0 +ColorEffect=0 +ContrastAmount=0.65 +ContrastEffect=1 +Enable= +IntensityAmount=0.1 +IntensityEffect=2 + +[ColorEffects:Inactive] +ChangeSelectionColor=true +Color=112,111,110 +ColorAmount=0.025 +ColorEffect=2 +ContrastAmount=0.1 +ContrastEffect=2 +Enable=false +IntensityAmount=0 +IntensityEffect=0 + +[Colors:Button] +BackgroundAlternate=52,52,52 +BackgroundNormal=46,46,46 +DecorationFocus=138,180,248 +DecorationHover=73,83,99 +ForegroundActive=61,174,233 +ForegroundInactive=105,105,105 +ForegroundLink=26,115,232 +ForegroundNegative=244,67,54 +ForegroundNeutral=255,152,0 +ForegroundNormal=255,255,255 +ForegroundPositive=76,175,80 +ForegroundVisited=173,101,175 + +[Colors:Complementary] +BackgroundAlternate=36,36,36 +BackgroundNormal=24,24,24 +DecorationFocus=30,146,255 +DecorationHover=61,174,230 +ForegroundActive=246,116,0 +ForegroundInactive=175,176,179 +ForegroundLink=138,180,248 +ForegroundNegative=237,21,21 +ForegroundNeutral=201,206,59 +ForegroundNormal=239,240,241 +ForegroundPositive=17,209,22 +ForegroundVisited=206,147,216 + +[Colors:Selection] +BackgroundAlternate=73,83,99 +BackgroundNormal=138,180,248 +DecorationFocus=73,83,99 +DecorationHover=73,83,99 +ForegroundActive=252,252,252 +ForegroundInactive=30,35,44 +ForegroundLink=26,115,232 +ForegroundNegative=244,67,54 +ForegroundNeutral=255,152,0 +ForegroundNormal=255,255,255 +ForegroundPositive=76,175,80 +ForegroundVisited=173,101,175 + +[Colors:Tooltip] +BackgroundAlternate=97,97,97 +BackgroundNormal=97,97,97 +DecorationFocus=73,83,99 +DecorationHover=73,83,99 +ForegroundActive=61,174,233 +ForegroundInactive=152,152,152 +ForegroundLink=26,115,232 +ForegroundNegative=244,67,54 +ForegroundNeutral=255,152,0 +ForegroundNormal=223,223,223 +ForegroundPositive=76,175,80 +ForegroundVisited=173,101,175 + +[Colors:View] +BackgroundAlternate=45,45,45 +BackgroundNormal=30,30,30 +DecorationFocus=73,83,99 +DecorationHover=73,83,99 +ForegroundActive=61,174,233 +ForegroundInactive=105,105,105 +ForegroundLink=26,115,232 +ForegroundNegative=244,67,54 +ForegroundNeutral=255,152,0 +ForegroundNormal=223,223,223 +ForegroundPositive=76,175,80 +ForegroundVisited=173,101,175 + +[Colors:Window] +BackgroundAlternate=24,24,24 +BackgroundNormal=18,18,18 +DecorationFocus=73,83,99 +DecorationHover=73,83,99 +ForegroundActive=61,174,233 +ForegroundInactive=105,105,105 +ForegroundLink=26,115,232 +ForegroundNegative=244,67,54 +ForegroundNeutral=255,152,0 +ForegroundNormal=223,223,223 +ForegroundPositive=76,175,80 +ForegroundVisited=173,101,175 + +[DirSelect Dialog] +DirSelectDialog Size=1280,720 +History Items[$e]=file:$HOME/Documents/git/fish-scripts,file:$HOME/Documents/git/web-foolbox,file:$HOME/Pictures,file:///run/media/rhpidfyre/HDD - Recordings +Splitter State=\x00\x00\x00\xff\x00\x00\x00\x01\x00\x00\x00\x02\x00\x00\x00\x99\x00\x00\x02\xa8\x00\xff\xff\xff\xff\x01\x00\x00\x00\x01\x00 + +[General] +ColorSchemeHash=3b17c5d56f8f372f0b0b9f709c4579c23e51fe6a +TerminalApplication=ghostty +TerminalService=com.mitchellh.ghostty.desktop + +[Icons] +Theme=Papirus-Dark + +[KDE] +LookAndFeelPackage=org.kde.breezedark.desktop + +[KFileDialog Settings] +Allow Expansion=false +Automatically select filename extension=true +Breadcrumb Navigation=true +Decoration position=2 +LocationCombo Completionmode=5 +PathCombo Completionmode=5 +Show Bookmarks=false +Show Full Path=false +Show Inline Previews=true +Show Preview=false +Show Speedbar=true +Show hidden files=false +Sort by=Date +Sort directories first=true +Sort hidden files last=false +Sort reversed=true +Speedbar Width=154 +View Style=DetailTree + +[WM] +activeBackground=39,39,39 +activeBlend=39,39,39 +activeForeground=223,223,223 +inactiveBackground=30,30,30 +inactiveBlend=30,30,30 +inactiveForeground=139,139,139 diff --git a/releng/airootfs/etc/skel/.config/kglobalshortcutsrc b/releng/airootfs/etc/skel/.config/kglobalshortcutsrc new file mode 100644 index 0000000..d26fe26 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/kglobalshortcutsrc @@ -0,0 +1,284 @@ +[ActivityManager] +_k_friendly_name=Activity Manager +switch-to-activity-ddd1edbf-4b52-4b97-ab35-218a4fd42565=none,none,Switch to activity "Default" + +[KDE Keyboard Layout Switcher] +Switch to Last-Used Keyboard Layout=Meta+Alt+L,Meta+Alt+L,Switch to Last-Used Keyboard Layout +Switch to Next Keyboard Layout=Meta+Alt+K,Meta+Alt+K,Switch to Next Keyboard Layout +_k_friendly_name=Keyboard Layout Switcher + +[kaccess] +Toggle Screen Reader On and Off=Meta+Alt+S,Meta+Alt+S,Toggle Screen Reader On and Off +_k_friendly_name=Accessibility + +[kcm_touchpad] +Disable Touchpad=Touchpad Off,Touchpad Off, +Enable Touchpad=Touchpad On,Touchpad On, +Toggle Touchpad=Touchpad Toggle\tMeta+Ctrl+Touchpad Toggle\tMeta+Ctrl+Zenkaku Hankaku,Touchpad Toggle\tTouchpad Toggle\tMeta+Ctrl+Touchpad Toggle\tMeta+Ctrl+Zenkaku Hankaku, +_k_friendly_name=Touchpad + +[kmix] +_k_friendly_name=Audio Volume +decrease_microphone_volume=Microphone Volume Down,Microphone Volume Down,Decrease Microphone Volume +decrease_volume=Volume Down,Volume Down,Decrease Volume +decrease_volume_small=Shift+Volume Down,Shift+Volume Down,Decrease Volume by 1% +increase_microphone_volume=Microphone Volume Up,Microphone Volume Up,Increase Microphone Volume +increase_volume=Volume Up,Volume Up,Increase Volume +increase_volume_small=Shift+Volume Up,Shift+Volume Up,Increase Volume by 1% +mic_mute=Microphone Mute\tMeta+Volume Mute,Microphone Mute\tMeta+Volume Mute,Mute Microphone +mute=Volume Mute,Volume Mute,Mute + +[ksmserver] +Halt Without Confirmation=none,,Shut Down Without Confirmation +Lock Session=Meta+L\tScreensaver,Meta+L\tScreensaver,Lock Session +Log Out=Ctrl+Alt+Del,Ctrl+Alt+Del,Show Logout Screen +Log Out Without Confirmation=none,,Log Out Without Confirmation +LogOut=none,,Log Out +Reboot=none,,Reboot +Reboot Without Confirmation=none,,Reboot Without Confirmation +Shut Down=none,,Shut Down +_k_friendly_name=Session Management + +[kwin] +Activate Window Demanding Attention=Meta+Ctrl+A,Meta+Ctrl+A,Activate Window Demanding Attention +Cube=Meta+C,none,Toggle Cube +Cycle Overview=none,none,Cycle through Overview and Grid View +Cycle Overview Opposite=none,none,Cycle through Grid View and Overview +Decrease Opacity=none,,Decrease Opacity of Active Window by 5% +Edit Tiles=Meta+T,Meta+T,Toggle Tiles Editor +Expose=Ctrl+F9,Ctrl+F9,Toggle Present Windows (Current desktop) +ExposeAll=Ctrl+F10\tLaunch (C),Ctrl+F10\tLaunch (C),Toggle Present Windows (All desktops) +ExposeClass=Ctrl+F7,Ctrl+F7,Toggle Present Windows (Window class) +ExposeClassCurrentDesktop=none,none,Toggle Present Windows (Window class on current desktop) +Grid View=Meta+G,Meta+G,Toggle Grid View +Increase Opacity=none,,Increase Opacity of Active Window by 5% +Kill Window=Meta+Ctrl+Esc,Meta+Ctrl+Esc,Kill Window +Move Tablet to Next Output=none,none,Move the tablet to the next output +MoveMouseToCenter=Meta+F6,Meta+F6,Move Mouse to Center +MoveMouseToFocus=Meta+F5,Meta+F5,Move Mouse to Focus +MoveZoomDown=none,none,Move Zoomed Area Downwards +MoveZoomLeft=none,none,Move Zoomed Area to Left +MoveZoomRight=none,none,Move Zoomed Area to Right +MoveZoomUp=none,none,Move Zoomed Area Upwards +Overview=Meta+W,Meta+W,Toggle Overview +Setup Window Shortcut=none,,Setup Window Shortcut +Show Desktop=Meta+D,Meta+D,Peek at Desktop +Switch One Desktop Down=Meta+Ctrl+Down,Meta+Ctrl+Down,Switch One Desktop Down +Switch One Desktop Up=Meta+Ctrl+Up,Meta+Ctrl+Up,Switch One Desktop Up +Switch One Desktop to the Left=Meta+Ctrl+Left,Meta+Ctrl+Left,Switch One Desktop to the Left +Switch One Desktop to the Right=Meta+Ctrl+Right,Meta+Ctrl+Right,Switch One Desktop to the Right +Switch Window Down=Meta+Alt+Down,Meta+Alt+Down,Switch to Window Below +Switch Window Left=Meta+Alt+Left,Meta+Alt+Left,Switch to Window to the Left +Switch Window Right=Meta+Alt+Right,Meta+Alt+Right,Switch to Window to the Right +Switch Window Up=Meta+Alt+Up,Meta+Alt+Up,Switch to Window Above +Switch to Desktop 1=Ctrl+F1,Ctrl+F1,Switch to Desktop 1 +Switch to Desktop 10=none,,Switch to Desktop 10 +Switch to Desktop 11=none,,Switch to Desktop 11 +Switch to Desktop 12=none,,Switch to Desktop 12 +Switch to Desktop 13=none,,Switch to Desktop 13 +Switch to Desktop 14=none,,Switch to Desktop 14 +Switch to Desktop 15=none,,Switch to Desktop 15 +Switch to Desktop 16=none,,Switch to Desktop 16 +Switch to Desktop 17=none,,Switch to Desktop 17 +Switch to Desktop 18=none,,Switch to Desktop 18 +Switch to Desktop 19=none,,Switch to Desktop 19 +Switch to Desktop 2=Ctrl+F2,Ctrl+F2,Switch to Desktop 2 +Switch to Desktop 20=none,,Switch to Desktop 20 +Switch to Desktop 3=Ctrl+F3,Ctrl+F3,Switch to Desktop 3 +Switch to Desktop 4=Ctrl+F4,Ctrl+F4,Switch to Desktop 4 +Switch to Desktop 5=none,,Switch to Desktop 5 +Switch to Desktop 6=none,,Switch to Desktop 6 +Switch to Desktop 7=none,,Switch to Desktop 7 +Switch to Desktop 8=none,,Switch to Desktop 8 +Switch to Desktop 9=none,,Switch to Desktop 9 +Switch to Next Desktop=none,,Switch to Next Desktop +Switch to Next Screen=none,,Switch to Next Screen +Switch to Previous Desktop=none,,Switch to Previous Desktop +Switch to Previous Screen=none,,Switch to Previous Screen +Switch to Screen 0=none,,Switch to Screen 0 +Switch to Screen 1=none,,Switch to Screen 1 +Switch to Screen 2=none,,Switch to Screen 2 +Switch to Screen 3=none,,Switch to Screen 3 +Switch to Screen 4=none,,Switch to Screen 4 +Switch to Screen 5=none,,Switch to Screen 5 +Switch to Screen 6=none,,Switch to Screen 6 +Switch to Screen 7=none,,Switch to Screen 7 +Switch to Screen Above=none,,Switch to Screen Above +Switch to Screen Below=none,,Switch to Screen Below +Switch to Screen to the Left=none,,Switch to Screen to the Left +Switch to Screen to the Right=none,,Switch to Screen to the Right +Toggle Night Color=none,none,Suspend/Resume Night Light +Toggle Window Raise/Lower=none,,Toggle Window Raise/Lower +Walk Through Windows=Alt+Tab,Alt+Tab,Walk Through Windows +Walk Through Windows (Reverse)=Alt+Shift+Tab,Alt+Shift+Tab,Walk Through Windows (Reverse) +Walk Through Windows Alternative=none,,Walk Through Windows Alternative +Walk Through Windows Alternative (Reverse)=none,,Walk Through Windows Alternative (Reverse) +Walk Through Windows of Current Application=Alt+`,Alt+`,Walk Through Windows of Current Application +Walk Through Windows of Current Application (Reverse)=Alt+~,Alt+~,Walk Through Windows of Current Application (Reverse) +Walk Through Windows of Current Application Alternative=none,,Walk Through Windows of Current Application Alternative +Walk Through Windows of Current Application Alternative (Reverse)=none,,Walk Through Windows of Current Application Alternative (Reverse) +Window Above Other Windows=none,,Keep Window Above Others +Window Below Other Windows=none,,Keep Window Below Others +Window Close=Alt+F4,Alt+F4,Close Window +Window Custom Quick Tile Bottom=none,,Custom Quick Tile Window to the Bottom +Window Custom Quick Tile Left=none,,Custom Quick Tile Window to the Left +Window Custom Quick Tile Right=none,,Custom Quick Tile Window to the Right +Window Custom Quick Tile Top=none,,Custom Quick Tile Window to the Top +Window Fullscreen=none,,Make Window Fullscreen +Window Grow Horizontal=none,,Expand Window Horizontally +Window Grow Vertical=none,,Expand Window Vertically +Window Lower=none,,Lower Window +Window Maximize=Meta+PgUp,Meta+PgUp,Maximize Window +Window Maximize Horizontal=none,,Maximize Window Horizontally +Window Maximize Vertical=none,,Maximize Window Vertically +Window Minimize=Meta+PgDown,Meta+PgDown,Minimize Window +Window Move=none,,Move Window +Window Move Center=none,,Move Window to the Center +Window No Border=none,,Toggle Window Titlebar and Frame +Window On All Desktops=none,,Keep Window on All Desktops +Window One Desktop Down=Meta+Ctrl+Shift+Down,Meta+Ctrl+Shift+Down,Window One Desktop Down +Window One Desktop Up=Meta+Ctrl+Shift+Up,Meta+Ctrl+Shift+Up,Window One Desktop Up +Window One Desktop to the Left=Meta+Ctrl+Shift+Left,Meta+Ctrl+Shift+Left,Window One Desktop to the Left +Window One Desktop to the Right=Meta+Ctrl+Shift+Right,Meta+Ctrl+Shift+Right,Window One Desktop to the Right +Window One Screen Down=none,,Move Window One Screen Down +Window One Screen Up=none,,Move Window One Screen Up +Window One Screen to the Left=none,,Move Window One Screen to the Left +Window One Screen to the Right=none,,Move Window One Screen to the Right +Window Operations Menu=Alt+F3,Alt+F3,Window Operations Menu +Window Pack Down=none,,Move Window Down +Window Pack Left=none,,Move Window Left +Window Pack Right=none,,Move Window Right +Window Pack Up=none,,Move Window Up +Window Quick Tile Bottom=Meta+Down,Meta+Down,Quick Tile Window to the Bottom +Window Quick Tile Bottom Left=none,,Quick Tile Window to the Bottom Left +Window Quick Tile Bottom Right=none,,Quick Tile Window to the Bottom Right +Window Quick Tile Left=Meta+Left,Meta+Left,Quick Tile Window to the Left +Window Quick Tile Right=Meta+Right,Meta+Right,Quick Tile Window to the Right +Window Quick Tile Top=Meta+Up,Meta+Up,Quick Tile Window to the Top +Window Quick Tile Top Left=none,,Quick Tile Window to the Top Left +Window Quick Tile Top Right=none,,Quick Tile Window to the Top Right +Window Raise=none,,Raise Window +Window Resize=none,,Resize Window +Window Shade=none,,Shade Window +Window Shrink Horizontal=none,,Shrink Window Horizontally +Window Shrink Vertical=none,,Shrink Window Vertically +Window to Desktop 1=none,,Window to Desktop 1 +Window to Desktop 10=none,,Window to Desktop 10 +Window to Desktop 11=none,,Window to Desktop 11 +Window to Desktop 12=none,,Window to Desktop 12 +Window to Desktop 13=none,,Window to Desktop 13 +Window to Desktop 14=none,,Window to Desktop 14 +Window to Desktop 15=none,,Window to Desktop 15 +Window to Desktop 16=none,,Window to Desktop 16 +Window to Desktop 17=none,,Window to Desktop 17 +Window to Desktop 18=none,,Window to Desktop 18 +Window to Desktop 19=none,,Window to Desktop 19 +Window to Desktop 2=none,,Window to Desktop 2 +Window to Desktop 20=none,,Window to Desktop 20 +Window to Desktop 3=none,,Window to Desktop 3 +Window to Desktop 4=none,,Window to Desktop 4 +Window to Desktop 5=none,,Window to Desktop 5 +Window to Desktop 6=none,,Window to Desktop 6 +Window to Desktop 7=none,,Window to Desktop 7 +Window to Desktop 8=none,,Window to Desktop 8 +Window to Desktop 9=none,,Window to Desktop 9 +Window to Next Desktop=none,,Window to Next Desktop +Window to Next Screen=Meta+Shift+Right,Meta+Shift+Right,Move Window to Next Screen +Window to Previous Desktop=none,,Window to Previous Desktop +Window to Previous Screen=Meta+Shift+Left,Meta+Shift+Left,Move Window to Previous Screen +Window to Screen 0=none,,Move Window to Screen 0 +Window to Screen 1=none,,Move Window to Screen 1 +Window to Screen 2=none,,Move Window to Screen 2 +Window to Screen 3=none,,Move Window to Screen 3 +Window to Screen 4=none,,Move Window to Screen 4 +Window to Screen 5=none,,Move Window to Screen 5 +Window to Screen 6=none,,Move Window to Screen 6 +Window to Screen 7=none,,Move Window to Screen 7 +_k_friendly_name=KWin +disableInputCapture=Meta+Shift+Esc,Meta+Shift+Esc,Disable Active Input Capture +view_actual_size=Meta+0,Meta+0,Zoom to Actual Size +view_zoom_in=Meta++\tMeta+=,Meta++\tMeta+=,Zoom In +view_zoom_out=Meta+-,Meta+-,Zoom Out + +[mediacontrol] +_k_friendly_name=Media Controller +mediavolumedown=none,,Media volume down +mediavolumeup=none,,Media volume up +nextmedia=Media Next,Media Next,Media playback next +pausemedia=Media Pause,Media Pause,Pause media playback +playmedia=none,,Play media playback +playpausemedia=Media Play,Media Play,Play/Pause media playback +previousmedia=Media Previous,Media Previous,Media playback previous +stopmedia=Media Stop,Media Stop,Stop media playback + +[org_kde_powerdevil] +Decrease Keyboard Brightness=Keyboard Brightness Down,Keyboard Brightness Down,Decrease Keyboard Brightness +Decrease Screen Brightness=Monitor Brightness Down,Monitor Brightness Down,Decrease Screen Brightness +Decrease Screen Brightness Small=Shift+Monitor Brightness Down,Shift+Monitor Brightness Down,Decrease Screen Brightness by 1% +Hibernate=Hibernate,Hibernate,Hibernate +Increase Keyboard Brightness=Keyboard Brightness Up,Keyboard Brightness Up,Increase Keyboard Brightness +Increase Screen Brightness=Monitor Brightness Up,Monitor Brightness Up,Increase Screen Brightness +Increase Screen Brightness Small=Shift+Monitor Brightness Up,Shift+Monitor Brightness Up,Increase Screen Brightness by 1% +PowerDown=Power Down,Power Down,Power Down +PowerOff=Power Off,Power Off,Power Off +Sleep=Sleep,Sleep,Suspend +Toggle Keyboard Backlight=Keyboard Light On/Off,Keyboard Light On/Off,Toggle Keyboard Backlight +Turn Off Screen=none,none,Turn Off Screen +_k_friendly_name=Power Management +powerProfile=Battery\tMeta+B,Battery\tMeta+B,Switch Power Profile + +[plasmashell] +_k_friendly_name=plasmashell +activate application launcher=Meta\tAlt+F1,Meta\tAlt+F1,Activate Application Launcher +activate task manager entry 1=Meta+1,Meta+1,Activate Task Manager Entry 1 +activate task manager entry 10=none,,Activate Task Manager Entry 10 +activate task manager entry 2=Meta+2,Meta+2,Activate Task Manager Entry 2 +activate task manager entry 3=Meta+3,Meta+3,Activate Task Manager Entry 3 +activate task manager entry 4=Meta+4,Meta+4,Activate Task Manager Entry 4 +activate task manager entry 5=Meta+5,Meta+5,Activate Task Manager Entry 5 +activate task manager entry 6=Meta+6,Meta+6,Activate Task Manager Entry 6 +activate task manager entry 7=Meta+7,Meta+7,Activate Task Manager Entry 7 +activate task manager entry 8=Meta+8,Meta+8,Activate Task Manager Entry 8 +activate task manager entry 9=Meta+9,Meta+9,Activate Task Manager Entry 9 +activate widget 27=none,none,Activate Icons-and-Text Task Manager Widget +activate widget 28=none,none,Activate Application Menu Widget +clear-history=none,,Clear Clipboard History +clipboard_action=Meta+Ctrl+X,Meta+Ctrl+X,Automatic Action Popup Menu +cycle-panels=Meta+Alt+P,Meta+Alt+P,Move keyboard focus between panels +cycleNextAction=none,,Next History Item +cyclePrevAction=none,,Previous History Item +manage activities=Meta+Q,Meta+Q,Show Activity Switcher +next activity=Meta+A,none,Walk through activities +previous activity=Meta+Shift+A,none,Walk through activities (Reverse) +repeat_action=none,,Manually Invoke Action on Current Clipboard +show dashboard=Ctrl+F12,Ctrl+F12,Show Desktop +show-barcode=none,,Show Barcode… +show-on-mouse-pos=Meta+V,Meta+V,Show Clipboard Items at Mouse Position +stop current activity=Meta+S,Meta+S,Stop Current Activity +switch to next activity=none,,Switch to Next Activity +switch to previous activity=none,,Switch to Previous Activity +toggle do not disturb=none,,Toggle do not disturb + +[services][com.mitchellh.ghostty.desktop] +_launch=Meta+R + +[services][org.gnome.Calculator.desktop] +_launch=Calculator + +[services][org.kde.spectacle.desktop] +CurrentMonitorScreenShot=Shift+Print +FullScreenScreenShot=none +RecordRegion=Meta+Shift+R +RectangularRegionScreenShot=Print +_launch=Meta+Shift+S + +[wacomtablet] +Map to fullscreen=Meta+Ctrl+F,Meta+Ctrl+F,Map to fullscreen +Map to screen 1=Meta+Ctrl+1,Meta+Ctrl+1,Map to screen 1 +Map to screen 2=Meta+Ctrl+2,Meta+Ctrl+2,Map to screen 2 +Next Profile=Meta+Ctrl+N,Meta+Ctrl+N,Next profile +Previous Profile=Meta+Ctrl+P,Meta+Ctrl+P,Previous Profile +Toggle screen map selection=Meta+Ctrl+M,Meta+Ctrl+M,Toggle between all screens +Toggle stylus mode=Meta+Ctrl+S,Meta+Ctrl+S,Toggle the Stylus Tool Relative/Absolute +Toggle touch tool=Meta+Ctrl+T,Meta+Ctrl+T,Enable/Disable the Touch Tool +_k_friendly_name=Wacom Tablet diff --git a/releng/airootfs/etc/skel/.config/kscreenlockerrc b/releng/airootfs/etc/skel/.config/kscreenlockerrc new file mode 100644 index 0000000..6a1c2d7 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/kscreenlockerrc @@ -0,0 +1,3 @@ +[Greeter][Wallpaper][org.kde.image][General] +Image=/home/rhpidfyre/Documents/GlIQmAoXcAACRQK.jpg +PreviewImage=/home/rhpidfyre/Documents/GlIQmAoXcAACRQK.jpg diff --git a/releng/airootfs/etc/skel/.config/ksmserverrc b/releng/airootfs/etc/skel/.config/ksmserverrc new file mode 100644 index 0000000..db60cc9 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/ksmserverrc @@ -0,0 +1,8 @@ +[General] +loginMode=restoreSavedSession + +[LegacySession: saved at previous logout] +count=0 + +[Session: saved at previous logout] +count=0 diff --git a/releng/airootfs/etc/skel/.config/ksplashrc b/releng/airootfs/etc/skel/.config/ksplashrc new file mode 100644 index 0000000..8835d78 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/ksplashrc @@ -0,0 +1,2 @@ +[KSplash] +Theme=org.kde.breeze.desktop diff --git a/releng/airootfs/etc/skel/.config/kwinrc b/releng/airootfs/etc/skel/.config/kwinrc new file mode 100644 index 0000000..0b22dc3 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/kwinrc @@ -0,0 +1,37 @@ +[Activities][LastVirtualDesktop] +ddd1edbf-4b52-4b97-ab35-218a4fd42565=13ba432d-3189-4072-86b5-90887420efd7 + +[Desktops] +Id_1=13ba432d-3189-4072-86b5-90887420efd7 +Id_2=92fd9261-5053-44f8-9d99-1ef234146836 +Id_3=15fa0139-4e83-4a1f-a908-22bd3843d126 +Id_4=99cae3a7-c068-4a8d-a5be-e7e052ef14bc +Number=4 +Rows=2 + +[Effect-overview] +BorderActivate=9 + +[Plugins] +cubeEnabled=true + +[TabBox] +HighlightWindows=false +LayoutName=big_icons +MultiScreenMode=1 + +[Tiling] +padding=4 + +[Tiling][96531e59-15fc-582e-bdaa-821d7fb9d210] +tiles={"layoutDirection":"horizontal","tiles":[{"width":0.25},{"width":0.5},{"width":0.25}]} + +[Tiling][a7207471-682c-5d60-9364-1f320f766322] +tiles={"layoutDirection":"horizontal","tiles":[{"width":0.25},{"width":0.5},{"width":0.25}]} + +[Xwayland] +Scale=1 + +[org.kde.kdecoration2] +library=org.kde.kwin.aurorae +theme=__aurorae__svg__Materia-Dark diff --git a/releng/airootfs/etc/skel/.config/paru/paru.conf b/releng/airootfs/etc/skel/.config/paru/paru.conf new file mode 100644 index 0000000..f1122fb --- /dev/null +++ b/releng/airootfs/etc/skel/.config/paru/paru.conf @@ -0,0 +1,2 @@ +[options] +BottomUp diff --git a/releng/airootfs/etc/skel/.config/plasma-org.kde.plasma.desktop-appletsrc b/releng/airootfs/etc/skel/.config/plasma-org.kde.plasma.desktop-appletsrc new file mode 100644 index 0000000..1e19735 --- /dev/null +++ b/releng/airootfs/etc/skel/.config/plasma-org.kde.plasma.desktop-appletsrc @@ -0,0 +1,245 @@ +[ActionPlugins][0] +RightButton;NoModifier=org.kde.contextmenu + +[ActionPlugins][1] +RightButton;NoModifier=org.kde.contextmenu + +[Containments][1] +ItemGeometriesHorizontal= +activityId=ddd1edbf-4b52-4b97-ab35-218a4fd42565 +formfactor=0 +immutability=1 +lastScreen=0 +location=0 +plugin=org.kde.plasma.folder +wallpaperplugin=org.kde.color + +[Containments][1][ConfigDialog] +DialogHeight=906 +DialogWidth=1530 + +[Containments][1][Wallpaper][org.kde.color][General] +Color=0,0,0 + +[Containments][1][Wallpaper][org.kde.image][General] +SlidePaths=/usr/share/wallpapers/ + +[Containments][2] +ItemGeometriesHorizontal= +activityId=ddd1edbf-4b52-4b97-ab35-218a4fd42565 +formfactor=0 +immutability=1 +lastScreen=1 +location=0 +plugin=org.kde.plasma.folder +wallpaperplugin=org.kde.image + +[Containments][3] +activityId= +formfactor=2 +immutability=1 +lastScreen=0 +location=3 +plugin=org.kde.panel +wallpaperplugin=org.kde.image + +[Containments][3][Applets][21] +immutability=1 +plugin=org.kde.plasma.digitalclock + +[Containments][3][Applets][21][Configuration] +PreloadWeight=100 +popupHeight=450 +popupWidth=810 + +[Containments][3][Applets][21][Configuration][Appearance] +autoFontAndSize=false +enabledCalendarPlugins=holidaysevents +fontFamily=Monospace +fontSize=12 +fontWeight=400 +use24hFormat=2 + +[Containments][3][Applets][21][Configuration][ConfigDialog] +DialogHeight=678 +DialogWidth=769 + +[Containments][3][Applets][27] +immutability=1 +plugin=org.kde.plasma.taskmanager + +[Containments][3][Applets][27][Configuration][ConfigDialog] +DialogHeight=540 +DialogWidth=720 + +[Containments][3][Applets][27][Configuration][General] +launchers=applications:systemsettings.desktop,applications:org.kde.dolphin.desktop,applications:com.mitchellh.ghostty.desktop,applications:chromium.desktop,applications:floorp.desktop +onlyGroupWhenFull=false + +[Containments][3][Applets][28] +immutability=1 +plugin=org.kde.plasma.kicker + +[Containments][3][Applets][28][Configuration] +PreloadWeight=100 +popupHeight=361 +popupWidth=300 + +[Containments][3][Applets][28][Configuration][ConfigDialog] +DialogHeight=540 +DialogWidth=720 + +[Containments][3][Applets][28][Configuration][General] +customButtonImage=computer +favoritesDisplay=1 +favoritesPortedToKAstats=true +showIconsRootLevel=true +systemFavorites=suspend\\,hibernate\\,reboot\\,shutdown + +[Containments][3][Applets][29] +immutability=1 +plugin=org.kde.plasma.userswitcher + +[Containments][3][Applets][29][Configuration] +PreloadWeight=100 +popupHeight=161 +popupWidth=216 + +[Containments][3][Applets][29][Configuration][ConfigDialog] +DialogHeight=540 +DialogWidth=720 + +[Containments][3][Applets][31] +immutability=1 +plugin=org.kde.plasma.marginsseparator + +[Containments][3][Applets][5] +immutability=1 +plugin=org.kde.plasma.pager + +[Containments][3][Applets][8] +immutability=1 +plugin=org.kde.plasma.systemtray + +[Containments][3][Applets][8][Configuration] +PreloadWeight=100 +SystrayContainmentId=9 + +[Containments][3][General] +AppletOrder=28;5;27;8;21;31;29 + +[Containments][9] +activityId= +formfactor=2 +immutability=1 +lastScreen=0 +location=3 +plugin=org.kde.plasma.private.systemtray +popupHeight=432 +popupWidth=432 +wallpaperplugin=org.kde.image + +[Containments][9][Applets][10] +immutability=1 +plugin=org.kde.plasma.manage-inputmethod + +[Containments][9][Applets][11] +immutability=1 +plugin=org.kde.plasma.notifications + +[Containments][9][Applets][11][Configuration] +PreloadWeight=100 + +[Containments][9][Applets][12] +immutability=1 +plugin=org.kde.plasma.cameraindicator + +[Containments][9][Applets][13] +immutability=1 +plugin=org.kde.plasma.devicenotifier + +[Containments][9][Applets][13][Configuration] +PreloadWeight=55 + +[Containments][9][Applets][14] +immutability=1 +plugin=org.kde.kscreen + +[Containments][9][Applets][15] +immutability=1 +plugin=org.kde.plasma.printmanager + +[Containments][9][Applets][16] +immutability=1 +plugin=org.kde.plasma.keyboardlayout + +[Containments][9][Applets][17] +immutability=1 +plugin=org.kde.plasma.vault + +[Containments][9][Applets][18] +immutability=1 +plugin=org.kde.plasma.keyboardindicator + +[Containments][9][Applets][18][Configuration] +PreloadWeight=55 + +[Containments][9][Applets][19] +immutability=1 +plugin=org.kde.plasma.clipboard + +[Containments][9][Applets][19][Configuration] +PreloadWeight=65 + +[Containments][9][Applets][20] +immutability=1 +plugin=org.kde.plasma.volume + +[Containments][9][Applets][20][Configuration] +PreloadWeight=75 + +[Containments][9][Applets][20][Configuration][General] +migrated=true + +[Containments][9][Applets][23] +immutability=1 +plugin=org.kde.plasma.battery + +[Containments][9][Applets][23][Configuration] +PreloadWeight=0 + +[Containments][9][Applets][24] +immutability=1 +plugin=org.kde.plasma.brightness + +[Containments][9][Applets][24][Configuration] +PreloadWeight=0 + +[Containments][9][Applets][25] +immutability=1 +plugin=org.kde.plasma.networkmanagement + +[Containments][9][Applets][25][Configuration] +PreloadWeight=100 + +[Containments][9][Applets][25][Configuration][General] +currentDetailsTab=details + +[Containments][9][Applets][26] +immutability=1 +plugin=org.kde.plasma.mediacontroller + +[Containments][9][Applets][26][Configuration] +PreloadWeight=0 + +[Containments][9][ConfigDialog] +DialogHeight=540 +DialogWidth=720 + +[Containments][9][General] +extraItems=org.kde.plasma.manage-inputmethod,org.kde.plasma.notifications,org.kde.plasma.bluetooth,org.kde.plasma.battery,org.kde.plasma.cameraindicator,org.kde.plasma.devicenotifier,org.kde.plasma.brightness,org.kde.kscreen,org.kde.plasma.printmanager,org.kde.plasma.networkmanagement,org.kde.plasma.keyboardlayout,org.kde.plasma.vault,org.kde.plasma.keyboardindicator,org.kde.plasma.clipboard,org.kde.plasma.mediacontroller,org.kde.plasma.volume +knownItems=org.kde.plasma.manage-inputmethod,org.kde.plasma.notifications,org.kde.plasma.bluetooth,org.kde.plasma.battery,org.kde.plasma.cameraindicator,org.kde.plasma.devicenotifier,org.kde.plasma.brightness,org.kde.kscreen,org.kde.plasma.printmanager,org.kde.plasma.networkmanagement,org.kde.plasma.keyboardlayout,org.kde.plasma.vault,org.kde.plasma.keyboardindicator,org.kde.plasma.clipboard,org.kde.plasma.mediacontroller,org.kde.plasma.volume + +[ScreenMapping] +itemsOnDisabledScreens= +screenMapping=desktop:/rhpidfyre-os,0,ddd1edbf-4b52-4b97-ab35-218a4fd42565 diff --git a/releng/airootfs/etc/skel/.config/plasmarc b/releng/airootfs/etc/skel/.config/plasmarc new file mode 100644 index 0000000..f5221ab --- /dev/null +++ b/releng/airootfs/etc/skel/.config/plasmarc @@ -0,0 +1,2 @@ +[Theme] +name=Materia diff --git a/releng/airootfs/etc/skel/.config/plasmashellrc b/releng/airootfs/etc/skel/.config/plasmashellrc new file mode 100644 index 0000000..cabc88f --- /dev/null +++ b/releng/airootfs/etc/skel/.config/plasmashellrc @@ -0,0 +1,10 @@ +[PlasmaViews][Panel 3] +floating=1 +panelOpacity=0 +panelVisibility=0 + +[PlasmaViews][Panel 3][Defaults] +thickness=32 + +[Updates] +performed=/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/move_desktop_layout_config.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/keyboardlayout_migrateiconsetting.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/mediaframe_migrate_useBackground_setting.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/maintain_existing_desktop_icon_sizes.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/systemloadviewer_systemmonitor.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/klipper_clear_config.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/keyboardlayout_remove_shortcut.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/containmentactions_middlebutton.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/folderview_fix_recursive_screenmapping.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/migrate_font_weights.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/digitalclock_migrate_font_settings.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/digitalclock_rename_timezonedisplay_key.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/digitalclock_migrate_showseconds_setting.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/no_middle_click_paste_on_panels.js,/usr/share/plasma/shells/org.kde.plasma.desktop/contents/updates/unlock_widgets.js diff --git a/releng/airootfs/etc/ssh/sshd_config.d/10-archiso.conf b/releng/airootfs/etc/ssh/sshd_config.d/10-archiso.conf new file mode 100644 index 0000000..6ea7b41 --- /dev/null +++ b/releng/airootfs/etc/ssh/sshd_config.d/10-archiso.conf @@ -0,0 +1,3 @@ +# Allow root login using password authentication +PasswordAuthentication yes +PermitRootLogin yes diff --git a/releng/airootfs/etc/systemd/journald.conf.d/volatile-storage.conf b/releng/airootfs/etc/systemd/journald.conf.d/volatile-storage.conf new file mode 100644 index 0000000..b69850d --- /dev/null +++ b/releng/airootfs/etc/systemd/journald.conf.d/volatile-storage.conf @@ -0,0 +1,2 @@ +[Journal] +Storage=volatile diff --git a/releng/airootfs/etc/systemd/logind.conf.d/do-not-suspend.conf b/releng/airootfs/etc/systemd/logind.conf.d/do-not-suspend.conf new file mode 100644 index 0000000..f3ecb39 --- /dev/null +++ b/releng/airootfs/etc/systemd/logind.conf.d/do-not-suspend.conf @@ -0,0 +1,4 @@ +[Login] +HandleSuspendKey=ignore +HandleHibernateKey=ignore +HandleLidSwitch=ignore diff --git a/releng/airootfs/etc/systemd/network.conf.d/ipv6-privacy-extensions.conf b/releng/airootfs/etc/systemd/network.conf.d/ipv6-privacy-extensions.conf new file mode 100644 index 0000000..0e9ceb4 --- /dev/null +++ b/releng/airootfs/etc/systemd/network.conf.d/ipv6-privacy-extensions.conf @@ -0,0 +1,2 @@ +[Network] +IPv6PrivacyExtensions=yes diff --git a/releng/airootfs/etc/systemd/network/20-ethernet.network b/releng/airootfs/etc/systemd/network/20-ethernet.network new file mode 100644 index 0000000..d3a3271 --- /dev/null +++ b/releng/airootfs/etc/systemd/network/20-ethernet.network @@ -0,0 +1,24 @@ +[Match] +# Matching with "Type=ether" causes issues with containers because it also matches virtual Ethernet interfaces (veth*). +# See https://bugs.archlinux.org/task/70892 +# Instead match by globbing the network interface name. +Name=en* +Name=eth* + +[Link] +RequiredForOnline=routable + +[Network] +DHCP=yes +MulticastDNS=yes + +# systemd-networkd does not set per-interface-type default route metrics +# https://github.com/systemd/systemd/issues/17698 +# Explicitly set route metric, so that Ethernet is preferred over Wi-Fi and Wi-Fi is preferred over mobile broadband. +# Use values from NetworkManager. From nm_device_get_route_metric_default in +# https://gitlab.freedesktop.org/NetworkManager/NetworkManager/-/blob/main/src/core/devices/nm-device.c +[DHCPv4] +RouteMetric=100 + +[IPv6AcceptRA] +RouteMetric=100 diff --git a/releng/airootfs/etc/systemd/network/20-wlan.network b/releng/airootfs/etc/systemd/network/20-wlan.network new file mode 100644 index 0000000..8b70a95 --- /dev/null +++ b/releng/airootfs/etc/systemd/network/20-wlan.network @@ -0,0 +1,20 @@ +[Match] +Name=wl* + +[Link] +RequiredForOnline=routable + +[Network] +DHCP=yes +MulticastDNS=yes + +# systemd-networkd does not set per-interface-type default route metrics +# https://github.com/systemd/systemd/issues/17698 +# Explicitly set route metric, so that Ethernet is preferred over Wi-Fi and Wi-Fi is preferred over mobile broadband. +# Use values from NetworkManager. From nm_device_get_route_metric_default in +# https://gitlab.freedesktop.org/NetworkManager/NetworkManager/-/blob/main/src/core/devices/nm-device.c +[DHCPv4] +RouteMetric=600 + +[IPv6AcceptRA] +RouteMetric=600 diff --git a/releng/airootfs/etc/systemd/network/20-wwan.network b/releng/airootfs/etc/systemd/network/20-wwan.network new file mode 100644 index 0000000..6e1c8dd --- /dev/null +++ b/releng/airootfs/etc/systemd/network/20-wwan.network @@ -0,0 +1,19 @@ +[Match] +Name=ww* + +[Link] +RequiredForOnline=routable + +[Network] +DHCP=yes + +# systemd-networkd does not set per-interface-type default route metrics +# https://github.com/systemd/systemd/issues/17698 +# Explicitly set route metric, so that Ethernet is preferred over Wi-Fi and Wi-Fi is preferred over mobile broadband. +# Use values from NetworkManager. From nm_device_get_route_metric_default in +# https://gitlab.freedesktop.org/NetworkManager/NetworkManager/-/blob/main/src/core/devices/nm-device.c +[DHCPv4] +RouteMetric=700 + +[IPv6AcceptRA] +RouteMetric=700 diff --git a/releng/airootfs/etc/systemd/resolved.conf.d/archiso.conf b/releng/airootfs/etc/systemd/resolved.conf.d/archiso.conf new file mode 100644 index 0000000..636f3bd --- /dev/null +++ b/releng/airootfs/etc/systemd/resolved.conf.d/archiso.conf @@ -0,0 +1,4 @@ +# Default systemd-resolved configuration for archiso + +[Resolve] +MulticastDNS=yes diff --git a/releng/airootfs/etc/systemd/system-generators/systemd-gpt-auto-generator b/releng/airootfs/etc/systemd/system-generators/systemd-gpt-auto-generator new file mode 120000 index 0000000..dc1dc0c --- /dev/null +++ b/releng/airootfs/etc/systemd/system-generators/systemd-gpt-auto-generator @@ -0,0 +1 @@ +/dev/null \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/choose-mirror.service b/releng/airootfs/etc/systemd/system/choose-mirror.service new file mode 100644 index 0000000..b6a3562 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/choose-mirror.service @@ -0,0 +1,10 @@ +[Unit] +Description=Choose mirror from the kernel command line +ConditionKernelCommandLine=mirror + +[Service] +Type=oneshot +ExecStart=/usr/local/bin/choose-mirror + +[Install] +WantedBy=multi-user.target diff --git a/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-config.service b/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-config.service new file mode 120000 index 0000000..ebc50f0 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-config.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/cloud-config.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-final.service b/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-final.service new file mode 120000 index 0000000..80fa3c8 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-final.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/cloud-final.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-init-local.service b/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-init-local.service new file mode 120000 index 0000000..dd8e9f1 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-init-local.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/cloud-init-local.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-init-main.service b/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-init-main.service new file mode 120000 index 0000000..875ff73 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-init-main.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/cloud-init-main.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-init-network.service b/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-init-network.service new file mode 120000 index 0000000..ae77734 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/cloud-init.target.wants/cloud-init-network.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/cloud-init-network.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/dbus-org.freedesktop.ModemManager1.service b/releng/airootfs/etc/systemd/system/dbus-org.freedesktop.ModemManager1.service new file mode 120000 index 0000000..dcf7c8e --- /dev/null +++ b/releng/airootfs/etc/systemd/system/dbus-org.freedesktop.ModemManager1.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/ModemManager.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/dbus-org.freedesktop.network1.service b/releng/airootfs/etc/systemd/system/dbus-org.freedesktop.network1.service new file mode 120000 index 0000000..4c158e6 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/dbus-org.freedesktop.network1.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/systemd-networkd.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/dbus-org.freedesktop.resolve1.service b/releng/airootfs/etc/systemd/system/dbus-org.freedesktop.resolve1.service new file mode 120000 index 0000000..4f6ae34 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/dbus-org.freedesktop.resolve1.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/systemd-resolved.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/dbus-org.freedesktop.timesync1.service b/releng/airootfs/etc/systemd/system/dbus-org.freedesktop.timesync1.service new file mode 120000 index 0000000..cd00411 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/dbus-org.freedesktop.timesync1.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/systemd-timesyncd.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/display-manager.service b/releng/airootfs/etc/systemd/system/display-manager.service new file mode 120000 index 0000000..56f1df2 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/display-manager.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/sddm.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/etc-pacman.d-gnupg.mount b/releng/airootfs/etc/systemd/system/etc-pacman.d-gnupg.mount new file mode 100644 index 0000000..038961e --- /dev/null +++ b/releng/airootfs/etc/systemd/system/etc-pacman.d-gnupg.mount @@ -0,0 +1,8 @@ +[Unit] +Description=Temporary /etc/pacman.d/gnupg directory + +[Mount] +What=tmpfs +Where=/etc/pacman.d/gnupg +Type=tmpfs +Options=mode=0755,noswap diff --git a/releng/airootfs/etc/systemd/system/getty@tty1.service.d/autologin.conf b/releng/airootfs/etc/systemd/system/getty@tty1.service.d/autologin.conf new file mode 100644 index 0000000..b9d22eb --- /dev/null +++ b/releng/airootfs/etc/systemd/system/getty@tty1.service.d/autologin.conf @@ -0,0 +1,3 @@ +[Service] +ExecStart= +ExecStart=-/sbin/agetty -o '-p -f -- \\u' --noclear --autologin root - $TERM diff --git a/releng/airootfs/etc/systemd/system/livecd-alsa-unmuter.service b/releng/airootfs/etc/systemd/system/livecd-alsa-unmuter.service new file mode 100644 index 0000000..03db4b9 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/livecd-alsa-unmuter.service @@ -0,0 +1,13 @@ +[Unit] +Description=Unmute All Sound Card Controls For Use With The Live Arch Environment +# This needs to run after the audio device becomes available. +Wants=systemd-udev-settle.service +After=systemd-udev-settle.service sound.target +ConditionKernelCommandLine=accessibility=on + +[Service] +Type=oneshot +ExecStart=/usr/local/bin/livecd-sound -u + +[Install] +WantedBy=sound.target diff --git a/releng/airootfs/etc/systemd/system/livecd-talk.service b/releng/airootfs/etc/systemd/system/livecd-talk.service new file mode 100644 index 0000000..b38df22 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/livecd-talk.service @@ -0,0 +1,20 @@ +[Unit] +Description=Screen reader service +After=livecd-alsa-unmuter.service +Before=getty@tty1.service +ConditionKernelCommandLine=accessibility=on + +[Service] +Type=oneshot +TTYPath=/dev/tty13 +ExecStartPre=/usr/bin/chvt 13 +ExecStart=/usr/local/bin/livecd-sound -p +ExecStartPost=/usr/bin/chvt 1 +ExecStartPost=systemctl start espeakup.service +StandardInput=tty +TTYVHangup=yes +TTYVTDisallocate=yes +RemainAfterExit=true + +[Install] +WantedBy=multi-user.target diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/ModemManager.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/ModemManager.service new file mode 120000 index 0000000..dcf7c8e --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/ModemManager.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/ModemManager.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/choose-mirror.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/choose-mirror.service new file mode 120000 index 0000000..2d8d256 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/choose-mirror.service @@ -0,0 +1 @@ +../choose-mirror.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/hv_fcopy_daemon.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/hv_fcopy_daemon.service new file mode 120000 index 0000000..20ac7b2 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/hv_fcopy_daemon.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/hv_fcopy_daemon.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/hv_kvp_daemon.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/hv_kvp_daemon.service new file mode 120000 index 0000000..a7eac4a --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/hv_kvp_daemon.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/hv_kvp_daemon.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/hv_vss_daemon.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/hv_vss_daemon.service new file mode 120000 index 0000000..eae19ef --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/hv_vss_daemon.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/hv_vss_daemon.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/iwd.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/iwd.service new file mode 120000 index 0000000..3625abd --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/iwd.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/iwd.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/livecd-talk.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/livecd-talk.service new file mode 120000 index 0000000..b917481 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/livecd-talk.service @@ -0,0 +1 @@ +/etc/systemd/system/livecd-talk.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/pacman-init.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/pacman-init.service new file mode 120000 index 0000000..d09eec6 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/pacman-init.service @@ -0,0 +1 @@ +../pacman-init.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/reflector.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/reflector.service new file mode 120000 index 0000000..d372729 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/reflector.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/reflector.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/sshd.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/sshd.service new file mode 120000 index 0000000..d21ebd9 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/sshd.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/sshd.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/systemd-networkd.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/systemd-networkd.service new file mode 120000 index 0000000..4c158e6 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/systemd-networkd.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/systemd-networkd.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/systemd-resolved.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/systemd-resolved.service new file mode 120000 index 0000000..4f6ae34 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/systemd-resolved.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/systemd-resolved.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/vboxservice.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/vboxservice.service new file mode 120000 index 0000000..cb2d560 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/vboxservice.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/vboxservice.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/vmtoolsd.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/vmtoolsd.service new file mode 120000 index 0000000..e0a11a7 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/vmtoolsd.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/vmtoolsd.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/multi-user.target.wants/vmware-vmblock-fuse.service b/releng/airootfs/etc/systemd/system/multi-user.target.wants/vmware-vmblock-fuse.service new file mode 120000 index 0000000..173f306 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/multi-user.target.wants/vmware-vmblock-fuse.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/vmware-vmblock-fuse.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/network-online.target.wants/systemd-networkd-wait-online.service b/releng/airootfs/etc/systemd/system/network-online.target.wants/systemd-networkd-wait-online.service new file mode 120000 index 0000000..7d6ad92 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/network-online.target.wants/systemd-networkd-wait-online.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/systemd-networkd-wait-online.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/pacman-init.service b/releng/airootfs/etc/systemd/system/pacman-init.service new file mode 100644 index 0000000..b824884 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/pacman-init.service @@ -0,0 +1,15 @@ +[Unit] +Description=Initializes Pacman keyring +Requires=etc-pacman.d-gnupg.mount +After=etc-pacman.d-gnupg.mount time-sync.target +BindsTo=etc-pacman.d-gnupg.mount +Before=archlinux-keyring-wkd-sync.service + +[Service] +Type=oneshot +RemainAfterExit=yes +ExecStart=/usr/bin/pacman-key --init +ExecStart=/usr/bin/pacman-key --populate + +[Install] +WantedBy=multi-user.target diff --git a/releng/airootfs/etc/systemd/system/reflector.service.d/archiso.conf b/releng/airootfs/etc/systemd/system/reflector.service.d/archiso.conf new file mode 100644 index 0000000..de6664d --- /dev/null +++ b/releng/airootfs/etc/systemd/system/reflector.service.d/archiso.conf @@ -0,0 +1,6 @@ +[Unit] +ConditionKernelCommandLine=!mirror + +[Service] +Restart=on-failure +RestartSec=10 diff --git a/releng/airootfs/etc/systemd/system/sockets.target.wants/pcscd.socket b/releng/airootfs/etc/systemd/system/sockets.target.wants/pcscd.socket new file mode 120000 index 0000000..3897c63 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/sockets.target.wants/pcscd.socket @@ -0,0 +1 @@ +/usr/lib/systemd/system/pcscd.socket \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/sockets.target.wants/systemd-networkd.socket b/releng/airootfs/etc/systemd/system/sockets.target.wants/systemd-networkd.socket new file mode 120000 index 0000000..51942c8 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/sockets.target.wants/systemd-networkd.socket @@ -0,0 +1 @@ +/usr/lib/systemd/system/systemd-networkd.socket \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/sound.target.wants/livecd-alsa-unmuter.service b/releng/airootfs/etc/systemd/system/sound.target.wants/livecd-alsa-unmuter.service new file mode 120000 index 0000000..98c0fc8 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/sound.target.wants/livecd-alsa-unmuter.service @@ -0,0 +1 @@ +../livecd-alsa-unmuter.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/sysinit.target.wants/systemd-time-wait-sync.service b/releng/airootfs/etc/systemd/system/sysinit.target.wants/systemd-time-wait-sync.service new file mode 120000 index 0000000..cabf28b --- /dev/null +++ b/releng/airootfs/etc/systemd/system/sysinit.target.wants/systemd-time-wait-sync.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/systemd-time-wait-sync.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/sysinit.target.wants/systemd-timesyncd.service b/releng/airootfs/etc/systemd/system/sysinit.target.wants/systemd-timesyncd.service new file mode 120000 index 0000000..cd00411 --- /dev/null +++ b/releng/airootfs/etc/systemd/system/sysinit.target.wants/systemd-timesyncd.service @@ -0,0 +1 @@ +/usr/lib/systemd/system/systemd-timesyncd.service \ No newline at end of file diff --git a/releng/airootfs/etc/systemd/system/systemd-networkd-wait-online.service.d/wait-for-only-one-interface.conf b/releng/airootfs/etc/systemd/system/systemd-networkd-wait-online.service.d/wait-for-only-one-interface.conf new file mode 100644 index 0000000..c9f9bce --- /dev/null +++ b/releng/airootfs/etc/systemd/system/systemd-networkd-wait-online.service.d/wait-for-only-one-interface.conf @@ -0,0 +1,6 @@ +# Allow systemd-networkd-wait-online to succeed with one interface, otherwise, if multiple network interfaces exist, +# network-online.target gets needlessly delayed. +# See https://wiki.archlinux.org/title/systemd-networkd#systemd-networkd-wait-online +[Service] +ExecStart= +ExecStart=/usr/lib/systemd/systemd-networkd-wait-online --any diff --git a/releng/airootfs/etc/xdg/reflector/reflector.conf b/releng/airootfs/etc/xdg/reflector/reflector.conf new file mode 100644 index 0000000..7c830d2 --- /dev/null +++ b/releng/airootfs/etc/xdg/reflector/reflector.conf @@ -0,0 +1,8 @@ +# Reflector configuration file for the systemd service. + +--save /etc/pacman.d/mirrorlist +--ipv4 +--ipv6 +--protocol https +--latest 20 +--sort rate diff --git a/releng/airootfs/root/.automated_script.sh b/releng/airootfs/root/.automated_script.sh new file mode 100755 index 0000000..f7f3ced --- /dev/null +++ b/releng/airootfs/root/.automated_script.sh @@ -0,0 +1,44 @@ +#!/usr/bin/env bash + +script_cmdline() { + local param + for param in $(/etc/pacman.d/mirrorlist < +# $2 +# $3 +unmute_and_set_level() { + [[ -n "$3" && -n "$2" && -n "$1" ]] || bugout + systemd-cat -t "livecdsound" printf "Setting: %s on card: %s to %s\n" "$2" "$1" "$3" + systemd-cat -t "livecdsound" amixer -c "$1" set "$2" "$3" unmute + return 0 +} + +# $1 +# $2 +mute_and_zero_level() { + [[ -n "$1" && -n "$2" ]] || bugout + systemd-cat -t "livecdsound" printf "Muting control: %s on card: %s\n" "$2" "$1" + systemd-cat -t "livecdsound" amixer -c "$1" set "$2" "0%" mute + return 0 +} + +# $1 +# $2 +# $3 "on" | "off" +switch_control() { + [[ -n "$3" && -n "$1" ]] || bugout + systemd-cat -t "livecdsound" printf "Switching control: %s on card: %s to %s\n" "$2" "$1" "$3" + systemd-cat -t "livecdsound" amixer -c "$1" set "$2" "$3" + return 0 +} + +# $1 +sanify_levels_on_card() { + unmute_and_set_level "$1" "Front" "80%" + unmute_and_set_level "$1" "Master" "80%" + unmute_and_set_level "$1" "Master Mono" "80%" + unmute_and_set_level "$1" "Master Digital" "80%" # E.g., cs4237B + unmute_and_set_level "$1" "Playback" "80%" + unmute_and_set_level "$1" "Headphone" "100%" + unmute_and_set_level "$1" "PCM" "80%" + unmute_and_set_level "$1" "PCM,1" "80%" # E.g., ess1969 + unmute_and_set_level "$1" "DAC" "80%" # E.g., envy24, cs46xx + unmute_and_set_level "$1" "DAC,0" "80%" # E.g., envy24 + unmute_and_set_level "$1" "DAC,1" "80%" # E.g., envy24 + unmute_and_set_level "$1" "Synth" "80%" + unmute_and_set_level "$1" "CD" "80%" + unmute_and_set_level "$1" "PC Speaker" "100%" + + mute_and_zero_level "$1" "Mic" + mute_and_zero_level "$1" "IEC958" # Ubuntu #19648 + + # Intel P4P800-MX + switch_control "$1" "Master Playback Switch" on + switch_control "$1" "Master Surround" on + + # Trident/YMFPCI/emu10k1: + unmute_and_set_level "$1" "Wave" "80%" + unmute_and_set_level "$1" "Music" "80%" + unmute_and_set_level "$1" "AC97" "80%" + + # DRC: + unmute_and_set_level "$1" "Dynamic Range Compression" "80%" + + # Required for HDA Intel (hda-intel): + unmute_and_set_level "$1" "Front" "80%" + + # Required for SB Live 7.1/24-bit (ca0106): + unmute_and_set_level "$1" "Analog Front" "80%" + + # Required at least for Via 823x hardware on DFI K8M800-MLVF Motherboard + switch_control "$1" "IEC958 Capture Monitor" off + + # Required for hardware allowing toggles for AC97 through IEC958, + # valid values are 0, 1, 2, 3. Needs to be set to 0 for PCM1. + unmute_and_set_level "$1" "IEC958 Playback AC97-SPSA" "0" + + # Required for newer Via hardware + unmute_and_set_level "$1" "VIA DXS,0" "80%" + unmute_and_set_level "$1" "VIA DXS,1" "80%" + unmute_and_set_level "$1" "VIA DXS,2" "80%" + unmute_and_set_level "$1" "VIA DXS,3" "80%" + + # Required on some notebooks with ICH4: + switch_control "$1" "Headphone Jack Sense" off + switch_control "$1" "Line Jack Sense" off + + # Some machines need one or more of these to be on; + # others need one or more of these to be off: + + switch_control "$1" "Audigy Analog/Digital Output Jack" on + switch_control "$1" "SB Live Analog/Digital Output Jack" on + + # D1984 -- Thinkpad T61/X61 + switch_control "$1" "Speaker" on + switch_control "$1" "Headphone" on + + # HDA-Intel w/ "Digital" capture mixer (See Ubuntu #193823) + unmute_and_set_level "$1" "Digital" "80%" + + return 0 +} + +# $1 | "all" +sanify_levels() { + local ttsdml_returnstatus=0 + local card + case "$1" in + all) + for card in $(echo_card_indices); do + sanify_levels_on_card "$card" || ttsdml_returnstatus=1 + done + ;; + *) + sanify_levels_on_card "$1" || ttsdml_returnstatus=1 + ;; + esac + return "$ttsdml_returnstatus" +} + +# List all cards that *should* be usable for PCM audio. In my experience, +# the console speaker (handled by the pcsp driver) isn't a suitable playback +# device, so we'll exclude it. +list_non_pcsp_cards() { + for card in $(echo_card_indices); do + local cardfile="/proc/asound/card${card}/id" + if [[ -r "$cardfile" && -f "$cardfile" && "$(cat "$cardfile")" != pcsp ]]; then + echo "$card" + fi + done +} + +# Properly initialize the sound card so that we have audio at boot. +unmute_all_cards() { + sanify_levels all +} + +is_numeric() { + local str="$1" + [[ "$str" =~ ^[0-9]+$ ]] +} + +set_default_card() { + local card="$1" + sed -e "s/%card%/$card/g" /etc/asound.conf +} + +play_on_card() { + local card="$1" file="$2" + aplay -q "-Dplughw:$card,0" "$file" +} + +# If there are multiple usable sound cards, prompt the user to choose one, +# using auditory feedback. +pick_a_card() { + set -f + usable_cards="$(list_non_pcsp_cards)" + num_usable_cards="$(wc -w <<<"$usable_cards")" + + if (( num_usable_cards == 1 )); then + systemd-cat -t "livecdsound" printf "Only one sound card is detected\n" + exit 0 + fi + systemd-cat -t "livecdsound" printf "multiple sound cards detected\n" + for card in "${usable_cards[@]}"; do + if ! is_numeric "$card"; then + continue + fi + play_on_card "$card" /usr/share/livecd-sounds/pick-a-card.wav & + done + wait + sleep 1 + for card in "${usable_cards[@]}"; do + if ! is_numeric "$card"; then + continue + fi + play_on_card "$card" /usr/share/livecd-sounds/beep.wav + if read -r -t 10; then + systemd-cat -t "livecdsound" printf "Selecting %s sound card as default\n" "$card" + set_default_card "$card" + break + fi + done +} + +if (( $# == 0 )); then + echo "error: No argument passed." + exit 1 +fi +while [[ "${1}" != "" ]]; do + case ${1} in + -h|--help) + usage + exit + ;; + -u|--unmute) + systemd-cat -t "livecdsound" printf "Unmuting all cards" + unmute_all_cards + ;; + -p|--pick) + pick_a_card + ;; + *) + echo "error: Unsupported argument" + usage + exit 1 + ;; + esac + shift +done diff --git a/releng/airootfs/usr/local/share/livecd-sound/asound.conf.in b/releng/airootfs/usr/local/share/livecd-sound/asound.conf.in new file mode 100644 index 0000000..3f9c7aa --- /dev/null +++ b/releng/airootfs/usr/local/share/livecd-sound/asound.conf.in @@ -0,0 +1,3 @@ +Defaults node +defaults.ctl.card %card%; +defaults.pcm.card %card%; diff --git a/releng/airootfs/usr/share/pacman/keyrings/chaotic-revoked b/releng/airootfs/usr/share/pacman/keyrings/chaotic-revoked new file mode 100644 index 0000000..c487530 --- /dev/null +++ b/releng/airootfs/usr/share/pacman/keyrings/chaotic-revoked @@ -0,0 +1,3 @@ +3FFA0B5E092ED4095E26F69B8ADB4AEC585061CF +1A79037533A110285AE92EF4FAF4946E8D60D074 +E732131CAF3C03724EF141A0749E88C8EC38D662 diff --git a/releng/airootfs/usr/share/pacman/keyrings/chaotic-trusted b/releng/airootfs/usr/share/pacman/keyrings/chaotic-trusted new file mode 100644 index 0000000..160fafb --- /dev/null +++ b/releng/airootfs/usr/share/pacman/keyrings/chaotic-trusted @@ -0,0 +1,6 @@ +EF925EA60F33D0CB85C44AD13056513887B78AEB:4: +1949E60D299007430C94DC0657F3D9CC660431DD:4: +3C3BE09E904072467EFEF0A395A6D49D0BBD2A8B:4: +A3873AB27021C5DD39E0501AFBA220DFC880C036:4: +1F0716DC94015CAC77FA65B619A2282AFCA8A81E:4: +67BF8CA6DA181643C9723B4ED6C9442437365605:4: diff --git a/releng/airootfs/usr/share/pacman/keyrings/chaotic.gpg b/releng/airootfs/usr/share/pacman/keyrings/chaotic.gpg new file mode 100644 index 0000000..bf05379 --- /dev/null +++ b/releng/airootfs/usr/share/pacman/keyrings/chaotic.gpg @@ -0,0 +1,542 @@ +-----BEGIN PGP PUBLIC KEY BLOCK----- + +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 +vdVamgUjUjENZ2WwHhGPtw== +=JdEm +-----END PGP PUBLIC KEY BLOCK----- +-----BEGIN PGP PUBLIC KEY BLOCK----- + +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 +=heFL +-----END PGP PUBLIC KEY BLOCK----- +-----BEGIN PGP PUBLIC KEY BLOCK----- + +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 +xEMp1jcrxSMy142Oco2VO/9T2g== +=tOkG +-----END PGP PUBLIC KEY BLOCK----- +-----BEGIN PGP PUBLIC KEY BLOCK----- + +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 +=T5nV +-----END PGP PUBLIC KEY BLOCK----- +-----BEGIN PGP PUBLIC KEY BLOCK----- + +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 +Axzd9A5vN54= +=JHlU +-----END PGP PUBLIC KEY BLOCK----- +-----BEGIN PGP PUBLIC KEY BLOCK----- + +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 +rVZx6wYz0qCUl1xwEbPkgIdw3rCiEPaseCQ= +=HsoV +-----END PGP PUBLIC KEY BLOCK----- +-----BEGIN PGP PUBLIC KEY BLOCK----- + +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 +=k+Zf +-----END PGP PUBLIC KEY BLOCK----- +-----BEGIN PGP PUBLIC KEY BLOCK----- + +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 +oQ0= +=Bkh0 +-----END PGP PUBLIC KEY BLOCK----- +-----BEGIN PGP PUBLIC KEY BLOCK----- + +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 +=LIbz +-----END PGP PUBLIC KEY BLOCK----- diff --git a/releng/bootstrap_packages.x86_64 b/releng/bootstrap_packages.x86_64 new file mode 100644 index 0000000..64966d0 --- /dev/null +++ b/releng/bootstrap_packages.x86_64 @@ -0,0 +1,2 @@ +arch-install-scripts +base diff --git a/releng/efiboot/loader/entries/01-archiso-x86_64-linux.conf b/releng/efiboot/loader/entries/01-archiso-x86_64-linux.conf new file mode 100644 index 0000000..9dd9b8a --- /dev/null +++ b/releng/efiboot/loader/entries/01-archiso-x86_64-linux.conf @@ -0,0 +1,5 @@ +title Rhpidfyre Linux install medium (x86_64, UEFI) +sort-key 01 +linux /%INSTALL_DIR%/boot/x86_64/vmlinuz-linux +initrd /%INSTALL_DIR%/boot/x86_64/initramfs-linux.img +options archisobasedir=%INSTALL_DIR% archisosearchuuid=%ARCHISO_UUID% diff --git a/releng/efiboot/loader/entries/02-archiso-x86_64-speech-linux.conf b/releng/efiboot/loader/entries/02-archiso-x86_64-speech-linux.conf new file mode 100644 index 0000000..727d348 --- /dev/null +++ b/releng/efiboot/loader/entries/02-archiso-x86_64-speech-linux.conf @@ -0,0 +1,5 @@ +title Rhpidfyre Linux install medium (x86_64, UEFI) with speech +sort-key 02 +linux /%INSTALL_DIR%/boot/x86_64/vmlinuz-linux +initrd /%INSTALL_DIR%/boot/x86_64/initramfs-linux.img +options archisobasedir=%INSTALL_DIR% archisosearchuuid=%ARCHISO_UUID% accessibility=on diff --git a/releng/efiboot/loader/entries/03-archiso-x86_64-memtest86+.conf b/releng/efiboot/loader/entries/03-archiso-x86_64-memtest86+.conf new file mode 100644 index 0000000..d0b305c --- /dev/null +++ b/releng/efiboot/loader/entries/03-archiso-x86_64-memtest86+.conf @@ -0,0 +1,3 @@ +title Memtest86+ +sort-key 03 +efi /boot/memtest86+/memtest.efi diff --git a/releng/efiboot/loader/loader.conf b/releng/efiboot/loader/loader.conf new file mode 100644 index 0000000..2d137aa --- /dev/null +++ b/releng/efiboot/loader/loader.conf @@ -0,0 +1,3 @@ +timeout 15 +default 01-archiso-x86_64-linux.conf +beep on diff --git a/releng/grub/grub.cfg b/releng/grub/grub.cfg new file mode 100644 index 0000000..25194a3 --- /dev/null +++ b/releng/grub/grub.cfg @@ -0,0 +1,107 @@ +# Load partition table and file system modules +insmod part_gpt +insmod part_msdos +insmod fat +insmod iso9660 +insmod ntfs +insmod ntfscomp +insmod exfat +insmod udf + +# Use graphics-mode output +if loadfont "${prefix}/fonts/unicode.pf2" ; then + insmod all_video + set gfxmode="auto" + terminal_input console + terminal_output console +fi + +# Enable serial console +insmod serial +insmod usbserial_common +insmod usbserial_ftdi +insmod usbserial_pl2303 +insmod usbserial_usbdebug +if serial --unit=0 --speed=115200; then + terminal_input --append serial + terminal_output --append serial +fi + +# Get a human readable platform identifier +if [ "${grub_platform}" == 'efi' ]; then + archiso_platform='UEFI' + if [ "${grub_cpu}" == 'x86_64' ]; then + archiso_platform="x64 ${archiso_platform}" + elif [ "${grub_cpu}" == 'i386' ]; then + archiso_platform="IA32 ${archiso_platform}" + else + archiso_platform="${grub_cpu} ${archiso_platform}" + fi +elif [ "${grub_platform}" == 'pc' ]; then + archiso_platform='BIOS' +else + archiso_platform="${grub_cpu} ${grub_platform}" +fi + +# Set default menu entry +default=archlinux +timeout=15 +timeout_style=menu + + +# Menu entries + +menuentry "Arch Linux install medium (%ARCH%, ${archiso_platform})" --class arch --class gnu-linux --class gnu --class os --id 'archlinux' { + set gfxpayload=keep + linux /%INSTALL_DIR%/boot/%ARCH%/vmlinuz-linux archisobasedir=%INSTALL_DIR% archisosearchuuid=%ARCHISO_UUID% + initrd /%INSTALL_DIR%/boot/%ARCH%/initramfs-linux.img +} + +menuentry "Arch Linux install medium with speakup screen reader (%ARCH%, ${archiso_platform})" --hotkey s --class arch --class gnu-linux --class gnu --class os --id 'archlinux-accessibility' { + set gfxpayload=keep + linux /%INSTALL_DIR%/boot/%ARCH%/vmlinuz-linux archisobasedir=%INSTALL_DIR% archisosearchuuid=%ARCHISO_UUID% accessibility=on + initrd /%INSTALL_DIR%/boot/%ARCH%/initramfs-linux.img +} + + +if [ "${grub_platform}" == 'efi' -a "${grub_cpu}" == 'x86_64' -a -f '/boot/memtest86+/memtest.efi' ]; then + menuentry 'Run Memtest86+ (RAM test)' --class memtest86 --class memtest --class gnu --class tool { + set gfxpayload=800x600,1024x768 + linux /boot/memtest86+/memtest.efi + } +fi +if [ "${grub_platform}" == 'pc' -a -f '/boot/memtest86+/memtest' ]; then + menuentry 'Run Memtest86+ (RAM test)' --class memtest86 --class memtest --class gnu --class tool { + set gfxpayload=800x600,1024x768 + linux /boot/memtest86+/memtest + } +fi +if [ "${grub_platform}" == 'efi' ]; then + if [ "${grub_cpu}" == 'x86_64' -a -f '/shellx64.efi' ]; then + menuentry 'UEFI Shell' --class efi { + chainloader /shellx64.efi + } + elif [ "${grub_cpu}" == "i386" -a -f '/shellia32.efi' ]; then + menuentry 'UEFI Shell' --class efi { + chainloader /shellia32.efi + } + fi + + menuentry 'UEFI Firmware Settings' --id 'uefi-firmware' { + fwsetup + } +fi + +menuentry 'System shutdown' --class shutdown --class poweroff { + echo 'System shutting down...' + halt +} + +menuentry 'System restart' --class reboot --class restart { + echo 'System rebooting...' + reboot +} + + +# GRUB init tune for accessibility +play 600 988 1 1319 4 diff --git a/releng/grub/loopback.cfg b/releng/grub/loopback.cfg new file mode 100644 index 0000000..d7d5ece --- /dev/null +++ b/releng/grub/loopback.cfg @@ -0,0 +1,80 @@ +# https://www.supergrubdisk.org/wiki/Loopback.cfg + +# Search for the ISO volume +search --no-floppy --set=archiso_img_dev --file "${iso_path}" +probe --set archiso_img_dev_uuid --fs-uuid "${archiso_img_dev}" + +# Get a human readable platform identifier +if [ "${grub_platform}" == 'efi' ]; then + archiso_platform='UEFI' + if [ "${grub_cpu}" == 'x86_64' ]; then + archiso_platform="x64 ${archiso_platform}" + elif [ "${grub_cpu}" == 'i386' ]; then + archiso_platform="IA32 ${archiso_platform}" + else + archiso_platform="${grub_cpu} ${archiso_platform}" + fi +elif [ "${grub_platform}" == 'pc' ]; then + archiso_platform='BIOS' +else + archiso_platform="${grub_cpu} ${grub_platform}" +fi + +# Set default menu entry +default=archlinux +timeout=15 +timeout_style=menu + + +# Menu entries + +menuentry "Arch Linux install medium (%ARCH%, ${archiso_platform})" --class arch --class gnu-linux --class gnu --class os --id 'archlinux' { + set gfxpayload=keep + linux /%INSTALL_DIR%/boot/%ARCH%/vmlinuz-linux archisobasedir=%INSTALL_DIR% img_dev=UUID=${archiso_img_dev_uuid} img_loop="${iso_path}" + initrd /%INSTALL_DIR%/boot/%ARCH%/initramfs-linux.img +} + +menuentry "Arch Linux install medium with speakup screen reader (%ARCH%, ${archiso_platform})" --hotkey s --class arch --class gnu-linux --class gnu --class os --id 'archlinux-accessibility' { + set gfxpayload=keep + linux /%INSTALL_DIR%/boot/%ARCH%/vmlinuz-linux archisobasedir=%INSTALL_DIR% img_dev=UUID=${archiso_img_dev_uuid} img_loop="${iso_path}" accessibility=on + initrd /%INSTALL_DIR%/boot/%ARCH%/initramfs-linux.img +} + + +if [ "${grub_platform}" == 'efi' -a "${grub_cpu}" == 'x86_64' -a -f '/boot/memtest86+/memtest.efi' ]; then + menuentry 'Run Memtest86+ (RAM test)' --class memtest86 --class memtest --class gnu --class tool { + set gfxpayload=800x600,1024x768 + linux /boot/memtest86+/memtest.efi + } +fi +if [ "${grub_platform}" == 'pc' -a -f '/boot/memtest86+/memtest' ]; then + menuentry 'Run Memtest86+ (RAM test)' --class memtest86 --class memtest --class gnu --class tool { + set gfxpayload=800x600,1024x768 + linux /boot/memtest86+/memtest + } +fi +if [ "${grub_platform}" == 'efi' ]; then + if [ "${grub_cpu}" == 'x86_64' -a -f '/shellx64.efi' ]; then + menuentry 'UEFI Shell' --class efi { + chainloader /shellx64.efi + } + elif [ "${grub_cpu}" == "i386" -a -f '/shellia32.efi' ]; then + menuentry 'UEFI Shell' --class efi { + chainloader /shellia32.efi + } + fi + + menuentry 'UEFI Firmware Settings' --id 'uefi-firmware' { + fwsetup + } +fi + +menuentry 'System shutdown' --class shutdown --class poweroff { + echo 'System shutting down...' + halt +} + +menuentry 'System restart' --class reboot --class restart { + echo 'System rebooting...' + reboot +} diff --git a/releng/packages.x86_64 b/releng/packages.x86_64 new file mode 100644 index 0000000..1e798e5 --- /dev/null +++ b/releng/packages.x86_64 @@ -0,0 +1,161 @@ +alsa-utils +amd-ucode +arch-install-scripts +archinstall +b43-fwcutter +base +bcachefs-tools +bind +bolt +brltty +broadcom-wl +btrfs-progs +clonezilla +cloud-init +cryptsetup +darkhttpd +ddrescue +dhcpcd +diffutils +dmidecode +dmraid +dnsmasq +dosfstools +e2fsprogs +edk2-shell +efibootmgr +espeakup +ethtool +exfatprogs +f2fs-tools +fatresize +foot-terminfo +fsarchiver +gpart +gpm +gptfdisk +grml-zsh-config +grub +hdparm +hyperv +intel-ucode +irssi +iw +iwd +jfsutils +kitty-terminfo +ldns +less +lftp +libfido2 +libusb-compat +linux-zen +linux-atm +linux-firmware +linux-firmware-marvell +livecd-sounds +lsscsi +lvm2 +lynx +man-db +man-pages +mc +mdadm +memtest86+ +memtest86+-efi +mkinitcpio +mkinitcpio-archiso +mkinitcpio-nfs-utils +modemmanager +mtools +nano +nbd +ndisc6 +nfs-utils +nilfs-utils +nmap +ntfs-3g +nvme-cli +open-iscsi +open-vm-tools +openconnect +openpgp-card-tools +openssh +openvpn +partclone +parted +partimage +pcsclite +ppp +pptpclient +pv +qemu-guest-agent +refind +reflector +rp-pppoe +rsync +rxvt-unicode-terminfo +screen +sdparm +sequoia-sq +sg3_utils +smartmontools +sof-firmware +squashfs-tools +sudo +syslinux +systemd-resolvconf +tcpdump +terminus-font +testdisk +tmux +tpm2-tools +tpm2-tss +udftools +usb_modeswitch +usbmuxd +usbutils +vim +virtualbox-guest-utils-nox +vpnc +wireless-regdb +wireless_tools +wpa_supplicant +wvdial +xfsprogs +xl2tpd +zsh + +spice-vdagent +qemu-guest-agent +adwaita-cursors +plasma-meta +kate +dolphin +dolphin-plugins +ffmpegthumbs +ark +plasma-workspace +gwenview +btop +nvtop +neovim +reflector +mission-center +materia-kde +materia-gtk-theme +papirus-icon-theme +xterm +fastfetch +sddm +mpv +tealdeer +ghostty +chromium +bat +bat-extras +fish +git +paru +floorp +filelight diff --git a/releng/pacman.conf b/releng/pacman.conf new file mode 100644 index 0000000..fd3e298 --- /dev/null +++ b/releng/pacman.conf @@ -0,0 +1,103 @@ +# +# /etc/pacman.conf +# +# See the pacman.conf(5) manpage for option and repository directives + +# +# GENERAL OPTIONS +# +[options] +# The following paths are commented out with their default values listed. +# If you wish to use different paths, uncomment and update the paths. +#RootDir = / +#DBPath = /var/lib/pacman/ +#CacheDir = /var/cache/pacman/pkg/ +#LogFile = /var/log/pacman.log +#GPGDir = /etc/pacman.d/gnupg/ +#HookDir = /etc/pacman.d/hooks/ +HoldPkg = pacman glibc +#XferCommand = /usr/bin/curl -L -C - -f -o %o %u +#XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u +#CleanMethod = KeepInstalled +Architecture = auto + +# Pacman won't upgrade packages listed in IgnorePkg and members of IgnoreGroup +#IgnorePkg = +#IgnoreGroup = + +#NoUpgrade = +#NoExtract = + +# Misc options +#UseSyslog +Color +#NoProgressBar +CheckSpace +VerbosePkgLists +ParallelDownloads = 5 +DownloadUser = alpm +ILoveCandy +#DisableSandbox + +# By default, pacman accepts packages signed by keys that its local keyring +# trusts (see pacman-key and its man page), as well as unsigned packages. +SigLevel = Required DatabaseOptional +LocalFileSigLevel = Optional +#RemoteFileSigLevel = Required + +# NOTE: You must run `pacman-key --init` before first using pacman; the local +# keyring can then be populated with the keys of all official Arch Linux +# packagers with `pacman-key --populate archlinux`. + +# +# REPOSITORIES +# - can be defined here or included from another file +# - pacman will search repositories in the order defined here +# - local/custom mirrors can be added here or in separate files +# - repositories listed first will take precedence when packages +# have identical names, regardless of version number +# - URLs will have $repo replaced by the name of the current repo +# - URLs will have $arch replaced by the name of the architecture +# +# Repository entries are of the format: +# [repo-name] +# Server = ServerName +# Include = IncludePath +# +# The header [repo-name] is crucial - it must be present and +# uncommented to enable the repo. +# + +# The testing repositories are disabled by default. To enable, uncomment the +# repo name header and Include lines. You can add preferred servers immediately +# after the header, and they will be used before the default mirrors. + +#[core-testing] +#Include = /etc/pacman.d/mirrorlist + +[core] +Include = /etc/pacman.d/mirrorlist + +#[extra-testing] +#Include = /etc/pacman.d/mirrorlist + +[extra] +Include = /etc/pacman.d/mirrorlist + +# If you want to run 32 bit applications on your x86_64 system, +# enable the multilib repositories as required here. + +#[multilib-testing] +#Include = /etc/pacman.d/mirrorlist + +[multilib] +Include = /etc/pacman.d/mirrorlist + +# An example of a custom package repository. See the pacman manpage for +# tips on creating your own repositories. +#[custom] +#SigLevel = Optional TrustAll +#Server = file:///home/custompkgs + +[chaotic-aur] +Include = /etc/pacman.d/chaotic-mirrorlist diff --git a/releng/profiledef.sh b/releng/profiledef.sh new file mode 100644 index 0000000..d9be5e0 --- /dev/null +++ b/releng/profiledef.sh @@ -0,0 +1,28 @@ +#!/usr/bin/env bash +# shellcheck disable=SC2034 + +iso_name="rhpidfyre Linux" +iso_label="rhpidfyre-linux_$(date --date="@${SOURCE_DATE_EPOCH:-$(date +%s)}" +%Y%m)" +iso_publisher="rhpidfyre Linux " +iso_application="rhpidfyre Linux Live ISO" +iso_version="$(date --date="@${SOURCE_DATE_EPOCH:-$(date +%s)}" +%Y.%m.%d)" +install_dir="arch" +buildmodes=('iso') +bootmodes=('bios.syslinux.mbr' 'bios.syslinux.eltorito' + 'uefi-ia32.systemd-boot.esp' 'uefi-x64.systemd-boot.esp' + 'uefi-ia32.systemd-boot.eltorito' 'uefi-x64.systemd-boot.eltorito') +arch="x86_64" +pacman_conf="pacman.conf" +airootfs_image_type="squashfs" +airootfs_image_tool_options=('-comp' 'xz' '-Xbcj' 'x86' '-b' '1M' '-Xdict-size' '1M') +bootstrap_tarball_compression=('zstd' '-c' '-T0' '--auto-threads=logical' '--long' '-19') +file_permissions=( + ["/etc/shadow"]="0:0:400" + ["/etc/gshadow"]="0:0:400" + ["/root"]="0:0:750" + ["/root/.automated_script.sh"]="0:0:755" + ["/root/.gnupg"]="0:0:700" + ["/usr/local/bin/choose-mirror"]="0:0:755" + ["/usr/local/bin/Installation_guide"]="0:0:755" + ["/usr/local/bin/livecd-sound"]="0:0:755" +) diff --git a/releng/syslinux/archiso_head.cfg b/releng/syslinux/archiso_head.cfg new file mode 100644 index 0000000..671ab4e --- /dev/null +++ b/releng/syslinux/archiso_head.cfg @@ -0,0 +1,28 @@ +SERIAL 0 115200 +UI vesamenu.c32 +MENU TITLE Arch Linux +MENU BACKGROUND splash.png + +MENU WIDTH 78 +MENU MARGIN 4 +MENU ROWS 7 +MENU VSHIFT 10 +MENU TABMSGROW 14 +MENU CMDLINEROW 14 +MENU HELPMSGROW 16 +MENU HELPMSGENDROW 29 + +# Refer to https://wiki.syslinux.org/wiki/index.php/Comboot/menu.c32 + +MENU COLOR border 30;44 #40ffffff #a0000000 std +MENU COLOR title 1;36;44 #9033ccff #a0000000 std +MENU COLOR sel 7;37;40 #e0ffffff #20ffffff all +MENU COLOR unsel 37;44 #50ffffff #a0000000 std +MENU COLOR help 37;40 #c0ffffff #a0000000 std +MENU COLOR timeout_msg 37;40 #80ffffff #00000000 std +MENU COLOR timeout 1;37;40 #c0ffffff #00000000 std +MENU COLOR msg07 37;40 #90ffffff #a0000000 std +MENU COLOR tabmsg 31;40 #30ffffff #00000000 std + +MENU CLEAR +MENU IMMEDIATE diff --git a/releng/syslinux/archiso_pxe-linux.cfg b/releng/syslinux/archiso_pxe-linux.cfg new file mode 100644 index 0000000..5d0f741 --- /dev/null +++ b/releng/syslinux/archiso_pxe-linux.cfg @@ -0,0 +1,32 @@ +LABEL arch64_nbd +TEXT HELP +Boot the Arch Linux install medium using NBD. +It allows you to install Arch Linux or perform system maintenance. +ENDTEXT +MENU LABEL Arch Linux install medium (x86_64, NBD) +LINUX ::/%INSTALL_DIR%/boot/x86_64/vmlinuz-linux +INITRD ::/%INSTALL_DIR%/boot/x86_64/initramfs-linux.img +APPEND archisobasedir=%INSTALL_DIR% archisosearchuuid=%ARCHISO_UUID% archiso_nbd_srv=${pxeserver} cms_verify=y +SYSAPPEND 3 + +LABEL arch64_nfs +TEXT HELP +Boot the Arch Linux live medium using NFS. +It allows you to install Arch Linux or perform system maintenance. +ENDTEXT +MENU LABEL Arch Linux install medium (x86_64, NFS) +LINUX ::/%INSTALL_DIR%/boot/x86_64/vmlinuz-linux +INITRD ::/%INSTALL_DIR%/boot/x86_64/initramfs-linux.img +APPEND archisobasedir=%INSTALL_DIR% archiso_nfs_srv=${pxeserver}:/run/archiso/bootmnt cms_verify=y +SYSAPPEND 3 + +LABEL arch64_http +TEXT HELP +Boot the Arch Linux live medium using HTTP. +It allows you to install Arch Linux or perform system maintenance. +ENDTEXT +MENU LABEL Arch Linux install medium (x86_64, HTTP) +LINUX ::/%INSTALL_DIR%/boot/x86_64/vmlinuz-linux +INITRD ::/%INSTALL_DIR%/boot/x86_64/initramfs-linux.img +APPEND archisobasedir=%INSTALL_DIR% archiso_http_srv=http://${pxeserver}/ cms_verify=y +SYSAPPEND 3 diff --git a/releng/syslinux/archiso_pxe.cfg b/releng/syslinux/archiso_pxe.cfg new file mode 100644 index 0000000..b4c9a80 --- /dev/null +++ b/releng/syslinux/archiso_pxe.cfg @@ -0,0 +1,5 @@ +INCLUDE archiso_head.cfg + +INCLUDE archiso_pxe-linux.cfg + +INCLUDE archiso_tail.cfg diff --git a/releng/syslinux/archiso_sys-linux.cfg b/releng/syslinux/archiso_sys-linux.cfg new file mode 100644 index 0000000..919e158 --- /dev/null +++ b/releng/syslinux/archiso_sys-linux.cfg @@ -0,0 +1,20 @@ +LABEL arch64 +TEXT HELP +Boot the Arch Linux install medium on BIOS. +It allows you to install Arch Linux or perform system maintenance. +ENDTEXT +MENU LABEL Arch Linux install medium (x86_64, BIOS) +LINUX /%INSTALL_DIR%/boot/x86_64/vmlinuz-linux +INITRD /%INSTALL_DIR%/boot/x86_64/initramfs-linux.img +APPEND archisobasedir=%INSTALL_DIR% archisosearchuuid=%ARCHISO_UUID% + +# Accessibility boot option +LABEL arch64speech +TEXT HELP +Boot the Arch Linux install medium on BIOS with speakup screen reader. +It allows you to install Arch Linux or perform system maintenance with speech feedback. +ENDTEXT +MENU LABEL Arch Linux install medium (x86_64, BIOS) with ^speech +LINUX /%INSTALL_DIR%/boot/x86_64/vmlinuz-linux +INITRD /%INSTALL_DIR%/boot/x86_64/initramfs-linux.img +APPEND archisobasedir=%INSTALL_DIR% archisosearchuuid=%ARCHISO_UUID% accessibility=on diff --git a/releng/syslinux/archiso_sys.cfg b/releng/syslinux/archiso_sys.cfg new file mode 100644 index 0000000..d93bcfe --- /dev/null +++ b/releng/syslinux/archiso_sys.cfg @@ -0,0 +1,8 @@ +INCLUDE archiso_head.cfg + +DEFAULT arch64 +TIMEOUT 150 + +INCLUDE archiso_sys-linux.cfg + +INCLUDE archiso_tail.cfg diff --git a/releng/syslinux/archiso_tail.cfg b/releng/syslinux/archiso_tail.cfg new file mode 100644 index 0000000..e84897c --- /dev/null +++ b/releng/syslinux/archiso_tail.cfg @@ -0,0 +1,35 @@ +LABEL existing +TEXT HELP +Boot an existing operating system. +Press TAB to edit the disk and partition number to boot. +ENDTEXT +MENU LABEL Boot existing OS +COM32 chain.c32 +APPEND hd0 0 + +# https://www.memtest.org/ +LABEL memtest +MENU LABEL Run Memtest86+ (RAM test) +LINUX /boot/memtest86+/memtest + +# https://wiki.syslinux.org/wiki/index.php/Hdt_(Hardware_Detection_Tool) +LABEL hdt +MENU LABEL Hardware Information (HDT) +COM32 hdt.c32 +APPEND modules_alias=hdt/modalias.gz pciids=hdt/pciids.gz + +LABEL reboot +TEXT HELP +Reboot computer. +The computer's firmware must support APM. +ENDTEXT +MENU LABEL Reboot +COM32 reboot.c32 + +LABEL poweroff +TEXT HELP +Power off computer. +The computer's firmware must support APM. +ENDTEXT +MENU LABEL Power Off +COM32 poweroff.c32 diff --git a/releng/syslinux/splash.png b/releng/syslinux/splash.png new file mode 100644 index 0000000000000000000000000000000000000000..64b959a61efb767a58d484601f122f6d4ead5a8a GIT binary patch literal 45400 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