2016-12-21 16:36:31 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
|
|
|
|
|
|
|
import uuid
|
|
|
|
from django.db import models
|
|
|
|
from django.utils.translation import ugettext_lazy as _
|
|
|
|
from rest_framework.authtoken.models import Token
|
2017-12-08 02:15:27 +00:00
|
|
|
from .user import User
|
2016-12-21 16:36:31 +00:00
|
|
|
|
2017-12-04 12:15:47 +00:00
|
|
|
__all__ = ['AccessKey', 'PrivateToken', 'LoginLog']
|
2016-12-21 16:36:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
class AccessKey(models.Model):
|
|
|
|
id = models.UUIDField(verbose_name='AccessKeyID', primary_key=True,
|
|
|
|
default=uuid.uuid4, editable=False)
|
|
|
|
secret = models.UUIDField(verbose_name='AccessKeySecret',
|
|
|
|
default=uuid.uuid4, editable=False)
|
2018-03-04 05:01:33 +00:00
|
|
|
user = models.ForeignKey(User, verbose_name='User',
|
2018-11-23 02:25:35 +00:00
|
|
|
on_delete=models.CASCADE, related_name='access_keys')
|
2016-12-21 16:36:31 +00:00
|
|
|
|
|
|
|
def get_id(self):
|
|
|
|
return str(self.id)
|
|
|
|
|
|
|
|
def get_secret(self):
|
|
|
|
return str(self.secret)
|
|
|
|
|
2018-11-23 02:25:35 +00:00
|
|
|
def get_full_value(self):
|
|
|
|
return '{}:{}'.format(self.id, self.secret)
|
|
|
|
|
2017-10-31 03:34:20 +00:00
|
|
|
def __str__(self):
|
2016-12-21 16:36:31 +00:00
|
|
|
return str(self.id)
|
|
|
|
|
|
|
|
|
|
|
|
class PrivateToken(Token):
|
|
|
|
"""Inherit from auth token, otherwise migration is boring"""
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
verbose_name = _('Private Token')
|
2017-12-04 12:15:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
class LoginLog(models.Model):
|
|
|
|
LOGIN_TYPE_CHOICE = (
|
|
|
|
('W', 'Web'),
|
2017-12-05 04:24:31 +00:00
|
|
|
('T', 'Terminal'),
|
2017-12-04 12:15:47 +00:00
|
|
|
)
|
2018-07-03 09:47:12 +00:00
|
|
|
|
|
|
|
MFA_DISABLED = 0
|
|
|
|
MFA_ENABLED = 1
|
|
|
|
MFA_UNKNOWN = 2
|
|
|
|
|
|
|
|
MFA_CHOICE = (
|
|
|
|
(MFA_DISABLED, _('Disabled')),
|
|
|
|
(MFA_ENABLED, _('Enabled')),
|
|
|
|
(MFA_UNKNOWN, _('-')),
|
|
|
|
)
|
|
|
|
|
|
|
|
REASON_NOTHING = 0
|
|
|
|
REASON_PASSWORD = 1
|
|
|
|
REASON_MFA = 2
|
2018-11-01 08:28:19 +00:00
|
|
|
REASON_NOT_EXIST = 3
|
2018-11-22 10:02:12 +00:00
|
|
|
REASON_PASSWORD_EXPIRED = 4
|
2018-07-03 09:47:12 +00:00
|
|
|
|
|
|
|
REASON_CHOICE = (
|
|
|
|
(REASON_NOTHING, _('-')),
|
|
|
|
(REASON_PASSWORD, _('Username/password check failed')),
|
|
|
|
(REASON_MFA, _('MFA authentication failed')),
|
2018-11-01 08:28:19 +00:00
|
|
|
(REASON_NOT_EXIST, _("Username does not exist")),
|
2018-11-22 10:02:12 +00:00
|
|
|
(REASON_PASSWORD_EXPIRED, _("Password expired")),
|
2018-07-03 09:47:12 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
STATUS_CHOICE = (
|
|
|
|
(True, _('Success')),
|
|
|
|
(False, _('Failed'))
|
|
|
|
)
|
2017-12-04 12:15:47 +00:00
|
|
|
id = models.UUIDField(default=uuid.uuid4, primary_key=True)
|
2018-11-01 08:28:19 +00:00
|
|
|
username = models.CharField(max_length=128, verbose_name=_('Username'))
|
2017-12-04 12:15:47 +00:00
|
|
|
type = models.CharField(choices=LOGIN_TYPE_CHOICE, max_length=2, verbose_name=_('Login type'))
|
|
|
|
ip = models.GenericIPAddressField(verbose_name=_('Login ip'))
|
|
|
|
city = models.CharField(max_length=254, blank=True, null=True, verbose_name=_('Login city'))
|
|
|
|
user_agent = models.CharField(max_length=254, blank=True, null=True, verbose_name=_('User agent'))
|
2018-07-05 08:45:05 +00:00
|
|
|
mfa = models.SmallIntegerField(default=MFA_UNKNOWN, choices=MFA_CHOICE, verbose_name=_('MFA'))
|
2018-07-03 09:47:12 +00:00
|
|
|
reason = models.SmallIntegerField(default=REASON_NOTHING, choices=REASON_CHOICE, verbose_name=_('Reason'))
|
|
|
|
status = models.BooleanField(max_length=2, default=True, choices=STATUS_CHOICE, verbose_name=_('Status'))
|
2017-12-04 12:15:47 +00:00
|
|
|
datetime = models.DateTimeField(auto_now_add=True, verbose_name=_('Date login'))
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
ordering = ['-datetime', 'username']
|