????

Your IP : 216.73.216.152


Current Path : /proc/self/root/proc/self/root/lib/python2.7/site-packages/sos/plugins/
Upload File :
Current File : //proc/self/root/proc/self/root/lib/python2.7/site-packages/sos/plugins/dnf.py

# Copyright (C) 2016 Red Hat, Inc., Sachin Patil <sacpatil@redhat.com>

# This file is part of the sos project: https://github.com/sosreport/sos
#
# This copyrighted material is made available to anyone wishing to use,
# modify, copy, or redistribute it subject to the terms and conditions of
# version 2 of the GNU General Public License.
#
# See the LICENSE file in the source distribution for further information.

from sos.plugins import Plugin, RedHatPlugin


class DNFPlugin(Plugin, RedHatPlugin):
    """dnf package manager"""
    plugin_name = "dnf"
    profiles = ('system', 'packagemanager', 'sysmgmt')

    files = ('/etc/dnf/dnf.conf',)
    packages = ('dnf',)

    option_list = [
        ("history", "captures transaction history", "fast", False),
        ("history-info", "detailed transaction history", "slow", False),
    ]

    def get_modules_info(self, module_file):
        if module_file:
            try:
                module_out = open(module_file).read()
            except IOError:
                self._log_warn("could not read module list file")
                return
            # take just lines with the module names, i.e. containing "[i]" and
            # not the "Hint: [d]efault, [e]nabled, [i]nstalled,.."
            for line in module_out.splitlines():
                if "[i]" in line:
                    module = line.split()[0]
                    if module != "Hint:":
                        self.add_cmd_output("dnf module info " + module)

    def setup(self):
        self.add_copy_spec([
            "/etc/dnf/dnf.conf",
            "/etc/dnf/plugins/*",
            "/etc/dnf/protected.d/*",
        ])

        if self.get_option("all_logs"):
            self.add_copy_spec("/var/log/dnf.*")
        else:
            self.add_copy_spec("/var/log/dnf.log")
            self.add_copy_spec("/var/log/dnf.librepo.log")
            self.add_copy_spec("/var/log/dnf.rpm.log")

        self.add_cmd_output([
            "dnf --version",
            "dnf list installed *dnf*",
            "dnf list extras",
            "package-cleanup --dupes",
            "package-cleanup --problems"
        ])

        if self.get_option("history"):
            self.add_cmd_output("dnf history")

        if self.get_option("history-info"):
            history = self.call_ext_prog("dnf history")
            transactions = -1
            if history['output']:
                for line in history['output'].splitlines():
                    try:
                        transactions = int(line.split('|')[0].strip())
                        break
                    except ValueError:
                        pass
            for tr_id in range(1, transactions+1):
                self.add_cmd_output("dnf history info %d" % tr_id)

        # Get list of dnf installed modules and their details.
        module_file = self.get_cmd_output_now("dnf module list --installed")
        self.get_modules_info(module_file)

# vim: set et ts=4 sw=4 :