Description
DOMPurify is a DOM-only cross-site scripting sanitizer for HTML, MathML, and SVG. Versions prior to 3.4.0 have an inconsistency between FORBID_TAGS and FORBID_ATTR handling when function-based ADD_TAGS is used. Commit c361baa added an early exit for FORBID_ATTR at line 1214. The same fix was not applied to FORBID_TAGS. At line 1118-1123, when EXTRA_ELEMENT_HANDLING.tagCheck returns true, the short-circuit evaluation skips the FORBID_TAGS check entirely. This allows forbidden elements to survive sanitization with their attributes intact. Version 3.4.0 patches the issue.
Problem types
CWE-183: Permissive List of Allowed Inputs
CWE-79: Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')
Product status
References
github.com/...Purify/security/advisories/GHSA-h7mw-gpvr-xq4m
github.com/...Purify/security/advisories/GHSA-h7mw-gpvr-xq4m
github.com/...ommit/c361baa18dbdcb3344a41110f4c48ad85bf48f80
github.com/cure53/DOMPurify/releases/tag/3.4.0