Home

Description

OpenEMR is a free and open source electronic health records and medical practice management application. Prior to version 8.0.0, the `xl()` translation function returns unescaped strings. While wrapper functions exist for escaping in different contexts (`xlt()` for HTML, `xla()` for attributes, `xlj()` for JavaScript), there are places in the codebase where `xl()` output is used directly without escaping. If an attacker could insert malicious content into the translation database, these unescaped outputs could lead to XSS. Version 8.0.0 fixes the issue.

PUBLISHED Reserved 2025-12-29 | Published 2026-02-25 | Updated 2026-02-25 | Assigner GitHub_M




LOW: 1.2CVSS:4.0/AV:N/AC:L/AT:N/PR:L/UI:P/VC:N/VI:N/VA:N/SC:L/SI:L/SA:N/E:U

Problem types

CWE-116: Improper Encoding or Escaping of Output

Product status

< 8.0.0
affected

References

github.com/...penemr/security/advisories/GHSA-3f9j-cqjj-7h46

github.com/...ommit/b1e3fe8a9ed8bcaf17e0b73d7fad5434f9fe36da

cve.org (CVE-2026-21443)

nvd.nist.gov (CVE-2026-21443)

Download JSON