Vikunja — это автономная платформа управления задачами с открытым исходным кодом. До версии 2.0.0 приложение позволяло пользователям загружать файлы SVG в виде вложений к задачам. SVG — это формат на основе XML, который поддерживает выполнение JavaScript через такие элементы, как теги <script> или обработчики событий, такие как onload.
Приложение не очищает содержимое SVG перед его сохранением. Когда доступ к загруженному файлу SVG осуществляется через прямой URL-адрес, он отображается в браузере в исходном коде приложения. В результате встроенный JavaScript выполняется в контексте аутентифицированного пользователя.
Поскольку токен аутентификации хранится в localStorage, он доступен через JavaScript и может быть получен вредоносной полезной нагрузкой. Версия 2.0.0 исправляет эту проблему.
Показать оригинальное описание (EN)
Vikunja is an open-source self-hosted task management platform. Prior to version 2.0.0, the application allows users to upload SVG files as task attachments. SVG is an XML-based format that supports JavaScript execution through elements such as <script> tags or event handlers like onload. The application does not sanitize SVG content before storing it. When the uploaded SVG file is accessed via its direct URL, it is rendered inline in the browser under the application's origin. As a result, embedded JavaScript executes in the context of the authenticated user. Because the authentication token is stored in localStorage, it is accessible via JavaScript and can be retrieved by a malicious payload. Version 2.0.0 patches this issue.
Характеристики атаки
Последствия
Строка CVSS v3.1