Skip to main content

Authenticate to JupyterHub using an active Django login session

Project description

JupyterHub django-session-authenticator - A Django Session Authenticator for JupyterHub

Authenticate to JupyterHub using an active Django login session, which was created by a Django-based service running on a server in the same domain as the JupyterHub service.

Prerequisites

The main purpose of this authenticator is to provide single sign-on (SSO) capability into JupyterHub, in cases where users are already authenticating with a web application based on the Django framework. This is a simpler alternative to a more centralized authentication solution, such as Cognito.

To allow this JupyterHub (and this authenticator) to "see" the session cookie generated by Django:

  • Django and JupyterHub must be hosted under the same domain. For example, django.hostname.com and jupyterhub.hostname.com
  • Django's SESSION_COOKIE_DOMAIN must be set to allow cross-domain cookies. For example, hostname.com

Note that only MySQL database-backed sessions are supported at present.

Installation

This package can be installed with pip:

pip install django-authenticator-gdaley

Alternately, you can clone the source repository and run:

cd django-authenticator
pip install -e .

Configuration

You should edit your file jupyterhub_config.py to set the authenticator class. The DjangoSessionLocalAuthenticator provides features such as local user creation. If you already have local users then you may use the DjangoSessionAuthenticator authenticator class, as follows:

For authentication and local user creation

c.JupyterHub.authenticator_class = 'djangoauthenticator.djangoauthenticator.DjangoSessionLocalAuthenticator'

This class is derived from LocalAuthenticator and therefore provides features such as the ability to add local accounts through the admin interface if configured to do so.

For authentication of the Django session only

c.JupyterHub.authenticator_class = 'djangoauthenticator.djangoauthenticator.DjangoSessionAuthenticator'

Required configuration

There are a number of configuration settings, which need to be made. The name of the session cookie used by Django is optional. If you are using the default session cookie name ("sessionid"), there is no need to set it here.

# Django session cookie name
c.DjangoSessionAuthenticator.django_session_cookie_name = '<insert-session-cookie-name-here>'
# Django MySQL database hostname
c.DjangoSessionAuthenticator.mysql_hostname = '<insert-db-hostname-here>'
# Django MySQL username
c.DjangoSessionAuthenticator.mysql_username = '<insert-db-username-here>'
# Django MySQL password
c.DjangoSessionAuthenticator.mysql_password = '<insert-db-password-here>'

Issues

If you have any issues or bug reports, all are welcome in the issues section. We'll do our best to respond quickly.

Contribution

If you want to fix the bugs yourself then raise a PR and we'll take a look :)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-authenticator-gdaley-0.1.5a0.tar.gz (7.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_authenticator_gdaley-0.1.5a0-py3-none-any.whl (8.5 kB view details)

Uploaded Python 3

File details

Details for the file django-authenticator-gdaley-0.1.5a0.tar.gz.

File metadata

  • Download URL: django-authenticator-gdaley-0.1.5a0.tar.gz
  • Upload date:
  • Size: 7.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.5.0 importlib_metadata/3.7.3 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.2

File hashes

Hashes for django-authenticator-gdaley-0.1.5a0.tar.gz
Algorithm Hash digest
SHA256 da5ffdad3752724df2cef9fe21d132a9998e264cf40aa07ed482e6c988e8fc1e
MD5 7704244326c1385f0f7603230cfc0269
BLAKE2b-256 7375d84c826012a1d5b998821ca2d4cf768fcc17f5280459581dfb420bde1874

See more details on using hashes here.

File details

Details for the file django_authenticator_gdaley-0.1.5a0-py3-none-any.whl.

File metadata

  • Download URL: django_authenticator_gdaley-0.1.5a0-py3-none-any.whl
  • Upload date:
  • Size: 8.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.5.0 importlib_metadata/3.7.3 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.2

File hashes

Hashes for django_authenticator_gdaley-0.1.5a0-py3-none-any.whl
Algorithm Hash digest
SHA256 ce6f90c7774ce90175bb7fe91c733d3662a2e3938d0d4335f49aa5dd0862f83d
MD5 71b4cb186f05f2599af2c4929c739f05
BLAKE2b-256 76c1ce1051bda5fcff1ca6d341b777cc8bee44125f8a7316c560da1f6e1eff3d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page