Skip to main content

Django based app for Microsoft authentication of users.

Project description

Django microsoft authentication

It is a very simple app which uses Microsoft authentication for user login and admin panel login. It uses the Microsoft authentication library for Python (msal).

Installation

Standard pip install:

pip install django-microsoft-authentication

Configuration

MICROSOFT = {
    "app_id": "YOUR_APP_ID_HERE",
    "app_secret": "YOUR_APP_SECRET_HERE",
    "redirect": "http://localhost:8000/microsoft_authentication/callback",
    "scopes": ["user.read"],
    "authority": "https://login.microsoftonline.com/common",  # or using tenant "https://login.microsoftonline.com/{tenant}",
    "valid_email_domains": ["<list_of_valid_domains>"],
    "logout_uri": "http://localhost:8000/admin/logout"
}
  • Add the following line to settings.py to change the LOGIN_URL and LOGIN_REDIRECT_URL settings.
LOGIN_URL = "/microsoft_authentication/login"
LOGIN_REDIRECT_URL = "/admin"  # optional and can be changed to any other url


# True: creates new Django User after valid microsoft authentication. 
# False: it will only allow those users which are already created in Django User model and 
# will validate the email using Microsoft.
MICROSOFT_CREATE_NEW_DJANGO_USER = True  # Optional, default value is True
MICROSOFT_NEW_DJANGO_USER_IS_STAFF = True  # Optional, default value is True
  • Add 'microsoft_authentication' to INSTALLED_APPS
  • Add the following to the project/urls.py
from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    path('admin/', admin.site.urls),
    # Add the following line
    path('microsoft_authentication/', include('microsoft_authentication.urls'))
]
  • In templates
    Use "{% url 'microsoft_authentication:microsoft_authentication_login' %}" as login url
    Use "{% url 'microsoft_authentication:microsoft_authentication_logout' %}" as logout url

How it works?

  1. It authenticates the user using their microsoft email and microsoft authentication.
  2. It also verifies if the domain of the microsoft authenticated email is also in MICROSOFT["valid_email_domains"]
  3. After the first two steps of authentication, if the user is not found, it creates a new user but with no access to any apps in admin panel.
  4. Superusers can assign User Groups to the users for Group based access to views.

Quickstart

This app provides a decorator which can be used as follows:

from django.http import HttpResponse
from microsoft_authentication.auth.auth_decorators import microsoft_login_required


@microsoft_login_required()
def home(request):
    return HttpResponse("Logged in")

# If pages need to be restricted to certain groups of users.
@microsoft_login_required(groups=("SpecificGroup1", "SpecificGroup2"))  # Add here the list of Group names
def specific_group_access(request):
    return HttpResponse("You are accessing page which is accessible only to users belonging to SpecificGroup1 or SpecificGroup2")

Troubleshooting during development

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-microsoft-authentication-0.1.6.tar.gz (6.3 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file django-microsoft-authentication-0.1.6.tar.gz.

File metadata

File hashes

Hashes for django-microsoft-authentication-0.1.6.tar.gz
Algorithm Hash digest
SHA256 ed0d941c4fa1afb1312242654ce3b5ebafe3977b0d4f884dcf16bb5ac95c1076
MD5 2bf1172b78f822dc9d465ea1912b2887
BLAKE2b-256 c4dc1da64da7c8263babe36f42183166e77677f4d0c629f5ac892f64bb23be1e

See more details on using hashes here.

File details

Details for the file django_microsoft_authentication-0.1.6-py3-none-any.whl.

File metadata

File hashes

Hashes for django_microsoft_authentication-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 974ecca76ccaef12a380a8d50c3e3121b34a92390dbc31f4f56c83cb15c0fb1d
MD5 374b94f0c82a3cf48923851af95fbebb
BLAKE2b-256 c5d636e678b07720486a645aa98a879cabc81bc1ccc5f6fa45abfcbc07dc082e

See more details on using hashes here.

Supported by

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