authentik/passbook/core/signals.py

42 lines
1.7 KiB
Python
Raw Normal View History

"""passbook core signals"""
2019-03-21 10:29:11 +00:00
from django.core.cache import cache
from django.core.signals import Signal
2019-03-21 10:29:11 +00:00
from django.db.models.signals import post_save
from django.dispatch import receiver
2019-10-01 09:24:10 +01:00
from structlog import get_logger
from passbook.core.exceptions import PasswordPolicyInvalid
LOGGER = get_logger()
2019-03-21 10:29:11 +00:00
user_signed_up = Signal(providing_args=['request', 'user'])
2018-12-10 13:21:42 +00:00
invitation_created = Signal(providing_args=['request', 'invitation'])
invitation_used = Signal(providing_args=['request', 'invitation', 'user'])
password_changed = Signal(providing_args=['user', 'password'])
@receiver(password_changed)
# pylint: disable=unused-argument
def password_policy_checker(sender, password, **kwargs):
"""Run password through all password policies which are applied to the user"""
from passbook.core.models import PasswordFactor
from passbook.policy.engine import PolicyEngine
setattr(sender, '__password__', password)
_all_factors = PasswordFactor.objects.filter(enabled=True).order_by('order')
for factor in _all_factors:
2019-02-27 14:49:20 +00:00
policy_engine = PolicyEngine(factor.password_policies.all().select_subclasses())
policy_engine.for_user(sender).build()
2019-02-27 14:49:20 +00:00
passing, messages = policy_engine.result
if not passing:
raise PasswordPolicyInvalid(*messages)
2019-03-21 10:29:11 +00:00
@receiver(post_save)
# pylint: disable=unused-argument
def invalidate_policy_cache(sender, instance, **kwargs):
"""Invalidate Policy cache when policy is updated"""
from passbook.core.models import Policy
if isinstance(instance, Policy):
LOGGER.debug("Invalidating cache for %s", instance.pk)
keys = cache.keys("%s#*" % instance.pk)
cache.delete_many(keys)
LOGGER.debug("Deleted %d keys", len(keys))