2020-09-07 09:42:59 +00:00
|
|
|
|
from importlib import import_module
|
|
|
|
|
|
|
|
|
|
from django.conf import settings
|
|
|
|
|
from django.contrib.auth import user_logged_in
|
|
|
|
|
from django.core.cache import cache
|
2018-11-27 02:21:47 +00:00
|
|
|
|
from django.dispatch import receiver
|
2020-09-14 03:22:45 +00:00
|
|
|
|
from django_cas_ng.signals import cas_user_authenticated
|
2019-02-27 00:45:00 +00:00
|
|
|
|
|
2022-03-08 05:35:40 +00:00
|
|
|
|
from authentication.backends.oidc.signals import (
|
|
|
|
|
openid_user_login_failed, openid_user_login_success
|
|
|
|
|
)
|
2021-12-09 07:47:21 +00:00
|
|
|
|
from authentication.backends.saml2.signals import (
|
|
|
|
|
saml2_user_authenticated, saml2_user_authentication_failed
|
|
|
|
|
)
|
2020-04-26 12:36:17 +00:00
|
|
|
|
from .signals import post_auth_success, post_auth_failed
|
2018-11-09 06:54:38 +00:00
|
|
|
|
|
|
|
|
|
|
2020-09-07 09:42:59 +00:00
|
|
|
|
@receiver(user_logged_in)
|
|
|
|
|
def on_user_auth_login_success(sender, user, request, **kwargs):
|
2022-03-08 05:35:40 +00:00
|
|
|
|
# 失效 perms 缓存
|
|
|
|
|
user.expire_perms_cache()
|
|
|
|
|
|
2021-11-10 03:30:48 +00:00
|
|
|
|
# 开启了 MFA,且没有校验过, 可以全局校验, middleware 中可以全局管理 oidc 等第三方认证的 MFA
|
2022-02-08 09:33:18 +00:00
|
|
|
|
if settings.SECURITY_MFA_AUTH_ENABLED_FOR_THIRD_PARTY \
|
|
|
|
|
and user.mfa_enabled \
|
|
|
|
|
and not request.session.get('auth_mfa'):
|
2021-08-26 07:01:43 +00:00
|
|
|
|
request.session['auth_mfa_required'] = 1
|
|
|
|
|
|
2021-11-10 03:30:48 +00:00
|
|
|
|
# 单点登录,超过了自动退出
|
2020-09-07 09:42:59 +00:00
|
|
|
|
if settings.USER_LOGIN_SINGLE_MACHINE_ENABLED:
|
2022-03-08 05:35:40 +00:00
|
|
|
|
lock_key = 'single_machine_login_' + str(user.id)
|
|
|
|
|
session_key = cache.get(lock_key)
|
2020-09-07 09:42:59 +00:00
|
|
|
|
if session_key and session_key != request.session.session_key:
|
|
|
|
|
session = import_module(settings.SESSION_ENGINE).SessionStore(session_key)
|
|
|
|
|
session.delete()
|
2022-03-08 05:35:40 +00:00
|
|
|
|
cache.set(lock_key, request.session.session_key, None)
|
2020-09-07 09:42:59 +00:00
|
|
|
|
|
|
|
|
|
|
2020-04-28 13:00:22 +00:00
|
|
|
|
@receiver(openid_user_login_success)
|
2021-02-26 09:33:11 +00:00
|
|
|
|
def on_oidc_user_login_success(sender, request, user, create=False, **kwargs):
|
2021-03-15 09:03:43 +00:00
|
|
|
|
request.session['auth_backend'] = settings.AUTH_BACKEND_OIDC_CODE
|
2020-04-26 12:36:17 +00:00
|
|
|
|
post_auth_success.send(sender, user=user, request=request)
|
2018-11-09 06:54:38 +00:00
|
|
|
|
|
|
|
|
|
|
2020-04-28 13:00:22 +00:00
|
|
|
|
@receiver(openid_user_login_failed)
|
2020-04-26 12:36:17 +00:00
|
|
|
|
def on_oidc_user_login_failed(sender, username, request, reason, **kwargs):
|
2021-03-15 09:03:43 +00:00
|
|
|
|
request.session['auth_backend'] = settings.AUTH_BACKEND_OIDC_CODE
|
2020-04-26 12:36:17 +00:00
|
|
|
|
post_auth_failed.send(sender, username=username, request=request, reason=reason)
|
2020-09-14 03:22:45 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@receiver(cas_user_authenticated)
|
|
|
|
|
def on_cas_user_login_success(sender, request, user, **kwargs):
|
2021-03-15 09:03:43 +00:00
|
|
|
|
request.session['auth_backend'] = settings.AUTH_BACKEND_CAS
|
2020-12-15 10:12:27 +00:00
|
|
|
|
post_auth_success.send(sender, user=user, request=request)
|
2021-12-09 07:47:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@receiver(saml2_user_authenticated)
|
|
|
|
|
def on_saml2_user_login_success(sender, request, user, **kwargs):
|
|
|
|
|
request.session['auth_backend'] = settings.AUTH_BACKEND_SAML2
|
|
|
|
|
post_auth_success.send(sender, user=user, request=request)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@receiver(saml2_user_authentication_failed)
|
|
|
|
|
def on_saml2_user_login_failed(sender, request, username, reason, **kwargs):
|
|
|
|
|
request.session['auth_backend'] = settings.AUTH_BACKEND_SAML2
|
|
|
|
|
post_auth_failed.send(sender, username=username, request=request, reason=reason)
|