Skip to main content

OpenID Connect client that works with GOV.UK One Login

Project description

govuk-onelogin-django

OpenID Connect client that works with GOV.UK One Login.

Package provides the following endpoints:

  • one-login/login/ to login via GOV.UK One Login.
  • one-login/callback/ endpoint GOV.UK One Login will send logged-in users back to.
  • back-channel-logout/ endpoint GOV.UK One Login will send logout notifications to.

The example project also provides an example logout view that will log the user out of your service as well as GOV.UK One Login.

See class ExampleLogoutView for example that includes post_logout_redirect_uri

Documentation:

Quick start

Before starting, you should create an example app using the GOV.OK One Login admin tool.

  1. Add "govuk_onelogin_django" to your INSTALLED_APPS setting like this:

    INSTALLED_APPS = [
        ...,
        "govuk_onelogin_django",
    ]
    
  2. Include the govuk_onelogin_django URLconf in your project urls.py like this:

    path("one-login/", include("govuk_onelogin_django.urls")),
    
  3. Include OneLoginBackend to your AUTHENTICATION_BACKENDS like this:

    AUTHENTICATION_BACKENDS.append("govuk_onelogin_django.backends.OneLoginBackend")
    
  4. Include the following settings in your settings.py file

    # Required start page that includes a link to log in to GOV.UK One Login
    LOGIN_URL = "your-login-start-page"
    # A view name that the logged-in user will be redirected to after logging in via GOV.UK One Login
    LOGIN_REDIRECT_URL = "view-to-send-logged-in-users-to"
    
    # All other GOV.UK One Login settings required to configure govuk-onelogin-django
    GOV_UK_ONE_LOGIN_CLIENT_ID = "Your client ID"
    GOV_UK_ONE_LOGIN_CLIENT_SECRET = "Your client secret"
    GOV_UK_ONE_LOGIN_OPENID_CONFIG_URL = "Either integration or production config url."
    GOV_UK_ONE_LOGIN_SCOPE = "Required scopes"
    GOV_UK_ONE_LOGIN_AUTHENTICATION_LEVEL = "Required authentication level"
    GOV_UK_ONE_LOGIN_CONFIDENCE_LEVEL = "Required confidence level"
    

    Note: GOV_UK_ONE_LOGIN_CLIENT_SECRET is a base64 encoded string of your private key. e.g. base64 -i private_key.pem

    See this document detailing how to generate your keys.

Configuration

See configuration document detailing how to override the following:

  • Service logout behaviour of back-channel-logout/ endpoint
  • Override how GOV.UK One Login config is fetched
  • how GOV_UK_ONE_LOGIN_CLIENT_ID is loaded
  • How GOV_UK_ONE_LOGIN_CLIENT_SECRET is loaded

Example project

See the example_project README.md for details on how to build and run the example project.

Commands to build and test govuk-onelogin-django

  • Install uv
  • Update the project's environment: uv sync
  • Run tests using local venv: uv run pytest
  • Running the tests against all supported python versions:
    • Install tox and tox-uv: uv tool install tox --with tox-uv
    • Check tox is installed: tox --version
    • run the tests: tox run
  • Install pre-commit hooks: uv run pre-commit install
  • Run pre-commit against all files: uv run pre-commit run --all-files

linting / formatting

  • Run the Ruff linter: uv run ruff check
  • Resolve fixable errors: uv run ruff check --fix
  • Run the Ruff formatter: uv run ruff format
  • mypy: uv run mypy --config-file=pyproject.toml

Publishing

  • View the current project version: uv version
  • Update the project version with dryrun: uv version --bump minor --dry-run
  • Update the project version: uv version --bump minor
  • Publish to PyPI: uv publish --token <token>

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

govuk_onelogin_django-0.4.6.tar.gz (79.4 kB view details)

Uploaded Source

Built Distribution

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

govuk_onelogin_django-0.4.6-py3-none-any.whl (20.3 kB view details)

Uploaded Python 3

File details

Details for the file govuk_onelogin_django-0.4.6.tar.gz.

File metadata

  • Download URL: govuk_onelogin_django-0.4.6.tar.gz
  • Upload date:
  • Size: 79.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.22 {"installer":{"name":"uv","version":"0.9.22","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for govuk_onelogin_django-0.4.6.tar.gz
Algorithm Hash digest
SHA256 0ddba4b7fbea7cd8c8f3d658380b90a6b3a536307c4e14914048e6b0dcbd66c2
MD5 ec09627f45b130036a8c19c714fa355a
BLAKE2b-256 abd3ebf5a31fde9f8537a99a3aeac8b3a85071b5ea436ae24dd78c1f165ee414

See more details on using hashes here.

File details

Details for the file govuk_onelogin_django-0.4.6-py3-none-any.whl.

File metadata

  • Download URL: govuk_onelogin_django-0.4.6-py3-none-any.whl
  • Upload date:
  • Size: 20.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.22 {"installer":{"name":"uv","version":"0.9.22","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for govuk_onelogin_django-0.4.6-py3-none-any.whl
Algorithm Hash digest
SHA256 cf3283d7fc32886855dc69bbd3aee7f5ba3c065d4e929ccc95694ed5045a405f
MD5 07e9380716659f05b54c158477c3adfb
BLAKE2b-256 75943d0fbc7c299b65bb994f0aa69c07fa046b09424494f19bd3ffd9f4d464be

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