SiYuan — это система управления персональными знаниями. В версиях 3.6.0 и ниже дерево мобильных файлов (MobileFiles.ts) отображает имена записных книжек через внутренний HTML без экранирования HTML при обработке событий Renamenotebook WebSocket. Версия для настольных компьютеров (Files.ts) правильно использует escapeHtml() для той же операции.
Аутентифицированный пользователь, который может переименовывать записные книжки, может внедрить произвольный HTML/JavaScript, который будет выполняться на любом мобильном клиенте, просматривающем дерево файлов. Поскольку Electron настроен с использованием nodeIntegration: true и contextIsolation: false, внедренный JavaScript имеет полный доступ к Node.js, что увеличивает сохраненный XSS до полного удаленного выполнения кода. Мобильный макет также используется в настольном приложении Electron, когда окно узкое, что делает его пригодным для использования и на настольном компьютере.
Эта проблема исправлена в версии 3.6.1.
Показать оригинальное описание (EN)
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.
Характеристики атаки
Последствия
Строка CVSS v4.0
Тип уязвимости (CWE)
Уязвимые продукты 1
| Конфигурация | От (включительно) | До (исключительно) |
|---|---|---|
|
B3log Siyuan
cpe:2.3:a:b3log:siyuan:*:*:*:*:*:*:*:*
|
— |
3.6.1
|