Blame SOURCES/sos-bz1956673-pulpcore-plugin.patch

2ed6e8
From 808d9f35ac504a58c337ffed14b39119a591808f Mon Sep 17 00:00:00 2001
2ed6e8
From: Pavel Moravec <pmoravec@redhat.com>
2ed6e8
Date: Tue, 27 Apr 2021 22:16:08 +0200
2ed6e8
Subject: [PATCH] [pulpcore] add plugin for pulp-3
2ed6e8
2ed6e8
Pulp-3 / pulpcore as a revolution from pulp-2 needs a separate
2ed6e8
plugin, since both plugins have nothing in common and there might
2ed6e8
be deployments where is active both pulp-2 and pulp-3.
2ed6e8
2ed6e8
Resolves: #2278
2ed6e8
2ed6e8
Signed-off-by: Pavel Moravec <pmoravec@redhat.com>
2ed6e8
Signed-off-by: Jake Hunsaker <jhunsake@redhat.com>
2ed6e8
---
2ed6e8
 sos/report/plugins/pulpcore.py | 120 +++++++++++++++++++++++++++++++++
2ed6e8
 1 file changed, 120 insertions(+)
2ed6e8
 create mode 100644 sos/report/plugins/pulpcore.py
2ed6e8
2ed6e8
diff --git a/sos/report/plugins/pulpcore.py b/sos/report/plugins/pulpcore.py
2ed6e8
new file mode 100644
2ed6e8
index 00000000..20403814
2ed6e8
--- /dev/null
2ed6e8
+++ b/sos/report/plugins/pulpcore.py
2ed6e8
@@ -0,0 +1,120 @@
2ed6e8
+# Copyright (C) 2021 Red Hat, Inc., Pavel Moravec <pmoravec@redhat.com>
2ed6e8
+
2ed6e8
+# This file is part of the sos project: https://github.com/sosreport/sos
2ed6e8
+#
2ed6e8
+# This copyrighted material is made available to anyone wishing to use,
2ed6e8
+# modify, copy, or redistribute it subject to the terms and conditions of
2ed6e8
+# version 2 of the GNU General Public License.
2ed6e8
+#
2ed6e8
+# See the LICENSE file in the source distribution for further information.
2ed6e8
+
2ed6e8
+from sos.report.plugins import Plugin, IndependentPlugin
2ed6e8
+from pipes import quote
2ed6e8
+from re import match
2ed6e8
+
2ed6e8
+
2ed6e8
+class PulpCore(Plugin, IndependentPlugin):
2ed6e8
+
2ed6e8
+    short_desc = 'Pulp-3 aka pulpcore'
2ed6e8
+
2ed6e8
+    plugin_name = "pulpcore"
2ed6e8
+    commands = ("pulpcore-manager",)
2ed6e8
+    files = ("/etc/pulp/settings.py",)
2ed6e8
+    option_list = [
2ed6e8
+        ('task-days', 'days of tasks history', 'fast', 7)
2ed6e8
+    ]
2ed6e8
+
2ed6e8
+    def parse_settings_config(self):
2ed6e8
+        databases_scope = False
2ed6e8
+        self.dbhost = "localhost"
2ed6e8
+        self.dbport = 5432
2ed6e8
+        self.dbpasswd = ""
2ed6e8
+        # TODO: read also redis config (we dont expect much customisations)
2ed6e8
+        # TODO: read also db user (pulp) and database name (pulpcore)
2ed6e8
+        self.staticroot = "/var/lib/pulp/assets"
2ed6e8
+        self.uploaddir = "/var/lib/pulp/media/upload"
2ed6e8
+
2ed6e8
+        def separate_value(line, sep=':'):
2ed6e8
+            # an auxiliary method to parse values from lines like:
2ed6e8
+            #       'HOST': 'localhost',
2ed6e8
+            val = line.split(sep)[1].lstrip().rstrip(',')
2ed6e8
+            if (val.startswith('"') and val.endswith('"')) or \
2ed6e8
+               (val.startswith('\'') and val.endswith('\'')):
2ed6e8
+                val = val[1:-1]
2ed6e8
+            return val
2ed6e8
+
2ed6e8
+        try:
2ed6e8
+            for line in open("/etc/pulp/settings.py").read().splitlines():
2ed6e8
+                # skip empty lines and lines with comments
2ed6e8
+                if not line or line[0] == '#':
2ed6e8
+                    continue
2ed6e8
+                if line.startswith("DATABASES"):
2ed6e8
+                    databases_scope = True
2ed6e8
+                    continue
2ed6e8
+                # example HOST line to parse:
2ed6e8
+                #         'HOST': 'localhost',
2ed6e8
+                if databases_scope and match(r"\s+'HOST'\s*:\s+\S+", line):
2ed6e8
+                    self.dbhost = separate_value(line)
2ed6e8
+                if databases_scope and match(r"\s+'PORT'\s*:\s+\S+", line):
2ed6e8
+                    self.dbport = separate_value(line)
2ed6e8
+                if databases_scope and match(r"\s+'PASSWORD'\s*:\s+\S+", line):
2ed6e8
+                    self.dbpasswd = separate_value(line)
2ed6e8
+                # if line contains closing '}' database_scope end
2ed6e8
+                if databases_scope and '}' in line:
2ed6e8
+                    databases_scope = False
2ed6e8
+                if line.startswith("STATIC_ROOT = "):
2ed6e8
+                    self.staticroot = separate_value(line, sep='=')
2ed6e8
+                if line.startswith("CHUNKED_UPLOAD_DIR = "):
2ed6e8
+                    self.uploaddir = separate_value(line, sep='=')
2ed6e8
+        except IOError:
2ed6e8
+            # fallback when the cfg file is not accessible
2ed6e8
+            pass
2ed6e8
+        # set the password to os.environ when calling psql commands to prevent
2ed6e8
+        # printing it in sos logs
2ed6e8
+        # we can't set os.environ directly now: other plugins can overwrite it
2ed6e8
+        self.env = {"PGPASSWORD": self.dbpasswd}
2ed6e8
+
2ed6e8
+    def setup(self):
2ed6e8
+        self.parse_settings_config()
2ed6e8
+
2ed6e8
+        self.add_copy_spec("/etc/pulp/settings.py")
2ed6e8
+
2ed6e8
+        self.add_cmd_output("rq info -u redis://localhost:6379/8",
2ed6e8
+                            env={"LC_ALL": "en_US.UTF-8"},
2ed6e8
+                            suggest_filename="rq_info")
2ed6e8
+        self.add_cmd_output("curl -ks https://localhost/pulp/api/v3/status/",
2ed6e8
+                            suggest_filename="pulp_status")
2ed6e8
+        dynaconf_env = {"LC_ALL": "en_US.UTF-8",
2ed6e8
+                        "PULP_SETTINGS": "/etc/pulp/settings.py",
2ed6e8
+                        "DJANGO_SETTINGS_MODULE": "pulpcore.app.settings"}
2ed6e8
+        self.add_cmd_output("dynaconf list", env=dynaconf_env)
2ed6e8
+        for _dir in [self.staticroot, self.uploaddir]:
2ed6e8
+            self.add_cmd_output("ls -l %s" % _dir)
2ed6e8
+
2ed6e8
+        task_days = self.get_option('task-days')
2ed6e8
+        for table in ['core_task', 'core_taskgroup',
2ed6e8
+                      'core_reservedresourcerecord',
2ed6e8
+                      'core_taskreservedresourcerecord',
2ed6e8
+                      'core_groupprogressreport', 'core_progressreport']:
2ed6e8
+            _query = "select * from %s where pulp_last_updated > NOW() - " \
2ed6e8
+                     "interval '%s days' order by pulp_last_updated" % \
2ed6e8
+                     (table, task_days)
2ed6e8
+            _cmd = "psql -h %s -p %s -U pulp -d pulpcore -c %s" % \
2ed6e8
+                   (self.dbhost, self.dbport, quote(_query))
2ed6e8
+            self.add_cmd_output(_cmd, env=self.env, suggest_filename=table)
2ed6e8
+
2ed6e8
+    def postproc(self):
2ed6e8
+        # TODO obfuscate from /etc/pulp/settings.py :
2ed6e8
+        # SECRET_KEY = "eKfeDkTnvss7p5WFqYdGPWxXfHnsbDBx"
2ed6e8
+        # 'PASSWORD': 'tGrag2DmtLqKLTWTQ6U68f6MAhbqZVQj',
2ed6e8
+        self.do_path_regex_sub(
2ed6e8
+            "/etc/pulp/settings.py",
2ed6e8
+            r"(SECRET_KEY\s*=\s*)(.*)",
2ed6e8
+            r"\1********")
2ed6e8
+        self.do_path_regex_sub(
2ed6e8
+            "/etc/pulp/settings.py",
2ed6e8
+            r"(PASSWORD\S*\s*:\s*)(.*)",
2ed6e8
+            r"\1********")
2ed6e8
+
2ed6e8
+
2ed6e8
+# vim: set et ts=4 sw=4 :
2ed6e8
-- 
2ed6e8
2.26.3
2ed6e8