SiYuan is a personal knowledge management system. In versions 3.6.0 and below, the mobile file tree (MobileFiles.ts) renders notebook names via innerHTML without HTML escaping when processing renamenotebook WebSocket events. The desktop version (Files.ts) properly uses escapeHtml() for the same operation. An authenticated user who can rename notebooks can inject arbitrary HTML/JavaScript that executes on any mobile client viewing the file tree. Since Electron is configured with nodeIntegration: true and contextIsolation: false, the injected JavaScript has full Node.js access, escalating stored XSS to full remote code execution. The mobile layout is also used in the Electron desktop app when the window is narrow, making this exploitable on desktop as well. This issue has been fixed in version 3.6.1.
References
| Link | Resource |
|---|---|
| https://github.com/siyuan-note/siyuan/commit/f6d35103f774b65e52f03e018649ff0e57924fb0 | Patch |
| https://github.com/siyuan-note/siyuan/releases/tag/v3.6.1 | Release Notes |
| https://github.com/siyuan-note/siyuan/security/advisories/GHSA-qr46-rcv3-4hq3 | Exploit Mitigation Vendor Advisory |
Configurations
History
No history.
Information
Published : 2026-03-19 22:16
Updated : 2026-03-23 18:16
NVD link : CVE-2026-32751
Mitre link : CVE-2026-32751
CVE.ORG link : CVE-2026-32751
JSON object : View
Products Affected
b3log
- siyuan
CWE
CWE-79
Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')
