Skip to content

SeaGL/av-linux

Repository files navigation

Aviary Linux

Purpose

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.

Prerequisites

Working knowledge in the following topics:

Installation

This procedure was tested on one of the conference's streaming laptops; you may need to adjust otherwise.

  1. Write and boot a Fedora Silverblue (as of October 2024, version 40) installer. On conference laptops, the boot menu key is F12.
  2. Select Automatic partitioning and check the checkbox to free space by removing or resizing existing partitions.
  3. When prompted, remove all partitions, including and especially the EFI System Partition.
  4. Run the installer.
  5. Reboot.
  6. Go through setup.
    1. 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.
    2. Leave location services enabled.
    3. Enable Third-Party Repositories and click Next.
    4. Set Full Name to "SeaGL Provisioning".
    5. Accept the default username of seaglprovisioning.
    6. Set the password to password.
  7. 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.
  8. 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 running rpm-ostree status and/or sudo journalctl -fu rpm-ostreed.service in a new terminal window.
  9. When rpm-ostree rebasefinishes (i.e. whenrpm-ostree statusreportsStatus: idle`), reboot.
  10. 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 an age password prompt which you can either close or ignore (doesn't matter) - just open a new terminal window.
  11. When rpm-ostree status reports Status: idle, reboot.

How to Use

Containerfile

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

About

ostree-based, custom-built Linux distribution for running A/V broadcast

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors 4

  •  
  •  
  •  
  •