Compare commits
	
		
			No commits in common. "c8" and "a9-beta" have entirely different histories.
		
	
	
		
	
		
							
								
								
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -1,2 +1,2 @@ | ||||
| SOURCES/sos-4.10.0.tar.gz | ||||
| SOURCES/sos-audit-0.3-1.tgz | ||||
| SOURCES/sos-4.5.0.tar.gz | ||||
| SOURCES/sos-audit-0.3.tgz | ||||
|  | ||||
| @ -1,2 +1,2 @@ | ||||
| 6042daa19f01ecf2f1e331ae70482653fd500d1f SOURCES/sos-4.10.0.tar.gz | ||||
| 00752b68ec5e1141192a9dab7d44377b8d637bf7 SOURCES/sos-audit-0.3-1.tgz | ||||
| d5e166c75250aef01c86a3a9d8c9fcc8db335f4e SOURCES/sos-4.5.0.tar.gz | ||||
| 9d478b9f0085da9178af103078bbf2fd77b0175a SOURCES/sos-audit-0.3.tgz | ||||
|  | ||||
| @ -1,101 +0,0 @@ | ||||
| From 3efc8888852225396ebb4f0f9ae95edf4e5badfa Mon Sep 17 00:00:00 2001 | ||||
| From: Pavel Moravec <pmoravec@redhat.com> | ||||
| Date: Wed, 20 Aug 2025 20:07:05 +0200 | ||||
| Subject: [PATCH] [cleaner] Make cleaner's obfuscate_file properly working | ||||
| 
 | ||||
| The fix is three-fold: | ||||
| - obfuscate_file must clean file content and not filename
 | ||||
| - cleaner's main_archive must be populated by parsers first
 | ||||
| - obfuscate_file dont need short_name as it is always called with
 | ||||
|   implicit value of short_name that cleaner will strip itself | ||||
| 
 | ||||
| Closes: #4109 | ||||
| Closes: #4110 | ||||
| 
 | ||||
| Signed-off-by: Pavel Moravec <pmoravec@redhat.com> | ||||
| ---
 | ||||
|  sos/cleaner/__init__.py   | 7 ++++--- | ||||
|  sos/collector/__init__.py | 9 +++------ | ||||
|  sos/report/__init__.py    | 9 +++------ | ||||
|  3 files changed, 10 insertions(+), 15 deletions(-) | ||||
| 
 | ||||
| diff --git a/sos/cleaner/__init__.py b/sos/cleaner/__init__.py
 | ||||
| index 4a1470b5..dcd60c66 100644
 | ||||
| --- a/sos/cleaner/__init__.py
 | ||||
| +++ b/sos/cleaner/__init__.py
 | ||||
| @@ -537,7 +537,7 @@ third party.
 | ||||
|                  logfile.write(line) | ||||
|   | ||||
|          if archive: | ||||
| -            self.obfuscate_file(log_name, short_name="sos_logs/cleaner.log")
 | ||||
| +            self.obfuscate_file(log_name)
 | ||||
|              self.archive.add_file(log_name, dest="sos_logs/cleaner.log") | ||||
|   | ||||
|      def get_new_checksum(self, archive_path): | ||||
| @@ -678,6 +678,7 @@ third party.
 | ||||
|          for prepper in self.get_preppers(): | ||||
|              for archive in self.report_paths: | ||||
|                  self._prepare_archive_with_prepper(archive, prepper) | ||||
| +        self.main_archive.set_parsers(self.parsers)
 | ||||
|   | ||||
|      def obfuscate_report(self, archive):  # pylint: disable=too-many-branches | ||||
|          """Individually handle each archive or directory we've discovered by | ||||
| @@ -784,8 +785,8 @@ third party.
 | ||||
|              self.ui_log.info("Exception while processing " | ||||
|                               f"{archive.archive_name}: {err}") | ||||
|   | ||||
| -    def obfuscate_file(self, filename, short_name):
 | ||||
| -        self.main_archive.obfuscate_filename(filename, short_name)
 | ||||
| +    def obfuscate_file(self, filename):
 | ||||
| +        self.main_archive.obfuscate_arc_files([filename])
 | ||||
|   | ||||
|      def obfuscate_symlinks(self, archive): | ||||
|          """Iterate over symlinks in the archive and obfuscate their names. | ||||
| diff --git a/sos/collector/__init__.py b/sos/collector/__init__.py
 | ||||
| index 7a414501..e6b55f20 100644
 | ||||
| --- a/sos/collector/__init__.py
 | ||||
| +++ b/sos/collector/__init__.py
 | ||||
| @@ -1405,16 +1405,13 @@ this utility or remote systems that it connects to.
 | ||||
|              if do_clean: | ||||
|                  _dir = os.path.join(self.tmpdir, self.archive._name) | ||||
|                  cleaner.obfuscate_file( | ||||
| -                    os.path.join(_dir, 'sos_logs', 'sos.log'),
 | ||||
| -                    short_name='sos.log'
 | ||||
| +                        os.path.join(_dir, 'sos_logs', 'sos.log')
 | ||||
|                  ) | ||||
|                  cleaner.obfuscate_file( | ||||
| -                    os.path.join(_dir, 'sos_logs', 'ui.log'),
 | ||||
| -                    short_name='ui.log'
 | ||||
| +                    os.path.join(_dir, 'sos_logs', 'ui.log')
 | ||||
|                  ) | ||||
|                  cleaner.obfuscate_file( | ||||
| -                    os.path.join(_dir, 'sos_reports', 'manifest.json'),
 | ||||
| -                    short_name='manifest.json'
 | ||||
| +                    os.path.join(_dir, 'sos_reports', 'manifest.json')
 | ||||
|                  ) | ||||
|   | ||||
|              arc_name = self.archive.finalize(method=None) | ||||
| diff --git a/sos/report/__init__.py b/sos/report/__init__.py
 | ||||
| index 074afcff..9fb94d6a 100644
 | ||||
| --- a/sos/report/__init__.py
 | ||||
| +++ b/sos/report/__init__.py
 | ||||
| @@ -1571,13 +1571,10 @@ class SoSReport(SoSComponent):
 | ||||
|          # Now, separately clean the log files that cleaner also wrote to | ||||
|          if do_clean: | ||||
|              _dir = os.path.join(self.tmpdir, self.archive._name) | ||||
| -            cleaner.obfuscate_file(os.path.join(_dir, 'sos_logs', 'sos.log'),
 | ||||
| -                                   short_name='sos.log')
 | ||||
| -            cleaner.obfuscate_file(os.path.join(_dir, 'sos_logs', 'ui.log'),
 | ||||
| -                                   short_name='ui.log')
 | ||||
| +            cleaner.obfuscate_file(os.path.join(_dir, 'sos_logs', 'sos.log'))
 | ||||
| +            cleaner.obfuscate_file(os.path.join(_dir, 'sos_logs', 'ui.log'))
 | ||||
|              cleaner.obfuscate_file( | ||||
| -                os.path.join(_dir, 'sos_reports', 'manifest.json'),
 | ||||
| -                short_name='manifest.json'
 | ||||
| +                    os.path.join(_dir, 'sos_reports', 'manifest.json')
 | ||||
|              ) | ||||
|   | ||||
|          # Now, just (optionally) pack the report and print work outcome; let | ||||
| -- 
 | ||||
| 2.49.0 | ||||
| 
 | ||||
| @ -1,72 +0,0 @@ | ||||
| From 6378a4ee9fa3eeaf384bd87fc87e24a0c5608658 Mon Sep 17 00:00:00 2001 | ||||
| From: Pavel Moravec <pmoravec@redhat.com> | ||||
| Date: Tue, 19 Aug 2025 09:08:15 +0200 | ||||
| Subject: [PATCH] [openstack_nova] Improve scrubbing | ||||
| 
 | ||||
| Improve postproc obfuscation in two ways: | ||||
| - apply postproc also to /var/lib/openstack/config/nova on RedHatNova
 | ||||
| - obfuscate just password from transport_url, not the whole URL
 | ||||
| 
 | ||||
| Closes: #4108 | ||||
| 
 | ||||
| Signed-off-by: Pavel Moravec <pmoravec@redhat.com> | ||||
| ---
 | ||||
|  sos/report/plugins/openstack_nova.py | 20 +++++++++++--------- | ||||
|  1 file changed, 11 insertions(+), 9 deletions(-) | ||||
| 
 | ||||
| diff --git a/sos/report/plugins/openstack_nova.py b/sos/report/plugins/openstack_nova.py
 | ||||
| index 728aed1e..2635866e 100644
 | ||||
| --- a/sos/report/plugins/openstack_nova.py
 | ||||
| +++ b/sos/report/plugins/openstack_nova.py
 | ||||
| @@ -29,6 +29,7 @@ class OpenStackNova(Plugin):
 | ||||
|      var_puppet_gen = "/var/lib/config-data/puppet-generated/nova" | ||||
|      service_name = "openstack-nova-api.service" | ||||
|      apachepkg = None | ||||
| +    postproc_dirs = ["/etc/nova/",]
 | ||||
|   | ||||
|      def setup(self): | ||||
|   | ||||
| @@ -141,12 +142,13 @@ class OpenStackNova(Plugin):
 | ||||
|          self.add_copy_spec(specs) | ||||
|   | ||||
|      def apply_regex_sub(self, regexp, subst): | ||||
| -        """ Apply regex substitution """
 | ||||
| -        self.do_path_regex_sub("/etc/nova/*", regexp, subst)
 | ||||
| -        for npath in ['', '_libvirt', '_metadata', '_placement']:
 | ||||
| -            self.do_path_regex_sub(
 | ||||
| -                f"{self.var_puppet_gen}{npath}/etc/nova/*",
 | ||||
| -                regexp, subst)
 | ||||
| +        """ Apply regex substitution to all sensitive dirs """
 | ||||
| +        for _dir in self.postproc_dirs:
 | ||||
| +            self.do_path_regex_sub(f"{_dir}/*", regexp, subst)
 | ||||
| +            for npath in ['', '_libvirt', '_metadata', '_placement']:
 | ||||
| +                self.do_path_regex_sub(
 | ||||
| +                    f"{self.var_puppet_gen}{npath}{_dir}/*",
 | ||||
| +                    regexp, subst)
 | ||||
|   | ||||
|      def postproc(self): | ||||
|          protect_keys = [ | ||||
| @@ -155,10 +157,9 @@ class OpenStackNova(Plugin):
 | ||||
|              "xenapi_connection_password", "password", "host_password", | ||||
|              "vnc_password", "admin_password", "connection_password", | ||||
|              "memcache_secret_key", "s3_secret_key", | ||||
| -            "metadata_proxy_shared_secret", "fixed_key", "transport_url",
 | ||||
| -            "rbd_secret_uuid"
 | ||||
| +            "metadata_proxy_shared_secret", "fixed_key", "rbd_secret_uuid"
 | ||||
|          ] | ||||
| -        connection_keys = ["connection", "sql_connection"]
 | ||||
| +        connection_keys = ["connection", "sql_connection", "transport_url"]
 | ||||
|   | ||||
|          join_con_keys = "|".join(connection_keys) | ||||
|   | ||||
| @@ -214,6 +215,7 @@ class RedHatNova(OpenStackNova, RedHatPlugin):
 | ||||
|      apachepkg = "httpd" | ||||
|      nova = False | ||||
|      packages = ('openstack-selinux',) | ||||
| +    postproc_dirs = ["/etc/nova/", "/var/lib/openstack/config/nova"]
 | ||||
|   | ||||
|      def setup(self): | ||||
|          super().setup() | ||||
| -- 
 | ||||
| 2.49.0 | ||||
| 
 | ||||
| @ -1,36 +0,0 @@ | ||||
| From c0e514894b2c35c2b36f247f8b84dd4311034fb6 Mon Sep 17 00:00:00 2001 | ||||
| From: Pavel Moravec <pmoravec@redhat.com> | ||||
| Date: Fri, 12 Sep 2025 11:36:02 +0200 | ||||
| Subject: [PATCH] [component] Fix regression 57bbc89 in toolbox containers | ||||
| 
 | ||||
| 57bbc89 commit set tmpdir to source the dir from Policy. Which means | ||||
| HOST sysroot directory is newly applied already in | ||||
| LinuxPolicy._container_init method. | ||||
| 
 | ||||
| Removed lines mimic the same in a worse way, so let drop them here. | ||||
| 
 | ||||
| Resolves: #4116 | ||||
| Closes: #4118 | ||||
| 
 | ||||
| Signed-off-by: Pavel Moravec <pmoravec@redhat.com> | ||||
| ---
 | ||||
|  sos/component.py | 3 --- | ||||
|  1 file changed, 3 deletions(-) | ||||
| 
 | ||||
| diff --git a/sos/component.py b/sos/component.py
 | ||||
| index a110c270..3e53fe3d 100644
 | ||||
| --- a/sos/component.py
 | ||||
| +++ b/sos/component.py
 | ||||
| @@ -170,9 +170,6 @@ class SoSComponent():
 | ||||
|          else: | ||||
|              tmpdir = os.getenv('TMPDIR', None) or self.policy.get_tmp_dir(None) | ||||
|   | ||||
| -        if os.getenv('HOST', None) and os.getenv('container', None):
 | ||||
| -            tmpdir = os.path.join(os.getenv('HOST'), tmpdir.lstrip('/'))
 | ||||
| -
 | ||||
|          # no standard library method exists for this, so call out to stat to | ||||
|          # avoid bringing in a dependency on psutil | ||||
|          self.tmpfstype = shell_out( | ||||
| -- 
 | ||||
| 2.49.0 | ||||
| 
 | ||||
| @ -1,49 +0,0 @@ | ||||
| --- a/sos/upload/targets/__init__.py	2025-09-16 19:57:27.294642506 +0200
 | ||||
| +++ b/sos/upload/targets/__init__.py	2025-09-16 19:59:44.498573843 +0200
 | ||||
| @@ -465,7 +465,7 @@
 | ||||
|                  self.upload_password or | ||||
|                  self._upload_password) | ||||
|   | ||||
| -    def upload_sftp(self, user=None, password=None, user_dir=None):
 | ||||
| +    def upload_sftp(self, user=None, password=None):
 | ||||
|          """Attempts to upload the archive to an SFTP location. | ||||
|   | ||||
|          Due to the lack of well maintained, secure, and generally widespread | ||||
| @@ -540,13 +540,10 @@
 | ||||
|              raise Exception("Unable to connect via SFTP to " | ||||
|                              f"{self.get_upload_url_string()}") | ||||
|   | ||||
| -        # certain implementations require file to be put in the user dir
 | ||||
| -        put_cmd = (
 | ||||
| -            f"put {self.upload_archive_name} "
 | ||||
| -            f"{f'{user_dir}/' if user_dir else ''}"
 | ||||
| -            f"{self._get_sftp_upload_name()}"
 | ||||
| -        )
 | ||||
| +        put_cmd = (f'put {self.upload_archive_name} '
 | ||||
| +                   f'{self._get_sftp_upload_name()}')
 | ||||
|          ret.sendline(put_cmd) | ||||
| +
 | ||||
|          put_expects = [ | ||||
|              '100%', | ||||
|              pexpect.TIMEOUT, | ||||
| --- a/sos/upload/targets/redhat.py	2025-09-16 19:57:36.804628207 +0200
 | ||||
| +++ b/sos/upload/targets/redhat.py	2025-09-16 20:00:52.578728154 +0200
 | ||||
| @@ -145,7 +145,7 @@
 | ||||
|          return fname | ||||
|   | ||||
|      # pylint: disable=too-many-branches | ||||
| -    def upload_sftp(self, user=None, password=None, user_dir=None):
 | ||||
| +    def upload_sftp(self, user=None, password=None):    
 | ||||
|          """Override the base upload_sftp to allow for setting an on-demand | ||||
|          generated anonymous login for the RH SFTP server if a username and | ||||
|          password are not given | ||||
| @@ -217,8 +217,7 @@
 | ||||
|                      f"{anon.status_code}): {anon.json()}" | ||||
|                  ) | ||||
|          if _user and _token: | ||||
| -            return super().upload_sftp(user=_user, password=_token,
 | ||||
| -                                       user_dir=_user)
 | ||||
| +            return super().upload_sftp(user=_user, password=_token)
 | ||||
|          raise Exception("Could not retrieve valid or anonymous credentials") | ||||
|   | ||||
|      def check_file_too_big(self, archive): | ||||
| @ -1,36 +0,0 @@ | ||||
| --- a/sos/cleaner/archives/__init__.py	2025-09-22 19:44:51.272619200 +0200
 | ||||
| +++ b/sos/cleaner/archives/__init__.py	2025-09-22 23:28:15.116001268 +0200
 | ||||
| @@ -118,6 +118,8 @@ class SoSObfuscationArchive():
 | ||||
|          self.parsers = parsers  # TODO: include this in __init__? | ||||
|   | ||||
|      def load_parser_entries(self): | ||||
| +        self.soslog = logging.getLogger('sos')
 | ||||
| +        self.ui_log = logging.getLogger('sos_ui')
 | ||||
|          for parser in self.parsers: | ||||
|              parser.load_map_entries() | ||||
|   | ||||
| @@ -150,6 +152,7 @@ class SoSObfuscationArchive():
 | ||||
|          return line, count | ||||
|   | ||||
|      def obfuscate_arc_files(self, flist): | ||||
| +        self.load_parser_entries()
 | ||||
|          for filename in flist: | ||||
|              self.log_debug(f"    pid={os.getpid()}: obfuscating {filename}") | ||||
|              try: | ||||
| --- a/sos/cleaner/__init__.py	2025-09-22 19:44:51.272619200 +0200
 | ||||
| +++ b/sos/cleaner/__init__.py	2025-09-22 23:32:17.606745778 +0200
 | ||||
| @@ -720,10 +720,11 @@ third party.
 | ||||
|              # based on files' sizes. | ||||
|   | ||||
|              files_obfuscated_count = total_sub_count = removed_file_count = 0 | ||||
| +            # two nullification required before processes cloning
 | ||||
| +            archive.soslog = None
 | ||||
| +            archive.ui_log = None
 | ||||
|              archive_list = [archive for i in range(self.opts.jobs)] | ||||
| -            with ProcessPoolExecutor(
 | ||||
| -                    max_workers=self.opts.jobs,
 | ||||
| -                    initializer=archive.load_parser_entries) as executor:
 | ||||
| +            with ProcessPoolExecutor(max_workers=self.opts.jobs) as executor:
 | ||||
|                  futures = executor.map(obfuscate_arc_files, archive_list, | ||||
|                                         [file_list[i::self.opts.jobs] for i in | ||||
|                                          range(self.opts.jobs)]) | ||||
							
								
								
									
										36
									
								
								SOURCES/sos-almalinux-branding.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								SOURCES/sos-almalinux-branding.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,36 @@ | ||||
| diff -aruN sos-4.3/sos/policies/distros/redhat.py sos-4.3.alma/sos/policies/distros/redhat.py
 | ||||
| --- sos-4.3/sos/policies/distros/redhat.py	2022-02-15 07:20:20.000000000 +0300
 | ||||
| +++ sos-4.3.alma/sos/policies/distros/redhat.py	2022-10-24 10:54:24.000000000 +0300
 | ||||
| @@ -435,6 +435,16 @@
 | ||||
|      vendor_urls = [('Community Website', 'https://www.centos.org/')] | ||||
|   | ||||
|   | ||||
| +class AlmaLinuxPolicy(RHELPolicy):
 | ||||
| +    distro = "AlmaLinux"
 | ||||
| +    vendor = "AlmaLinux OS Foundation"
 | ||||
| +    vendor_urls = [
 | ||||
| +        ('Distribution Website', 'https://www.almalinux.org/'),
 | ||||
| +        ('Commercial Support', 'https://tuxcare.com/linux-support-services/')
 | ||||
| +    ]
 | ||||
| +
 | ||||
| +
 | ||||
| +
 | ||||
|  class RedHatAtomicPolicy(RHELPolicy): | ||||
|      distro = "Red Hat Atomic Host" | ||||
|      msg = _("""\ | ||||
| @@ -592,6 +602,15 @@
 | ||||
|      vendor_urls = [('Community Website', 'https://www.centos.org/')] | ||||
|   | ||||
|   | ||||
| +class AlmaLinuxAtomicPolicy(RedHatAtomicPolicy):
 | ||||
| +    distro = "AlmaLinux Atomic Host"
 | ||||
| +    vendor = "AlmaLinux OS Foundation"
 | ||||
| +    vendor_urls = [
 | ||||
| +        ('Distribution Website', 'https://www.almalinux.org/'),
 | ||||
| +        ('Commercial Support', 'https://tuxcare.com/linux-support-services/')
 | ||||
| +    ]
 | ||||
| +
 | ||||
| +
 | ||||
|  class FedoraPolicy(RedHatPolicy): | ||||
|      """ | ||||
|      The policy for Fedora based systems, regardless of spin/edition. This | ||||
| @ -1,54 +0,0 @@ | ||||
| --- a/sos/report/plugins/coredump.py
 | ||||
| +++ b/sos/report/plugins/coredump.py
 | ||||
| @@ -72,8 +72,8 @@
 | ||||
|              cdump = line.split() | ||||
|              pid = cdump[4] | ||||
|              exe = cdump[-2] | ||||
| -            if regex := self.get_option("executable"):
 | ||||
| -                if not re.search(regex, exe, re.I):
 | ||||
| +            if self.get_option("executable"):
 | ||||
| +                if not re.search(self.get_option("executable"), exe, re.I):
 | ||||
|                      continue | ||||
|              cinfo = self.collect_cmd_output(f"coredumpctl info {pid}") | ||||
|              if cinfo['status'] != 0: | ||||
| --- a/sos/collector/sosnode.py
 | ||||
| +++ b/sos/collector/sosnode.py
 | ||||
| @@ -372,7 +372,8 @@
 | ||||
|              for line in result.splitlines(): | ||||
|                  if not is_list: | ||||
|                      try: | ||||
| -                        if ls := line.split():
 | ||||
| +                        ls = line.split()
 | ||||
| +                        if ls:
 | ||||
|                              res.append(ls[0]) | ||||
|                      except Exception as err: | ||||
|                          self.log_debug(f"Error parsing sos help: {err}") | ||||
| --- a/sos/report/plugins/mongodb.py
 | ||||
| +++ b/sos/report/plugins/mongodb.py
 | ||||
| @@ -87,9 +87,11 @@
 | ||||
|      ) | ||||
|   | ||||
|      def setup(self): | ||||
| -        if get_juju_info := self.path_exists('/var/lib/juju/db'):
 | ||||
| +        if self.path_exists('/var/lib/juju/db'):
 | ||||
| +            get_juju_info = self.path_exists('/var/lib/juju/db')
 | ||||
|              self.db_folder = "/var/lib/juju/db" | ||||
| -        elif get_juju_info := self.path_exists('/var/snap/juju-db/curent/db'):
 | ||||
| +        elif self.path_exists('/var/snap/juju-db/curent/db'):
 | ||||
| +            get_juju_info = self.path_exists('/var/snap/juju-db/curent/db')
 | ||||
|              self.db_folder = "/var/snap/juju-db/current/db" | ||||
|   | ||||
|          super().setup() | ||||
| --- a/sos/report/plugins/__init__.py	2025-08-21 12:41:10.418390705 +0200
 | ||||
| +++ b/sos/report/plugins/__init__.py	2025-08-21 12:55:39.546634618 +0200
 | ||||
| @@ -2965,8 +2965,9 @@
 | ||||
|          :rtype: ``str`` | ||||
|          """ | ||||
|          if self.container_exists(container, runtime) or \ | ||||
| -           ((_runtime := self._get_container_runtime(runtime)) and
 | ||||
| +           ((self._get_container_runtime(runtime)) and
 | ||||
|             runas is not None): | ||||
| +            _runtime = self._get_container_runtime(runtime)
 | ||||
|              return _runtime.fmt_container_cmd(container, cmd, quotecmd) | ||||
|          return '' | ||||
| 
 | ||||
| @ -1,31 +0,0 @@ | ||||
| --- /dev/null			2025-04-03 01:35:45.132999852 +0200
 | ||||
| +++ sos-4.10.0/bin/sosreport	2025-04-15 13:54:04.924751581 +0200
 | ||||
| @@ -0,0 +1,6 @@
 | ||||
| +#!/usr/bin/python3
 | ||||
| +msg = ("sosreport binary is deprecated, use 'sos report' instead")
 | ||||
| +print(msg)
 | ||||
| +exit(1)
 | ||||
| +
 | ||||
| +# vim:ts=4 et sw=4
 | ||||
| 
 | ||||
| --- /dev/null			2025-04-03 01:35:45.132999852 +0200
 | ||||
| +++ sos-4.10.0/bin/sos-collector	2025-04-15 15:10:17.780281627 +0200
 | ||||
| @@ -0,0 +1,6 @@
 | ||||
| +#!/usr/bin/python3
 | ||||
| +msg = ("sos-collector binary is deprecated, use 'sos collector' instead")
 | ||||
| +print(msg)
 | ||||
| +exit(1)
 | ||||
| +
 | ||||
| +# vim:ts=4 et sw=4
 | ||||
| 
 | ||||
| --- sos-4.9.2/setup.py	2025-04-15 15:17:21.938635468 +0200
 | ||||
| +++ sos-4.9.2/setup.py	2025-04-15 15:17:41.328198501 +0200
 | ||||
| @@ -34,7 +34,7 @@
 | ||||
|      maintainer_email='jacob.r.hunsaker@gmail.com', | ||||
|      url='https://github.com/sosreport/sos', | ||||
|      license="GPLv2+", | ||||
| -    scripts=['bin/sos'],
 | ||||
| +    scripts=['bin/sos', 'bin/sosreport', 'bin/sos-collector'],
 | ||||
|      data_files=data_files, | ||||
|      packages=find_packages(include=['sos', 'sos.*']) | ||||
|  ) | ||||
							
								
								
									
										529
									
								
								SPECS/sos.spec
									
									
									
									
									
								
							
							
						
						
									
										529
									
								
								SPECS/sos.spec
									
									
									
									
									
								
							| @ -1,34 +1,34 @@ | ||||
| %{!?python_sitelib: %define python_sitelib %(%{__python} -c "from distutils.sysconfig import get_python_lib; print get_python_lib()")} | ||||
| 
 | ||||
| %global auditversion 0.3-1 | ||||
| %global auditversion 0.3 | ||||
| 
 | ||||
| Summary: A set of tools to gather troubleshooting information from a system | ||||
| Name: sos | ||||
| Version: 4.10.0 | ||||
| Release: 4%{?dist} | ||||
| Version: 4.5.0 | ||||
| Release: 1%{?dist}.alma | ||||
| Group: Applications/System | ||||
| Source0: https://github.com/sosreport/sos/archive/%{version}/sos-%{version}.tar.gz | ||||
| Source1: sos-audit-%{auditversion}.tgz | ||||
| License: GPL-2.0-or-later | ||||
| License: GPLv2+ | ||||
| BuildArch: noarch | ||||
| Url: https://github.com/sosreport/sos | ||||
| BuildRequires: python3-devel | ||||
| BuildRequires: gettext | ||||
| BuildRequires: python3-setuptools | ||||
| Requires: tar | ||||
| Requires: bzip2 | ||||
| Requires: xz | ||||
| Requires: python3-requests | ||||
| Requires: python3-setuptools | ||||
| Recommends: python3-magic | ||||
| Recommends: python3-pexpect | ||||
| Recommends: python3-pyyaml | ||||
| Conflicts: vdsm < 4.40 | ||||
| Obsoletes: sos-collector | ||||
| Patch1: sos-python36-walrus-operator.patch | ||||
| Patch2: sosreport-binary.patch | ||||
| Patch3: 0001-cleaner-Make-cleaner-s-obfuscate_file-properly-worki.patch | ||||
| Patch4: 0002-openstack_nova-Improve-scrubbing.patch | ||||
| Patch5: 0003-component-Fix-regression-57bbc89-in-toolbox-containe.patch | ||||
| Patch6: 0004-revert-PR4092.patch | ||||
| Patch7: 0005-cleaner-rhel8.patch | ||||
| Obsoletes: sos-collector <= 1.9 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| # almalinux | ||||
| Patch1000: sos-almalinux-branding.patch | ||||
| 
 | ||||
| %description | ||||
| Sos is a set of tools that gathers information about system | ||||
| @ -39,24 +39,25 @@ support technicians and developers. | ||||
| %prep | ||||
| %setup -qn %{name}-%{version} | ||||
| %setup -T -D -a1 -q | ||||
| %patch -P 1 -p1  | ||||
| %patch -P 2 -p1 | ||||
| %patch -P 3 -p1 | ||||
| %patch -P 4 -p1 | ||||
| %patch -P 5 -p1 | ||||
| %patch -P 6 -p1 | ||||
| %patch -P 7 -p1 | ||||
| 
 | ||||
| 
 | ||||
| # almalinux | ||||
| %patch1000 -p1 | ||||
| 
 | ||||
| %build | ||||
| %py3_build | ||||
| 
 | ||||
| %install | ||||
| %py3_install '--install-scripts=%{_sbindir}' | ||||
| rm -f %{buildroot}/usr/config/sos.conf | ||||
| rm -f %{buildroot}/usr/config/tmpfilesd-sos-rh.conf | ||||
| install -Dm644 %{name}.conf %{buildroot}%{_sysconfdir}/%{name}/%{name}.conf | ||||
| install -d -m 755 %{buildroot}%{_sysconfdir}/tmpfiles.d/ | ||||
| install -m 644 tmpfiles/tmpfilesd-sos-rh.conf %{buildroot}%{_sysconfdir}/tmpfiles.d/%{name}.conf | ||||
| 
 | ||||
| install -d -m 755 %{buildroot}%{_sysconfdir}/%{name} | ||||
| install -d -m 700 %{buildroot}%{_sysconfdir}/%{name}/cleaner | ||||
| install -d -m 755 %{buildroot}%{_sysconfdir}/%{name}/presets.d | ||||
| install -d -m 755 %{buildroot}%{_sysconfdir}/%{name}/groups.d | ||||
| install -d -m 755 %{buildroot}%{_sysconfdir}/%{name}/extras.d | ||||
| install -m 644 %{name}.conf %{buildroot}%{_sysconfdir}/%{name}/%{name}.conf | ||||
| 
 | ||||
| rm -rf %{buildroot}/usr/config/ | ||||
| 
 | ||||
| %find_lang %{name} || echo 0 | ||||
| 
 | ||||
| @ -64,42 +65,35 @@ cd %{name}-audit-%{auditversion} | ||||
| DESTDIR=%{buildroot} ./install.sh | ||||
| cd .. | ||||
| 
 | ||||
| mkdir -p %{buildroot}%{_sysconfdir}/sos/{cleaner,presets.d,extras.d,groups.d} | ||||
| 
 | ||||
| # internationalization is currently broken. Uncomment this line once fixed. | ||||
| # %%files -f %%{name}.lang | ||||
| %files | ||||
| %{_sbindir}/sos | ||||
| %{_sbindir}/sosreport | ||||
| %{_sbindir}/sos-collector | ||||
| #%dir /etc/sos/cleaner | ||||
| %dir /etc/sos/presets.d | ||||
| %dir /etc/sos/extras.d | ||||
| %dir /etc/sos/groups.d | ||||
| /etc/tmpfiles.d/%{name}.conf | ||||
| %{python3_sitelib}/* | ||||
| %{_mandir}/man1/sos-clean.1.gz | ||||
| %{_mandir}/man1/sos-upload.1.gz | ||||
| %{_mandir}/man1/sos-collect.1.gz | ||||
| %{_mandir}/man1/sos-help.1.gz | ||||
| %{_mandir}/man1/sos-mask.1.gz | ||||
| %{_mandir}/man1/sos-report.1.gz | ||||
| %{_mandir}/man1/sos.1.gz | ||||
| %{_mandir}/man1/* | ||||
| %{_mandir}/man5/sos.conf.5.gz | ||||
| %doc AUTHORS README.md | ||||
| %license LICENSE | ||||
| %config(noreplace) %{_sysconfdir}/sos/sos.conf | ||||
| %config(noreplace) %{_sysconfdir}/sos/cleaner | ||||
| 
 | ||||
| 
 | ||||
| %package audit | ||||
| Summary: Audit use of some commands for support purposes | ||||
| License: GPL-2.0-or-later | ||||
| License: GPLv2+ | ||||
| Group: Application/System | ||||
| 
 | ||||
| %description audit | ||||
| 
 | ||||
| Sos-audit provides configuration files for the Linux Auditing System | ||||
| to track the use of some commands capable of changing the configuration | ||||
| of the system. Currently storage and filesystem commands are audited. | ||||
| of the system.  Currently storage and filesystem commands are audited. | ||||
| 
 | ||||
| %post audit | ||||
| %{_sbindir}/sos-audit.sh | ||||
| @ -115,463 +109,246 @@ of the system. Currently storage and filesystem commands are audited. | ||||
| %{_mandir}/man8/sos-audit.sh.8.gz | ||||
| %ghost /etc/audit/rules.d/40-sos-filesystem.rules | ||||
| %ghost /etc/audit/rules.d/40-sos-storage.rules | ||||
| %license LICENSE | ||||
| 
 | ||||
| 
 | ||||
| %changelog | ||||
| * Tue Sep 23 2025 Jan Jansky <jjansky@redhat.com> = 4.10.0-4 | ||||
| - Update to 4.10.0-4 | ||||
|   Resolves: RHEL-112413 | ||||
| 
 | ||||
| * Wed Sep 17 2025 Jan Jansky <jjansky@redhat.com> = 4.10.0-2 | ||||
| - Update to 4.10.0-2 | ||||
|   Resolves: RHEL-112413 | ||||
| 
 | ||||
| * Thu Aug 21 2025 Jan Jansky <jjansky@redhat.com> = 4.10.0-1 | ||||
| - Update to 4.10.0 | ||||
|   Resolves: RHEL-110499 | ||||
| 
 | ||||
| * Fri Jul 04 2025 Jan Jansky <jjansky@redhat.com> = 4.9.2-1 | ||||
| - Update to 4.9.2 in RHEL 8 | ||||
|   Resolves: RHEL-101716 | ||||
| 
 | ||||
| * Fri May 30 2025 Jan Jansky <jjansky@redhat.com> = 4.9.1-2 | ||||
| - Update to 4.9.1-2 in RHEL 8 | ||||
|   Resolves: RHEL-86645 | ||||
| 
 | ||||
| * Tue Apr 15 2025 Jan Jansky <jjansky@redhat.com> = 4.9.1-1 | ||||
| - Update to 4.9.1 in RHEL 8 | ||||
|   Resolves: RHEL-86645 | ||||
| 
 | ||||
| * Tue Jan 07 2025 Jan Jansky <jjansky@redhat.com> = 4.8.2-1 | ||||
| - Update to 4.8.2 in RHEL 8 | ||||
|   Resolves: RHEL-72941 | ||||
| 
 | ||||
| * Wed Oct 23 2024 Jan Jansky <jjansky@redhat.com> = 4.8.1-1 | ||||
| - Update to 4.8.1 in RHEL 8 | ||||
|   Resolves: RHEL-64160 | ||||
| 
 | ||||
| * Fri Sep 27 2024 Jan Jansky <jjansky@redhat.com> = 4.8.0-3 | ||||
| - Added credentials obfuscation from multiple files | ||||
|   Resolves: RHEL-58097 | ||||
| 
 | ||||
| * Sat Sep 14 2024 Pierguido Lambri <plambri@redhat.com> = 4.8.0-2 | ||||
| - Resolves: RHEL-22732 | ||||
|   Fix wrong formatting | ||||
| 
 | ||||
| * Mon Sep 09 2024 Pierguido Lambri <plambri@redhat.com> = 4.8.0-1 | ||||
| - New upstream release | ||||
|   Resolves: RHEL-58097 | ||||
| 
 | ||||
| * Wed Aug 21 2024 Pavel Moravec <pmoravec@redhat.com> = 4.7.2-2 | ||||
| - reverting RHEL-22732 patch due to regressions | ||||
|   Resolves: RHEL-49779 | ||||
| 
 | ||||
| * Fri Jun 21 2024 Pierguido Lambri <plambri@redhat.com> = 4.7.2-1 | ||||
| - New upstream release | ||||
|   Resolves: RHEL-40871 | ||||
|   Resolves: RHEL-33703 | ||||
|   Resolves: RHEL-22732 | ||||
| 
 | ||||
| * Thu May 09 2024 Pavel Moravec <pmoravec@redhat.com> = 4.7.1-3 | ||||
| - [archive] Fix get_archive_root after files reordering | ||||
|   Resolves: RHEL-35945 | ||||
| 
 | ||||
| * Mon Apr 08 2024 Jan Jansky <jjansky@redhat.com> = 4.7.1-1 | ||||
| - rebase to upstream 4.7.1 | ||||
|   Resolves: RHEL-32104 | ||||
| 
 | ||||
| * Tue Feb 20 2024 Jan Jansky <jjansky@redhat.com> = 4.7.0-1 | ||||
| - rebase to upstream 4.7.0 | ||||
|   Resolves: RHEL-26111 | ||||
| 
 | ||||
| * Thu Jan 11 2024 Pavel Moravec <pmoravec@redhat.com> = 4.6.1-1 | ||||
| - rebase to upstream 4.6.1 | ||||
|   Resolves: RHEL-21173 | ||||
| - [redhat] Change authentication method for RHEL | ||||
|   Resolves: RHEL-21177 | ||||
| 
 | ||||
| * Wed Oct 18 2023 Pavel Moravec <pmoravec@redhat.com> = 4.6.0-5 | ||||
|   [pulpcore] Scrub AUTH_LDAP_BIND_PASSWORD value | ||||
|   Resolves: RHEL-13697 | ||||
| 
 | ||||
| * Tue Oct 17 2023 Pavel Moravec <pmoravec@redhat.com> = 4.6.0-4 | ||||
| - [pulp] Fix dynaconf obfuscation and add AUTH_LDAP_BIND_PASSWORD | ||||
|   Resolves: RHEL-13697 | ||||
| 
 | ||||
| * Fri Sep 01 2023 Pavel Moravec <pmoravec@redhat.com> = 4.6.0-2 | ||||
| - [openshift_ovn] Collect additional ovnkube node logs | ||||
|   Resolves: SUPDEV145 | ||||
| 
 | ||||
| * Wed Aug 23 2023 Jan Jansky <jjansky@redhat.com> = 4.6.0-1 | ||||
| - [cleaner] Use data filter for extraction | ||||
|   Resolves: bz2218873 | ||||
| 
 | ||||
| * Thu Jul 27 2023 Pavel Moravec <pmoravec@redhat.com> = 4.5.6-1 | ||||
| - Rebase sos to 4.5.6 | ||||
|   Resolves: bz2226724 | ||||
| 
 | ||||
| * Fri Jul 14 2023 Jan Jansky <jjansky@redhat.com> = 4.5.5-2 | ||||
| - Adding patch for mac obfuscation | ||||
|   Resolves: bz2218279 | ||||
|   Resolves: bz2216608 | ||||
|   Resolves: bz2207562 | ||||
| 
 | ||||
| * Mon Jul 03 2023 Jan Jansky <jjansky@redhat.com> = 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 <pmoravec@redhat.com> = 4.5.4-1 | ||||
| - [plugins] collect strings before commands | ||||
|   Resolves: bz2203141 | ||||
| - [collector] collect report from primary node if in node_list | ||||
|   Resolves: bz2186460 | ||||
| - [powerpc] collect invscout logs | ||||
|   Resolves: bz2210543 | ||||
| - [rhc] New plugin for RHC | ||||
|   Resolves: bz2196649 | ||||
| 
 | ||||
| * Fri May 05 2023 Jan Jansky <jjansky@redhat.com> = 4.5.3-1 | ||||
| - [report] Ignore case when scrubbing via do_file_sub | ||||
|   Resolves: bz2143272 | ||||
| - [subscription_manager] Scrub proxy passwords from repo_server_val | ||||
|   Resolves: bz2177282 | ||||
| - [virsh] Scrub passwords in virt-manager logs | ||||
|   Resolves: bz2184062 | ||||
| 
 | ||||
| * Wed Mar 08 2023 Pavel Moravec <pmoravec@redhat.com> = 4.5.1-3 | ||||
| - Rebase on upstream 4.5.1 | ||||
|   Resolves: bz2175806 | ||||
| - [composer] Capure /etc/osbuild-composer file | ||||
|   Resolves: bz2169776 | ||||
| - [ostree] Collect "ostree fsck" under plugin specific opt | ||||
|   Resolves: bz2161533 | ||||
| - [iprconfig] guard whole plugin by sg kmod predicate | ||||
|   Resolves: bz2176086 | ||||
| - [cleaner] dont clean sys_tmp from final_path | ||||
|   Resolves: bz2176218 | ||||
| * Wed Mar 29 2023 Eduard Abdullin <eabdullin@almalinux.org> - 4.5.0-1.alma | ||||
| - Debrand for AlmaLinux | ||||
| 
 | ||||
| * Tue Feb 07 2023 Pavel Moravec <pmoravec@redhat.com> = 4.5.0-1 | ||||
| - Rebase on upstream 4.5.0 | ||||
|   Resolves: bz2082614 | ||||
|   Resolves: bz2082615 | ||||
| 
 | ||||
| * Thu Nov 03 2022 Pavel Moravec <pmoravec@redhat.com> = 4.4-4 | ||||
| - [ocp] Add newly required labels to temp OCP namespace | ||||
|   Resolves: bz2130922 | ||||
|   Resolves: bz2130976 | ||||
| 
 | ||||
| * Fri Oct 28 2022 Pavel Moravec <pmoravec@redhat.com> = 4.4-3 | ||||
| - [cleaner] Apply compile_regexes after a regular parse line | ||||
|   Resolves: bz2138173 | ||||
|   Resolves: bz2138174 | ||||
| 
 | ||||
| * Thu Sep 22 2022 Pavel Moravec <pmoravec@redhat.com> = 4.4-2 | ||||
| - [utilities] Relax from hard dependency of python3-magic | ||||
|   Resolves: bz2129038 | ||||
|   Resolves: bz2126089 | ||||
| - [dnf] Collect legacy yum config symlinks, properly obfuscate pwds | ||||
|   Resolves: bz2100154 | ||||
|   Resolves: bz2125499 | ||||
| 
 | ||||
| * Fri Sep 09 2022 Pavel Moravec <pmoravec@redhat.com> = 4.4-1 | ||||
| - Rebase on upstream 4.4 | ||||
|   Resolves: bz2082614 | ||||
|   Resolves: bz2082615 | ||||
| - [redhat] Honour credential-less --upload-url on RedHat distro properly | ||||
|   Resolves: bz2059572 | ||||
| - [sos] Fix unhandled exception when concurrently removing temp dir | ||||
|   Resolves: bz2088439 | ||||
| - [specfile] drop python3-libxml2 dependency | ||||
|   Resolves: bz2125486 | ||||
|   Resolves: bz2059573 | ||||
| - [md] Restrict data capture to raid members | ||||
|   Resolves: bz2125485 | ||||
| - [cleaner] Use compiled regex lists for parsers by default | ||||
|   Resolves: bz2043233 | ||||
| - [cgroups] not collect memory.kmem.slabinfo | ||||
|   Resolves: bz1995120 | ||||
| - [report] Fix loop devices data gathering | ||||
|   Resolves: bz2010735 | ||||
| - [insights] Collect /var/lib/insights | ||||
|   Resolves: bz2103233 | ||||
| - [candlepin] collect information about SCA | ||||
|   Resolves: bz2060925 | ||||
| - [manpages] Clarify --upload-directory applicable to FTP protocol only | ||||
|   Resolves: bz2063259 | ||||
| - [cleaner] Dont obfuscate tmpdir path of local private_map | ||||
|   Resolves: bz2064815 | ||||
| - [fibrechannel] collect Cisco fnic statistics | ||||
|   Resolves: bz2074715 | ||||
| - [pulpcore] Collect db_tables_sizes | ||||
|   Resolves: bz2081433 | ||||
| - [fibrechannel]: Update fibrechannel plugin to collect HBA logs | ||||
|   Resolves: bz2089591 | ||||
| - [arcconf]: Update arcconf plugin to collect UART logs | ||||
|   Resolves: bz2090283 | ||||
| - [pulpcore] Stop collecting commands relevant to old taskig system | ||||
|   Resolves: bz2093191 | ||||
| - [dnf,yum] Merge plugins into dnf, remove yum plugin | ||||
|   Resolves: bz2100154 | ||||
| - [policies] Simplify flow in _container_init() | ||||
|   Resolves: bz2100480 | ||||
| - [pacemaker] Update collect cluster profile for pacemaker | ||||
|   Resolves: bz2065821 | ||||
|   Resolves: bz2062283 | ||||
| - [sos] Fix unhandled exception when concurrently removing temp dir | ||||
|   Resolves: bz2088440 | ||||
| 
 | ||||
| * Mon Aug 29 2022 Pavel Moravec <pmoravec@redhat.com> = 4.3-3 | ||||
| - [vdsm] Set LVM option use_devicesfile=0 | ||||
|   Resolves: bz2093993 | ||||
|   Resolves: bz2122355 | ||||
| - [Plugin] Make forbidden path checks more efficient | ||||
|   Resolves: bz2099598 | ||||
|   Resolves: bz2122354 | ||||
| 
 | ||||
| * Thu Jun 16 2022 Pavel Moravec <pmoravec@redhat.com> = 4.3-2 | ||||
| - [ovirt] answer files: Filter out all password keys | ||||
|   Resolves: bz2095263 | ||||
| - [plugins] Allow 'str' PlugOpt type to accept any value | ||||
|   Resolves: bz2079485 | ||||
| - [tigervnc] Update collections for newer versions of TigerVNC | ||||
|   Resolves: bz2062908 | ||||
| - [pacemaker] Redesign node enumeration logic | ||||
|   Resolves: bz2065805 | ||||
| - crio: switch from parsing output in table format to json | ||||
|   Resolves: bz2092969 | ||||
| - [report] Honor plugins' hardcoded plugin_timeout | ||||
|   Resolves: bz2079187 | ||||
| - [report] --list-plugins should report used, not default, | ||||
|   Resolves: bz2079484 | ||||
| - [ocp, openshift] Re-align API collection options and rename | ||||
|   Resolves: bz2065563 | ||||
| - [utilities] Close file only when storing to file | ||||
|   Resolves: bz2079486 | ||||
| - [presets] Adjust OCP preset options, more OCP backports | ||||
|   Resolves: bz2058279 | ||||
|   Resolves: bz2079492 | ||||
| - [report] --list-plugins should report used, not default, | ||||
|   Resolves: bz2079490 | ||||
| - [report] Honor plugins' hardcoded plugin_timeout | ||||
|   Resolves: bz2079188 | ||||
| - crio: switch from parsing output in table format to json | ||||
|   Resolves: bz2097674 | ||||
| - [pacemaker] Redesign node enumeration logic | ||||
|   Resolves: bz2082914 | ||||
| - [tigervnc] Update collections for newer versions of TigerVNC | ||||
|   Resolves: bz2066181 | ||||
| - [plugins] Allow 'str' PlugOpt type to accept any value | ||||
|   Resolves: bz2079491 | ||||
| - [ovirt] answer files: Filter out all password keys | ||||
|   Resolves: bz2095267 | ||||
| 
 | ||||
| * Mon Apr 04 2022 Pavel Moravec <pmoravec@redhat.com> = 4.3-1 | ||||
| * Thu Mar 24 2022 Pavel Moravec <pmoravec@redhat.com> = 4.3-1 | ||||
| - Rebase on upstream 4.3 | ||||
|   Resolves: bz2055002 | ||||
|   Resolves: 2055003 | ||||
| - [sapnw] Fix IndexError exception | ||||
|   Resolves: bz1992938 | ||||
|   Resolves: 2065551 | ||||
| - [subscription_manager] collect syspurpose data via sub-man | ||||
|   Resolves: 2002333 | ||||
| - [Plugin, utilities] Allow writing command output directly to disk | ||||
|   Resolves: bz1726023 | ||||
|   Resolves: 2065564 | ||||
| - [Ceph] Add support for containerized Ceph setup | ||||
|   Resolves: bz1882544 | ||||
|   Resolves: 2065562 | ||||
| - [unbound] Add new plugin for Unbound DNS resolver | ||||
|   Resolves: bz2018228 | ||||
|   Resolves: 2065560 | ||||
| - [discovery] Add new discovery plugin | ||||
|   Resolves: bz2018549 | ||||
| - [vdsm] Exclude /var/lib/vdsm/storage/transient_disks | ||||
|   Resolves: bz2029154 | ||||
|   Resolves: 2065558 | ||||
| - [system] Collect glibc tuning decisions | ||||
|   Resolves: 2032913 | ||||
| 
 | ||||
| * Wed Feb 23 2022 Pavel Moravec <pmoravec@redhat.com> = 4.2-15 | ||||
| - [sosnode] Handle downstream versioning for runtime option | ||||
|   Resolves: bz2036697 | ||||
|   Resolves: bz2037350 | ||||
| - [options] Fix logging on plugopts in effective sos command | ||||
|   Resolves: bz2054882 | ||||
|   Resolves: bz2054883 | ||||
| - [report] Honor plugins' hardcoded plugin_timeout | ||||
|   Resolves: bz2055547 | ||||
|   Resolves: bz2055548 | ||||
| - [policies] Set fallback to None sysroot, don't chroot to '/' | ||||
|   Resolves: bz1873185 | ||||
|   Resolves: bz2011537 | ||||
| - [ovn_central] Rename container responsable of Red Hat | ||||
|   Resolves: bz2042966 | ||||
|   Resolves: bz2043488 | ||||
| 
 | ||||
| * Wed Jan 26 2022 Pavel Moravec <pmoravec@redhat.com> = 4.2-13 | ||||
| - [virsh] Catch parsing exception | ||||
|   Resolves: bz2041488 | ||||
|   Resolves: bz2041855 | ||||
| 
 | ||||
| * Tue Jan 25 2022 Pavel Moravec <pmoravec@redhat.com> = 4.2-12 | ||||
| - [foreman] Use psql-msgpack-decode wrapper for dynflow >= 1.6 | ||||
|   Resolves: bz2043102 | ||||
|   Resolves: bz2043104 | ||||
| - [virsh] Call virsh commands in the foreground / with a TTY | ||||
|   Resolves: bz2041488 | ||||
|   Resolves: bz2041855 | ||||
| - [ovn_central] Account for Red Hat ovn package naming | ||||
|   Resolves: bz2042966 | ||||
|   Resolves: bz2043488 | ||||
| - [clean,parsers] Build regex lists for static items only once | ||||
|   Resolves: bz2036697 | ||||
|   Resolves: bz2037350 | ||||
| 
 | ||||
| * Mon Jan 10 2022 Pavel Moravec <pmoravec@redhat.com> = 4.2-11 | ||||
| - [report] Add journal logs for NetworkManager plugin | ||||
|   Resolves: bz2036697 | ||||
|   Resolves: bz2037350 | ||||
| 
 | ||||
| * Fri Jan 07 2022 Pavel Moravec <pmoravec@redhat.com> = 4.2-9 | ||||
| - add oc transport, backport various PRs for OCP | ||||
|   Resolves: bz2036697 | ||||
|   Resolves: bz2037350 | ||||
| - [report] Provide better warning about estimate-mode | ||||
|   Resolves: bz1873185 | ||||
|   Resolves: bz2011537 | ||||
| - [hostname] Fix loading and detection of long base domains | ||||
|   Resolves: bz2023867 | ||||
|   Resolves: bz2024893 | ||||
| 
 | ||||
| * Sun Dec 19 2021 Pavel Moravec <pmoravec@redhat.com> = 4.2-8 | ||||
| - [rhui] New log folder | ||||
|   Resolves: bz2030741 | ||||
|   Resolves: bz2031777 | ||||
| - nvidia]:Patch to update nvidia plugin for GPU info | ||||
|   Resolves: bz2025403 | ||||
|   Resolves: bz2034001 | ||||
| - [hostname] Fix edge case for new hosts in a known subdomain | ||||
|   Resolves: bz2023867 | ||||
|   Resolves: bz2024893 | ||||
| 
 | ||||
| * Wed Dec 08 2021 Pavel Moravec <pmoravec@redhat.com> = 4.2-7 | ||||
| - [hostname] Simplify case matching for domains | ||||
|   Resolves: bz2023867 | ||||
|   Resolves: bz2024893 | ||||
| 
 | ||||
| * Tue Nov 30 2021 Pavel Moravec <pmoravec@redhat.com> = 4.2-6 | ||||
| - [redhat] Fix broken URI to upload to customer portal | ||||
|   Resolves: bz2025610 | ||||
|   Resolves: bz2025611 | ||||
| 
 | ||||
| * Mon Nov 22 2021 Pavel Moravec <pmoravec@redhat.com> = 4.2-5 | ||||
| - [clean,hostname_parser] Source /etc/hosts for obfuscation | ||||
|   Resolves: bz2023867 | ||||
|   Resolves: bz2024893 | ||||
| - [clean, hostname] Fix unintentionally case sensitive | ||||
|   Resolves: bz2023863 | ||||
|   Resolves: bz2024892 | ||||
| - [redhat] update SFTP API version to v2 | ||||
|   Resolves: bz2025610 | ||||
|   Resolves: bz2025611 | ||||
| 
 | ||||
| * Tue Nov 16 2021 Pavel Moravec <pmoravec@redhat.com> = 4.2-4 | ||||
| - [report] Calculate sizes of dirs, symlinks and manifest in | ||||
|   Resolves: bz1873185 | ||||
|   Resolves: bz2011537 | ||||
| - [report] shutdown threads for timeouted plugins | ||||
|   Resolves: bz2012857 | ||||
|   Resolves: bz2012859 | ||||
| - [report] fix filter_namespace per pattern | ||||
|   Resolves: bz2020777 | ||||
|   Resolves: bz2020778 | ||||
| - Ensure specific plugin timeouts are only set | ||||
|   Resolves: bz2018033 | ||||
|   Resolves: bz2023481 | ||||
| 
 | ||||
| * Wed Nov 03 2021 Pavel Moravec <pmoravec@redhat.com> = 4.2-2 | ||||
| - [firewall_tables] call iptables -t <table> based on nft | ||||
|   Resolves: bz2005195 | ||||
|   Resolves: bz2011536 | ||||
| - [report] Count with sos_logs and sos_reports in | ||||
|   Resolves: bz1873185 | ||||
|   Resolves: bz2011537 | ||||
| - [foreman] Collect puma status and stats | ||||
|   Resolves: bz2011506 | ||||
|   Resolves: bz2011507 | ||||
| - [report] Overwrite pred=None before refering predicate | ||||
|   Resolves: bz2012856 | ||||
|   Resolves: bz2012858 | ||||
| - [openvswitch] add commands for offline analysis | ||||
|   Resolves: bz2004929 | ||||
|   Resolves: bz2019697 | ||||
| 
 | ||||
| * Wed Oct 06 2021 Pavel Moravec <pmoravec@redhat.com> = 4.2-1 | ||||
| - Rebase on upstream 4.2 | ||||
|   Resolves: bz1998133 | ||||
|   Resolves: bz1998134 | ||||
| - [report] Implement --estimate-only | ||||
|   Resolves: bz1873185 | ||||
|   Resolves: bz2011537 | ||||
| - [omnipath_client] Opacapture to run only with allow changes | ||||
|   Resolves: bz1998433 | ||||
|   Resolves: bz2011534 | ||||
| - [unpackaged] deal with recursive loop of symlinks properly | ||||
|   Resolves: bz1998521 | ||||
|   Resolves: bz2011533 | ||||
| - [networking] prevent iptables-save commands to load nf_tables | ||||
|   Resolves: bz2001096 | ||||
|   Resolves: bz2011538 | ||||
| - [kernel] Capture Pressure Stall Information | ||||
|   Resolves: bz2002145 | ||||
|   Resolves: bz2011535 | ||||
| - [processor] Apply sizelimit to /sys/devices/system/cpu/cpuX | ||||
|   Resolves: bz2011413 | ||||
|   Resolves: bz1869561 | ||||
| 
 | ||||
| * Wed Aug 11 2021 Pavel Moravec <pmoravec@redhat.com> = 4.1-5 | ||||
| * Wed Aug 11 2021 Pavel Moravec <pmoravec@redhat.com> = 4.1-8 | ||||
| - [report,collect] unify --map-file arguments | ||||
|   Resolves: bz1923938 | ||||
|   Resolves: bz1985985 | ||||
| - [rhui] add new plugin for RHUI 4 | ||||
|   Resolves: bz1665947 | ||||
|   Resolves: bz1992859 | ||||
| - [username parser] Load usernames from `last` for LDAP users | ||||
|   Resolves: bz1985037 | ||||
|   Resolves: bz1992861 | ||||
| 
 | ||||
| * Mon Jul 26 2021 Pavel Moravec <pmoravec@redhat.com> = 4.1-4 | ||||
| - [options] allow variant option names in config file | ||||
|   Resolves: bz1923938 | ||||
| - [plugins] Set default predicate instead of None | ||||
|   Resolves: bz1985986 | ||||
| - [MigrationResults] collect info about conversions | ||||
|   Resolves: bz1959598 | ||||
| * Tue Aug 10 2021 Mohan Boddu <mboddu@redhat.com> - 4.1-7 | ||||
| - Rebuilt for IMA sigs, glibc 2.34, aarch64 flags | ||||
|   Related: rhbz#1991688 | ||||
| 
 | ||||
| * Mon Jun 21 2021 Pavel Moravec <pmoravec@redhat.com> = 4.1-3 | ||||
| - [gluster] collect public keys from the right dir | ||||
|   Resolves: bz1925419 | ||||
| - [cleaner] Only skip packaging-based files for the IP parse | ||||
|   Resolves: bz1964499 | ||||
| * Tue Jul 27 2021 Pavel Moravec <pmoravec@redhat.com> - 4.1-6 | ||||
| - [networking] collect also tc filter show ingress | ||||
|   Resolves: bz1886711 | ||||
| - [archive] skip copying SELinux context for /proc and /sys | ||||
|   Resolves: bz1965001 | ||||
|   Resolves: bz1985976 | ||||
| - [cleaner] Only skip packaging-based files for the IP parser | ||||
|   Resolves: bz1985982 | ||||
| - [sssd] sssd plugin when sssd-common | ||||
|   Resolves: bz1967613 | ||||
|   Resolves: bz1967718 | ||||
| - Various OCP/cluster/cleanup enhancements | ||||
|   Resolves: bz1973675 | ||||
|   Resolves: bz1985983 | ||||
| - [options] allow variant option names in config file | ||||
|   Resolves: bz1985985 | ||||
| - [plugins] Set default predicate instead of None | ||||
|   Resolves: bz1938874 | ||||
| - [MigrationResults] collect info about conversions and | ||||
|   Resolves: bz1959779 | ||||
| 
 | ||||
| * Tue May 18 2021 Pavel Moravec <pmoravec@redhat.com> = 4.1-2 | ||||
| * Wed Jun 02 2021 Pavel Moravec <pmoravec@redhat.com> - 4.1-4 | ||||
| - [archive] skip copying SELinux context for /proc and /sys everytime | ||||
|   Resolves: bz1965002 | ||||
| - Load maps from all archives before obfuscation | ||||
|   Resolves: bz1930181 | ||||
|   Resolves: bz1967110 | ||||
| - Multiple fixes in man pages | ||||
|   Resolves: bz1935603 | ||||
|   Resolves: bz1967111 | ||||
| - [ds] Mask password and encryption keys in ldif files | ||||
|   Resolves: bz1937298 | ||||
|   Resolves: bz1967112 | ||||
| - [report] add --cmd-timeout option | ||||
|   Resolves: bz1937418 | ||||
|   Resolves: bz1967113 | ||||
| - [cups] Add gathering cups-browsed logs | ||||
|   Resolves: bz1939963 | ||||
|   Resolves: bz1967114 | ||||
| - [sssd] Collect memory cache / individual logfiles | ||||
|   Resolves: bz1940502 | ||||
|   Resolves: bz1967115 | ||||
| - Collect ibmvNIC dynamic_debugs | ||||
|   Resolves: bz1942276 | ||||
|   Resolves: bz1967116 | ||||
| - [pulpcore] add plugin for pulp-3 | ||||
|   Resolves: bz1956673 | ||||
|   Resolves: bz1967117 | ||||
| - [saphana] remove redundant unused argument of get_inst_info | ||||
|   Resolves: bz1959413 | ||||
|   Resolves: bz1967118 | ||||
| - [networking] Add nstat command support | ||||
|   Resolves: bz1961458 | ||||
|   Resolves: bz1967119 | ||||
| - [snapper] add a new plugin | ||||
|   Resolves: bz1961229 | ||||
|   Resolves: bz1967120 | ||||
| 
 | ||||
| * Mon Apr 26 2021 Pavel Moravec <pmoravec@redhat.com> = 4.1-1 | ||||
| - Rebase on upstream 4.1 | ||||
|   Resolves: bz1928679 | ||||
| * Fri Apr 16 2021 Mohan Boddu <mboddu@redhat.com> - 4.1-4 | ||||
| - Rebuilt for RHEL 9 BETA on Apr 15th 2021. Related: rhbz#1947937 | ||||
| 
 | ||||
| * Tue Feb 16 2021 Pavel Moravec <pmoravec@redhat.com> = 4.0-8 | ||||
| - Automatically create directory for sos-cleaner default_mapping | ||||
|   Resolves: bz1923937 | ||||
| * Thu Apr 01 2021 Pavel Moravec <pmoravec@redhat.com> - 4.1-3 | ||||
| - adding sos-audit | ||||
| - [gluster] Add glusterd public keys and status files | ||||
|   Resolves: bz1925419  | ||||
| 
 | ||||
| * Fri Jan 29 2021 Pavel Moravec <pmoravec@redhat.com> = 4.0-7 | ||||
| - [kdump] Gather the file kexec-dmesg.log | ||||
|   Resolves: bz1887402 | ||||
| - [Policy] Handle additional FTP authentication issues | ||||
|   Resolves: bz1916729 | ||||
| * Wed Mar 10 2021 Sandro Bonazzola <sbonazzo@redhat.com> - 4.1-1 | ||||
| - Rebase to 4.1 | ||||
| 
 | ||||
| * Thu Jan 21 2021 Pavel Moravec <pmoravec@redhat.com> = 4.0-6 | ||||
| - [networking] Collect 'ethtool -e <device>' conditionally only | ||||
|   Resolves: bz1917196 | ||||
| 
 | ||||
| * Wed Jan 06 2021 Pavel Moravec <pmoravec@redhat.com> = 4.0-5 | ||||
| - [component] honour plugopts from config file | ||||
|   Resolves: bz1912889 | ||||
| - [collector] declare sysroot for each component | ||||
|   Resolves: bz1912821 | ||||
| - [plugins] Dont stop collecting by empty specfile when sizelimit=0 | ||||
|   Resolves: bz1912910 | ||||
| 
 | ||||
| * Mon Jan 04 2021 Pavel Moravec <pmoravec@redhat.com> = 4.0-4 | ||||
| - [component] Use sysroot from Policy when opts doesn't specify it | ||||
|   Resolves: bz1881118 | ||||
| 
 | ||||
| * Mon Dec 14 2020 Pavel Moravec <pmoravec@redhat.com> = 4.0-3 | ||||
| - [ovirt] collect /etc/pki/ovirt-engine/.truststore | ||||
|   Resolves: bz1848095 | ||||
| - [collector] allow overriding plain --cluster-type | ||||
|   Resolves: bz1895316 | ||||
| - [component] Add log verbosity from presets | ||||
|   Resolves: bz1904045 | ||||
| - [options] Fix --log-size=0 being ignored and unreported | ||||
|   Resolves: bz1905657 | ||||
| - [report] collect broken symlinks | ||||
|   Resolves: bz1906598 | ||||
| 
 | ||||
| * Thu Oct 29 2020 Pavel Moravec <pmoravec@redhat.com> = 4.0-2 | ||||
| - [cleaner] more streamlined sanitize_item method | ||||
|   Resolves: bz1827801 | ||||
| - [openstack_ironic] Missing ironic-inspector configs | ||||
|   Resolves: bz1874295 | ||||
| - Add support to collect hardware component logs | ||||
|   Resolves: bz1880372 | ||||
| - [crio] collect /etc/crio/crio.conf.d/ | ||||
|   Resolves: bz1881118 | ||||
| - [policy] Handle additional failure conditions for FTP uploads | ||||
|   Resolves: bz1882368 | ||||
| - [filesys] never collect content of /proc/fs/panfs | ||||
|   Resolves: bz1886782 | ||||
| - [kdump] Collect new kdump logfiles | ||||
|   Resolves: bz1887390 | ||||
| - [stratis] Collect key list and report engine | ||||
|   Resolves: bz1888012 | ||||
| - return tmp-dir with absolute path | ||||
|   Resolves: bz1891562 | ||||
| 
 | ||||
| * Tue Oct 13 2020 Pavel Moravec <pmoravec@redhat.com> = 4.0-1 | ||||
| - Rebase on upstream 4.0 | ||||
|   Resolves: bz1827801 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user