SiYuan — это система управления персональными знаниями. В версиях 3.6.0 и ниже API globalCopyFiles читает исходные файлы с помощью filepath.Abs() без проверки границ рабочей области, полагаясь исключительно на util.IsSensitivePath(), в черном списке которого отсутствуют /proc/, /run/secrets/ и точечные файлы домашнего каталога. Администратор может скопировать секреты /proc/1/environ или Docker в рабочую область и прочитать их через стандартный файловый API.
Администратор может удалить любой файл, читаемый процессом SiYuan, который находится за пределами неполного черного списка. В контейнерных развертываниях сюда входят все введенные секреты и переменные среды — общий шаблон передачи учетных данных в контейнеры. Затем удаленные файлы становятся доступными через стандартный файловый API рабочей области и сохраняются до тех пор, пока не будут удалены вручную.
Эта проблема исправлена в версии 3.6.1.
Показать оригинальное описание (EN)
SiYuan is a personal knowledge management system. In versions 3.6.0 and below, the globalCopyFiles API eads source files using filepath.Abs() with no workspace boundary check, relying solely on util.IsSensitivePath() whose blocklist omits /proc/, /run/secrets/, and home directory dotfiles. An admin can copy /proc/1/environ or Docker secrets into the workspace and read them via the standard file API. An admin can exfiltrate any file readable by the SiYuan process that falls outside the incomplete blocklist. In containerized deployments this includes all injected secrets and environment variables - a common pattern for passing credentials to containers. The exfiltrated files are then accessible via the standard workspace file API and persist until manually deleted. This issue has been fixed in version 3.6.1.
Характеристики атаки
Последствия
Строка CVSS v3.1
Тип уязвимости (CWE)
Уязвимые продукты 1
| Конфигурация | От (включительно) | До (исключительно) |
|---|---|---|
|
B3log Siyuan
cpe:2.3:a:b3log:siyuan:*:*:*:*:*:*:*:*
|
— |
3.6.1
|