OESA-2025-2684

Source
https://www.openeuler.org/en/security/security-bulletins/detail/?id=openEuler-SA-2025-2684
Import Source
https://repo.openeuler.org/security/data/osv/OESA-2025-2684.json
JSON Data
https://api.test.osv.dev/v1/vulns/OESA-2025-2684
Upstream
Published
2025-11-14T12:39:15Z
Modified
2025-11-14T13:32:35.777159Z
Summary
python-ldap security update
Details

python-ldap: python-ldap provides an object-oriented API to access LDAP directory servers from Python programs. Mainly it wraps the OpenLDAP 2.x libs for that purpose. Additionally the package contains modules for other LDAP-related stuff (e.g. processing LDIF, LDAPURLs, LDAPv3 schema, LDAPv3 extended operations and controls, etc.).

Security Fix(es):

python-ldap is a lightweight directory access protocol (LDAP) client API for Python. In versions prior to 3.4.5, the sanitization method ldap.filter.escape_filter_chars can be tricked to skip escaping of special characters when a crafted list or dict is supplied as the assertion_value parameter, and the non-default escape_mode=1 is configured. The method ldap.filter.escape_filter_chars supports 3 different escaping modes. escape_mode=0 (default) and escape_mode=2 happen to raise exceptions when a list or dict object is supplied as the assertion_value parameter. However, escape_mode=1 computes without performing adequate logic to ensure a fully escaped return value. If an application relies on the vulnerable method in the python-ldap library to escape untrusted user input, an attacker might be able to abuse the vulnerability to launch ldap injection attacks which could potentially disclose or manipulate ldap data meant to be inaccessible to them. Version 3.4.5 fixes the issue by adding a type check at the start of the ldap.filter.escape_filter_chars method to raise an exception when the supplied assertion_value parameter is not of type str.(CVE-2025-61911)

python-ldap is a lightweight directory access protocol (LDAP) client API for Python. In versions prior to 3.4.5, ldap.dn.escapednchars() escapes \x00 incorrectly by emitting a backslash followed by a literal NUL byte instead of the RFC-4514 hex form \00. Any application that uses this helper to construct DNs from untrusted input can be made to consistently fail before a request is sent to the LDAP server (e.g., AD), resulting in a client-side denial of service. Version 3.4.5 contains a patch for the issue.(CVE-2025-61912)

Database specific
{
    "severity": "Medium"
}
References

Affected packages

openEuler:24.03-LTS-SP2 / python-ldap

Package

Name
python-ldap
Purl
pkg:rpm/openEuler/python-ldap&distro=openEuler-24.03-LTS-SP2

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
3.4.4-3.oe2403sp2

Ecosystem specific

{
    "noarch": [
        "python-ldap-help-3.4.4-3.oe2403sp2.noarch.rpm"
    ],
    "src": [
        "python-ldap-3.4.4-3.oe2403sp2.src.rpm"
    ],
    "aarch64": [
        "python-ldap-debuginfo-3.4.4-3.oe2403sp2.aarch64.rpm",
        "python-ldap-debugsource-3.4.4-3.oe2403sp2.aarch64.rpm",
        "python3-ldap-3.4.4-3.oe2403sp2.aarch64.rpm"
    ],
    "x86_64": [
        "python-ldap-debuginfo-3.4.4-3.oe2403sp2.x86_64.rpm",
        "python-ldap-debugsource-3.4.4-3.oe2403sp2.x86_64.rpm",
        "python3-ldap-3.4.4-3.oe2403sp2.x86_64.rpm"
    ]
}