mirror of
https://github.com/jazzband/django-axes.git
synced 2026-03-21 16:40:23 +00:00
34 lines
919 B
Python
34 lines
919 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 django.core.exceptions import ObjectDoesNotExist
|
|
|
|
from axes.models import AccessLog
|
|
|
|
|
|
user_locked_out = Signal(providing_args=['request', 'username', 'ip_address'])
|
|
|
|
|
|
@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
|
|
|
|
try:
|
|
username = user.get_username()
|
|
except AttributeError:
|
|
# Django < 1.5
|
|
username = user.username
|
|
|
|
access_logs = AccessLog.objects.filter(
|
|
username=username,
|
|
logout_time__isnull=True,
|
|
).order_by('-attempt_time')
|
|
|
|
if access_logs:
|
|
access_log = access_logs[0]
|
|
access_log.logout_time = now()
|
|
access_log.save()
|