Home

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.

PUBLISHED Reserved 2026-05-07 | Published 2026-05-26 | Updated 2026-05-27 | Assigner GitHub_M




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

Problem types

CWE-79: Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')

Product status

< 3.2.1
affected

References

github.com/...istune/security/advisories/GHSA-6269-cqxg-mhhv exploit

github.com/...istune/security/advisories/GHSA-6269-cqxg-mhhv

github.com/lepture/mistune/releases/tag/v3.2.1

cve.org (CVE-2026-44898)

nvd.nist.gov (CVE-2026-44898)

Download JSON