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
|