CVE-2026-41159
Published:May 11, 2026
Updated:May 12, 2026
Impact Mermaid's default configuration allows injecting CSS that applies outside of the Mermaid diagram via the "fontFamily", "themeCSS", and "altFontFamily" configuration options. Live demo: "mermaid.live" (https://mermaid.live/edit#pako:eNpNjktLxDAUhf9KvFBR6JS-60QQfODKlUvJ5k6TtsEmKTHFGUP-u-mI6Nmdy3fOPR56wwVQSBIvtXSUeAaD0e4ZlZxPDChhcLxFfwiEauOuLq_9Afv30ZpVczpaITS5kGox1qF2gfSeBwYhJAnThAyz-ewntI68vG5-0z3Z7e7IA9OQwmglB-rsKlJQwircLPgNZeAmocTPAi4GXGfHgOkQYwvqN2PUbzJuGSegA84f0a0LRyeeJI4W_xChubCPcbQD2pwbgHo4Aq2aKmvbqq3zoiu7pizqFE6RybN9VFfFY1HWXRVS-Dr_zLObrt7_V_gGGXZlGg) Example code: %%{init: {"fontFamily": "x;a{b} :not(&){background:green !important} c{d}"}}%% flowchart LR A --> B The injected CSS exploits stylis's "&" (scope reference) handling. ":not(&)" escapes the "#mermaid-xxx" automatic scoping, applying styles to all page elements. Global at-rules ("@font-face", "@keyframes", "@counter-style") are also injectable as stylis hoists them to top level. This allows page defacement and DOM attribute exfiltration via CSS ":has()" selectors. Patches - "v11.15.0" (https://github.com/mermaid-js/mermaid/releases/tag/mermaid%4011.15.0) (see "64769738d5b59211e1decb471ffbaca8afec51aa" (https://github.com/mermaid-js/mermaid/commit/64769738d5b59211e1decb471ffbaca8afec51aa)) - "v10.9.6" (https://github.com/mermaid-js/mermaid/releases/tag/v10.9.6) (see "a9d9f0d8eb790349121508688cd338253fd80d76" (https://github.com/mermaid-js/mermaid/commit/a9d9f0d8eb790349121508688cd338253fd80d76)) Workarounds If you can't upgrade mermaid, you can set the ""secure"" (https://mermaid.js.org/config/schema-docs/config.html#secure) config value in the mermaid config to avoid allowing diagrams to modify "fontFamily", "themeCSS", "altFontFamily", and "themeVariables". Setting """securityLevel": "sandbox""" (https://mermaid.js.org/config/schema-docs/config.html#securitylevel) will also prevent this. Credits Reported by @zsxsoft on behalf of @KeenSecurityLab
Affected Packages
mermaid (CDN_JS):
Affected version(s) >=0.1.0 <10.9.6Fix Suggestion:
Update to version 10.9.6mermaid (CDN_JS):
Affected version(s) >=11.0.0-alpha.1 <11.15.0Fix Suggestion:
Update to version 11.15.0https://github.com/mermaid-js/mermaid.git (GITHUB):
Affected version(s) >=v10.9.0 <v10.9.6Fix Suggestion:
Update to version v10.9.6https://github.com/mermaid-js/mermaid.git (GITHUB):
Affected version(s) >=mermaid@11.0.1 <mermaid@11.15.0Fix Suggestion:
Update to version mermaid@11.15.0mermaid (NPM):
Affected version(s) >=0.2.11 <10.9.6Fix Suggestion:
Update to version 10.9.6mermaid (NPM):
Affected version(s) >=11.0.0-alpha.1 <11.15.0Fix Suggestion:
Update to version 11.15.0Related Resources (6)
Do you need more information?
Contact UsCVSS v4
Base Score:
5.3
Attack Vector
NETWORK
Attack Complexity
LOW
Attack Requirements
NONE
Privileges Required
NONE
User Interaction
PASSIVE
Vulnerable System Confidentiality
NONE
Vulnerable System Integrity
LOW
Vulnerable System Availability
NONE
Subsequent System Confidentiality
LOW
Subsequent System Integrity
LOW
Subsequent System Availability
LOW
CVSS v3
Base Score:
4.7
Attack Vector
NETWORK
Attack Complexity
LOW
Privileges Required
NONE
User Interaction
REQUIRED
Scope
CHANGED
Confidentiality
NONE
Integrity
LOW
Availability
NONE
Weakness Type (CWE)
Improper Control of Generation of Code ('Code Injection')