Home

Description

SiYuan is an open-source personal knowledge management system. In versions 3.6.3 and below, Mermaid diagrams are rendered with securityLevel set to "loose", and the resulting SVG is injected into the DOM via innerHTML. This allows attacker-controlled javascript: URLs in Mermaid code blocks to survive into the rendered output. On desktop builds using Electron, windows are created with nodeIntegration enabled and contextIsolation disabled, escalating the stored XSS to arbitrary code execution when a victim opens a note containing a malicious Mermaid block and clicks the rendered diagram node. This issue has been fixed in version 3.6.4.

PUBLISHED Reserved 2026-04-10 | Published 2026-04-16 | Updated 2026-04-17 | Assigner GitHub_M




CRITICAL: 9.1CVSS:3.1/AV:N/AC:L/PR:L/UI:R/S:C/C:H/I:H/A:H

Problem types

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

CWE-94: Improper Control of Generation of Code ('Code Injection')

Product status

< 3.6.4
affected

References

github.com/...siyuan/security/advisories/GHSA-x63q-3rcj-hhp5 exploit

github.com/...siyuan/security/advisories/GHSA-x63q-3rcj-hhp5

github.com/siyuan-note/siyuan/releases/tag/v3.6.4

cve.org (CVE-2026-40322)

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

Download JSON