Плагин 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