CVE-2026-44898

MEDIUM

Mistune TOC Anchor Injection XSS

Title source: cna
STIX 2.1

Description

Mistune is a Python Markdown parser with renderers and plugins. Prior to 3.2.1, render_toc_ul() builds a <ul> table-of-contents tree from a list of (level, id, text) tuples. Both the id value (used as href="#<id>") and the text value (used as the visible link label) are inserted into <a> tags via a plain Python format string — with no HTML escaping applied to either value. When heading IDs are derived from user-supplied heading text (the standard use-case for readable slug anchors), an attacker can craft a heading whose text breaks out of the href="#..." attribute context, injecting arbitrary HTML tags including <script> blocks directly into the rendered TOC. This vulnerability is fixed in 3.2.1.

References (2)

Core 2
Core References
X_Refsource_Misc x_refsource_misc
https://github.com/lepture/mistune/releases/tag/v3.2.1

Scores

CVSS v3 6.1
EPSS 0.0020
EPSS Percentile 9.7%
Attack Vector NETWORK
CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N

CISA SSVC

Vulnrichment
Exploitation poc
Automatable no
Technical Impact partial

Details

CWE
CWE-79
Status published
Products (3)
lepture/mistune < 3.2.1
mistune_project/mistune < 3.2.1
pypi/mistune 3.2.0 - 3.2.1PyPI
Published May 26, 2026
Tracked Since May 27, 2026