Compare commits
107 Commits
renovate/f
...
jamesp-for
| Author | SHA1 | Date |
|---|---|---|
|
|
67b144cbf9 | |
|
|
7b4e013126 | |
|
|
c1a4b38c46 | |
|
|
0ac5ee04ba | |
|
|
da3c6ef677 | |
|
|
5276e451f4 | |
|
|
3ebf803f5f | |
|
|
e62452d096 | |
|
|
d88208bfba | |
|
|
3374cd8842 | |
|
|
92e7c1b2e1 | |
|
|
9bc06392c3 | |
|
|
7e65f01306 | |
|
|
1003402e6f | |
|
|
37900787f1 | |
|
|
22527b5f13 | |
|
|
93c50b4806 | |
|
|
c51559b7eb | |
|
|
578e95fe81 | |
|
|
9e300fb68f | |
|
|
06fddc9007 | |
|
|
934570054e | |
|
|
b44ea1ace5 | |
|
|
d7142132b7 | |
|
|
535cea4155 | |
|
|
444acb374b | |
|
|
edac3c53ca | |
|
|
461786bc6a | |
|
|
7369824a54 | |
|
|
b991db43cb | |
|
|
cf1cab8b60 | |
|
|
58ba425a83 | |
|
|
279b050acb | |
|
|
7d5a0646a5 | |
|
|
7530b75489 | |
|
|
2906394fba | |
|
|
7b7c32b015 | |
|
|
44258fdde4 | |
|
|
908c347bb9 | |
|
|
6315275af7 | |
|
|
0980197ad9 | |
|
|
230c105895 | |
|
|
b22d3422f4 | |
|
|
c758998b0d | |
|
|
128daa662c | |
|
|
1eb031710f | |
|
|
b9593426a8 | |
|
|
8e6ef05eb2 | |
|
|
4511546f08 | |
|
|
92172d2d56 | |
|
|
8a37080d85 | |
|
|
cbd531bc53 | |
|
|
62be40d8b4 | |
|
|
b9fdc53e87 | |
|
|
d6f00d618f | |
|
|
243b2c03bc | |
|
|
2d19347f1b | |
|
|
83542ad32e | |
|
|
034cf4bf28 | |
|
|
d65c8fa91e | |
|
|
e5d5452ace | |
|
|
97e5c775fd | |
|
|
2c3aea7d8e | |
|
|
9e2e845372 | |
|
|
39240d2848 | |
|
|
e6c505b14a | |
|
|
e89c5542ea | |
|
|
eecff86d81 | |
|
|
035de97f61 | |
|
|
9ce9d35a61 | |
|
|
de0ff17f75 | |
|
|
f4eba96aef | |
|
|
55609b1d19 | |
|
|
a3629ba21a | |
|
|
864ecc4aa0 | |
|
|
9410195760 | |
|
|
4e736cc6bb | |
|
|
a85de9b2e0 | |
|
|
684ea928c2 | |
|
|
17bb5e4128 | |
|
|
166df9118a | |
|
|
e01020ddc2 | |
|
|
8b551127e6 | |
|
|
0e9bf457eb | |
|
|
3f6db2ef2e | |
|
|
5d8e7a5f6b | |
|
|
8f5208a42c | |
|
|
7109132dd6 | |
|
|
4a4e727254 | |
|
|
0da319f566 | |
|
|
1350cb68ca | |
|
|
ec8fb6085c | |
|
|
ee7ceb348c | |
|
|
0858175b46 | |
|
|
e99b62981a | |
|
|
40df0eb382 | |
|
|
73fca28298 | |
|
|
3237cc0a8e | |
|
|
7cb7a397aa | |
|
|
64a741188c | |
|
|
fb882c9002 | |
|
|
9ed1a7fef3 | |
|
|
33ba2536f3 | |
|
|
6beab2a659 | |
|
|
aaa71e6629 | |
|
|
f870a77a25 | |
|
|
243848c59b |
|
|
@ -4,8 +4,11 @@ include:
|
||||||
|
|
||||||
build-image:
|
build-image:
|
||||||
extends: .build-image
|
extends: .build-image
|
||||||
|
parallel:
|
||||||
|
matrix:
|
||||||
|
- TIER: [tier-0, tier-1, tier-x]
|
||||||
variables:
|
variables:
|
||||||
EXTRA_ARGS: "--security-opt=label=disable --cap-add=all"
|
EXTRA_ARGS: "--security-opt=label=disable --cap-add=all --build-arg MANIFEST=fedora-$TIER.yaml"
|
||||||
rules:
|
rules:
|
||||||
- if: $CI_PROJECT_NAMESPACE != "fedora/bootc"
|
- if: $CI_PROJECT_NAMESPACE != "fedora/bootc"
|
||||||
when: never
|
when: never
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
---
|
---
|
||||||
repos:
|
repos:
|
||||||
- repo: https://github.com/pre-commit/pre-commit-hooks
|
- repo: https://github.com/pre-commit/pre-commit-hooks
|
||||||
rev: v4.5.0
|
rev: v4.6.0
|
||||||
hooks:
|
hooks:
|
||||||
- id: end-of-file-fixer
|
- id: end-of-file-fixer
|
||||||
- id: trailing-whitespace
|
- id: trailing-whitespace
|
||||||
|
|
|
||||||
|
|
@ -20,13 +20,14 @@
|
||||||
#
|
#
|
||||||
# # Why does this build process require additional privileges?
|
# # Why does this build process require additional privileges?
|
||||||
#
|
#
|
||||||
# Because it's generating a base image and uses containerbuildcontextization features itself.
|
# Because it's generating a base image and uses containerization features itself.
|
||||||
# In the future some of this can be lifted.
|
# In the future some of this can be lifted.
|
||||||
|
|
||||||
# renovate: datasource=endoflife-date depName=fedora versioning=docker
|
FROM quay.io/fedora/fedora:41 as repos
|
||||||
FROM quay.io/fedora/fedora:40 as repos
|
|
||||||
|
|
||||||
FROM quay.io/centos-bootc/bootc-image-builder:latest as builder
|
# BOOTSTRAPPING: This can be any image that has rpm-ostree and selinux-policy-targeted.
|
||||||
|
FROM quay.io/fedora/fedora:41 as builder
|
||||||
|
RUN dnf -y install rpm-ostree selinux-policy-targeted
|
||||||
ARG MANIFEST=fedora-bootc.yaml
|
ARG MANIFEST=fedora-bootc.yaml
|
||||||
COPY --from=repos /etc/dnf/vars /etc/dnf/vars
|
COPY --from=repos /etc/dnf/vars /etc/dnf/vars
|
||||||
COPY --from=repos /etc/pki/rpm-gpg/RPM-GPG-KEY-fedora-* /etc/pki/rpm-gpg
|
COPY --from=repos /etc/pki/rpm-gpg/RPM-GPG-KEY-fedora-* /etc/pki/rpm-gpg
|
||||||
|
|
@ -38,10 +39,16 @@ COPY . /src
|
||||||
WORKDIR /src
|
WORKDIR /src
|
||||||
RUN rm -vf /src/*.repo
|
RUN rm -vf /src/*.repo
|
||||||
COPY --from=repos /etc/yum.repos.d/*.repo /src
|
COPY --from=repos /etc/yum.repos.d/*.repo /src
|
||||||
RUN --mount=type=cache,target=/workdir --mount=type=bind,rw=true,src=.,dst=/buildcontext,bind-propagation=shared rpm-ostree compose image \
|
RUN --mount=type=cache,target=/workdir \
|
||||||
--image-config fedora-bootc-config.json --cachedir=/workdir --format=ociarchive --initialize ${MANIFEST} /buildcontext/out.ociarchive
|
--mount=type=bind,rw=true,src=.,dst=/buildcontext,bind-propagation=shared \
|
||||||
|
--mount=type=bind,from=repos,src=/,dst=/repos \
|
||||||
|
rpm-ostree compose image --image-config fedora-bootc-config.json \
|
||||||
|
--cachedir=/workdir --format=ociarchive --initialize ${MANIFEST} \
|
||||||
|
--source-root=/repos /buildcontext/out.ociarchive
|
||||||
|
|
||||||
FROM oci-archive:./out.ociarchive
|
FROM oci-archive:./out.ociarchive
|
||||||
# Need to reference builder here to force ordering. But since we have to run
|
# Need to reference builder here to force ordering. But since we have to run
|
||||||
# something anyway, we might as well cleanup after ourselves.
|
# something anyway, we might as well cleanup after ourselves.
|
||||||
RUN --mount=type=bind,from=builder,src=.,target=/var/tmp --mount=type=bind,rw=true,src=.,dst=/buildcontext,bind-propagation=shared rm /buildcontext/out.ociarchive
|
RUN --mount=type=bind,from=builder,src=.,target=/var/tmp \
|
||||||
|
--mount=type=bind,rw=true,src=.,dst=/buildcontext,bind-propagation=shared \
|
||||||
|
rm /buildcontext/out.ociarchive
|
||||||
|
|
|
||||||
61
README.md
61
README.md
|
|
@ -9,25 +9,72 @@ been extremely successful. This project aims to apply the same technique for
|
||||||
bootable host systems - using standard OCI/Docker containers as a transport and
|
bootable host systems - using standard OCI/Docker containers as a transport and
|
||||||
delivery format for base operating system updates.
|
delivery format for base operating system updates.
|
||||||
|
|
||||||
## Building
|
## Building images
|
||||||
|
|
||||||
First, the expectation is that most users will want to build *layered* images
|
The current default user experience is to build *layered* images on top of the official
|
||||||
on top of the official base images. See the documentation[5] for more info.
|
binary base images produced and tested by this project. See the documentation[5] for more info.
|
||||||
|
|
||||||
Building the images in this repo can be done with `podman build` as with any
|
You can build custom base images by forking this repository; however,
|
||||||
other application image (note that building with `docker` is not currently
|
https://gitlab.com/fedora/bootc/tracker/-/issues/32 tracks a more supportable
|
||||||
supported). You need to enable some privileges for technical reasons.
|
mechanism that is not simply forking. For more information see[6].
|
||||||
|
|
||||||
|
## Build process
|
||||||
|
|
||||||
|
Building the images in this repo can be done with `podman build`, but
|
||||||
|
note the build process uses a special podman-ecosystem specific mechanism
|
||||||
|
to create fully custom images while inside a `Containerfile`.
|
||||||
|
You need to enable some privileges as nested containerization is required.
|
||||||
|
|
||||||
```
|
```
|
||||||
podman build --security-opt=label=disable --cap-add=all \
|
podman build --security-opt=label=disable --cap-add=all \
|
||||||
--device /dev/fuse -t localhost/fedora-bootc .
|
--device /dev/fuse -t localhost/fedora-bootc .
|
||||||
```
|
```
|
||||||
|
|
||||||
See the `Containerfile` for more details.
|
See the `Containerfile` for more details. This builds the default `tier-1` image.
|
||||||
|
|
||||||
|
## Fedora versions
|
||||||
|
|
||||||
|
By default, the base images are built for Fedora rawhide. To build against a
|
||||||
|
different Fedora version, you can override the `FROM` image used to obtain the
|
||||||
|
Fedora repos and dnf variables. E.g.:
|
||||||
|
|
||||||
|
```
|
||||||
|
podman build --from quay.io/fedora/fedora:41 ...
|
||||||
|
```
|
||||||
|
|
||||||
|
### Deriving
|
||||||
|
|
||||||
You are of course also free to fork, customize, and build base images yourself.
|
You are of course also free to fork, customize, and build base images yourself.
|
||||||
See this page[6] of the documentation for more information.
|
See this page[6] of the documentation for more information.
|
||||||
|
|
||||||
|
## Tiers
|
||||||
|
|
||||||
|
At the current time, there is just one reference base image published
|
||||||
|
to the registry. Internally the content set is split up somewhat
|
||||||
|
into "tiers", but this is an internal implementation detail and may change
|
||||||
|
at any time.
|
||||||
|
|
||||||
|
It is planned to rework and improve this in the future, especially
|
||||||
|
to support smaller custom images. For more on this, see
|
||||||
|
[this tracker issue](https://gitlab.com/fedora/bootc/tracker/-/issues/32).
|
||||||
|
|
||||||
|
- **tier-1**: This image is the default, what is published as
|
||||||
|
https://quay.io/repository/fedora/fedora-bootc
|
||||||
|
- **tier-0**: This content set is more of a convenient centralization point for CI
|
||||||
|
and curation around a package set that we can all agree is the rough minimum
|
||||||
|
necessary for a usable system. It's not meant to be used as is, but layered
|
||||||
|
upon.
|
||||||
|
- **tier-x**: This content set is the shared base used by all image-based
|
||||||
|
Fedora variants (IoT, Atomic Desktops, and CoreOS).
|
||||||
|
Changes to this tier may be done without accounting for external users.
|
||||||
|
To build this, pass `--build-arg=MANIFEST=fedora-tier-x.yaml` to the build
|
||||||
|
command above.
|
||||||
|
|
||||||
|
**tier-1** inherits from **tier-x** and **tier-x** in turn inherit from **tier-0**.
|
||||||
|
|
||||||
|
All non-trivial changes to **tier-0** and **tier-x** should be ACKed by at least
|
||||||
|
one stakeholder of each Fedora variant WGs.
|
||||||
|
|
||||||
## More information
|
## More information
|
||||||
|
|
||||||
Documentation: <https://docs.fedoraproject.org/en-US/bootc/>
|
Documentation: <https://docs.fedoraproject.org/en-US/bootc/>
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,5 @@
|
||||||
|
podman build \
|
||||||
|
--security-opt=label=disable \
|
||||||
|
--cap-add=all \
|
||||||
|
--device /dev/fuse \
|
||||||
|
-t localhost/fedora-bootc .
|
||||||
|
|
@ -0,0 +1,7 @@
|
||||||
|
# NB: This treefile is used by the legacy pungi path only to build tier-1. It
|
||||||
|
# will be removed in the future.
|
||||||
|
releasever: 40
|
||||||
|
repos:
|
||||||
|
- fedora
|
||||||
|
- fedora-updates
|
||||||
|
include: fedora-bootc.yaml
|
||||||
|
|
@ -0,0 +1,7 @@
|
||||||
|
# NB: This treefile is used by the legacy pungi path only to build tier-1. It
|
||||||
|
# will be removed in the future.
|
||||||
|
releasever: 41
|
||||||
|
repos:
|
||||||
|
- fedora
|
||||||
|
- fedora-updates
|
||||||
|
include: fedora-bootc.yaml
|
||||||
|
|
@ -0,0 +1,6 @@
|
||||||
|
# NB: This treefile is used by the legacy pungi path only to build tier-1. It
|
||||||
|
# will be removed in the future.
|
||||||
|
releasever: 42
|
||||||
|
repos:
|
||||||
|
- fedora-devel
|
||||||
|
include: fedora-bootc.yaml
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
"containers.bootc": "1",
|
"containers.bootc": "1",
|
||||||
"bootc.diskimage-builder": "quay.io/centos-bootc/bootc-image-builder",
|
"bootc.diskimage-builder": "quay.io/centos-bootc/bootc-image-builder",
|
||||||
"redhat.id": "fedora",
|
"redhat.id": "fedora",
|
||||||
"redhat.version-id": "40"
|
"redhat.version-id": "rawhide"
|
||||||
},
|
},
|
||||||
"StopSignal": "SIGRTMIN+3",
|
"StopSignal": "SIGRTMIN+3",
|
||||||
"Env": [
|
"Env": [
|
||||||
|
|
|
||||||
|
|
@ -1,14 +0,0 @@
|
||||||
releasever: rawhide
|
|
||||||
variables:
|
|
||||||
distro: "fedora"
|
|
||||||
|
|
||||||
repos:
|
|
||||||
- rawhide
|
|
||||||
|
|
||||||
metadata:
|
|
||||||
name: fedora-boot-tier1
|
|
||||||
summary: Fedora Bootable Tier 1
|
|
||||||
|
|
||||||
include:
|
|
||||||
- tier-1/manifest.yaml
|
|
||||||
- tier-1/kernel.yaml
|
|
||||||
|
|
@ -1,15 +1,8 @@
|
||||||
releasever: 40
|
|
||||||
variables:
|
|
||||||
distro: "fedora"
|
|
||||||
|
|
||||||
repos:
|
|
||||||
- fedora
|
|
||||||
- updates
|
|
||||||
|
|
||||||
metadata:
|
metadata:
|
||||||
name: fedora-boot-tier1
|
name: fedora-boot-tier1
|
||||||
summary: Fedora Bootable Tier 1
|
summary: Fedora Bootable Tier 1
|
||||||
|
|
||||||
include:
|
include:
|
||||||
|
- fedora-generic.yaml
|
||||||
- tier-1/manifest.yaml
|
- tier-1/manifest.yaml
|
||||||
- tier-1/kernel.yaml
|
- tier-1/kernel.yaml
|
||||||
|
|
|
||||||
|
|
@ -1,15 +0,0 @@
|
||||||
releasever: 39
|
|
||||||
variables:
|
|
||||||
distro: "eln"
|
|
||||||
|
|
||||||
repos:
|
|
||||||
- eln-baseos
|
|
||||||
- eln-appstream
|
|
||||||
|
|
||||||
metadata:
|
|
||||||
name: fedora-boot-tier1
|
|
||||||
summary: Fedora Bootable Tier 1
|
|
||||||
|
|
||||||
include:
|
|
||||||
- tier-1/manifest.yaml
|
|
||||||
- tier-1/kernel.yaml
|
|
||||||
408
fedora-eln.repo
408
fedora-eln.repo
|
|
@ -1,408 +0,0 @@
|
||||||
# These packages are untested and still under development. This
|
|
||||||
# repository is used for development of new releases.
|
|
||||||
#
|
|
||||||
# This repository can see significant daily turnover and major
|
|
||||||
# functionality changes which cause unexpected problems with other
|
|
||||||
# development packages. Please use these packages if you want to work
|
|
||||||
# with the Fedora developers by testing these new development packages.
|
|
||||||
#
|
|
||||||
# # https://admin.fedoraproject.org/mailman/listinfo/test (Subscription
|
|
||||||
# Required) is available as a discussion forum for
|
|
||||||
# testing and troubleshooting for development packages in conjunction
|
|
||||||
# with new test releases.
|
|
||||||
#
|
|
||||||
# More information is available at http://fedoraproject.org/wiki/Testing
|
|
||||||
#
|
|
||||||
# Reproducible and reportable issues should be filed at
|
|
||||||
# http://bugzilla.redhat.com/.
|
|
||||||
#
|
|
||||||
# Product: Fedora
|
|
||||||
# Version: eln
|
|
||||||
|
|
||||||
[eln-baseos]
|
|
||||||
name=Fedora - ELN BaseOS - Developmental packages for the next Enterprise Linux release
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/BaseOS/$basearch/os/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln&arch=$basearch
|
|
||||||
enabled=1
|
|
||||||
countme=1
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-baseos-debuginfo]
|
|
||||||
name=Fedora - ELN BaseOS - Debug
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/BaseOS/$basearch/debug/tree
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-debug&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-baseos-source]
|
|
||||||
name=Fedora - ELN BaseOS - Source
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/BaseOS/source/tree/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-source&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[eln-appstream]
|
|
||||||
name=Fedora - ELN AppStream - Developmental packages for the next Enterprise Linux release
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/AppStream/$basearch/os/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln&arch=$basearch
|
|
||||||
enabled=1
|
|
||||||
countme=1
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-appstream-debuginfo]
|
|
||||||
name=Fedora - ELN AppStream - Debug
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/AppStream/$basearch/debug/tree
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-debug&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-appstream-source]
|
|
||||||
name=Fedora - ELN AppStream - Source
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/AppStream/source/tree/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-source&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[eln-crb]
|
|
||||||
name=Fedora - ELN CRB - Developmental packages for the next Enterprise Linux release
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/CRB/$basearch/os/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln&arch=$basearch
|
|
||||||
enabled=1
|
|
||||||
countme=1
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-crb-debuginfo]
|
|
||||||
name=Fedora - ELN CRB - Debug
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/CRB/$basearch/debug/tree
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-debug&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-crb-source]
|
|
||||||
name=Fedora - ELN CRB - Source
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/CRB/source/tree/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-source&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[eln-extras]
|
|
||||||
name=Fedora - ELN Extras - Developmental packages for the next Enterprise Linux release
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/Extras/$basearch/os/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln&arch=$basearch
|
|
||||||
enabled=1
|
|
||||||
countme=1
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-extras-debuginfo]
|
|
||||||
name=Fedora - ELN Extras - Debug
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/Extras/$basearch/debug/tree
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-debug&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-extras-source]
|
|
||||||
name=Fedora - ELN Extras - Source
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/Extras/source/tree/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-source&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[eln-ha]
|
|
||||||
name=Fedora - ELN HighAvailability - Developmental packages for the next Enterprise Linux release
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/HighAvailability/$basearch/os/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
countme=1
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-ha-debuginfo]
|
|
||||||
name=Fedora - ELN HighAvailability - Debug
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/HighAvailability/$basearch/debug/tree
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-debug&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-ha-source]
|
|
||||||
name=Fedora - ELN HighAvailability - Source
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/HighAvailability/source/tree/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-source&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[eln-rs]
|
|
||||||
name=Fedora - ELN ResilientStorage - Developmental packages for the next Enterprise Linux release
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/ResilientStorage/$basearch/os/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
countme=1
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-rs-debuginfo]
|
|
||||||
name=Fedora - ELN ResilientStorage - Debug
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/ResilientStorage/$basearch/debug/tree
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-debug&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-rs-source]
|
|
||||||
name=Fedora - ELN ResilientStorage - Source
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/ResilientStorage/source/tree/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-source&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[eln-rt]
|
|
||||||
name=Fedora - ELN RT - Developmental packages for the next Enterprise Linux release
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/RT/$basearch/os/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
countme=1
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-rt-debuginfo]
|
|
||||||
name=Fedora - ELN RT - Debug
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/RT/$basearch/debug/tree
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-debug&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-rt-source]
|
|
||||||
name=Fedora - ELN RT - Source
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/RT/source/tree/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-source&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[eln-nfv]
|
|
||||||
name=Fedora - ELN NFV - Developmental packages for the next Enterprise Linux release
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/NFV/$basearch/os/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
countme=1
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-nfv-debuginfo]
|
|
||||||
name=Fedora - ELN NFV - Debug
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/NFV/$basearch/debug/tree
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-debug&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-nfv-source]
|
|
||||||
name=Fedora - ELN NFV - Source
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/NFV/source/tree/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-source&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[eln-sap]
|
|
||||||
name=Fedora - ELN SAP - Developmental packages for the next Enterprise Linux release
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/SAP/$basearch/os/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
countme=1
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-sap-debuginfo]
|
|
||||||
name=Fedora - ELN SAP - Debug
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/SAP/$basearch/debug/tree
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-debug&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-sap-source]
|
|
||||||
name=Fedora - ELN SAP - Source
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/SAP/source/tree/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-source&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[eln-saphana]
|
|
||||||
name=Fedora - ELN SAPHANA - Developmental packages for the next Enterprise Linux release
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/SAPHANA/$basearch/os/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
countme=1
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-saphana-debuginfo]
|
|
||||||
name=Fedora - ELN SAPHANA - Debug
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/SAPHANA/$basearch/debug/tree
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-debug&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
||||||
[eln-saphana-source]
|
|
||||||
name=Fedora - ELN SAPHANA - Source
|
|
||||||
baseurl=https://odcs.fedoraproject.org/composes/production/Fedora-ELN-20240402.2/compose/SAPHANA/source/tree/
|
|
||||||
#metalink=https://mirrors.fedoraproject.org/metalink?repo=eln-source&arch=$basearch
|
|
||||||
enabled=0
|
|
||||||
metadata_expire=6h
|
|
||||||
repo_gpgcheck=0
|
|
||||||
type=rpm
|
|
||||||
gpgcheck=1
|
|
||||||
gpgkey=file:///usr/share/distribution-gpg-keys/fedora/RPM-GPG-KEY-fedora-40-primary
|
|
||||||
skip_if_unavailable=False
|
|
||||||
|
|
@ -0,0 +1,9 @@
|
||||||
|
variables:
|
||||||
|
distro: "fedora"
|
||||||
|
|
||||||
|
# Fedora-specific packages here
|
||||||
|
packages:
|
||||||
|
# https://gitlab.com/fedora/bootc/base-images/-/issues/12
|
||||||
|
- fedora-repos-archive
|
||||||
|
# Not in RHEL10
|
||||||
|
- systemd-resolved
|
||||||
|
|
@ -0,0 +1,6 @@
|
||||||
|
# NB: This treefile is used by the legacy pungi path only to build tier-1. It
|
||||||
|
# will be removed in the future.
|
||||||
|
releasever: rawhide
|
||||||
|
repos:
|
||||||
|
- fedora-rawhide
|
||||||
|
include: fedora-bootc.yaml
|
||||||
|
|
@ -1,15 +0,0 @@
|
||||||
releasever: 40
|
|
||||||
variables:
|
|
||||||
distro: "fedora"
|
|
||||||
|
|
||||||
repos:
|
|
||||||
- fedora-devel
|
|
||||||
- fedora-updates
|
|
||||||
|
|
||||||
metadata:
|
|
||||||
name: fedora-boot-tier0
|
|
||||||
summary: Fedora Bootable Tier 0
|
|
||||||
|
|
||||||
include:
|
|
||||||
- tier-0/manifest.yaml
|
|
||||||
- tier-0/kernel.yaml
|
|
||||||
|
|
@ -1,11 +0,0 @@
|
||||||
releasever: 39
|
|
||||||
variables:
|
|
||||||
distro: "eln"
|
|
||||||
|
|
||||||
repos:
|
|
||||||
- eln-baseos
|
|
||||||
- eln-appstream
|
|
||||||
|
|
||||||
include:
|
|
||||||
- tier-0/manifest.yaml
|
|
||||||
- tier-0/kernel.yaml
|
|
||||||
|
|
@ -1,14 +1,8 @@
|
||||||
releasever: rawhide
|
|
||||||
variables:
|
|
||||||
distro: "fedora"
|
|
||||||
|
|
||||||
repos:
|
|
||||||
- rawhide
|
|
||||||
|
|
||||||
metadata:
|
metadata:
|
||||||
name: fedora-boot-tier0
|
name: fedora-boot-tier0
|
||||||
summary: Fedora Bootable Tier 0
|
summary: Fedora Bootable Tier 0
|
||||||
|
|
||||||
include:
|
include:
|
||||||
|
- fedora-generic.yaml
|
||||||
- tier-0/manifest.yaml
|
- tier-0/manifest.yaml
|
||||||
- tier-0/kernel.yaml
|
- tier-0/kernel.yaml
|
||||||
|
|
@ -0,0 +1 @@
|
||||||
|
fedora-bootc.yaml
|
||||||
|
|
@ -0,0 +1,8 @@
|
||||||
|
metadata:
|
||||||
|
name: fedora-boot-tier-x
|
||||||
|
summary: Fedora Bootable Tier X
|
||||||
|
|
||||||
|
include:
|
||||||
|
- fedora-generic.yaml
|
||||||
|
- tier-x/manifest.yaml
|
||||||
|
- tier-x/kernel.yaml
|
||||||
|
|
@ -2,5 +2,18 @@
|
||||||
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
|
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
|
||||||
"extends": [
|
"extends": [
|
||||||
"github>platform-engineering-org/.github"
|
"github>platform-engineering-org/.github"
|
||||||
|
],
|
||||||
|
"baseBranches": ["main", "f40", "f41"],
|
||||||
|
"packageRules": [
|
||||||
|
{
|
||||||
|
"matchPackageNames": ["quay.io/fedora/fedora"],
|
||||||
|
"allowedVersions": "=40",
|
||||||
|
"matchBaseBranches": ["f40"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"matchPackageNames": ["quay.io/fedora/fedora"],
|
||||||
|
"allowedVersions": "=41",
|
||||||
|
"matchBaseBranches": ["f41"]
|
||||||
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,9 +0,0 @@
|
||||||
# Enable automatic updates by default
|
|
||||||
postprocess:
|
|
||||||
- |
|
|
||||||
#!/usr/bin/env bash
|
|
||||||
set -euo pipefail
|
|
||||||
target=/usr/lib/systemd/system/default.target.wants
|
|
||||||
mkdir -p $target
|
|
||||||
set -x
|
|
||||||
ln -s ../bootc-fetch-apply-updates.timer $target
|
|
||||||
|
|
@ -23,7 +23,7 @@ postprocess:
|
||||||
# tmpfiles.d unit for `/var/roothome` is fine, but this actually doesn't
|
# tmpfiles.d unit for `/var/roothome` is fine, but this actually doesn't
|
||||||
# work if we want to use tmpfiles.d to write to `/root/.ssh` because
|
# work if we want to use tmpfiles.d to write to `/root/.ssh` because
|
||||||
# tmpfiles gives up on that before getting to `/var/roothome`.
|
# tmpfiles gives up on that before getting to `/var/roothome`.
|
||||||
sed -ie 's, /root, /var/roothome,' /usr/lib/tmpfiles.d/provision.conf
|
sed -i -e 's, /root, /var/roothome,' /usr/lib/tmpfiles.d/provision.conf
|
||||||
# Because /var/roothome is also defined in rpm-ostree-0-integration.conf
|
# Because /var/roothome is also defined in rpm-ostree-0-integration.conf
|
||||||
# we need to delete /var/roothome
|
# we need to delete /var/roothome
|
||||||
sed -ie '/^d- \/var\/roothome /d' /usr/lib/tmpfiles.d/provision.conf
|
sed -i -e '/^d- \/var\/roothome /d' /usr/lib/tmpfiles.d/provision.conf
|
||||||
|
|
|
||||||
|
|
@ -2,8 +2,13 @@
|
||||||
packages:
|
packages:
|
||||||
- systemd
|
- systemd
|
||||||
- bootc
|
- bootc
|
||||||
# Required by bootc install today, though we'll likely switch bootc to use a Rust crate instead of sgdisk
|
# bootc pulls in podman, which pulls in containers-common, which wants
|
||||||
- gdisk xfsprogs e2fsprogs dosfstools
|
# `iptables`. Currently that pulls in iptables-legacy. Let's explicitly name
|
||||||
|
# iptables-nft instead to satisfy it.
|
||||||
|
- iptables-nft
|
||||||
|
# Required by bootc install, sgdisk has been replaced by Rust crate
|
||||||
|
# in bootc https://github.com/containers/bootc/pull/775
|
||||||
|
- xfsprogs e2fsprogs dosfstools
|
||||||
|
|
||||||
exclude-packages:
|
exclude-packages:
|
||||||
# Exclude kernel-debug-core to make sure that it doesn't somehow get
|
# Exclude kernel-debug-core to make sure that it doesn't somehow get
|
||||||
|
|
|
||||||
|
|
@ -9,9 +9,8 @@ packages-aarch64:
|
||||||
packages-ppc64le:
|
packages-ppc64le:
|
||||||
- grub2 ostree-grub2
|
- grub2 ostree-grub2
|
||||||
packages-s390x:
|
packages-s390x:
|
||||||
# On Fedora, this is provided by s390utils-core. on RHEL, this is for now
|
# For zipl
|
||||||
# provided by s390utils-base, but soon will be -core too.
|
- s390utils-core
|
||||||
- /usr/sbin/zipl
|
|
||||||
packages-x86_64:
|
packages-x86_64:
|
||||||
- grub2 grub2-efi-x64 efibootmgr shim
|
- grub2 grub2-efi-x64 efibootmgr shim
|
||||||
- microcode_ctl
|
- microcode_ctl
|
||||||
|
|
@ -25,7 +24,10 @@ postprocess:
|
||||||
- |
|
- |
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
set -xeuo pipefail
|
set -xeuo pipefail
|
||||||
# Until we have https://github.com/coreos/rpm-ostree/pull/2275
|
|
||||||
mkdir -p /run
|
|
||||||
# Transforms /usr/lib/ostree-boot into a bootupd-compatible update payload
|
# Transforms /usr/lib/ostree-boot into a bootupd-compatible update payload
|
||||||
/usr/bin/bootupctl backend generate-update-metadata
|
/usr/bin/bootupctl backend generate-update-metadata
|
||||||
|
- |
|
||||||
|
#!/bin/bash
|
||||||
|
# Workaround for https://issues.redhat.com/browse/RHEL-78104
|
||||||
|
set -xeuo pipefail
|
||||||
|
rm -vrf /usr/lib/ostree-boot/loader
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,6 @@
|
||||||
|
#!/bin/bash
|
||||||
|
# https://gitlab.com/fedora/bootc/base-images/-/issues/28
|
||||||
|
set -xeuo pipefail
|
||||||
|
ln -s ../run var/run
|
||||||
|
# https://gitlab.com/fedora/bootc/tracker/-/issues/58
|
||||||
|
mkdir -p var/lib/rpm-state
|
||||||
|
|
@ -6,13 +6,19 @@ postprocess:
|
||||||
cat > /usr/lib/dracut/dracut.conf.d/20-bootc-base.conf << 'EOF'
|
cat > /usr/lib/dracut/dracut.conf.d/20-bootc-base.conf << 'EOF'
|
||||||
# We want a generic image; hostonly makes no sense as part of a server side build
|
# We want a generic image; hostonly makes no sense as part of a server side build
|
||||||
hostonly=no
|
hostonly=no
|
||||||
dracutmodules+=" kernel-modules dracut-systemd systemd-initrd base ostree "
|
add_dracutmodules+=" kernel-modules dracut-systemd systemd-initrd base ostree "
|
||||||
EOF
|
EOF
|
||||||
cat > /usr/lib/dracut/dracut.conf.d/22-bootc-generic.conf << 'EOF'
|
cat > /usr/lib/dracut/dracut.conf.d/22-bootc-generic.conf << 'EOF'
|
||||||
# Extra modules that we want by default that are known to exist in the kernel
|
# Extra modules that we want by default that are known to exist in the kernel
|
||||||
dracutmodules+=" virtiofs "
|
add_dracutmodules+=" virtiofs "
|
||||||
EOF
|
EOF
|
||||||
cat > /usr/lib/dracut/dracut.conf.d/49-bootc-tpm2-tss.conf << 'EOF'
|
cat > /usr/lib/dracut/dracut.conf.d/49-bootc-tpm2-tss.conf << 'EOF'
|
||||||
# We want this for systemd-cryptsetup tpm2 locking
|
# We want this for systemd-cryptsetup tpm2 locking
|
||||||
dracutmodules+=" tpm2-tss "
|
add_dracutmodules+=" tpm2-tss "
|
||||||
|
EOF
|
||||||
|
cat > /usr/lib/dracut/dracut.conf.d/59-altfiles.conf << 'EOF'
|
||||||
|
# https://issues.redhat.com/browse/RHEL-49590
|
||||||
|
# On image mode systems we use nss-altfiles for passwd and group,
|
||||||
|
# this makes sure dracut uses them which also fixes kdump writing to NFS.
|
||||||
|
install_items+=" /usr/lib/passwd /usr/lib/group "
|
||||||
EOF
|
EOF
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,21 @@
|
||||||
|
# Configuration to enable kernel-install integration
|
||||||
|
postprocess:
|
||||||
|
- |
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -xeuo pipefail
|
||||||
|
source /usr/lib/os-release
|
||||||
|
echo -e "# kernel-install will not try to run dracut and allow rpm-ostree to\n\
|
||||||
|
# take over. Rpm-ostree will use this to know that it is responsible\n\
|
||||||
|
# to run dracut and ensure that there is only one kernel in the image\n\
|
||||||
|
layout=ostree" | tee /usr/lib/kernel/install.conf > /dev/null
|
||||||
|
# By default dnf keeps multiple versions of the kernel, with this
|
||||||
|
# configuration we tell dnf to treat the kernel as everything else.
|
||||||
|
# https://dnf.readthedocs.io/en/latest/conf_ref.html#main-options
|
||||||
|
# Let's add the config to a distribution configuration file if dnf5
|
||||||
|
# is used, we append to /etc/dnf/dnf.conf if not.
|
||||||
|
if [ -d "/usr/share/dnf5/libdnf.conf.d/" ]; then
|
||||||
|
echo -e "[main]\ninstallonlypkgs=''" >> /usr/share/dnf5/libdnf.conf.d/20-ostree-installonlypkgs.conf
|
||||||
|
else
|
||||||
|
echo "installonlypkgs=''" >> /etc/dnf/dnf.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
@ -1,10 +0,0 @@
|
||||||
repos:
|
|
||||||
- rt
|
|
||||||
- nfv
|
|
||||||
|
|
||||||
# Enable the "realtime" AKA soft-realtime AKA latency-optimized kernel.
|
|
||||||
packages:
|
|
||||||
- kernel-rt-core kernel-rt-modules kernel-rt-modules-extra kernel-rt-kvm
|
|
||||||
|
|
||||||
exclude-packages:
|
|
||||||
- kernel-rt-debug-core
|
|
||||||
|
|
@ -1,63 +1,35 @@
|
||||||
|
edition: "2024"
|
||||||
|
|
||||||
# Modern defaults we want
|
|
||||||
boot-location: modules
|
|
||||||
tmp-is-dir: true
|
|
||||||
# https://github.com/CentOS/centos-bootc/issues/167
|
|
||||||
machineid-compat: true
|
|
||||||
# Be minimal
|
# Be minimal
|
||||||
recommends: false
|
recommends: false
|
||||||
|
|
||||||
ignore-removed-users:
|
|
||||||
- root
|
|
||||||
ignore-removed-groups:
|
|
||||||
- root
|
|
||||||
etc-group-members:
|
|
||||||
- wheel
|
|
||||||
- sudo
|
|
||||||
- systemd-journal
|
|
||||||
- adm
|
|
||||||
|
|
||||||
# Default to `bash` in our container, the same as other containers we ship.
|
# Default to `bash` in our container, the same as other containers we ship.
|
||||||
container-cmd:
|
container-cmd:
|
||||||
- /sbin/init
|
- /sbin/init
|
||||||
|
|
||||||
# Note that the default for c9s+ is sqlite; we can't rely on rpm being
|
|
||||||
# in the target (it isn't in tier-0!) so turn this to host here. This
|
|
||||||
# does break the "hermetic build" aspect a bit. Maybe eventually
|
|
||||||
# what we should do is special case this and actually install RPM temporarily
|
|
||||||
# and then remove it...
|
|
||||||
rpmdb: host
|
|
||||||
|
|
||||||
check-passwd:
|
|
||||||
type: "file"
|
|
||||||
filename: "passwd"
|
|
||||||
check-groups:
|
|
||||||
type: "file"
|
|
||||||
filename: "group"
|
|
||||||
|
|
||||||
automatic-version-prefix: "${releasever}.<date:%Y%m%d>"
|
|
||||||
mutate-os-release: "${releasever}"
|
|
||||||
|
|
||||||
remove-from-packages:
|
remove-from-packages:
|
||||||
# Generally we expect other tools to do this (e.g. Ignition or cloud-init)
|
# Generally we expect other tools to do this (e.g. Ignition or cloud-init)
|
||||||
- [systemd, /usr/lib/systemd/system/sysinit.target.wants/systemd-firstboot.service]
|
- [systemd, /usr/lib/systemd/system/sysinit.target.wants/systemd-firstboot.service]
|
||||||
# We don't want auto-generated mount units. See also
|
# We don't want auto-generated mount units. See also
|
||||||
# https://github.com/systemd/systemd/issues/13099
|
# https://github.com/systemd/systemd/issues/13099
|
||||||
- [systemd-udev, /usr/lib/systemd/system-generators/systemd-gpt-auto-generator]
|
- [systemd-udev, /usr/lib/systemd/system-generators/systemd-gpt-auto-generator]
|
||||||
# Drop some buggy sysusers fragments which do not match static IDs allocation:
|
|
||||||
# https://bugzilla.redhat.com/show_bug.cgi?id=2105177
|
|
||||||
- [dbus-common, /usr/lib/sysusers.d/dbus.conf]
|
|
||||||
|
|
||||||
include:
|
include:
|
||||||
|
- postprocess-conf.yaml
|
||||||
- bootc.yaml
|
- bootc.yaml
|
||||||
|
- bootupd.yaml
|
||||||
- ostree.yaml
|
- ostree.yaml
|
||||||
- initramfs.yaml
|
- initramfs.yaml
|
||||||
- autoupdates.yaml
|
|
||||||
- basic-fixes.yaml
|
- basic-fixes.yaml
|
||||||
|
- kernel-install.yaml
|
||||||
|
|
||||||
packages:
|
packages:
|
||||||
# needed for building derived container images
|
# this is implied by dependencies but let's make it explicit
|
||||||
- dnf
|
- coreutils
|
||||||
|
# We need dnf for building derived container images. In Fedora, this pulls
|
||||||
|
# in dnf5. In CentOS/RHEL, this pulls in dnf(4). We can simplify this back to
|
||||||
|
# just `dnf` once the `dnf` package is retired from Fedora.
|
||||||
|
- /usr/bin/dnf
|
||||||
# Even in tier-0, we have this. If you don't want SELinux today, you'll need
|
# Even in tier-0, we have this. If you don't want SELinux today, you'll need
|
||||||
# to build a custom image.
|
# to build a custom image.
|
||||||
- selinux-policy-targeted
|
- selinux-policy-targeted
|
||||||
|
|
@ -65,8 +37,3 @@ packages:
|
||||||
- container-selinux
|
- container-selinux
|
||||||
# Needed for tpm2 bound luks
|
# Needed for tpm2 bound luks
|
||||||
- tpm2-tools
|
- tpm2-tools
|
||||||
|
|
||||||
# See https://github.com/coreos/bootupd
|
|
||||||
arch-include:
|
|
||||||
x86_64: bootupd.yaml
|
|
||||||
aarch64: bootupd.yaml
|
|
||||||
|
|
|
||||||
|
|
@ -1,9 +1,6 @@
|
||||||
packages:
|
packages:
|
||||||
- ostree nss-altfiles
|
- ostree nss-altfiles
|
||||||
|
|
||||||
# We want content lifecycled with the image
|
|
||||||
opt-usrlocal: "root"
|
|
||||||
|
|
||||||
postprocess:
|
postprocess:
|
||||||
# Set up default root config
|
# Set up default root config
|
||||||
- |
|
- |
|
||||||
|
|
|
||||||
|
|
@ -23,7 +23,7 @@ rpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/usr/sbin/nologin
|
||||||
rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/usr/sbin/nologin
|
rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/usr/sbin/nologin
|
||||||
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
|
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
|
||||||
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/usr/sbin/nologin
|
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/usr/sbin/nologin
|
||||||
sssd:x:995:993:User for sssd:/:/usr/sbin/nologin
|
sssd:x:995:993:User for sssd:/run/sssd:/usr/sbin/nologin
|
||||||
sync:x:5:0:sync:/sbin:/bin/sync
|
sync:x:5:0:sync:/sbin:/bin/sync
|
||||||
systemd-bus-proxy:x:989:988:systemd Bus Proxy:/:/usr/sbin/nologin
|
systemd-bus-proxy:x:989:988:systemd Bus Proxy:/:/usr/sbin/nologin
|
||||||
systemd-network:x:991:990:systemd Network Management:/:/usr/sbin/nologin
|
systemd-network:x:991:990:systemd Network Management:/:/usr/sbin/nologin
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,34 @@
|
||||||
|
# This file configures things relevant to `rpm-ostree compose postprocess`.
|
||||||
|
|
||||||
|
# We want content lifecycled with the image
|
||||||
|
opt-usrlocal: "root"
|
||||||
|
|
||||||
|
# https://github.com/CentOS/centos-bootc/issues/167
|
||||||
|
machineid-compat: true
|
||||||
|
|
||||||
|
# Note that the default for c9s+ is sqlite; we can't rely on rpm being
|
||||||
|
# in the target (it isn't in tier-0!) so turn this to host here. This
|
||||||
|
# does break the "hermetic build" aspect a bit. Maybe eventually
|
||||||
|
# what we should do is special case this and actually install RPM temporarily
|
||||||
|
# and then remove it...
|
||||||
|
rpmdb: host
|
||||||
|
|
||||||
|
ignore-removed-users:
|
||||||
|
- root
|
||||||
|
ignore-removed-groups:
|
||||||
|
- root
|
||||||
|
etc-group-members:
|
||||||
|
- wheel
|
||||||
|
- sudo
|
||||||
|
- systemd-journal
|
||||||
|
- adm
|
||||||
|
|
||||||
|
check-passwd:
|
||||||
|
type: "file"
|
||||||
|
filename: "passwd"
|
||||||
|
check-groups:
|
||||||
|
type: "file"
|
||||||
|
filename: "group"
|
||||||
|
|
||||||
|
automatic-version-prefix: "${releasever}.<date:%Y%m%d>"
|
||||||
|
mutate-os-release: "${releasever}"
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
../tier-0/autoupdates.yaml
|
|
||||||
|
|
@ -0,0 +1,9 @@
|
||||||
|
# Enable automatic updates by default
|
||||||
|
postprocess:
|
||||||
|
- |
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -euo pipefail
|
||||||
|
target=/usr/lib/systemd/system/default.target.wants
|
||||||
|
mkdir -p $target
|
||||||
|
set -x
|
||||||
|
ln -s ../bootc-fetch-apply-updates.timer $target
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
../tier-0/basic-fixes.yaml
|
|
||||||
|
|
@ -1,8 +0,0 @@
|
||||||
packages:
|
|
||||||
- rpm-ostree nss-altfiles
|
|
||||||
|
|
||||||
exclude-packages:
|
|
||||||
# Exclude kernel-debug-core to make sure that it doesn't somehow get
|
|
||||||
# chosen as the package to satisfy the `kernel-core` dependency from
|
|
||||||
# the kernel package.
|
|
||||||
- kernel-debug-core
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
../tier-0/bootc-config.yaml
|
|
||||||
|
|
@ -3,15 +3,18 @@ set -eu
|
||||||
|
|
||||||
backing_device=$(findmnt -vno SOURCE /sysroot)
|
backing_device=$(findmnt -vno SOURCE /sysroot)
|
||||||
echo "Backing device: ${backing_device}"
|
echo "Backing device: ${backing_device}"
|
||||||
|
|
||||||
|
# Handling devicemapper targets is a whole other thing
|
||||||
|
case $backing_device in
|
||||||
|
/dev/mapper/*) echo "Not growing $backing_device"; exit 0 ;;
|
||||||
|
esac
|
||||||
|
|
||||||
syspath=/sys/class/block/$(basename "${backing_device}")
|
syspath=/sys/class/block/$(basename "${backing_device}")
|
||||||
if ! test -d "${syspath}"; then
|
if ! test -d "${syspath}"; then
|
||||||
echo "failed to find backing device ${syspath}"; exit 1
|
echo "failed to find backing device ${syspath}"; exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Handling devicemapper targets is a whole other thing
|
|
||||||
case $backing_device in
|
|
||||||
/dev/mapper/*) "Not growing $backing_device"; exit 0 ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Note that we expect that the rootfs is on a partition
|
# Note that we expect that the rootfs is on a partition
|
||||||
partition=$(cat "${syspath}"/partition)
|
partition=$(cat "${syspath}"/partition)
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,8 @@ Documentation=https://gitlab.com/fedora/bootc/docs
|
||||||
ConditionVirtualization=vm
|
ConditionVirtualization=vm
|
||||||
# This helps verify that we're running in a bootc/ostree based target.
|
# This helps verify that we're running in a bootc/ostree based target.
|
||||||
ConditionPathIsMountPoint=/sysroot
|
ConditionPathIsMountPoint=/sysroot
|
||||||
|
# For someone making a smaller image, assume they have this handled.
|
||||||
|
ConditionPathExists=/usr/bin/growpart
|
||||||
# We want to run before any e.g. large container images might be pulled.
|
# We want to run before any e.g. large container images might be pulled.
|
||||||
DefaultDependencies=no
|
DefaultDependencies=no
|
||||||
Requires=sysinit.target
|
Requires=sysinit.target
|
||||||
|
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
../tier-0/bootc.yaml
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
../tier-0/bootupd.yaml
|
|
||||||
|
|
@ -1,41 +1,10 @@
|
||||||
# This file was forked/copied from Fedora CoreOS. TODO: resync
|
# This file was forked/copied from Fedora CoreOS. TODO: resync
|
||||||
# once we have a good generic mechanism for sharing.
|
# once we have a good generic mechanism for sharing.
|
||||||
packages:
|
packages:
|
||||||
# Basic user tools
|
# Additional file compression/decompression
|
||||||
## jq - parsing/interacting with JSON data
|
- bzip2 zstd
|
||||||
- bash-completion
|
|
||||||
- coreutils
|
|
||||||
- file
|
|
||||||
- jq
|
|
||||||
- less
|
|
||||||
- sudo
|
|
||||||
- vim-minimal
|
|
||||||
# File compression/decompression
|
|
||||||
## bsdtar - dependency of 35coreos-live dracut module
|
|
||||||
- bsdtar
|
|
||||||
- bzip2
|
|
||||||
- gzip
|
|
||||||
- tar
|
|
||||||
- xz
|
|
||||||
- zstd
|
|
||||||
# Improved MOTD experience
|
|
||||||
- console-login-helper-messages-issuegen
|
|
||||||
- console-login-helper-messages-profile
|
|
||||||
# kdump support
|
# kdump support
|
||||||
# https://github.com/coreos/fedora-coreos-tracker/issues/622
|
# https://github.com/coreos/fedora-coreos-tracker/issues/622
|
||||||
- kexec-tools
|
- kexec-tools
|
||||||
# Remote Access
|
|
||||||
- openssh-clients openssh-server
|
|
||||||
# Container tooling
|
|
||||||
## crun recommends but doesn't require criu and criu-libs. We want them for
|
|
||||||
## checkpoint/restore. https://github.com/coreos/fedora-coreos-tracker/issues/1370
|
|
||||||
- crun criu criu-libs
|
|
||||||
- podman
|
|
||||||
- skopeo
|
|
||||||
- toolbox
|
|
||||||
# passt provides user-mode networking daemons for namespaces
|
|
||||||
- passt
|
|
||||||
# nvme-cli for managing nvme disks
|
# nvme-cli for managing nvme disks
|
||||||
- nvme-cli
|
- nvme-cli
|
||||||
# Used by admins interactively
|
|
||||||
- lsof
|
|
||||||
|
|
|
||||||
|
|
@ -1,7 +0,0 @@
|
||||||
packages:
|
|
||||||
# linux-firmware now a recommends so let's explicitly include it
|
|
||||||
# https://gitlab.com/cki-project/kernel-ark/-/commit/32271d0cd9bd52d386eb35497c4876a8f041f70b
|
|
||||||
# https://src.fedoraproject.org/rpms/kernel/c/f55c3e9ed8605ff28cb9a922efbab1055947e213?branch=rawhide
|
|
||||||
- linux-firmware
|
|
||||||
# If you're using linux-firmware, you probably also want fwupd
|
|
||||||
- fwupd
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
# Firmware updates
|
|
||||||
packages-aarch64:
|
|
||||||
- fwupd
|
|
||||||
packages-x86_64:
|
|
||||||
- fwupd
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
../tier-0/group
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
../tier-0/grub2-removals.yaml
|
|
||||||
|
|
@ -4,5 +4,5 @@ postprocess:
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
mkdir -p /usr/lib/dracut/dracut.conf.d
|
mkdir -p /usr/lib/dracut/dracut.conf.d
|
||||||
cat > /usr/lib/dracut/dracut.conf.d/30-bootc-tier-1.conf << 'EOF'
|
cat > /usr/lib/dracut/dracut.conf.d/30-bootc-tier-1.conf << 'EOF'
|
||||||
dracutmodules+=" lvm crypt "
|
add_dracutmodules+=" lvm crypt fips "
|
||||||
EOF
|
EOF
|
||||||
|
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
../tier-0/initramfs.yaml
|
|
||||||
|
|
@ -1,12 +0,0 @@
|
||||||
# This file includes a fixup for kdump on aarch64 AWS instances.
|
|
||||||
# The issue seems specific to aarch64 AWS instances, but we'll go
|
|
||||||
# ahead and apply it across the board for aarch64, since that's
|
|
||||||
# the easiest thing to do. Hopefully the upstream issue will get
|
|
||||||
# resolved soon.
|
|
||||||
postprocess:
|
|
||||||
- |
|
|
||||||
#!/usr/bin/env bash
|
|
||||||
# Remove irqpoll from the list of KDUMP_COMMANDLINE_APPEND. This
|
|
||||||
# causes issues on aarch64 AWS instances.
|
|
||||||
# https://github.com/coreos/fedora-coreos-tracker/issues/1187
|
|
||||||
sed -i -e 's/irqpoll //' /etc/sysconfig/kdump
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
../tier-0/manifest.yaml
|
|
||||||
|
|
@ -2,38 +2,21 @@
|
||||||
recommends: true
|
recommends: true
|
||||||
|
|
||||||
include:
|
include:
|
||||||
- manifest-tier-0.yaml
|
- ../tier-x/manifest.yaml
|
||||||
- bootable-rpm-ostree.yaml
|
|
||||||
- podman.yaml
|
|
||||||
- firmware.yaml
|
|
||||||
- networking-tools.yaml
|
- networking-tools.yaml
|
||||||
- system-configuration.yaml
|
- system-configuration.yaml
|
||||||
- coreos-user-experience.yaml
|
- coreos-user-experience.yaml
|
||||||
- fwupd.yaml
|
|
||||||
- persistent-journal.yaml
|
- persistent-journal.yaml
|
||||||
- initramfs-full.yaml
|
- initramfs-full.yaml
|
||||||
- generic-growfs.yaml
|
|
||||||
|
|
||||||
packages:
|
packages:
|
||||||
# Include and set the default editor
|
|
||||||
- nano
|
|
||||||
# And we expect this in general
|
|
||||||
- vim-minimal
|
|
||||||
- nfs-utils
|
- nfs-utils
|
||||||
# Additional firewall support; we aren't including these in RHCOS or they
|
# Additional firewall support; we aren't including these in RHCOS or they
|
||||||
# don't exist in RHEL
|
# don't exist in RHEL
|
||||||
- iptables-nft iptables-services
|
- iptables-services
|
||||||
- WALinuxAgent-udev
|
- WALinuxAgent-udev
|
||||||
# Allow communication between sudo and SSSD
|
|
||||||
# for caching sudo rules by SSSD.
|
|
||||||
# https://github.com/coreos/fedora-coreos-tracker/issues/445
|
|
||||||
- libsss_sudo
|
|
||||||
# SSSD; we only ship a subset of the backends
|
|
||||||
- sssd-client sssd-ad sssd-ipa sssd-krb5 sssd-ldap
|
|
||||||
# Used by admins interactively
|
# Used by admins interactively
|
||||||
- attr
|
|
||||||
- openssl
|
- openssl
|
||||||
- lsof
|
|
||||||
# Provides terminal tools like clear, reset, tput, and tset
|
# Provides terminal tools like clear, reset, tput, and tset
|
||||||
- ncurses
|
- ncurses
|
||||||
# i18n
|
# i18n
|
||||||
|
|
@ -41,21 +24,10 @@ packages:
|
||||||
# zram-generator (but not zram-generator-defaults) for F33 change
|
# zram-generator (but not zram-generator-defaults) for F33 change
|
||||||
# https://github.com/coreos/fedora-coreos-tracker/issues/509
|
# https://github.com/coreos/fedora-coreos-tracker/issues/509
|
||||||
- zram-generator
|
- zram-generator
|
||||||
# resolved was broken out to its own package in rawhide/f35
|
|
||||||
- systemd-resolved
|
|
||||||
# This one is in Python so isn't in FCOS, but we can safely add it here.
|
|
||||||
- sos
|
|
||||||
|
|
||||||
# These are random architecture-specific packages
|
# These are random architecture-specific packages
|
||||||
packages-x86_64:
|
packages-x86_64: []
|
||||||
- irqbalance
|
packages-aarch64: []
|
||||||
packages-ppc64le:
|
|
||||||
- irqbalance
|
|
||||||
- librtas
|
|
||||||
- powerpc-utils-core
|
|
||||||
- ppc64-diag-rtas
|
|
||||||
packages-aarch64:
|
|
||||||
- irqbalance
|
|
||||||
|
|
||||||
postprocess:
|
postprocess:
|
||||||
# Undo RPM scripts enabling units; we want the presets to be canonical
|
# Undo RPM scripts enabling units; we want the presets to be canonical
|
||||||
|
|
@ -67,19 +39,6 @@ postprocess:
|
||||||
systemctl preset-all
|
systemctl preset-all
|
||||||
rm -rf /etc/systemd/user/*
|
rm -rf /etc/systemd/user/*
|
||||||
systemctl --user --global preset-all
|
systemctl --user --global preset-all
|
||||||
# Default to iptables-nft. Otherwise, legacy wins. We can drop this once/if we
|
|
||||||
# remove iptables-legacy. This is needed because alternatives don't work
|
|
||||||
# https://github.com/coreos/fedora-coreos-tracker/issues/677
|
|
||||||
# https://github.com/coreos/fedora-coreos-tracker/issues/676
|
|
||||||
- |
|
|
||||||
#!/usr/bin/env bash
|
|
||||||
set -xeuo pipefail
|
|
||||||
ln -sf /usr/sbin/ip6tables-nft /etc/alternatives/ip6tables
|
|
||||||
ln -sf /usr/sbin/ip6tables-nft-restore /etc/alternatives/ip6tables-restore
|
|
||||||
ln -sf /usr/sbin/ip6tables-nft-save /etc/alternatives/ip6tables-save
|
|
||||||
ln -sf /usr/sbin/iptables-nft /etc/alternatives/iptables
|
|
||||||
ln -sf /usr/sbin/iptables-nft-restore /etc/alternatives/iptables-restore
|
|
||||||
ln -sf /usr/sbin/iptables-nft-save /etc/alternatives/iptables-save
|
|
||||||
# See: https://github.com/coreos/fedora-coreos-tracker/issues/1253
|
# See: https://github.com/coreos/fedora-coreos-tracker/issues/1253
|
||||||
# https://bugzilla.redhat.com/show_bug.cgi?id=2112857
|
# https://bugzilla.redhat.com/show_bug.cgi?id=2112857
|
||||||
# https://github.com/coreos/rpm-ostree/issues/3918
|
# https://github.com/coreos/rpm-ostree/issues/3918
|
||||||
|
|
@ -108,3 +67,6 @@ exclude-packages:
|
||||||
# Do not use legacy ifcfg config format in NetworkManager
|
# Do not use legacy ifcfg config format in NetworkManager
|
||||||
# See https://github.com/coreos/fedora-coreos-config/pull/1991
|
# See https://github.com/coreos/fedora-coreos-config/pull/1991
|
||||||
- NetworkManager-initscripts-ifcfg-rh
|
- NetworkManager-initscripts-ifcfg-rh
|
||||||
|
# Let's not have both legacy and nft versions in the image. Users are free to
|
||||||
|
# also layer legacy themselves if they want.
|
||||||
|
- iptables-legacy
|
||||||
|
|
|
||||||
|
|
@ -3,8 +3,6 @@
|
||||||
# generic enough to be shared downstream with RHCOS.
|
# generic enough to be shared downstream with RHCOS.
|
||||||
|
|
||||||
packages:
|
packages:
|
||||||
# Standard tools for configuring network/hostname
|
|
||||||
- NetworkManager hostname
|
|
||||||
# Interactive Networking configuration during coreos-install
|
# Interactive Networking configuration during coreos-install
|
||||||
- NetworkManager-tui
|
- NetworkManager-tui
|
||||||
# Support for cloud quirks and dynamic config in real rootfs:
|
# Support for cloud quirks and dynamic config in real rootfs:
|
||||||
|
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
../tier-0/ostree.yaml
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
../tier-0/passwd
|
|
||||||
|
|
@ -1,7 +0,0 @@
|
||||||
# Core podman bits
|
|
||||||
|
|
||||||
packages:
|
|
||||||
- crun
|
|
||||||
- podman
|
|
||||||
- container-selinux
|
|
||||||
- skopeo
|
|
||||||
|
|
@ -1,17 +1,12 @@
|
||||||
# These are packages that are related to configuring parts of the system.
|
# These are packages that are related to configuring parts of the system.
|
||||||
|
|
||||||
packages:
|
packages:
|
||||||
# Configuring SSH keys, cloud provider check-in, etc
|
# Explicit dep for RHEL >= 10
|
||||||
# TODO: needs Ignition kargs
|
- crypto-policies-scripts
|
||||||
# - afterburn afterburn-dracut
|
|
||||||
# NTP support
|
# NTP support
|
||||||
- chrony
|
- chrony
|
||||||
# Storage configuration/management
|
# Storage configuration/management
|
||||||
- lvm2
|
|
||||||
- cryptsetup
|
|
||||||
- e2fsprogs
|
|
||||||
- sg3_utils
|
- sg3_utils
|
||||||
- xfsprogs
|
|
||||||
## This is generally useful... https://github.com/CentOS/centos-bootc/issues/394
|
## This is generally useful... https://github.com/CentOS/centos-bootc/issues/394
|
||||||
- cloud-utils-growpart
|
- cloud-utils-growpart
|
||||||
# User configuration
|
# User configuration
|
||||||
|
|
@ -26,7 +21,4 @@ packages:
|
||||||
# Anything package layered will also tend to expect files dropped in
|
# Anything package layered will also tend to expect files dropped in
|
||||||
# /etc/logrotate.d to work. Really, this is a legacy thing, but if we don't
|
# /etc/logrotate.d to work. Really, this is a legacy thing, but if we don't
|
||||||
# have it then people's disks will slowly fill up with logs.
|
# have it then people's disks will slowly fill up with logs.
|
||||||
- logrotate
|
- logrotate
|
||||||
# Boost starving threads
|
|
||||||
# https://github.com/coreos/fedora-coreos-tracker/issues/753
|
|
||||||
- stalld
|
|
||||||
|
|
@ -0,0 +1 @@
|
||||||
|
../tier-0/kernel.yaml
|
||||||
|
|
@ -0,0 +1,44 @@
|
||||||
|
include:
|
||||||
|
- ../tier-0/manifest.yaml
|
||||||
|
|
||||||
|
packages:
|
||||||
|
# Used by admins interactively
|
||||||
|
- attr
|
||||||
|
- bash-completion
|
||||||
|
- hostname
|
||||||
|
- iproute
|
||||||
|
- jq
|
||||||
|
- less
|
||||||
|
- vim-minimal
|
||||||
|
# deps of bootc, but let's be explicit. e.g. even if bootc drops the skopeo
|
||||||
|
# dep, we still want it
|
||||||
|
- podman skopeo
|
||||||
|
# crun recommends but doesn't require criu and criu-libs. We want them for
|
||||||
|
# checkpoint/restore. https://github.com/coreos/fedora-coreos-tracker/issues/1370
|
||||||
|
- crun criu criu-libs
|
||||||
|
# storage
|
||||||
|
- cryptsetup
|
||||||
|
- lvm2
|
||||||
|
- tar
|
||||||
|
# zram-generator (but not zram-generator-defaults) for F33 change
|
||||||
|
# https://github.com/coreos/fedora-coreos-tracker/issues/509
|
||||||
|
- zram-generator
|
||||||
|
# networking
|
||||||
|
- iptables-nft
|
||||||
|
- NetworkManager
|
||||||
|
- openssh-clients
|
||||||
|
- openssh-server
|
||||||
|
# linux-firmware now a recommends so let's explicitly include it
|
||||||
|
# https://gitlab.com/cki-project/kernel-ark/-/commit/32271d0cd9bd52d386eb35497c4876a8f041f70b
|
||||||
|
# https://src.fedoraproject.org/rpms/kernel/c/f55c3e9ed8605ff28cb9a922efbab1055947e213?branch=rawhide
|
||||||
|
- linux-firmware
|
||||||
|
# security
|
||||||
|
- polkit
|
||||||
|
- sudo
|
||||||
|
# Allow for configuring different timezones
|
||||||
|
- tzdata
|
||||||
|
# rpm-ostree
|
||||||
|
- rpm-ostree nss-altfiles
|
||||||
|
# firmware updates
|
||||||
|
# If you're using linux-firmware, you probably also want fwupd
|
||||||
|
- fwupd
|
||||||
Loading…
Reference in New Issue