Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Master enable ostree containers #4561

Merged
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Next Next commit
Add RPM OSTree source from container (#2125655)
RPM OSTree is getting new functionality to use containers as the base
image. Thanks to that it's possible to use standard container
repositories.

This source enables to use these repositories.

Related: rhbz#2125655
  • Loading branch information
jkonecny12 committed Mar 21, 2023
commit 51b7b14ce8ebc64020901706c87511fb353a90d2
1 change: 1 addition & 0 deletions configure.ac
Original file line number Diff line number Diff line change
Expand Up @@ -182,6 +182,7 @@ AC_CONFIG_FILES([Makefile
pyanaconda/modules/payloads/source/repo_files/Makefile
pyanaconda/modules/payloads/source/repo_path/Makefile
pyanaconda/modules/payloads/source/rpm_ostree/Makefile
pyanaconda/modules/payloads/source/rpm_ostree_container/Makefile
pyanaconda/modules/payloads/source/url/Makefile
pyanaconda/modules/storage/Makefile
pyanaconda/modules/storage/bootloader/Makefile
Expand Down
1 change: 1 addition & 0 deletions pyanaconda/core/constants.py
Original file line number Diff line number Diff line change
Expand Up @@ -410,6 +410,7 @@ class DisplayModes(Enum):
SOURCE_TYPE_LIVE_IMAGE = "LIVE_IMAGE"
SOURCE_TYPE_LIVE_TAR = "LIVE_TAR"
SOURCE_TYPE_RPM_OSTREE = "RPM_OSTREE"
SOURCE_TYPE_RPM_OSTREE_CONTAINER = "RPM_OSTREE_CONTAINER"
SOURCE_TYPE_FLATPAK = "FLATPAK"
SOURCE_TYPE_HMC = "HMC"
SOURCE_TYPE_CDROM = "CDROM"
Expand Down
1 change: 1 addition & 0 deletions pyanaconda/core/kickstart/commands.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@
from pykickstart.commands.network import F39_Network as Network
from pykickstart.commands.nfs import FC6_NFS as NFS
from pykickstart.commands.nvdimm import F28_Nvdimm as Nvdimm
from pykickstart.commands.ostreecontainer import F38_OSTreeContainer as OSTreeContainer
from pykickstart.commands.ostreesetup import F21_OSTreeSetup as OSTreeSetup
from pykickstart.commands.partition import F34_Partition as Partition
from pykickstart.commands.raid import F29_Raid as Raid
Expand Down
5 changes: 5 additions & 0 deletions pyanaconda/modules/common/constants/interfaces.py
Original file line number Diff line number Diff line change
Expand Up @@ -148,6 +148,11 @@
basename="RPMOSTree"
)

PAYLOAD_SOURCE_RPM_OSTREE_CONTAINER = DBusInterfaceIdentifier(
namespace=SOURCE_NAMESPACE,
basename="RPMOSTreeContainer"
)

PAYLOAD_SOURCE_FLATPAK = DBusInterfaceIdentifier(
namespace=SOURCE_NAMESPACE,
basename="Flatpak"
Expand Down
74 changes: 73 additions & 1 deletion pyanaconda/modules/common/structures/rpm_ostree.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
from dasbus.structure import DBusData
from dasbus.typing import Str, Bool

__all__ = ["RPMOSTreeConfigurationData"]
__all__ = ["RPMOSTreeConfigurationData", "RPMOSTreeContainerConfigurationData"]


class RPMOSTreeConfigurationData(DBusData):
Expand All @@ -33,6 +33,11 @@ def __init__(self):
self._ref = ""
self._gpg_verification_enabled = True

@staticmethod
def is_container():
"""Is this native container source?"""
return False
Comment on lines +36 to +39
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You extended this class so it's the same as the new class... but then made it different anyway?


@property
def osname(self) -> Str:
"""Management root for OS installation."""
Expand Down Expand Up @@ -77,3 +82,70 @@ def gpg_verification_enabled(self) -> Bool:
@gpg_verification_enabled.setter
def gpg_verification_enabled(self, value: Bool):
self._gpg_verification_enabled = value


class RPMOSTreeContainerConfigurationData(DBusData):
"""Structure to hold RPM OSTree from container configuration."""

def __init__(self):
self._stateroot = ""
self._remote = ""
self._transport = ""
self._url = ""
self._signature_verification_enabled = True

@staticmethod
def is_container():
"""Is this native container source?"""
return True

@property
def stateroot(self) -> Str:
"""Name for the state directory, also known as "osname".

This could be optional.
"""
return self._stateroot

@stateroot.setter
def stateroot(self, value: Str):
self._stateroot = value

@property
def transport(self) -> Str:
"""Ostree transport protocol used.

This could be optional (default will be 'repository').
"""
return self._transport

@transport.setter
def transport(self, value: Str):
self._transport = value

@property
def remote(self) -> Str:
"""Name of the OSTree remote."""
return self._remote

@remote.setter
def remote(self, value: Str):
self._remote = value

@property
def url(self) -> Str:
"""URL of the repository to install from."""
return self._url

@url.setter
def url(self, value: Str):
self._url = value

@property
def signature_verification_enabled(self) -> Bool:
poncovka marked this conversation as resolved.
Show resolved Hide resolved
"""Is the GPG key verification enabled?"""
return self._signature_verification_enabled

@signature_verification_enabled.setter
def signature_verification_enabled(self, value: Bool):
self._signature_verification_enabled = value
4 changes: 3 additions & 1 deletion pyanaconda/modules/payloads/constants.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,8 @@
PAYLOAD_TYPE_DNF, PAYLOAD_TYPE_LIVE_OS, PAYLOAD_TYPE_LIVE_IMAGE, \
SOURCE_TYPE_LIVE_OS_IMAGE, SOURCE_TYPE_HMC, SOURCE_TYPE_CDROM, SOURCE_TYPE_REPO_FILES, \
SOURCE_TYPE_REPO_PATH, SOURCE_TYPE_NFS, SOURCE_TYPE_URL, SOURCE_TYPE_HDD, SOURCE_TYPE_CDN, \
SOURCE_TYPE_CLOSEST_MIRROR, PAYLOAD_TYPE_RPM_OSTREE, SOURCE_TYPE_RPM_OSTREE, \
SOURCE_TYPE_CLOSEST_MIRROR, PAYLOAD_TYPE_RPM_OSTREE, \
SOURCE_TYPE_RPM_OSTREE, SOURCE_TYPE_RPM_OSTREE_CONTAINER, \
SOURCE_TYPE_LIVE_IMAGE, SOURCE_TYPE_FLATPAK, SOURCE_TYPE_LIVE_TAR

# Locations of repo files.
Expand All @@ -48,6 +49,7 @@ class SourceType(Enum):
LIVE_IMAGE = SOURCE_TYPE_LIVE_IMAGE
LIVE_TAR = SOURCE_TYPE_LIVE_TAR
RPM_OSTREE = SOURCE_TYPE_RPM_OSTREE
RPM_OSTREE_CONTAINER = SOURCE_TYPE_RPM_OSTREE_CONTAINER
FLATPAK = SOURCE_TYPE_FLATPAK
HMC = SOURCE_TYPE_HMC
CDROM = SOURCE_TYPE_CDROM
Expand Down
1 change: 1 addition & 0 deletions pyanaconda/modules/payloads/kickstart.py
Original file line number Diff line number Diff line change
Expand Up @@ -293,6 +293,7 @@ class PayloadKickstartSpecification(KickstartSpecification):
"liveimg": COMMANDS.Liveimg,
"module": COMMANDS.Module,
"nfs": COMMANDS.NFS,
"ostreecontainer": COMMANDS.OSTreeContainer,
"ostreesetup": COMMANDS.OSTreeSetup,
"repo": COMMANDS.Repo,
"url": COMMANDS.Url
Expand Down
4 changes: 2 additions & 2 deletions pyanaconda/modules/payloads/source/Makefile.am
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,8 @@
# You should have received a copy of the GNU Lesser General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.

SUBDIRS = hmc cdrom repo_files nfs url harddrive cdn closest_mirror rpm_ostree flatpak \
live_image live_os live_tar repo_path
SUBDIRS = hmc cdrom repo_files nfs url harddrive cdn closest_mirror rpm_ostree \
rpm_ostree_container flatpak live_image live_os live_tar repo_path

pkgpyexecdir = $(pyexecdir)/py$(PACKAGE_NAME)
payload_moduledir = $(pkgpyexecdir)/modules/payloads/source
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
#
# Copyright (C) 2023 Red Hat, Inc.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published
# by the Free Software Foundation; either version 2.1 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.

pkgpyexecdir = $(pyexecdir)/py$(PACKAGE_NAME)
payload_moduledir = $(pkgpyexecdir)/modules/payloads/source/rpm_ostree_container
payload_module_PYTHON = $(srcdir)/*.py

MAINTAINERCLEANFILES = Makefile.in
Empty file.
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
#
# The RPM OSTree source module.
#
# 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 pyanaconda.anaconda_loggers import get_module_logger
from pyanaconda.core.i18n import _
from pyanaconda.modules.common.structures.rpm_ostree import RPMOSTreeContainerConfigurationData
from pyanaconda.modules.payloads.constants import SourceType
from pyanaconda.modules.payloads.source.rpm_ostree.rpm_ostree import \
RPMOSTreeSourceModule
from pyanaconda.modules.payloads.source.rpm_ostree_container.rpm_ostree_container_interface import \
RPMOSTreeContainerSourceInterface

log = get_module_logger(__name__)

__all__ = ["RPMOSTreeContainerSourceModule"]


class RPMOSTreeContainerSourceModule(RPMOSTreeSourceModule):
"""The RPM OSTree from container source module."""

def __init__(self):
super().__init__()
self._configuration = RPMOSTreeContainerConfigurationData()

@property
def type(self):
"""Get type of this source."""
return SourceType.RPM_OSTREE_CONTAINER

@property
def description(self):
"""Get description of this source."""
return _("RPM OSTree Container")

def for_publication(self):
"""Return a DBus representation."""
return RPMOSTreeContainerSourceInterface(self)

@property
def network_required(self):
"""Does the source require a network?

:return: True or False
"""
# FIXME: Missing network detection logic based on the URL
return False

def process_kickstart(self, data):
"""Process the kickstart data."""
configuration = RPMOSTreeContainerConfigurationData()

configuration.stateroot = data.ostreecontainer.stateroot
configuration.url = data.ostreecontainer.url
configuration.remote = data.ostreecontainer.remote
configuration.transport = data.ostreecontainer.transport
configuration.signature_verification_enabled = not data.ostreecontainer.noSignatureVerification

self.set_configuration(configuration)

def setup_kickstart(self, data):
"""Setup the kickstart data."""
data.ostreecontainer.stateroot = self.configuration.stateroot
data.ostreecontainer.remote = self.configuration.remote
data.ostreecontainer.transport = self.configuration.transport
data.ostreecontainer.url = self.configuration.url
data.ostreecontainer.noSignatureVerification = not self.configuration.signature_verification_enabled
data.ostreecontainer.seen = True

def __repr__(self):
"""Return a string representation of the source."""
return "Source(type='{}', stateroot='{}', transport='{}', url='{}')".format(
self.type.value,
self.configuration.stateroot,
self.configuration.transport,
self.configuration.url
)
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
#
# DBus interface for the RPM OSTree source module.
#
# 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 dasbus.server.property import emits_properties_changed
from dasbus.typing import * # pylint: disable=wildcard-import
from dasbus.server.interface import dbus_interface
from pyanaconda.modules.common.constants.interfaces import PAYLOAD_SOURCE_RPM_OSTREE_CONTAINER
from pyanaconda.modules.common.structures.rpm_ostree import RPMOSTreeContainerConfigurationData
from pyanaconda.modules.payloads.source.source_base_interface import PayloadSourceBaseInterface

__all__ = ["RPMOSTreeContainerSourceInterface"]


@dbus_interface(PAYLOAD_SOURCE_RPM_OSTREE_CONTAINER.interface_name)
class RPMOSTreeContainerSourceInterface(PayloadSourceBaseInterface):
"""DBus interface for the RPM OSTree source module."""

def connect_signals(self):
"""Connect the signals."""
super().connect_signals()
self.watch_property("Configuration", self.implementation.configuration_changed)

@property
def Configuration(self) -> Structure:
"""The source configuration.

:return: a structure of the type RPMOSTreeConfigurationData
"""
return RPMOSTreeContainerConfigurationData.to_structure(
self.implementation.configuration
)

@Configuration.setter
@emits_properties_changed
def Configuration(self, data: Structure):
"""Set the source configuration.

:param data: a structure of the type RPMOSTreeConfigurationData
"""
self.implementation.set_configuration(
RPMOSTreeContainerConfigurationData.from_structure(data)
)