Lucene search

K
githubGitHub Advisory DatabaseGHSA-M64Q-4JQH-F72F
HistoryApr 17, 2024 - 9:32 p.m.

Stored Cross-site Scripting (XSS) in excalidraw's web embed component

2024-04-1721:32:57
CWE-79
GitHub Advisory Database
github.com
8
stored cross-site scripting
excalidraw
arbitrary javascript
domain context
vulnerability
npm package
patched
html injection
iframe
same origin

6.1 Medium

CVSS3

Attack Vector

NETWORK

Attack Complexity

LOW

Privileges Required

NONE

User Interaction

REQUIRED

Scope

CHANGED

Confidentiality Impact

LOW

Integrity Impact

LOW

Availability Impact

NONE

CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N

5.8 Medium

AI Score

Confidence

High

0.0004 Low

EPSS

Percentile

15.7%

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.

Affected configurations

Vulners
Node
excalidrawexcalidrawRange<0.17.6
OR
excalidrawexcalidrawRange<0.16.4

6.1 Medium

CVSS3

Attack Vector

NETWORK

Attack Complexity

LOW

Privileges Required

NONE

User Interaction

REQUIRED

Scope

CHANGED

Confidentiality Impact

LOW

Integrity Impact

LOW

Availability Impact

NONE

CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N

5.8 Medium

AI Score

Confidence

High

0.0004 Low

EPSS

Percentile

15.7%

Related for GHSA-M64Q-4JQH-F72F