azure/Containerfile

73 lines
2.6 KiB
Text
Raw Normal View History

2024-05-03 07:56:30 +00:00
## 1. BUILD ARGS
# These allow changing the produced image by passing different build args to adjust
# the source from which your image is built.
# Build args can be provided on the commandline when building locally with:
2024-05-03 15:11:18 +00:00
# podman build -f Containerfile --build-arg FEDORA_MAJOR_VERSION=40 -t local-image
2024-05-03 07:56:30 +00:00
ARG FEDORA_MAJOR_VERSION="${FEDORA_MAJOR_VERSION:-40}"
2024-05-03 07:56:30 +00:00
# SOURCE_IMAGE arg can be anything from ublue upstream which matches your desired version:
# See list here: https://github.com/orgs/ublue-os/packages?repo_name=main
# - "silverblue"
# - "kinoite"
# - "sericea"
# - "onyx"
# - "lazurite"
# - "vauxite"
# - "base"
#
# "aurora", "bazzite", "bluefin" or "ucore" may also be used but have different suffixes.
2024-05-03 15:11:18 +00:00
ARG SOURCE_IMAGE="base"
2024-05-03 07:56:30 +00:00
## SOURCE_SUFFIX arg should include a hyphen and the appropriate suffix name
# These examples all work for silverblue/kinoite/sericea/onyx/lazurite/vauxite/base
# - "-main"
# - "-nvidia"
# - "-asus"
# - "-asus-nvidia"
# - "-surface"
# - "-surface-nvidia"
#
# aurora, bazzite and bluefin each have unique suffixes. Please check the specific image.
# ucore has the following possible suffixes
# - stable
# - stable-nvidia
# - stable-zfs
# - stable-nvidia-zfs
# - (and the above with testing rather than stable)
2024-05-03 15:11:18 +00:00
ARG SOURCE_SUFFIX="-nvidia"
2024-05-03 07:56:30 +00:00
## SOURCE_TAG arg must be a version built for the specific image: eg, 39, 40, gts, latest
ARG SOURCE_TAG="${FEDORA_MAJOR_VERSION}"
2024-05-03 07:56:30 +00:00
### 2. SOURCE IMAGE
## this is a standard Containerfile FROM using the build ARGs above to select the right upstream image
FROM ghcr.io/ublue-os/${SOURCE_IMAGE}${SOURCE_SUFFIX}:${SOURCE_TAG}
2024-05-03 15:11:18 +00:00
ARG FEDORA_MAJOR_VERSION="${FEDORA_MAJOR_VERSION}"
2024-05-03 07:56:30 +00:00
### 3. MODIFICATIONS
## make modifications desired in your image and install packages by modifying the build.sh script
## the following RUN directive does all the things required to run "build.sh" as recommended.
2024-05-03 15:11:18 +00:00
COPY --from=ghcr.io/ublue-os/config:latest /files/ublue-os-just /
COPY --from=ghcr.io/ublue-os/config:latest /files/ublue-os-udev-rules /
COPY --from=ghcr.io/ublue-os/config:latest /files/ublue-os-update-services /
2024-05-03 16:19:48 +00:00
# COPY --from=ghcr.io/ublue-os/bluefin:latest /usr/share/fish /usr/share/fish
2024-05-03 15:11:18 +00:00
COPY files /
2024-05-03 07:56:30 +00:00
COPY build.sh /tmp/build.sh
2024-05-03 15:11:18 +00:00
COPY packages /tmp/packages
2024-05-03 07:56:30 +00:00
RUN mkdir -p /var/lib/alternatives && \
/tmp/build.sh && \
2024-05-03 15:11:18 +00:00
fc-cache --system-only --really-force --verbose && \
2024-05-03 15:48:12 +00:00
rm -rf /tmp/* /var/* && \
2024-05-03 15:11:18 +00:00
mkdir -p /var/tmp && \
chmod -R 1777 /var/tmp && \
2024-05-03 07:56:30 +00:00
ostree container commit
## NOTES:
# - /var/lib/alternatives is required to prevent failure with some RPM installs
# - All RUN commands must end with ostree container commit
# see: https://coreos.github.io/rpm-ostree/container/#using-ostree-container-commit