Skip to content

jupyterhub/oauthenticator

Folders and files

NameName
Last commit message
Last commit date
Dec 1, 2024
Feb 9, 2025
Feb 9, 2024
Feb 9, 2025
Jun 24, 2023
Jan 18, 2023
Feb 3, 2025
Jun 24, 2023
Feb 27, 2025
Aug 26, 2017
May 20, 2022
Oct 5, 2023
Sep 4, 2024
Dec 11, 2024
Feb 12, 2024
Dec 11, 2024

OAuth + JupyterHub Authenticator = OAuthenticator ❤️

Documentation build status GitHub Workflow Status - Test Latest PyPI version Latest conda-forge version GitHub Discourse Gitter

OAuth is a token based login mechanism that doesn't rely on a username and password mapping. In order to use this login mechanism with JupyerHub the login handlers need to be overridden. OAuthenticator overrides these handlers for the common OAuth2 identity providers allowing them to be plugged in and used with JupyterHub.

The following authentication services are supported through their own authenticator: Auth0, Azure AD, Bitbucket, CILogon, FeiShu, GitHub, GitLab, Globus, Google, MediaWiki, OpenShift.

There is also a GenericAuthenticator that can be configured with any OAuth 2.0 identity provider or can be used to create a new authenticator class when additional customization is needed.

Installation

The installation guide can be found in the docs.

The docs also provide example setups for different OAuth2 identity providers.

Running tests

To run the tests locally, first setup a development environment as described in CONTRIBUTING.md, and then do:

pytest -v ./oauthenticator/tests/

Or you run a specific test file with:

pytest -v ./oauthenticator/tests/<test-file-name>