Vikunja — это автономная платформа управления задачами с открытым исходным кодом. До версии 2.3.0 проверка CanUpdate по адресу pkg/models/project_permissions.go:139-148 требует CanWrite только в новом родительском проекте при изменении родительского_проекта_id. Однако модель разрешений Vikunja использует рекурсивный CTE, который проходит вверх по иерархии проекта для вычисления разрешений.
Перемещение проекта под другой родительский элемент меняет цепочку наследования разрешений. Когда пользователь унаследовал доступ на запись (из общей папки родительского проекта) и повторно создает дочерний проект в своем собственном дереве проектов, CTE разрешает ему владение новым родительским проектом в качестве администратора (уровень разрешений 2) в перемещенном проекте. Эта уязвимость исправлена в версии 2.3.0.
Показать оригинальное описание (EN)
Vikunja is an open-source self-hosted task management platform. Prior to 2.3.0, the CanUpdate check at pkg/models/project_permissions.go:139-148 only requires CanWrite on the new parent project when changing parent_project_id. However, Vikunja's permission model uses a recursive CTE that walks up the project hierarchy to compute permissions. Moving a project under a different parent changes the permission inheritance chain. When a user has inherited Write access (from a parent project share) and reparents the child project under their own project tree, the CTE resolves their ownership of the new parent as Admin (permission level 2) on the moved project. This vulnerability is fixed in 2.3.0.
Характеристики атаки
Последствия
Строка CVSS v3.1
Тип уязвимости (CWE)
Уязвимые продукты 1
| Конфигурация | От (включительно) | До (исключительно) |
|---|---|---|
|
Vikunja Vikunja
cpe:2.3:a:vikunja:vikunja:*:*:*:*:*:*:*:*
|
— |
2.3.0
|