CVE-2026-4021

HIGH CVSS 3.1: 8,1 EPSS 0.12%
Обновлено 24 марта 2026
MySQL
Параметр Значение
CVSS 8,1 (HIGH)
Тип уязвимости CWE-287 (Неправильная аутентификация)
Поставщик MySQL
Публичный эксплойт Нет

Плагин Contest Gallery для WordPress уязвим для обхода аутентификации, приводящего к захвату учетной записи администратора во всех версиях до 28.1.5 включительно. Это связано с тем, что обработчик подтверждения электронной почты в `users-registry-check-after-email-or-pin-confirmation.php` использует строку электронной почты пользователя в предложении `WHERE ID = %s` вместо числового идентификатора пользователя в сочетании с неаутентифицированной конечной точкой входа на основе ключа в `ajax-functions-frontend.php`. Если включена нестандартная настройка `RegMailOptional=1`, злоумышленник может зарегистрироваться с помощью созданного электронного письма, начинающегося с целевого идентификатора пользователя (например, `1poc@example.test`), запустить поток подтверждения, чтобы перезаписать `user_activation_key` администратора посредством целочисленного приведения MySQL, а затем использовать действие AJAX `post_cg1l_login_user_by_key` для аутентификации в качестве администратора без каких-либо учетных данных.

Это позволяет неаутентифицированным злоумышленникам захватить любую учетную запись администратора WordPress и получить полный контроль над сайтом.

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

The Contest Gallery plugin for WordPress is vulnerable to an authentication bypass leading to admin account takeover in all versions up to, and including, 28.1.5. This is due to the email confirmation handler in `users-registry-check-after-email-or-pin-confirmation.php` using the user's email string in a `WHERE ID = %s` clause instead of the numeric user ID, combined with an unauthenticated key-based login endpoint in `ajax-functions-frontend.php`. When the non-default `RegMailOptional=1` setting is enabled, an attacker can register with a crafted email starting with the target user ID (e.g., `1poc@example.test`), trigger the confirmation flow to overwrite the admin's `user_activation_key` via MySQL integer coercion, and then use the `post_cg1l_login_user_by_key` AJAX action to authenticate as the admin without any credentials. This makes it possible for unauthenticated attackers to take over any WordPress administrator account and gain full site control.

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

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

Последствия

Конфиденциальность
Высокое
Полная утечка данных
Целостность
Высокое
Полная модификация данных
Доступность
Высокое
Полный отказ в обслуживании

Строка CVSS v3.1