Gradio — это пакет Python с открытым исходным кодом, предназначенный для быстрого прототипирования. Начиная с версии 4.16.0 и до версии 6.6.0, приложения Gradio, работающие за пределами Hugging Face Spaces, автоматически включают «фиктивные» маршруты OAuth при использовании компонентов OAuth (например, `gr.LoginButton`). Когда пользователь посещает `/login/huggingface`, сервер получает свой собственный токен доступа Hugging Face через `huggingface_hub.get_token()` и сохраняет его в файле cookie сеанса посетителя.
Если приложение доступно по сети, любой удаленный злоумышленник может запустить этот поток, чтобы украсть токен HF владельца сервера. Файл cookie сеанса подписывается жестко запрограммированным секретом, полученным из строки `"-v4"`, что делает полезную нагрузку легко декодируемой. Версия 6.6.0 устраняет проблему.
Показать оригинальное описание (EN)
Gradio is an open-source Python package designed for quick prototyping. Starting in version 4.16.0 and prior to version 6.6.0, Gradio applications running outside of Hugging Face Spaces automatically enable "mocked" OAuth routes when OAuth components (e.g. `gr.LoginButton`) are used. When a user visits `/login/huggingface`, the server retrieves its own Hugging Face access token via `huggingface_hub.get_token()` and stores it in the visitor's session cookie. If the application is network-accessible, any remote attacker can trigger this flow to steal the server owner's HF token. The session cookie is signed with a hardcoded secret derived from the string `"-v4"`, making the payload trivially decodable. Version 6.6.0 fixes the issue.
Характеристики атаки
Последствия
Строка CVSS v3.1