Add messages on auth success & failure
Refactor auth code to use class based views
This commit is contained in:
parent
1850746975
commit
02aaa79047
3 changed files with 87 additions and 54 deletions
|
@ -40,7 +40,7 @@ MIDDLEWARE = [
|
|||
"django.contrib.auth.middleware.AuthenticationMiddleware",
|
||||
"django.contrib.messages.middleware.MessageMiddleware",
|
||||
"django.middleware.clickjacking.XFrameOptionsMiddleware",
|
||||
'django_cas_ng.middleware.CASMiddleware'
|
||||
"django_cas_ng.middleware.CASMiddleware",
|
||||
]
|
||||
|
||||
ROOT_URLCONF = "gestiojeux.urls"
|
||||
|
@ -64,8 +64,8 @@ TEMPLATES = [
|
|||
WSGI_APPLICATION = "gestiojeux.wsgi.application"
|
||||
|
||||
AUTHENTICATION_BACKENDS = (
|
||||
'django.contrib.auth.backends.ModelBackend',
|
||||
'django_cas_ng.backends.CASBackend',
|
||||
"django.contrib.auth.backends.ModelBackend",
|
||||
"django_cas_ng.backends.CASBackend",
|
||||
)
|
||||
|
||||
# Password validation
|
||||
|
@ -90,8 +90,10 @@ STATIC_URL = "/static/"
|
|||
MEDIA_URL = "/media/"
|
||||
|
||||
CAS_SERVER_URL = "https://cas.eleves.ens.fr/"
|
||||
CAS_VERSION = "2"
|
||||
CAS_LOGIN_MSG = None
|
||||
CAS_VERIFY_URL = "https://cas.eleves.ens.fr/"
|
||||
CAS_VERSION = "CAS_2_SAML_1_0"
|
||||
CAS_IGNORE_REFERER = True
|
||||
CAS_EMAIL_FORMAT = "%s@clipper.ens.fr"
|
||||
|
||||
CAS_FORCE_CHANGE_USERNAME_CASE = "lower"
|
||||
CAS_LOGIN_MSG = None
|
||||
CAS_LOGIN_URL_NAME = "gestiojeux_auth:cas_ng_login"
|
||||
CAS_LOGOUT_URL_NAME = "gestiojeux_auth:cas_ng_logout"
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
from django.urls import include, path
|
||||
import django.contrib.auth.views as dj_auth_views
|
||||
from .views import login, logout
|
||||
from .views import LoginView, LogoutView
|
||||
import django_cas_ng.views
|
||||
|
||||
app_name = "gestiojeux_auth"
|
||||
|
@ -17,8 +17,8 @@ cas_patterns = [
|
|||
|
||||
accounts_patterns = [
|
||||
path("cas/", include(cas_patterns)),
|
||||
path("login/", login, name="login"),
|
||||
path("logout/", logout, name="logout"),
|
||||
path("login/", LoginView.as_view(), name="login"),
|
||||
path("logout/", LogoutView.as_view(), name="logout"),
|
||||
path("password_login/", dj_auth_views.LoginView.as_view(), name="password_login"),
|
||||
]
|
||||
|
||||
|
|
|
@ -1,52 +1,83 @@
|
|||
from django.shortcuts import render, redirect
|
||||
from django.views.generic import TemplateView, RedirectView
|
||||
from django.shortcuts import redirect
|
||||
from django.urls import reverse
|
||||
from django.dispatch import receiver
|
||||
from django.contrib.auth import logout as auth_logout
|
||||
from django.contrib.auth.decorators import login_required
|
||||
from django.contrib.auth import user_logged_in, user_logged_out, user_login_failed
|
||||
from django.contrib import messages
|
||||
|
||||
from urllib.parse import quote as urlquote
|
||||
|
||||
|
||||
def login(req):
|
||||
if req.user.is_authenticated:
|
||||
return redirect("mainsite:home")
|
||||
class LoginView(TemplateView):
|
||||
template_name = "registration/login_switch.html"
|
||||
|
||||
if req.method == "GET":
|
||||
reqDict = req.GET
|
||||
elif req.method == "POST":
|
||||
reqDict = req.POST
|
||||
if "next" in reqDict:
|
||||
nextUrl = reqDict["next"]
|
||||
context = {
|
||||
"pass_url": "{}?next={}".format(
|
||||
reverse("gestiojeux_auth:password_login"), urlquote(nextUrl, safe="")
|
||||
def dispatch(self, request, *args, **kwargs):
|
||||
if request.user.is_authenticated:
|
||||
messages.warning(
|
||||
request,
|
||||
"Vous êtes déjà connecté·e en tant que {}.".format(
|
||||
request.user.username
|
||||
),
|
||||
"cas_url": "{}?next={}".format(
|
||||
reverse("gestiojeux_auth:cas_ng_login"), urlquote(nextUrl, safe="")
|
||||
),
|
||||
}
|
||||
)
|
||||
return redirect(self.get_next_url() or "/")
|
||||
|
||||
return super().dispatch(request, *args, **kwargs)
|
||||
|
||||
def get_next_url(self):
|
||||
if self.request.method == "GET":
|
||||
req_dict = self.request.GET
|
||||
elif self.request.method == "POST":
|
||||
req_dict = self.request.POST
|
||||
return req_dict.get("next")
|
||||
|
||||
def get_context_data(self, **kwargs):
|
||||
context = super().get_context_data(**kwargs)
|
||||
|
||||
next_url = self.get_next_url()
|
||||
if next_url:
|
||||
context["pass_url"] = "{}?next={}".format(
|
||||
reverse("gestiojeux_auth:password_login"), urlquote(next_url, safe="")
|
||||
)
|
||||
context["cas_url"] = "{}?next={}".format(
|
||||
reverse("gestiojeux_auth:cas_ng_login"), urlquote(next_url, safe="")
|
||||
)
|
||||
else:
|
||||
context = {
|
||||
"pass_url": reverse("gestiojeux_auth:password_login"),
|
||||
"cas_url": reverse("gestiojeux_auth:cas_ng_login"),
|
||||
}
|
||||
context["pass_url"] = reverse("gestiojeux_auth:password_login")
|
||||
context["cas_url"] = reverse("gestiojeux_auth:cas_ng_login")
|
||||
|
||||
return render(req, "registration/login_switch.html", context=context)
|
||||
return context
|
||||
|
||||
|
||||
@login_required
|
||||
def logout(req):
|
||||
class LogoutView(RedirectView):
|
||||
permanent = False
|
||||
|
||||
def get_redirect_url(self, *args, **kwargs):
|
||||
CAS_BACKEND_NAME = "django_cas_ng.backends.CASBackend"
|
||||
if req.session["_auth_user_backend"] != CAS_BACKEND_NAME:
|
||||
auth_logout(req)
|
||||
if "next" in req.GET:
|
||||
return redirect(req.GET["next"])
|
||||
return redirect("mainsite:home")
|
||||
if self.request.session["_auth_user_backend"] != CAS_BACKEND_NAME:
|
||||
auth_logout(self.request)
|
||||
if "next" in self.request.GET:
|
||||
return self.request.GET["next"]
|
||||
return reverse("mainsite:home")
|
||||
|
||||
if "next" in req.GET:
|
||||
return redirect(
|
||||
"{}?next={}".format(
|
||||
if "next" in self.request.GET:
|
||||
return "{}?next={}".format(
|
||||
reverse("gestiojeux_auth:cas_ng_logout"),
|
||||
urlquote(req.GET["next"], safe=""),
|
||||
urlquote(self.request.GET["next"], safe=""),
|
||||
)
|
||||
)
|
||||
return redirect("gestiojeux_auth:cas_ng_logout")
|
||||
return reverse("gestiojeux_auth:cas_ng_logout")
|
||||
|
||||
|
||||
@receiver(user_logged_in)
|
||||
def on_login(request, user, **kwargs):
|
||||
messages.success(request, "Connexion réussie. Bienvenue, {}.".format(user))
|
||||
|
||||
|
||||
@receiver(user_logged_out)
|
||||
def on_logout(request, **kwargs):
|
||||
messages.info(request, "Vous avez bien été déconnecté·e.")
|
||||
|
||||
|
||||
@receiver(user_login_failed)
|
||||
def on_login_failed(request, **kwargs):
|
||||
messages.error(request, "Connexion échouée.")
|
||||
|
|
Loading…
Reference in a new issue