CVE-2026-35597

HIGH CVSS 3.1: 7,5 EPSS 0.04%
Обновлено 17 апреля 2026
Vikunja
Параметр Значение
CVSS 7,5 (HIGH)
Уязвимые версии до 2.3.0
Устранено в версии 2.3.0
Тип уязвимости CWE-307
Поставщик Vikunja
Публичный эксплойт Нет

Vikunja — это автономная платформа управления задачами с открытым исходным кодом. До версии 2.3.0 механизм блокировки при неудачной попытке TOTP не работал из-за ошибки обработки транзакций базы данных. При сбое проверки TOTP обработчик входа в pkg/routes/api/v1/login.go вызывает HandleFailedTOTPAuth, а затем безоговорочно выполняет откат. HandleFailedTOTPAuth в pkg/user/totp.go использует счетчик в памяти (хранилище значений ключей) для отслеживания неудачных попыток.

Когда счетчик достигает 10, он вызывает user.SetStatus(s, StatusAccountLocked) в том же сеансе базы данных. Поскольку обработчик входа всегда выполняет откат после сбоя TOTP, запись StatusAccountLocked отменяется. Счетчик в памяти правильно увеличивается до 10, поэтому код блокировки выполняется при каждой последующей попытке, но запись в базу данных каждый раз откатывается.

Это позволяет неограниченное количество попыток перебора кодов TOTP. Эта уязвимость исправлена ​​в версии 2.3.0.

Показать оригинальное описание (EN)

Vikunja is an open-source self-hosted task management platform. Prior to 2.3.0, the TOTP failed-attempt lockout mechanism is non-functional due to a database transaction handling bug. When a TOTP validation fails, the login handler in pkg/routes/api/v1/login.go calls HandleFailedTOTPAuth and then unconditionally rolls back. HandleFailedTOTPAuth in pkg/user/totp.go uses an in-memory counter (key-value store) to track failed attempts. When the counter reaches 10, it calls user.SetStatus(s, StatusAccountLocked) on the same database session s. Because the login handler always rolls back after a TOTP failure, the StatusAccountLocked write is undone. The in-memory counter correctly increments past 10, so the lockout code executes on every subsequent attempt, but the database write is rolled back every time. This allows unlimited brute-force attempts against TOTP codes. This vulnerability is fixed in 2.3.0.

Характеристики атаки

Способ атаки
По сети
Атака возможна удалённо
Сложность
Низкая
Легко эксплуатировать
Нужны права
Не требуются
Права не нужны
Участие пользователя
Не требуется
Не нужно действие пользователя

Последствия

Конфиденциальность
Высокое
Полная утечка данных
Целостность
Нет
Нет модификации данных
Доступность
Нет
Нет нарушения работы

Строка CVSS v3.1

Тип уязвимости (CWE)

Уязвимые продукты 1

Конфигурация От (включительно) До (исключительно)
Vikunja Vikunja
cpe:2.3:a:vikunja:vikunja:*:*:*:*:*:*:*:*
2.3.0