CVE-2026-40864 PUBLISHED

JupyterHub: Cross-origin form POSTs bypass XSRF

Assigner: GitHub_M
Reserved: 15.04.2026 Published: 22.05.2026 Updated: 22.05.2026

JupyterHub is software that allows users to create a multi-user server for Jupyter notebooks. In versions 4.1.0 through 5.4.4, XSRF protection (updated in 4.1.0) inappropriately treated requests with Sec-Fetch-Mode: no-cors as same-origin requests, 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. This issue has been fixed in version 5.4.5. If developers are unable to immediately upgrade, they can temporarily mitigate this issue by dropping requests to JupyterHub with Sec-Fetch-Mode: no-cors if they are using a reverse proxy.

Metrics

CVSS Vector: CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:U/C:N/I:L/A:L
CVSS Score: 5.4

Product Status

Vendor jupyterhub
Product jupyterhub
Versions
  • Version >= 4.1.0, < 5.4.5 is affected

References

Problem Types

  • CWE-352: Cross-Site Request Forgery (CSRF) CWE