49 lines
1.9 KiB
Diff
49 lines
1.9 KiB
Diff
From 36fc21545f8bbedca2a498682ceb953979fa7da7 Mon Sep 17 00:00:00 2001
|
|
From: Koichiro Iwao <meta@almalinux.org>
|
|
Date: Wed, 11 Dec 2024 14:59:00 +0900
|
|
Subject: [PATCH] [policies] Fix bug in distro identification
|
|
|
|
Fixes a bug in #3764.
|
|
|
|
A bug in the distro-identifying logic caused incorrect identification
|
|
of the distro as CentOS, Fedora, or RHEL under the following conditions:
|
|
|
|
1. Distro inherits RedHatPolicy
|
|
2. Distro has either of /etc/{centos,fedora,redhat}-release
|
|
3. Policy file appears earlier than redhat.py in dictionary order
|
|
|
|
The issue occurs because the distro-identifying logic relies on the
|
|
existence of the above os_release_file without examining its contents,
|
|
more than checking NAME or ID in the /etc/os-release file. As a result,
|
|
once /etc/{centos,fedora,redhat}-release is found, the contents of
|
|
/etc/os-release are never checked, leading to distro misidentification.
|
|
|
|
At least AlmaLinux is affected by this bug.
|
|
|
|
Signed-off-by: Koichiro Iwao <meta@almalinux.org>
|
|
---
|
|
sos/policies/distros/__init__.py | 8 ++++----
|
|
1 file changed, 4 insertions(+), 4 deletions(-)
|
|
|
|
diff --git a/sos/policies/distros/__init__.py b/sos/policies/distros/__init__.py
|
|
index 66970c72d..989f02067 100644
|
|
--- a/sos/policies/distros/__init__.py
|
|
+++ b/sos/policies/distros/__init__.py
|
|
@@ -163,12 +163,12 @@ def _check_release(content):
|
|
|
|
if remote:
|
|
return _check_release(remote)
|
|
- # use the os-specific file primarily
|
|
- if os.path.isfile(cls.os_release_file):
|
|
- return True
|
|
- # next check os-release for a NAME or ID value we expect
|
|
+ # check os-release for a NAME or ID value we expect
|
|
with open(OS_RELEASE, "r", encoding='utf-8') as f:
|
|
return _check_release(f.read())
|
|
+ # next use the os-specific file
|
|
+ if os.path.isfile(cls.os_release_file):
|
|
+ return True
|
|
|
|
def kernel_version(self):
|
|
return self.release
|