On Wed, 2023-06-28 at 18:44 +0200, Simon de Vlieger wrote:
> 
> What I would like to know is what is the minimum customizations needed 
> in blueprints for this change proposal and what is necessary for 
> supporting editions and spins down the line.

Thanks, Simon. So, we obviously don't need layering/inheritance
*implemented* to build a single live image. I'm not saying we do, just
that we need a plan to address the need that is currently addressed by
kickstart inheritance.

The current Workstation live has the package exclusions from fedora-
workstation-common.ks in it:

https://pagure.io/fedora-kickstarts/blob/main/f/fedora-workstation-common.ks

so it excludes three groups that are part of the 'standard' for live
images but which Workstation doesn't want to include, and it excludes
two packages that usually get pulled in as part of the installer
environment. The reiserfs-utils exclusion could actually be dropped as
we dropped reiserfs-utils from comps long ago, but the gfs2-utils
exclusion is still 'active'.
> 
> The second one is likely harder but seems to be based very much on 
> 'thats how we do it now'. Personally I'd prefer having base fedora 
> defined in code and each edition/spin being a small blueprint that only 
> adds onto that base Fedora. That way spins would be less affected by 
> changes in inherited kickstarts/blueprints.
> 
> I'll dive into the kickstart repository to see what exactly is being 
> done but it's likely that a lot of what happens in kickstarts currently 
> already happens in code in osbuild-composer (e.g. adjustments to 
> bootloaders/partitions/extra packages to install based on the output 
> image type and architecture).

It's not really, or not entirely, about either of those. Ensuring all
bootloader packages is present is really handled by comps - they are in
the anaconda-tools group, and we always pull that into live images
(it's in fedora-live-base.ks ).

There is a bit of "defining base Fedora" - that's what fedora-live-
base.ks does - but there is other stuff too. One very prevalent pattern
is that we share a lot of stuff between live image and disk image
definitions. So for e.g. for Workstation, we have these chains:

fedora-live-workstation.ks inherits from fedora-live-base.ks and
fedora-workstation-common.ks
fedora-disk-workstation.ks inherits from fedora-disk-base.ks, fedora-
disk-xbase.ks and fedora-workstation-common.ks

so things that are 'basic' to each particular type of image are shared,
but also things that are 'basic' to each edition or spin are shared, so
we're not doing them twice between the lives and the disk images. 

Then we have things like labs/spins that are based on desktop
spins/editions, but extend them. For e.g., the Design Suite lab is
based on Workstation, so it inherits from fedora-live-workstation.ks .
Astronomy_KDE and Scientific_KDE, obviously, inherit from the KDE
kickstarts.

There's also a 'minimization' pattern where several kickstarts inherit
from fedora-live-minimization.ks , which does/did some shared
minimization stuff. I kinda disliked that pattern and I've managed to
pare that file down to just `-hplip` now, but that's still there as I
haven't managed to shift it.

So, there's a lot going on with the inheritance stuff. :D It definitely
needs to be evaluated at least. You can just do `grep include *.ks` in
the fedora-kickstarts repo to get a feel for everything.
-- 
Adam Williamson (he/him/his)
Fedora QA
Fedora Chat: @adamwill:fedora.im | Mastodon: @ad...@fosstodon.org
https://www.happyassassin.net



_______________________________________________
devel mailing list -- devel@lists.fedoraproject.org
To unsubscribe send an email to devel-le...@lists.fedoraproject.org
Fedora Code of Conduct: 
https://docs.fedoraproject.org/en-US/project/code-of-conduct/
List Guidelines: https://fedoraproject.org/wiki/Mailing_list_guidelines
List Archives: 
https://lists.fedoraproject.org/archives/list/devel@lists.fedoraproject.org
Do not reply to spam, report it: 
https://pagure.io/fedora-infrastructure/new_issue

Reply via email to