Vulnerability Details CVE-2022-31027
OAuthenticator is an OAuth token library for the JupyerHub login handler. CILogonOAuthenticator is provided by the OAuthenticator package, and lets users log in to a JupyterHub via CILogon. This is primarily used to restrict a JupyterHub only to users of a given institute. The allowed_idps configuration trait of CILogonOAuthenticator is documented to be a list of domains that indicate the institutions whose users are authorized to access this JupyterHub. This authorization is validated by ensuring that the *email* field provided to us by CILogon has a *domain* that matches one of the domains listed in `allowed_idps`.If `allowed_idps` contains `berkeley.edu`, you might expect only users with valid current credentials provided by University of California, Berkeley to be able to access the JupyterHub. However, CILogonOAuthenticator does *not* verify which provider is used by the user to login, only the email address provided. So a user can login with a GitHub account that has email set to `<something>@berkeley.edu`, and that will be treated exactly the same as someone logging in using the UC Berkeley official Identity Provider. The patch fixing this issue makes a *breaking change* in how `allowed_idps` is interpreted. It's no longer a list of domains, but configuration representing the `EntityID` of the IdPs that are allowed, picked from the [list maintained by CILogon](https://cilogon.org/idplist/). Users are advised to upgrade.
Exploit prediction scoring system (EPSS) score
EPSS Score 0.002
EPSS Ranking 44.0%
CVSS Severity
CVSS v3 Score 4.2
CVSS v2 Score 4.0
Products affected by CVE-2022-31027
-
cpe:2.3:a:jupyter:oauthenticator:-
-
cpe:2.3:a:jupyter:oauthenticator:0.1.0
-
cpe:2.3:a:jupyter:oauthenticator:0.10.0
-
cpe:2.3:a:jupyter:oauthenticator:0.11.0
-
cpe:2.3:a:jupyter:oauthenticator:0.12.0
-
cpe:2.3:a:jupyter:oauthenticator:0.12.1
-
cpe:2.3:a:jupyter:oauthenticator:0.12.2
-
cpe:2.3:a:jupyter:oauthenticator:0.12.3
-
cpe:2.3:a:jupyter:oauthenticator:0.2.0
-
cpe:2.3:a:jupyter:oauthenticator:0.3.0
-
cpe:2.3:a:jupyter:oauthenticator:0.4.0
-
cpe:2.3:a:jupyter:oauthenticator:0.4.1
-
cpe:2.3:a:jupyter:oauthenticator:0.5.0
-
cpe:2.3:a:jupyter:oauthenticator:0.5.1
-
cpe:2.3:a:jupyter:oauthenticator:0.6.0
-
cpe:2.3:a:jupyter:oauthenticator:0.6.1
-
cpe:2.3:a:jupyter:oauthenticator:0.6.2
-
cpe:2.3:a:jupyter:oauthenticator:0.7.0
-
cpe:2.3:a:jupyter:oauthenticator:0.7.1
-
cpe:2.3:a:jupyter:oauthenticator:0.7.2
-
cpe:2.3:a:jupyter:oauthenticator:0.7.3
-
cpe:2.3:a:jupyter:oauthenticator:0.8.0
-
cpe:2.3:a:jupyter:oauthenticator:0.8.1
-
cpe:2.3:a:jupyter:oauthenticator:0.8.2
-
cpe:2.3:a:jupyter:oauthenticator:0.9.0
-
cpe:2.3:a:jupyter:oauthenticator:14.2.0