First published: Wed Dec 13 2023(Updated: )
### Summary When parsing SVG images Dompdf performs an initial validation to ensure that paths within the SVG are allowed. One of the validations is that the [SVG document does not reference itself](https://github.com/dompdf/dompdf/blob/v2.0.3/src/Image/Cache.php#L136-L153). However, a recursive chained using two or more SVG documents is not correctly validated. Depending on the system configuration and attack pattern this could exhaust the memory available to the executing process and/or to the server itself. ### Details php-svg-lib, when run in isolation, does not support SVG references for `image` elements. An SVG document can, however, be referenced and Dompdf will run that reference through the same validation. Dompdf currently includes validation to prevent self-referential `image` references, but a chained reference is not checked. A malicious actor may thus trigger infinite recursion in the validation process by chaining references between two or more SVG images. ### PoC This following sources can be used to bypass validation provided by Dompdf: recurse.html ``` <img src="one.svg"> ``` one.svg ``` <svg width="200" height="200" xmlns="http://www.w3.org/2000/svg"> <image href="two.svg" /> </svg> ``` two.svg ``` <svg width="200" height="200" xmlns="http://www.w3.org/2000/svg"> <image href="one.svg" /> </svg> ``` ### Impact When Dompdf parses the above payload, it will crash due after exceeding the allowed execution time or memory usage. An attacker sending multiple request to a system can potentially cause resource exhaustion to the point that the system is unable to handle incoming request.
Credit: security-advisories@github.com
Affected Software | Affected Version | How to fix |
---|---|---|
composer/dompdf/dompdf | <2.0.4 | 2.0.4 |
Dompdf | <=2.0.3 |
Sign up to SecAlerts for real-time vulnerability data matched to your software, aggregated from hundreds of sources.
CVE-2023-50262 has been classified as a medium-severity vulnerability.
To fix CVE-2023-50262, upgrade Dompdf to version 2.0.4 or later.
The main risk associated with CVE-2023-50262 is potential XML External Entity (XXE) injection which can lead to information disclosure.
Dompdf versions prior to 2.0.4 are affected by CVE-2023-50262.
Using SVG images with affected versions of Dompdf can be risky due to the self-referential path validation issue.