Skip to main content

A django-allauth dotnetid provider

Project description

django-dotnetid

django-dotnetid is a Django app extending django-allauth. It implements an OpenID connect provider able to map extra_info from the id_token into Django User model. It is also capable of attributing groups automatically.

You need to install django-allauth to be able to use this extension.

A full working example can be found here: https://github.com/sitn/django-dotnetid-example

Quick start

  1. Install requiremed packages in your project:
python -m pip install django-dotnetid
  1. Add django_dotnetid to your INSTALLED_APPS setting like this:
    INSTALLED_APPS = [
        ...,
        "django_dotnetid",
        "allauth",
        "allauth.account",
        "allauth.socialaccount",
        "allauth.socialaccount.providers.openid_connect",
    ]
  1. Include the dotnetidprovider URL conf in your project urls.py like this:
from django.urls import include, path
...
    path('accounts/', include('allauth.urls')),
  1. Run python manage.py migrate to create the models.

  2. In your settings.py, you can add the provider like that:

    AUTHENTICATION_BACKENDS = [
        "django.contrib.auth.backends.ModelBackend",
        "allauth.account.auth_backends.AuthenticationBackend",
    ]

    SOCIALACCOUNT_PROVIDERS = {
        "dotnetidprovider": {
            "APP": {
                "provider_id": "dotnetid",
                "name": "Etat de Neuchâtel",
                "client_id": os.environ['DOTNETID_CLIENT_ID'],
                "secret": os.environ['DOTNETID_CLIENT_SECRET'],
                "settings": {
                    "server_url": os.environ['DOTNETID_SERVER_URL'],
                },
            },
            "SCOPE": [
                "profile",
                "openid",
                "glados",
            ],
            "EXTRA_ATTRIBUTES_PREFIX": "djangoopenid",
            "EXTRA_ATTRIBUTES_NAMES": [
                "groups",
                "admin",
            ],
            "OAUTH_PKCE_ENABLED": True,
            "ID_TOKEN_ISSUER": os.environ['DOTNETID_SERVER_URL'],
        }
    }
    SOCIALACCOUNT_EMAIL_VERIFICATION = None
    SOCIALACCOUNT_ADAPTER  = 'django_dotnetid.adapter.DotnetIdAccountAdapter'
    LOGIN_REDIRECT_URL = 'index'
    ACCOUNT_LOGOUT_REDIRECT = 'index'
    SITE_ID = 1

Add allauth.account.middleware.AccountMiddleware at the end of your middlewares:

MIDDLEWARE = [
...
    "allauth.account.middleware.AccountMiddleware",
]
  1. Start the development server.

  2. Visit the /.

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_dotnetid-1.0.1.tar.gz (5.8 kB view details)

Uploaded Source

Built Distribution

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

django_dotnetid-1.0.1-py3-none-any.whl (6.8 kB view details)

Uploaded Python 3

File details

Details for the file django_dotnetid-1.0.1.tar.gz.

File metadata

  • Download URL: django_dotnetid-1.0.1.tar.gz
  • Upload date:
  • Size: 5.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for django_dotnetid-1.0.1.tar.gz
Algorithm Hash digest
SHA256 9b96b805516f5578e4a20f6d803510607b81285e8ea15bdadfe8a7cc875557b4
MD5 4556d0efa030b754c7b8321d0bd96c6c
BLAKE2b-256 2aaffc9cb35ca7d7833206b820e76fdee718eca12aa0fd5190ecf55219daf109

See more details on using hashes here.

File details

Details for the file django_dotnetid-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for django_dotnetid-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a630e67c84eb89da38b315e7b0504eebf4ee3cf0d5d53b5d4eee39379b127c6e
MD5 8de45491f8ca8ad6e2c9a52b30099fd0
BLAKE2b-256 60b00cb1242b906964947b2187d9923acca93bec5675d1dd9ffe495a9b6906bf

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