# -*- coding: utf-8 -*- # from django.dispatch import receiver from django.db.models.signals import m2m_changed from django_auth_ldap.backend import populate_user from django.conf import settings from django_cas_ng.signals import cas_user_authenticated from jms_oidc_rp.signals import oidc_user_created, oidc_user_updated from jms_oidc_rp.backends import get_userinfo_from_claims from common.utils import get_logger from .utils import construct_user_email from .signals import post_user_create from .models import User logger = get_logger(__file__) @receiver(post_user_create) def on_user_create(sender, user=None, **kwargs): logger.debug("Receive user `{}` create signal".format(user.name)) from .utils import send_user_created_mail logger.info(" - Sending welcome mail ...".format(user.name)) if user.can_send_created_mail(): send_user_created_mail(user) @receiver(m2m_changed, sender=User.groups.through) def on_user_groups_change(sender, instance=None, action='', **kwargs): """ 资产节点发生变化时,刷新节点 """ if action.startswith('post'): logger.debug("User group member change signal recv: {}".format(instance)) from perms.utils import AssetPermissionUtil AssetPermissionUtil.expire_all_user_tree_cache() @receiver(cas_user_authenticated) def on_cas_user_authenticated(sender, user, created, **kwargs): if created: user.source = user.SOURCE_CAS user.save() @receiver(populate_user) def on_ldap_create_user(sender, user, ldap_user, **kwargs): if user and user.username not in ['admin']: exists = User.objects.filter(username=user.username).exists() if not exists: user.source = user.SOURCE_LDAP user.save() @receiver(oidc_user_created) def on_oidc_user_created(sender, request, oidc_user, **kwargs): oidc_user.user.source = User.SOURCE_OPENID oidc_user.user.save() @receiver(oidc_user_updated) def on_oidc_user_updated(sender, request, oidc_user, **kwargs): if not settings.AUTH_OPENID_ALWAYS_UPDATE_USER_INFORMATION: return name, username, email = get_userinfo_from_claims(oidc_user.userinfo) email = construct_user_email(username, email) oidc_user.user.name = name oidc_user.user.username = username oidc_user.user.email = email oidc_user.user.save()