No description
Find a file
Martin Sehnoutka 8b0ea15817 stages: add org.osbuild.ostree.passwd
This stage takes /usr/lib/passwd and /usr/etc/passwd from an OSTree
checkout, merges them into one file, and store it as /etc/passwd in the
buildroot.

It does the same for /etc/group.

The reason for doing this is that there is an issue with unstable UIDs
and GIDs when creating OSTree commits from scratch. When there is a
package that creates a system user or a system group, it can change the
UID and GID of users and groups that are created later.

This is not a problem in traditional deployments because already created
users and groups never change their UIDs and GIDs, but with OSTree we
recreate the files from scratch and then replace the previous one so it
can actually change.

By copying the files to the build root before doing any other
operations, we can make sure that the UIDs and GIDs of already existing
users and groups won't change.

Co-author: Christian Kellner <christian@kellner.me>
2021-08-17 13:53:00 +02:00
.devcontainer devcontainer: include packit, boto3 & more tools 2021-08-17 10:42:03 +02:00
.github ci: use new ci image that includes lvm2 2021-08-13 12:20:54 +02:00
assemblers assembler/ostree.commit: fix copying of links 2021-07-16 10:32:12 +02:00
devices devices/loopback: it is flush_buf not flushbuf 2021-08-14 13:25:19 +02:00
docs docs: add --export option to the osbuild man page 2021-07-14 14:35:30 +02:00
inputs inputs: add org.osbuild.ostree.checkout 2021-08-17 13:53:00 +02:00
mounts mounts: add org.osbuild.noop 2021-07-21 13:28:22 +02:00
osbuild stages: add org.osbuild.ostree.passwd 2021-08-17 13:53:00 +02:00
runners runners: add a runner for RHEL 8.6 2021-08-05 22:11:24 +02:00
schemas device: add support for parent devices 2021-08-13 12:20:54 +02:00
schutzbot mockbuild: add rhel 9 2021-07-22 17:58:41 +02:00
selinux selinux: allow nnp and nosuid transitions 2020-08-10 14:05:24 +02:00
sources sources/inline: fix schema 2021-06-30 12:06:30 +02:00
stages stages: add org.osbuild.ostree.passwd 2021-08-17 13:53:00 +02:00
test stages: add org.osbuild.ostree.passwd 2021-08-17 13:53:00 +02:00
tools tools/mpp: expand basurl after dep-solving 2021-07-20 13:23:58 +02:00
.editorconfig editorconfig: include markdown specifications 2020-10-23 16:29:50 +02:00
.gitignore gitignore: ignore macos metadata file 2021-08-13 12:20:54 +02:00
.gitlab-ci.yml mockbuild: add rhel 9 2021-07-22 17:58:41 +02:00
.packit.yaml packit: configure tag template 2021-08-17 10:42:03 +02:00
.travis.yml ci: move test_boot to github-actions 2020-05-13 22:00:27 +02:00
LICENSE Revert "Fill in the license template" 2019-11-18 12:23:10 +01:00
Makefile test/data: add version agnostic build manifest 2021-08-17 10:42:03 +02:00
NEWS.md NEWS: update for release 30 2021-07-22 21:15:37 +02:00
osbuild.spec 30 2021-07-22 21:15:37 +02:00
README.md README: improve Build section 2021-07-14 14:37:03 +02:00
requirements.txt Makefile: use pytest for nicer output 2020-12-04 18:24:48 +01:00
samples samples: replace with symlink to test data 2021-07-12 18:44:50 +02:00
setup.cfg setup.cfg: set max line length in pycodestyle 2021-05-12 14:26:16 +02:00
setup.py 30 2021-07-22 21:15:37 +02:00

OSBuild

Build-Pipelines for Operating System Artifacts

OSBuild is a pipeline-based build system for operating system artifacts. It defines a universal pipeline description and a build system to execute them, producing artifacts like operating system images, working towards an image build pipeline that is more comprehensible, reproducible, and extendable.

See the osbuild(1) man-page for details on how to run osbuild, the definition of the pipeline description, and more.

Project

Requirements

The requirements for this project are:

  • bubblewrap >= 0.4.0
  • python >= 3.7

Additionally, the built-in stages require:

  • bash >= 5.0
  • coreutils >= 8.31
  • curl >= 7.68
  • qemu-img >= 4.2.0
  • rpm >= 4.15
  • tar >= 1.32
  • util-linux >= 235

At build-time, the following software is required:

  • python-docutils >= 0.13
  • pkg-config >= 0.29

Testing requires additional software:

  • pytest

Install

Installing osbuild requires to not only install the osbuild module, but also additional artifacts such as tools (i.e: osbuild-mpp) sources, stages, schemas and SELinux policies.

For this reason, doing an installation from source is not trivial and the easier way to install it is to create the set of RPMs that contain all these components.

This can be done with the rpm make target, i.e:

make rpm

A set of RPMs will be created in the ./rpmbuild/RPMS/noarch/ directory and can be installed in the system using the distribution package manager, i.e:

sudo dnf install ./rpmbuild/RPMS/noarch/*.rpm

Repository:

License:

  • Apache-2.0
  • See LICENSE file for details.