recipe.yml
A recipe.yml
file describes the build process of a custom image. The top-level keys set the metadata and base for the image, and modules are build steps that add things on top of the base.
name:
The image name. Used when publishing to GHCR as ghcr.io/<user>/<name>
.
Example:
name: weird-os
description:
The image description. Published to GHCR in the image metadata.
Example:
description: This is my personal OS image.
base-image:
The OCI image to base your custom image on. Only atomic Fedora images and those based on them are officially supported. Universal Blue is recommended. A list of uBlue images can be found on the uBlue website. BlueBuild-built images can be used as well.
Example:
base-image: ghcr.io/ublue-os/silverblue-main
image-version:
The tag of the base image to build on. Used to select a version explicitly (39
) or to always use the latest stable version (latest
). A list of all available tags can be viewed by pasting your base-image
url into your browser.
Example:
image-version: 39
modules:
A list of modules that is executed in order. Multiple of the same module can be included.
Each item in this list should have at least a type:
or be specified to be included from an external file in the recipes/
directory with from-file:
.
Example:
modules: - type: rpm-ostree # rest of the module config... - from-file: common-packages.yml
The included file can have one or multiple modules:
# one moduletype: rpm-ostree# rest of the module config...
# multiple modulesmodules: - type: script # rest of the module config... - type: rpm-ostree # rest of the module config...