The utility for building of AlmaLinux distributions (repos, ISO images).
Go to file
Adam Williamson aa7fcc1c20 Improve autodetection of productmd image type for osbuild images
I don't love inferring the type from the filename like this -
it's kinda backwards - but it's an improvement on the current
logic (I don't think 'dvd' is ever currently the correct value
here, I don't think osbuild *can* currently build the type of
image that 'dvd' is meant to indicate). I can't immediately see
any better source of data here (we could use the 'name' or
'package_name' from 'build_info', but those are pretty much
just inputs to the filenames anyway).

Types that are possible in productmd but not covered here are
'cd' (never likely to be used again in Fedora at least, not sure
about RHEL), 'dvd-debuginfo' (again not used in Fedora, may be
used in RHEL), 'ec2', 'kvm' (not sure about those), 'netinst'
(this is a synonym for 'boot', we use 'boot' in practice in
Fedora metadata), 'p2v' and 'rescue' (not sure).

Signed-off-by: Adam Williamson <awilliam@redhat.com>
2023-11-06 08:24:12 -10:00
contrib Add config file for cleaning up cache files 2023-04-12 09:56:43 +08:00
doc Drop buildinstall method 2023-10-18 06:38:14 +00:00
pungi Improve autodetection of productmd image type for osbuild images 2023-11-06 08:24:12 -10:00
pungi_utils Drop pungi-orchestrator code 2023-06-02 06:14:10 +00:00
share Allow setting <kojitag/> in <modules/> in variants.xml to get the modules from this Koji tag. 2018-03-21 14:33:45 +01:00
tests pkgset: ignore events for modular content tags 2023-10-27 08:16:30 +02:00
.gitignore nomacboot option for livemedia koji tasks 2022-03-23 09:36:51 +01:00
AUTHORS extra-files: Write a metadata file enumerating extra files 2016-09-07 13:02:48 +02:00
COPYING Remove FSF address from comments 2016-09-23 10:26:43 +02:00
GPL Update GPL to latest version from https://www.gnu.org/licenses/gpl-2.0.txt 2015-06-25 07:50:03 -04:00
MANIFEST.in Default bztar format for sdist command 2022-12-12 12:10:54 +01:00
Makefile Use pytest instead of nosetests 2020-07-29 14:57:16 +08:00
README.md Correct irc network name & add matrix room 2021-10-25 07:26:18 +00:00
TODO Drop buildinstall method 2023-10-18 06:38:14 +00:00
git-changelog git-changelog: Fix running on Python 3 2019-07-02 15:05:25 +02:00
pungi.spec 4.5.1 release 2023-09-07 15:00:59 +02:00
requirements.txt Add support for not having koji volume mounted locally 2023-08-23 07:26:56 +00:00
setup.cfg Default bztar format for sdist command 2022-12-12 12:10:54 +01:00
setup.py 4.5.1 release 2023-09-07 15:00:59 +02:00
test-requirements.txt Use requirements.txt 2020-08-11 20:36:22 +08:00
tox.ini Involve bandit 2022-04-07 14:03:57 +08:00

README.md

Pungi

Pungi is a distribution compose tool.

Composes are release snapshots that contain release deliverables such as:

  • installation trees
    • RPMs
    • repodata
    • comps
  • (bootable) ISOs
  • kickstart trees
    • anaconda images
    • images for PXE boot

Tool overview

Pungi consists of multiple separate executables backed by a common library.

The main entry-point is the pungi-koji script. It loads the compose configuration and kicks off the process. Composing itself is done in phases. Each phase is responsible for generating some artifacts on disk and updating the compose object that is threaded through all the phases.

Pungi itself does not actually do that much. Most of the actual work is delegated to separate executables. Pungi just makes sure that all the commands are invoked in the appropriate order and with correct arguments. It also moves the artifacts to correct locations.