django-axes/axes/models.py
Aleksi Häkli e24f0453bb
Remove reduntant AccessLog.trusted flag
All attempts that are logged are marked as trusted
and no other attempts are created in the code,
so having a flag that also uses a database index
is redundant and unnecessary.

Signed-off-by: Aleksi Häkli <aleksi.hakli@iki.fi>
2019-03-13 16:07:25 +02:00

79 lines
1.6 KiB
Python

from django.db import models
from django.utils.translation import gettext_lazy as _
class AccessBase(models.Model):
user_agent = models.CharField(
_('User Agent'),
max_length=255,
db_index=True,
)
ip_address = models.GenericIPAddressField(
_('IP Address'),
null=True,
db_index=True,
)
username = models.CharField(
_('Username'),
max_length=255,
null=True,
db_index=True,
)
http_accept = models.CharField(
_('HTTP Accept'),
max_length=1025,
)
path_info = models.CharField(
_('Path'),
max_length=255,
)
attempt_time = models.DateTimeField(
_('Attempt Time'),
auto_now_add=True,
)
class Meta:
app_label = 'axes'
abstract = True
ordering = ['-attempt_time']
class AccessAttempt(AccessBase):
get_data = models.TextField(
_('GET Data'),
)
post_data = models.TextField(
_('POST Data'),
)
failures_since_start = models.PositiveIntegerField(
_('Failed Logins'),
)
def __str__(self):
return f'Attempted Access: {self.attempt_time}'
class Meta:
verbose_name = _('access attempt')
verbose_name_plural = _('access attempts')
class AccessLog(AccessBase):
logout_time = models.DateTimeField(
_('Logout Time'),
null=True,
blank=True,
)
def __str__(self):
return f'Access Log for {self.username} @ {self.attempt_time}'
class Meta:
verbose_name = _('access log')
verbose_name_plural = _('access logs')