GHSA-m68r-v472-jgq9MediumCVSS 5.4
JupyterHub has cross-origin form POSTs bypass XSRF (CWE-352)
🔗 CVE IDs covered (1)
📋 Description
Summary
JupyterHub's XSRF protection (updated in 4.1.0) inappropriately treated requests with Sec-Fetch-Mode: no-cors as same-origin requests, which they are not, bypassing XSRF checks. The JSON API is not affected, only HTTP form endpoints, such as /hub/spawn and /hub/accept-share, meaning attackers could trigger server spawn (but not access the server) and if the attacker is a JupyterHub user permitted to share access to their server, cause a user to accept a share and have access to the attacker's server.
Patches
Upgrade to JupyterHub 5.4.5.
Mitigations
If a reverse proxy is in use, drop requests to JupyterHub with Sec-Fetch-Mode: no-cors.
🎯 Affected products1
- pip/jupyterhub:>= 4.1.0, < 5.4.5