Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jupyterhub/oauthenticator
OAuth + JupyterHub Authenticator = OAuthenticator
https://github.com/jupyterhub/oauthenticator
authenticator github-oauth globus jupyter jupyterhub oauth-client
Last synced: 5 minutes ago
JSON representation
OAuth + JupyterHub Authenticator = OAuthenticator
- Host: GitHub
- URL: https://github.com/jupyterhub/oauthenticator
- Owner: jupyterhub
- License: bsd-3-clause
- Created: 2014-09-23T21:37:06.000Z (over 10 years ago)
- Default Branch: main
- Last Pushed: 2024-10-17T08:45:05.000Z (3 months ago)
- Last Synced: 2024-10-29T14:52:49.502Z (3 months ago)
- Topics: authenticator, github-oauth, globus, jupyter, jupyterhub, oauth-client
- Language: Python
- Homepage: https://oauthenticator.readthedocs.io
- Size: 1.74 MB
- Stars: 413
- Watchers: 20
- Forks: 365
- Open Issues: 54
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-jupyter-resources - GitHub - 13% open · ⏱️ 23.08.2022): (JupyterHub认证)
- best-of-jupyter - GitHub - 16% open · ⏱️ 08.01.2025): (JupyterHub Authenticators)
README
# OAuth + JupyterHub Authenticator = OAuthenticator :heart:
[![Documentation build status](https://img.shields.io/readthedocs/oauthenticator?logo=read-the-docs)](https://oauthenticator.readthedocs.org/en/latest)
[![GitHub Workflow Status - Test](https://img.shields.io/github/actions/workflow/status/jupyterhub/oauthenticator/test.yml?logo=github&label=tests)](https://github.com/jupyterhub/oauthenticator/actions)
[![Latest PyPI version](https://img.shields.io/pypi/v/oauthenticator?logo=pypi)](https://pypi.python.org/pypi/oauthenticator)
[![Latest conda-forge version](https://img.shields.io/conda/vn/conda-forge/oauthenticator?logo=conda-forge)](https://anaconda.org/conda-forge/oauthenticator)
[![GitHub](https://img.shields.io/badge/issue_tracking-github-blue?logo=github)](https://github.com/jupyterhub/oauthenticator/issues)
[![Discourse](https://img.shields.io/badge/help_forum-discourse-blue?logo=discourse)](https://discourse.jupyter.org/c/jupyterhub)
[![Gitter](https://img.shields.io/badge/social_chat-gitter-blue?logo=gitter)](https://gitter.im/jupyterhub/jupyterhub)[OAuth](https://en.wikipedia.org/wiki/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](oauthenticator/auth0.py),
[Azure AD](oauthenticator/azuread.py), [Bitbucket](oauthenticator/bitbucket.py), [CILogon](oauthenticator/cilogon.py), [FeiShu](https://github.com/tezignlab/jupyterhub_feishu_authenticator),
[GitHub](oauthenticator/github.py), [GitLab](oauthenticator/gitlab.py), [Globus](oauthenticator/globus.py),
[Google](oauthenticator/google.py), [MediaWiki](oauthenticator/mediawiki.py),
[OpenShift](oauthenticator/openshift.py).There is also a [GenericAuthenticator](oauthenticator/generic.py)
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](https://oauthenticator.readthedocs.io/en/latest/tutorials/install.html).
The [docs](https://oauthenticator.readthedocs.io/en/latest/tutorials/provider-specific-setup/index.html) 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/
```[contributing.md]: https://github.com/jupyterhub/oauthenticator/blob/main/CONTRIBUTING.md