Lucene search

K
rustsecRustsecRUSTSEC-2021-0074
HistoryJul 08, 2021 - 12:00 p.m.

Incorrect handling of embedded SVG and MathML leads to mutation XSS

2021-07-0812:00:00
rustsec.org
10

0.001 Low

EPSS

Percentile

32.3%

Affected versions of this crate did not account for namespace-related parsing
differences between HTML, SVG, and MathML. Even if the svg and math elements
are not allowed, the underlying HTML parser still treats them differently.
Running cleanup without accounting for these differing namespaces resulted in an “impossible”
DOM, which appeared “safe” when examining the DOM tree, but when serialized and deserialized,
could be exploited to inject arbitrary markup.

To exploit this, the application using this library must allow a tag that is parsed as raw text in HTML.
These elements are:

  • title
  • textarea
  • xmp
  • iframe
  • noembed
  • noframes
  • plaintext
  • noscript
  • style
  • script

Applications that do not explicitly allow any of these tags should not be affected, since none are allowed by default.

CPENameOperatorVersion
ammonialt2.1.3
ammoniage3.0.0
ammonialt3.1.0

0.001 Low

EPSS

Percentile

32.3%