From 4b746d78d4a452206f24e1198157baffd2c740f8 Mon Sep 17 00:00:00 2001 From: Jan Jansky Date: Mon, 3 Jul 2023 15:52:44 +0200 Subject: [PATCH] sos updates to 8.9 Resolves: bz2218279 bz2216608 bz2207562 Signed-off-by: Jan Jansky --- sos-bz2218279-clean-respect-permissions.patch | 93 +++++++++++++++++++ sos.spec | 14 ++- sources | 2 +- 3 files changed, 105 insertions(+), 4 deletions(-) create mode 100644 sos-bz2218279-clean-respect-permissions.patch diff --git a/sos-bz2218279-clean-respect-permissions.patch b/sos-bz2218279-clean-respect-permissions.patch new file mode 100644 index 0000000..ab384f8 --- /dev/null +++ b/sos-bz2218279-clean-respect-permissions.patch @@ -0,0 +1,93 @@ +From cca04c1e1fdc97632cdefdc1d1d7a3dea9cb4aea Mon Sep 17 00:00:00 2001 +From: Pavel Moravec +Date: Wed, 28 Jun 2023 11:49:56 +0200 +Subject: [PATCH 1/2] [clean] Respect permissions of sanitised files + +When copying files we applied a substitution in, we must replace just +original file content (shutil.copyfile) and not also its stat data +(shutil.copy). + +Resolves: #3292 + +Signed-off-by: Pavel Moravec +--- + sos/cleaner/__init__.py | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/sos/cleaner/__init__.py b/sos/cleaner/__init__.py +index feeedf66..fbcaa9c3 100644 +--- a/sos/cleaner/__init__.py ++++ b/sos/cleaner/__init__.py +@@ -778,7 +778,7 @@ third party. + % (short_name, err), caller=arc_name) + tfile.seek(0) + if subs: +- shutil.copy(tfile.name, filename) ++ shutil.copyfile(tfile.name, filename) + tfile.close() + + _ob_short_name = self.obfuscate_string(short_name.split('/')[-1]) +-- +2.31.1 + + +From fc1489a621108d3613d3337489a64950e52d77c3 Mon Sep 17 00:00:00 2001 +From: Pavel Moravec +Date: Thu, 29 Jun 2023 22:57:46 +0200 +Subject: [PATCH 2/2] [tests] add test for #3292 + +Add a test that cleaner keeps permissions of a sanitised file + +Relevant to: #3292 + +Signed-off-by: Pavel Moravec +--- + .../basic_function_tests/report_with_mask.py | 18 ++++++++++++++++++ + 1 file changed, 18 insertions(+) + +diff --git a/tests/cleaner_tests/basic_function_tests/report_with_mask.py b/tests/cleaner_tests/basic_function_tests/report_with_mask.py +index 7c4d3905..baee836a 100644 +--- a/tests/cleaner_tests/basic_function_tests/report_with_mask.py ++++ b/tests/cleaner_tests/basic_function_tests/report_with_mask.py +@@ -9,6 +9,7 @@ + from sos_tests import StageOneReportTest, StageTwoReportTest + + import re ++from os import stat + + + class ReportWithMask(StageOneReportTest): +@@ -18,6 +19,17 @@ class ReportWithMask(StageOneReportTest): + """ + + sos_cmd = '--mask -o host,networking' ++ hosts_obfuscated = None ++ ++ def pre_sos_setup(self): ++ # obfuscate a random word from /etc/hosts and ensure the updated ++ # sanitised file has same permissions (a+r) ++ try: ++ self.hosts_obfuscated = open('/etc/hosts').read().strip('#\n').split()[-1] ++ except (FileNotFoundError, IndexError) as e: ++ self.warning(f"Unable to process /etc/hosts: {e}") ++ if self.hosts_obfuscated: ++ self.sos_cmd += f' --keywords={self.hosts_obfuscated}' + + def test_mask_was_run(self): + self.assertOutputContains('Beginning obfuscation') +@@ -53,6 +65,12 @@ class ReportWithMask(StageOneReportTest): + mac = line.strip().split()[1] + assert mac.startswith('53:4f:53'), "Found unobfuscated mac addr %s" % mac + ++ def test_perms_unchanged_on_modified_file(self): ++ if self.hosts_obfuscated: ++ imode_orig = stat('/etc/hosts').st_mode ++ imode_obfuscated = stat(self.get_name_in_archive('etc/hosts')).st_mode ++ self.assertEqual(imode_orig, imode_obfuscated) ++ + + class ReportWithCleanedKeywords(StageOneReportTest): + """Testing for obfuscated keywords provided by the user +-- +2.31.1 + diff --git a/sos.spec b/sos.spec index f88db8d..c49290f 100644 --- a/sos.spec +++ b/sos.spec @@ -4,7 +4,7 @@ Summary: A set of tools to gather troubleshooting information from a system Name: sos -Version: 4.5.4 +Version: 4.5.5 Release: 1%{?dist} Group: Applications/System Source0: https://github.com/sosreport/sos/archive/%{version}/sos-%{version}.tar.gz @@ -22,7 +22,7 @@ Recommends: python3-pexpect Recommends: python3-pyyaml Conflicts: vdsm < 4.40 Obsoletes: sos-collector - +Patch1: sos-bz2218279-clean-respect-permissions.patch %description Sos is a set of tools that gathers information about system @@ -33,7 +33,7 @@ support technicians and developers. %prep %setup -qn %{name}-%{version} %setup -T -D -a1 -q - +%patch1 -p1 %build %py3_build @@ -106,6 +106,14 @@ of the system. Currently storage and filesystem commands are audited. %ghost /etc/audit/rules.d/40-sos-storage.rules %changelog +* Mon Jul 03 2023 Jan Jansky = 4.5.5-1 +- [clean] Respect permissions of sanitised files + Resolves: bz2218279 +- [plugin] Fix exception when calling os.makedirs + Resolves: bz2216608 +- [cleaner] Enhance trailing characters list after AMC address + Resolves: bz2207562 + * Thu Jun 01 2023 Pavel Moravec = 4.5.4-1 - [plugins] collect strings before commands Resolves: bz2203141 diff --git a/sources b/sources index 16a8384..0d6b38d 100644 --- a/sources +++ b/sources @@ -1,2 +1,2 @@ -SHA512 (sos-4.5.4.tar.gz) = a883e277c749ad053d763b57e50d83f577d67dad76cc4307e08854361fb0046b4222c64a69daba0258cf3acef8ccb7b4e905a86feb143805f96be5c09ece2c9f +SHA512 (sos-4.5.5.tar.gz) = 6731d2b9671350eeb8dd738516fa484f2b8a3eb17e9caef9ade1aeee1fe581a67e4c2ea0cc8e89838770ffc85f052e0dd6422f2121efb4a99728b1e865780c50 SHA512 (sos-audit-0.3.tgz) = 32597baf6350804d08179a0dbe48470a93df148e83d2e49bb3288f6bcc2d151bb1433761913bfbccd912c14de92435939fef5bcd7e091dfe33a345d61ea842ea