Skip to content

Commit

Permalink
Revert "Add detection for ostree-based systems and warn users about l…
Browse files Browse the repository at this point in the history
…osing changes"

This reverts commit d100c8d because
it breaks "dnf --installroot".
Related: https://issues.redhat.com/browse/RHEL-49670
  • Loading branch information
ppisar committed Aug 14, 2024
1 parent 9079c98 commit bc5bac3
Show file tree
Hide file tree
Showing 2 changed files with 0 additions and 40 deletions.
9 changes: 0 additions & 9 deletions dnf/cli/cli.py
Original file line number Diff line number Diff line change
Expand Up @@ -214,15 +214,6 @@ def do_transaction(self, display=()):
elif 'test' in self.conf.tsflags:
logger.info(_("{prog} will only download packages, install gpg keys, and check the "
"transaction.").format(prog=dnf.util.MAIN_PROG_UPPER))
if dnf.util.is_container():
_container_msg = _("""
*** This system is managed with ostree. Changes to the system
*** made with dnf will be lost with the next ostree-based update.
*** If you do not want to lose these changes, use 'rpm-ostree'.
""")
logger.info(_container_msg)
raise CliError(_("Operation aborted."))

if self._promptWanted():
if self.conf.assumeno or not self.output.userconfirm():
raise CliError(_("Operation aborted."))
Expand Down
31 changes: 0 additions & 31 deletions dnf/util.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,13 +33,11 @@
import functools
import hawkey
import itertools
import json
import locale
import logging
import os
import pwd
import shutil
import subprocess
import sys
import tempfile
import time
Expand Down Expand Up @@ -633,32 +631,3 @@ def _tsi_or_pkg_nevra_cmp(item1, item2):
def _name_unset_wrapper(input_name):
# returns <name-unset> for everything that evaluates to False (None, empty..)
return input_name if input_name else _("<name-unset>")


def is_container():
"""Returns true is the system is managed as an immutable container,
false otherwise. If msg is True, a warning message is displayed
for the user.
"""

bootc = '/usr/bin/bootc'
ostree = '/sysroot/ostree'

if os.path.isfile(bootc) and os.access(bootc, os.X_OK):
p = subprocess.Popen([bootc, "status", "--json"], stdout=subprocess.PIPE, stderr=subprocess.PIPE)
(out, err) = p.communicate()

if p.returncode == 0:
# check the output of 'bootc status'
j = json.loads(out)

# XXX: the API from bootc status is evolving
status = j.get("status", "")
kind = j.get("kind", "")

if kind.lower() == "bootchost" and bool(status.get("isContainer", None)):
return True
elif os.path.isdir(ostree):
return True

return False

0 comments on commit bc5bac3

Please sign in to comment.