commit 1aacb9fa39f38e07a8992e730be850710de4d7da Author: rhpidfyre Date: Tue May 27 01:42:27 2025 -0400 init commit 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----- + +mQINBGK0oT4BEACut59DLMUjepIXsSNOOP2C+d7PcZBwdjBBx+qkhvkJK9xlabzS +uLJjklbH7v7BABmXand9LFE0Zs0flF6s+nMyBlS2n7UGZfn4M1X7qfZ7hq2TRaxl +dDcORI874rXuBJAL/rC2tEkaL0W2CGCf1hFly1Ns1fy/AccwioVQVtzPuIN4XN9A +Fz4WvVKRFdiUHEMNii5Qy6/OG3ab9h8/Wxh36j5LjBu23TnA4PvYlKaACybNrvaR +zrI1eT1vLzJ55kYzyl2fn9auDCnBZSiXbxazVc0njeC1TY7PzwPvRz1+/Y9qR3Gx +Ql47JwGJYikG0T522RhKwdXjpg3bPZCvEWgqVqTzMK6tt8mh+MppI2rgMRkGNOIG +VrEt+2yBtk3qjJRfReQsVc83F8U2/4QFyhbbdoPhcUjGJV/I6xIdGb3r/ErqkU01 +Gxswn0zFXk1wepF2lnowmqL13vfDgLqQg4W0QU0PeeOaXDYLh75Rkr5EBMPbi+RH +tLKw7xBTV8hNT43SXM00KPF3VHR/dcCBBXE9JQoyqkcnCXAwaQQdsml3ZofKHawP ++Y0i27gXLQx3k1nJdhTnqRowGB23cTmHOqJ7D98fp3Oh/cG7BWq+IU5XJFsFVMUr +SbEWAaZ6/w0GLmWXDk8AIBqX0cicIUqHXzsI76J688RhPdJzmwSdQrl5kQARAQAB +tDpOaWNvIEplbnNjaCAoQ2hhb3RpYy1BVVIgJzIyKSA8Y2hhb3RpYy1hdXJAZHI0 +NjBuZjFyMy5vcmc+iQJUBBMBCAA+FiEEPDvgnpBAckZ+/vCjlabUnQu9KosFAmK0 +oT4CGwMFCQ8L12IFCwkIBwIGFQoJCAsCBBYCAwECHgECF4AACgkQlabUnQu9KotJ ++g/+KuIu5xBJkWwIEvpUSndQcIlojq8Q9t+ZDWWB9DyNrwwhtHKN4AIbJs3yNE5S +aPejplEooXkN2ue1CciQQwNpHyzFcKeZLVi1QwXaBthfRgORDwpqCe8xP/gtKTIY +DZrYh/CzT0Um8IhG/S/Vfaf7k7Zq6AssyR9wy9YTW7PFCI/JoQmaPc0tkIEIPp5v +6qhvDq8oym16D0ufyF3L+a+VKQyOlS5AHzj16VfOdDLdwImXipJ3azgWbKI42kar +bmM7/Zt5R9JB2epTeqYd6qhjn58XtmQuFm8Dv+u5Eywso7Uubzlz7eXHRVwtf3yd +qe3INs3UHPIU88GINfnt1sSK5J5YXhFrDtY/oxpFXE8zWRaf/B0Aekreo5tONGQ4 +IAnuAp2LewzF349nXKzOymL/hr9t4QJLcsVDRAvZrJ4C0pPUJlZnpVbbFOtV1gdg +oWG5CjlKp9Y+ZrED3meGGBPwayEsjnsKitslMF2UVyGRN1qPLMsMyLFgmYtUmPVX +6SLQ5D3R7wQ5u5OV8pUk0hd3Q/fCZOG4gG2CaxRUJ0Kh7b7VDr1ZqPuoUi0aoSAp +W2zldMhrJ726oaDjHsZR2H08nYQiEcIW697tKpJ6pqKPeWsT0gZpfocoDIOljTO7 +i2Q9Z61GrLPle9MBoTO+qG1ZieahckzSDO86Kb+jdTJnrsi5Ag0EYrShPgEQALpA +Z55oWyPYE7pYE234TgqlzrQ9lOkOv15IsKyUf1XYjGEDjhH2s5GLWzWm+uuiZKhi +rzvmOFWhIBrmS4t95lUH4KteumgQY3qxNOuQU9GH087iFck2mpDHUl4y+Gr2sCb9 +54HJfHN2u1ZSHEuN4RmbNsIiviMx5kHJqb7i3gOwlhdsZlE2jL5uPBSzuxeHQPUm +xXQWmR2UiLW/DdfLQmqVu3GEFAbZfo49DGJv9eHMDLSEW3MZqB4Wd3j6UF4dTMUs +HuUbUxuL7B9yoKXDX8J0DfQcHopXpYpwD0XFyIGzAnAvtvLBDyWzJn2+gYCyFj2p +UOCG9p33gnFn/XflJejgRk42EvQyiGXfiAS2RNrcesWq179KG2TfCUdWOLe0wgje +19rLcAEbKaQfEky/HaZmjJleY9DfqkhzG1/GwMplO4baDhV7NV1tYZQrun7c1woh +iD9eMdMDdgdXayrPfrtb+EhFSFJeKoCjPUGTIcCU4/mWbUAOEu6sVGGZ/kJfniFP +fSrY/zi8iYZPf17ly/Srga1tVNluIB4tKVW4khFc1CAlDEPzoOa2wcf+U+BDNafV +KC5TMXPyUSOM6I6QA2D+tvuPLVbsc5A1RB/jpy7OP17IlUfmsNuIDaoAZ44rZOg5 +01lQlaeSduB38HyY3yrD0wuskrLxzMwqqlVK6dwFABEBAAGJAjwEGAEIACYWIQQ8 +O+CekEByRn7+8KOVptSdC70qiwUCYrShPgIbDAUJDwvXYgAKCRCVptSdC70qi9+f +D/sHTlbEOO0yOTna+4EqaG86r49e6HI+gtEYDtvt50SuY3WlALqTJ5fHISpdhHB/ +6eqwl5k4T/hAFgtD7qxNQl3s24j0N/snIsPAE0ykV8tQsDUO6HUZ82XfG8tx2xo+ +5D4Nf1qNkV31yv9JhjqHwKyOv/M9mlQLOe3dV3+fxXXxGY0yLuVIoPfwJdNZN+nT +mGNDkZ4tgB1jtIg7qg2uBq63NemXXs7gxUvs0OX/vi4TmcwM8rIYQbGta3uSLCGe +w+o2Y+R8L0QR+5yapgO+vXNKcj/fF3Vtlh0kkjYqNzVXqimvhx+dnVTpNsAbIBAf +B5G2dC/uy/NDc1/YrW0LNybiQlMsPmTVpx3DYBlYlTO1Ov7hdE5oy9kgy7B1kmF3 +/ORAQssbFXmGVsgWjaUhNNUjTW2sY7P4U36FMAJFR59Ylf3gsoDIpVh6SaX8qubt +YKgxpQekGu7SGECbRl9+537sCXynUyN8rMrAqkvXiK8MQIIkaRgi28fbA+ALGw9W +/xdX7h2gSmEp8cvC1AQGE/VB/kuJL5ez0qV9CgQ7RK7BrSPHEd2bxy0wc8xSUQpk +tJGgbWCdBIFtq8429vFTB8StM8AKd7sDAZ8Vk6UL1XvekumePd0YKzJh3Q28t6hj +6exr0nD2eQlYLlEqUFd1hN+M6QpR8keV9/R4zOz4uQG+oQ== +=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----- + +mQINBGH2n68BEACtxzwcelKUkk1y4yNNcyme4voBUHmgYfwMRaMxJX6I4ciVE7NP +18hBnX01T9nI7vaEZvc0agl8LcKUJT5mMBA5CZD9ItXn5nzbBi/oG8uTX/Pndek6 +muaLSbEiWuKxfNN2bLDkBaaGkYGWsoAG//slsRgGyp2AiWQKYp3uOjACcBosvgxP +2wz2n86Qdc7Gu49ADsUZD0Tj0BCeOL45KJAu/ByKyKLmNGlOfKmc/fAdMRuKwQFK +WU2r1onbymDTTpcCFidy16PYCXa+C/VwzLxP4ZLNcCsmDEqPt5ULI9WKWIRa0sgn +wCpzSnJM9a01Z9tlGQsS+ZUlcUKGJ4OSr5sxqTLHIgUtEdAemxm37hNe/ssn4j7T +Q7IGfpNFnrYazhPTL22OXIjDDAMDv8KFE9hRZ71IeX9vMWHBw4LsiSjeIgVpJBTt +4xUeH7mr/5giDdAxPcfDY7bI259ELrulb23dPlVYS1gzDV/M72UkhM4X1XqlDYie +3cYC8Vx7EkiM/3PhXmQldT6ce9NUtsQ2U/XygrcO10vqUhCRvak5DfQp6rNpGAWL +TU7FuJAWMxdF44UDMsOJnMxm30at5gO9dHxEUe/JdtQOjePoK0/0K6d43HWZQaxo +ZOJnUkV1iwABNwIV+g138prFRxZHO8Dz58SbzseQH2xyZC4z5/dliZeycQARAQAB +tEJFZHVhcmQgVG9sb3NhIChDaGFvdGljIEFVUiBTaWduaW5nIEtleSkgPGVkdTRy +ZHNobEBwcm90b25tYWlsLmNvbT6JAk4EEwEIADgWIQQfBxbclAFcrHf6ZbYZoigq +/KioHgUCYfafrwIbAwULCQgHAgYVCgkICwIEFgIDAQIeAQIXgAAKCRAZoigq/Kio +HqAiD/9btSMUAkzT9YbqEkrLPdzEJ4tcoqQtyxd3fVFKujd/D+5ktUrG3WQdfPA+ +Ioak971QuwrnaK4aFxlobJdndlKTRcoeJneXu6Ccb9F7/i/n7gUbfOZ/Zjz6gFG1 +auBDNEb7R8xFkqooJ2BKWES3hJxqY5V6yI/aHLhveMI/RHdg411T0HLtq2mmjUxM +W1pgsm/gDA7Gk1IvBF6ujVVZohN8jjr6zjzZV7ns0W/5vjHDpAB/dSLFkR4xUf7T +7wCy0vutSjBYyjeKlTDyXWes6JHOFrcnpG5d2sRfuqkq5pwZUzeiOcm56GiR0vs1 +JEzfysyKjbFuc+7H2vMQbFFqaZmCqPYVj4LORlewARMiKb4YJXQhbmQnIsNLeQQ3 +VTA0sGOeW6QY6YUZFovlmsKG1eEeLapUDRUHtvq8ma/lEuuFEmBzCnS96UecWa17 +gwvbajOubZxb+8LFYIxfjFoOE4QJmL0N1KDYU8kwzAMrSJoYZEAAeO5KaGOJU5Ce +Z+GyvkJc1t8HpM4zNOOd/XnMhdEd0S+w8pcJlvgFe8ie0bkHq/IY/TN3toIB50YJ +68mwKHb77+qQ+C4ByxAuFVfcKs8VNE7KDQgFzBUgGL6hCwj1+UWbN+c45VgjL4jT +z3hxUM6+qcdEdxpuOEhpktu7h1ZWEy7kcvNfB85LUwbFlmvRtrkCDQRh9p+vARAA +xStXIs/gDfvTeAhyVMcLP3hL/QcetDw1KL+vUVyHZoez034rs8PCh5Eh+7kZiGno +3ZA2PTxpb5R9abwkWxjZkKXKxsCV46RKrVMEQPEuiY7K5ts08y2CxSwewt+M/Jss +wrVZCFKKPSNG291UvDh1By6S4tVNoj/jOxy2n7ZcoiOVn1R1m22W5q3og86W5SvU +N0AR9xyMnzJLerop2CW0eiuPmMnNFZAlTMNICIVPAXW9uxpPjyZXTnvPMJz5omgp +enf45vdiXqVfCo1ql7O5rulLj+cjqGzJIZa8mTrcwweKys3/j4g+Iv06L9e2oGSz +/pfvIILLJGx4Mj7+IIApuFhWV8z3CzWf2NHNXRvZjpT8K00t5zpHimDkWndUS0ow +dTnQcH1B3yPDkBeNzsHDH/GOs+eTZrU4nJaBM2dYs10cSMozSVhO1tZ+GsnRzrlh +noS+sVV2CWkI4atSS2q8U7PMHXjuhkBC83PwUoB7B+vxXOKdCj0lKkXuVYKgAN0P +RFQ8CVgnjKucofSUx0ouHMXHNoQM8/XyGLlW4Pe6O/1N1PUY+P2g/4U49vS6QJ86 +DjiX3hV2Xktmyj12vZGk3z7CxZzN35UeUmnlli6B9N7pUnp6baoNqc+XMymLA1Ha +jabduTshGnJzoa0Lr5NIsMEnxSmTMlnvEdRUod8Wd5UAEQEAAYkCNgQYAQgAIBYh +BB8HFtyUAVysd/plthmiKCr8qKgeBQJh9p+vAhsMAAoJEBmiKCr8qKgefBUP/Rg0 +Ctdr4ttyLra7dnO9JMRAejQbqe8nCtx983qtg7jyRjGyML2L5CCwXl+fg22bCoCG +U/XN2QYp4IZtejT7LQa3tcdLgXTU8eVdOtDhZ4ZTNPw1GEYoGQN49vNAKMmCaH+t +zEVxmgdJJUeMcXSm+FGAPG20p/HW+rBTamDw2tclcW+n9OOl3ZBHcs0cmtjT/wkf +JPXeF1gDvvbUCuGhXfFIPcfIWyhpxmTBe4vSSioU4S7qaOXDCHcp1PM1ONAp9jAd +ukIHcPzJuj5a9mdnYl7Nxr9LCGn45Nb+VMpeRevQQTg+fQWLRypjHxxap7hR9fic +SQzblMiZqPn9fyzF5J1PmW9VHfMHeVbT17aiP0aQv/egz7xVTDPWcK+4X/wKoV8M +PoIMUfSMbFOQ6+dwoIpbZGQH4V23Z5HGNVAEd7svy4hjBsT6r3dCyZjsfG5Fc3L/ +PU3f+5odPuV3g8luVU9r550GaGcuASJk8e3ctymFCTCrbTn8+k4kXIZ6DhFJ8bvr +Im2OQAfWJer5Qfp+YTE+XZ8xtqlA6/P2lT1gevLnhvG1LeRzALsLFZn1EI+2IDVX +beWswjwhzll/TSCynWJdJTD5I8oXZ9XbP92tlkqJPKGn1e5E+j+7QXxUltTHusPC +OE7a+RAnCuos4PHF9vec0ALf9DPJZYQkUNdxH2Op +=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 0000000..64b959a Binary files /dev/null and b/releng/syslinux/splash.png differ diff --git a/releng/syslinux/syslinux.cfg b/releng/syslinux/syslinux.cfg new file mode 100644 index 0000000..cbda72f --- /dev/null +++ b/releng/syslinux/syslinux.cfg @@ -0,0 +1,11 @@ +DEFAULT select + +LABEL select +COM32 whichsys.c32 +APPEND -pxe- pxe -sys- sys -iso- sys + +LABEL pxe +CONFIG archiso_pxe.cfg + +LABEL sys +CONFIG archiso_sys.cfg