Home

Description

Openfire is an XMPP server licensed under the Open Source Apache License. Openfire’s SASL EXTERNAL mechanism for client TLS authentication contains a vulnerability in how it extracts user identities from X.509 certificates. Instead of parsing the structured ASN.1 data, the code calls X509Certificate.getSubjectDN().getName() and applies a regex to look for CN=. This method produces a provider-dependent string that does not escape special characters. In SunJSSE (sun.security.x509.X500Name), for example, commas and equals signs inside attribute values are not escaped. As a result, a malicious certificate can embed CN= inside another attribute value (e.g. OU="CN=admin,"). The regex will incorrectly interpret this as a legitimate Common Name and extract admin. If SASL EXTERNAL is enabled and configured to map CNs to user accounts, this allows the attacker to impersonate another user. The fix is included in Openfire 5.0.2 and 5.1.0.

PUBLISHED Reserved 2025-09-09 | Published 2025-09-15 | Updated 2025-09-15 | Assigner GitHub_M




MEDIUM: 5.9CVSS:3.1/AV:N/AC:H/PR:H/UI:N/S:U/C:H/I:H/A:N

Problem types

CWE-290: Authentication Bypass by Spoofing

Product status

< 5.0.2
affected

References

github.com/...enfire/security/advisories/GHSA-w252-645g-87mp

github.com/...re/util/cert/CNCertificateIdentityMapping.java

igniterealtime.atlassian.net/browse/OF-3122

igniterealtime.atlassian.net/browse/OF-3123

igniterealtime.atlassian.net/browse/OF-3124

cve.org (CVE-2025-59154)

nvd.nist.gov (CVE-2025-59154)

Download JSON