Ecosyste.ms: Advisories
An open API service providing security vulnerability metadata for many open source software ecosystems.
Security Advisories: GSA_kwCzR0hTQS1tNjRxLTRqcWgtZjcyZs4AA7KT
Stored Cross-site Scripting (XSS) in excalidraw's web embed component
Summary
A stored XSS vulnerability in Excalidraw's web embeddable component. This allows arbitrary JavaScript to be run in the context of the domain where the editor is hosted.
Poc
Inserting an embed with the below url (can be copy/pasted onto canvas to insert as embed) will log 42
to the console:
https://gist.github.com/vv=v<script>console.log(42)</script>
Details
There were two vectors. One rendering untrusted string as iframe's srcdoc
without properly sanitizing against HTML injection. Second by improperly sanitizing against attribute HTML injection. This in conjunction with allowing allow-same-origin
sandbox flag (necessary for several embeds) resulted in the XSS.
Former was fixed by no longer rendering unsafe srcdoc
content verbatim, and instead strictly parsing the supplied content and constructing the srcdoc
manually. The latter by sanitizing properly.
The allow-same-origin
flag is now also set only in cases that require it, following the principle of least privilege.
Impact
This is a cross site scripting vulnerability, for more information, please see: https://portswigger.net/web-security/cross-site-scripting
Two npm @excalidraw/excalidraw
stable version releases were affected (0.16.x
, 0.17.x
), and both are now patched.
JSON: https://advisories.ecosyste.ms/api/v1/advisories/GSA_kwCzR0hTQS1tNjRxLTRqcWgtZjcyZs4AA7KT
Source: GitHub Advisory Database
Origin: Unspecified
Severity: Moderate
Classification: General
Published: 8 months ago
Updated: 8 months ago
CVSS Score: 6.1
CVSS vector: CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N
Identifiers: GHSA-m64q-4jqh-f72f, CVE-2024-32472
References:
- https://github.com/excalidraw/excalidraw/security/advisories/GHSA-m64q-4jqh-f72f
- https://github.com/excalidraw/excalidraw/commit/6be752e1b6d776ccfbd3bb9eea17463cb264121d
- https://github.com/excalidraw/excalidraw/commit/988f81911ca58e3ca2583e0dd44a954dd00e09d0
- https://nvd.nist.gov/vuln/detail/CVE-2024-32472
- https://github.com/advisories/GHSA-m64q-4jqh-f72f
Blast Radius: 16.6
Affected Packages
npm:@excalidraw/excalidraw
Dependent packages: 52Dependent repositories: 523
Downloads: 304,455 last month
Affected Version Ranges: >= 0.17.0, < 0.17.6, >= 0.16.0, < 0.16.4
Fixed in: 0.17.6, 0.16.4
All affected versions: 0.16.0, 0.16.1, 0.16.2, 0.16.3, 0.17.0, 0.17.1, 0.17.2, 0.17.3, 0.17.4, 0.17.5
All unaffected versions: 0.1.0, 0.1.1, 0.2.0, 0.2.1, 0.3.0, 0.3.1, 0.4.0, 0.4.1, 0.4.2, 0.4.3, 0.5.0, 0.6.0, 0.7.0, 0.8.0, 0.9.0, 0.10.0, 0.10.1, 0.11.0, 0.12.0, 0.13.0, 0.14.0, 0.14.1, 0.14.2, 0.15.0, 0.15.1, 0.15.2, 0.15.3, 0.16.4, 0.17.6