CVE Vulnerabilities

CVE-2025-61911

Failure to Sanitize Special Elements into a Different Plane (Special Element Injection)

Published: Oct 10, 2025 | Modified: Oct 14, 2025
CVSS 3.x
N/A
Source:
NVD
CVSS 2.x
RedHat/V2
RedHat/V3
6.5 MODERATE
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N
Ubuntu
MEDIUM

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.

Weakness

The product does not adequately filter user-controlled input for special elements with control implications.

Affected Software

Name Vendor Start Version End Version
Python-ldap Ubuntu devel *
Python-ldap Ubuntu esm-apps/xenial *
Python-ldap Ubuntu esm-infra/bionic *
Python-ldap Ubuntu esm-infra/focal *
Python-ldap Ubuntu jammy *
Python-ldap Ubuntu noble *
Python-ldap Ubuntu plucky *
Python-ldap Ubuntu questing *
Python-ldap Ubuntu upstream *

Potential Mitigations

References