django-axes/axes/signals.py
2016-09-06 13:37:25 +02:00

28 lines
876 B
Python

from django.dispatch import receiver
from django.dispatch import Signal
from django.utils.timezone import now
from django.contrib.auth.signals import user_logged_out
from axes.models import AccessLog
from axes.settings import DISABLE_ACCESS_LOG
user_locked_out = Signal(providing_args=['request', 'username', 'ip_address'])
if not DISABLE_ACCESS_LOG:
@receiver(user_logged_out)
def log_user_lockout(sender, request, user, signal, *args, **kwargs):
""" When a user logs out, update the access log
"""
if not user:
return
access_logs = AccessLog.objects.filter(
username=user.get_username(),
logout_time__isnull=True,
).order_by('-attempt_time')[0:1]
if access_logs:
access_log = access_logs[0]
access_log.logout_time = now()
access_log.save()