2022-08-08 15:17:48 +00:00
|
|
|
from django.contrib.auth.models import AbstractBaseUser, PermissionsMixin
|
|
|
|
from django.db import models
|
|
|
|
from django.utils import timezone
|
2022-08-09 06:27:55 +00:00
|
|
|
from django.contrib.auth.hashers import check_password
|
|
|
|
|
|
|
|
import uuid
|
2022-08-08 15:17:48 +00:00
|
|
|
|
|
|
|
from ..managers import UserManager
|
|
|
|
|
|
|
|
|
|
|
|
class User(AbstractBaseUser, PermissionsMixin):
|
|
|
|
email = models.EmailField('email address', unique=True)
|
|
|
|
is_staff = models.BooleanField(default=False)
|
|
|
|
is_active = models.BooleanField(default=True)
|
2022-08-09 06:27:55 +00:00
|
|
|
date_joined = models.DateTimeField(auto_now_add=True)
|
2022-08-08 15:17:48 +00:00
|
|
|
|
|
|
|
USERNAME_FIELD = 'email'
|
|
|
|
REQUIRED_FIELDS = []
|
|
|
|
|
|
|
|
objects = UserManager()
|
|
|
|
|
|
|
|
def __str__(self):
|
2022-08-09 06:27:55 +00:00
|
|
|
return self.email
|
|
|
|
|
|
|
|
|
|
|
|
class APIUser(models.Model):
|
2022-09-26 11:48:15 +00:00
|
|
|
username = models.CharField(max_length=256, unique=True)
|
2022-08-09 06:27:55 +00:00
|
|
|
password = models.CharField(max_length=256)
|
|
|
|
|
|
|
|
def check_password(self, password):
|
|
|
|
return check_password(password, self.password)
|
|
|
|
|
2022-09-26 11:48:15 +00:00
|
|
|
def __str__(self):
|
|
|
|
return self.username
|
|
|
|
|
2022-08-09 06:27:55 +00:00
|
|
|
|
|
|
|
class APIToken(models.Model):
|
2022-09-26 11:48:15 +00:00
|
|
|
value = models.UUIDField(default=uuid.uuid4, unique=True)
|
2022-08-09 06:27:55 +00:00
|
|
|
user = models.ForeignKey(APIUser, models.CASCADE)
|
|
|
|
expiry = models.DateTimeField()
|
|
|
|
created_at = models.DateTimeField(auto_now_add=True)
|
|
|
|
|
|
|
|
def is_valid(self):
|
|
|
|
return timezone.now() < self.expiry
|