This is a purpose-built, atomic/immutable Linux operating system designed to have everything needed to run live broadcasting on-site at SeaGL. It is intended to be installed on laptops that run broadcasting in each talk room, and is based on Universal Blue which is itself based on Fedora Silverblue.
This template includes a Containerfile and a GitHub workflow for building the container image. Commits trigger container builds that are pushed to GitHub Container Registry.
Working knowledge in the following topics:
- Containers
- rpm-ostree
- Fedora Silverblue (and other Fedora Atomic variants)
- GitHub Workflows
This procedure was tested on one of the conference's streaming laptops; you may need to adjust otherwise.
- Write and boot a Fedora Silverblue (as of October 2024, version 40) installer. On conference laptops, the boot menu key is F12.
- Select Automatic partitioning and check the checkbox to free space by removing or resizing existing partitions.
- When prompted, remove all partitions, including and especially the EFI System Partition.
- Run the installer.
- Reboot.
- Go through setup.
- Connect to WiFi. NOTE that as of Fedora 40, captive portal login (like UW uses) does not work during initial setup. Use a phone hotspot to get through initial setup, then you can switch to UW's WiFi once you're on the desktop.
- Leave location services enabled.
- Enable Third-Party Repositories and click Next.
- Set Full Name to "SeaGL Provisioning".
- Accept the default username of
seaglprovisioning. - Set the password to
password.
- Apply firmware updates in GNOME Software, if applicable. This is very important as once you've switched to Aviary Linux, you can't apply these anymore due to EFI partition naming shenanigans.
- In a terminal, run
sudo rpm-ostree rebase ostree-unverified-registry:ghcr.io/seagl/av-linux:latest. The system should print logs of what it's doing as it works, but you can monitor progress of this step by runningrpm-ostree statusand/orsudo journalctl -fu rpm-ostreed.servicein a new terminal window. - When rpm-ostree rebase
finishes (i.e. whenrpm-ostree statusreportsStatus: idle`), reboot. - In a terminal, rebase to the signed image with
sudo rpm-ostree rebase ostree-image-signed:docker://ghcr.io/seagl/av-linux:latest. You will have anagepassword prompt which you can either close or ignore (doesn't matter) - just open a new terminal window. - When
rpm-ostree statusreportsStatus: idle, reboot.
This file defines the operations used to customize the selected image. It contains examples of possible modifications, including how to:
- change the upstream from which the custom image is derived
- add additional RPM packages
- add binaries as a layer from other images