CVE Vulnerabilities

CVE-2019-20044

Improper Check for Dropped Privileges

Published: Feb 24, 2020 | Modified: Nov 21, 2024
CVSS 3.x
7.8
HIGH
Source:
NVD
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H
CVSS 2.x
7.2 HIGH
AV:L/AC:L/Au:N/C:C/I:C/A:C
RedHat/V2
RedHat/V3
7.8 IMPORTANT
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H
Ubuntu
LOW
root.io logo minimus.io logo echo.ai logo

In Zsh before 5.8, attackers able to execute commands can regain privileges dropped by the –no-PRIVILEGED option. Zsh fails to overwrite the saved uid, so the original privileges can be restored by executing MODULE_PATH=/dir/with/module zmodload with a module that calls setuid().

Weakness

The product attempts to drop privileges but does not check or incorrectly checks to see if the drop succeeded.

Affected Software

NameVendorStart VersionEnd Version
ZshZsh*5.8 (excluding)
Red Hat Enterprise Linux 6RedHatzsh-0:4.3.11-11.el6_10*
Red Hat Enterprise Linux 7RedHatzsh-0:5.0.2-34.el7_7.2*
Red Hat Enterprise Linux 8RedHatzsh-0:5.5.1-6.el8_1.2*
Red Hat Enterprise Linux 8RedHatzsh-0:5.5.1-6.el8_1.2*
Red Hat Enterprise Linux 8.0 Update Services for SAP SolutionsRedHatzsh-0:5.5.1-6.el8_0.2*
ZshUbuntubionic*
ZshUbuntueoan*
ZshUbuntuesm-infra/bionic*
ZshUbuntuesm-infra/xenial*
ZshUbuntutrusty*
ZshUbuntuupstream*
ZshUbuntuxenial*

Potential Mitigations

  • Compartmentalize the system to have “safe” areas where trust boundaries can be unambiguously drawn. Do not allow sensitive data to go outside of the trust boundary and always be careful when interfacing with a compartment outside of the safe area.
  • Ensure that appropriate compartmentalization is built into the system design, and the compartmentalization allows for and reinforces privilege separation functionality. Architects and designers should rely on the principle of least privilege to decide the appropriate time to use privileges and the time to drop privileges.

References