Source code for pykickstart.commands.ostreecontainer
#
# Copyright (C) 2023 Red Hat, Inc.
#
# This copyrighted material is made available to anyone wishing to use,
# modify, copy, or redistribute it subject to the terms and conditions of
# the GNU General Public License v.2, or (at your option) any later version.
# This program is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY expressed or implied, including the implied warranties of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
# Public License for more details. You should have received a copy of the
# GNU General Public License along with this program; if not, write to the
# Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
# 02110-1301, USA. Any Red Hat trademarks that are incorporated in the
# source code or documentation are not subject to the GNU General Public
# License and may only be used or replicated with the express permission of
# Red Hat, Inc.
#
from pykickstart.version import F38
from pykickstart.base import KickstartCommand
from pykickstart.options import KSOptionParser
[docs]
class F38_OSTreeContainer(KickstartCommand):
removedKeywords = KickstartCommand.removedKeywords
removedAttrs = KickstartCommand.removedAttrs
conflictingCommands = ["ostreesetup"]
def __init__(self, *args, **kwargs):
KickstartCommand.__init__(self, *args, **kwargs)
self.op = self._getParser()
self.stateroot = kwargs.get('stateroot', None)
self.url = kwargs.get('url', None)
self.transport = kwargs.get("transport", None)
self.remote = kwargs.get("remote", self.stateroot)
self.noSignatureVerification = kwargs.get('noSignatureVerification', False)
def __str__(self):
retval = KickstartCommand.__str__(self)
if not self.seen:
return retval
retval += "# OSTree container setup\n"
retval += "ostreecontainer %s\n" % self._getArgsAsStr()
return retval
def _getArgsAsStr(self):
retcmd = []
if self.stateroot:
retcmd.append('--stateroot="%s"' % self.stateroot)
if self.remote:
retcmd.append('--remote="%s"' % self.remote)
if self.noSignatureVerification:
retcmd.append('--no-signature-verification')
if self.transport:
retcmd.append('--transport="%s"' % self.transport)
if self.url:
retcmd.append('--url="%s"' % self.url)
return ' '.join(retcmd)
def _getParser(self):
op = KSOptionParser(prog="ostreecontainer", description="""
Used for OSTree installations from native container. See
https://coreos.github.io/rpm-ostree/container/
for more information about OSTree.
**Experimental. Use on your own risk.**
""", version=F38, conflicts=self.conflictingCommands)
# Rename the osname to stateroot and set default as proposed by
# https://github.com/ostreedev/ostree/issues/2794
op.add_argument("--stateroot", version=F38, help="""
Name for the state directory, also known as "osname".
Default value will be `default`.""")
op.add_argument("--url", required=True, version=F38, help="""
Name of the container image; for the `registry` transport.
This would be e.g. `quay.io/exampleos/foo:latest`.""")
op.add_argument("--transport", version=F38, help="""
The transport; e.g. registry, oci, oci-archive.
The default is `registry`.""")
op.add_argument("--remote", version=F38, help="""
Name of the OSTree remote.""")
op.add_argument("--no-signature-verification",
dest="noSignatureVerification",
action="store_true",
version=F38,
help="""Disable verification via an ostree remote.""")
return op
[docs]
def parse(self, args):
ns = self.op.parse_args(args=args, lineno=self.lineno)
self.set_to_self(ns)
if not self.remote:
self.remote = self.stateroot
return self
[docs]
class RHEL9_OSTreeContainer(F38_OSTreeContainer):
pass