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 visitors session cookie. If the application is network-accessible, any remote attacker can trigger this flow to steal the server owners 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.
The product transmits or stores authentication credentials, but it uses an insecure method that is susceptible to unauthorized interception and/or retrieval.
| Name | Vendor | Start Version | End Version |
|---|---|---|---|
| Gradio | Gradio_project | 4.16.0 (including) | 6.6.0 (excluding) |