summaryrefslogtreecommitdiffstats
path: root/myuser/models.py
diff options
context:
space:
mode:
authorYulqen <246857+yulqen@users.noreply.github.com>2024-04-23 11:22:21 +0100
committerGitHub <noreply@github.com>2024-04-23 11:22:21 +0100
commitceca6fa956b21c43263e53c328d619c4ede21914 (patch)
treea48384210cdc168e3bd3ccff6d6d516eeed9e748 /myuser/models.py
parent8b084e9fe7a5f3a04c32daf9a24f7f2cf67300f9 (diff)
parent0f951dcf029d4af284467543a3afdf5bf6581a20 (diff)
Merge pull request #22 from defencedigital/pyswitch
switched to Django
Diffstat (limited to 'myuser/models.py')
-rw-r--r--myuser/models.py75
1 files changed, 75 insertions, 0 deletions
diff --git a/myuser/models.py b/myuser/models.py
new file mode 100644
index 0000000..1236ba6
--- /dev/null
+++ b/myuser/models.py
@@ -0,0 +1,75 @@
+from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager
+from django.contrib.auth.models import PermissionsMixin
+from django.db import models
+from django.db.models import BooleanField, CharField, EmailField
+
+
+class Common(models.Model):
+ date_created = models.DateTimeField(auto_now_add=True)
+ last_modified = models.DateTimeField(auto_now=True)
+
+ class Meta:
+ abstract = True
+
+
+class TeamMgr(BaseUserManager):
+ def create_user(self, email, password=None):
+ if not email:
+ raise ValueError("Users must have an email address")
+ user = self.model(
+ email=self.normalize_email(email),
+ )
+ user.set_password(password)
+ user.save(using=self._db)
+ return user
+
+ def create_superuser(self, email, password=None):
+ user = self.create_user(
+ email,
+ password=password,
+ )
+ user.is_admin = True
+ user.save(using=self._db)
+ return user
+
+
+class Team(Common):
+ name = models.CharField(max_length=256)
+
+ def __str__(self):
+ return self.name
+
+
+class TeamUser(AbstractBaseUser, PermissionsMixin):
+ email = EmailField(verbose_name="email address", max_length=255, unique=True)
+ first_name = CharField(max_length=20, null=True, blank=True)
+ last_name = CharField(max_length=20, null=True, blank=True)
+ dapsy = BooleanField(default=False)
+ is_active = BooleanField(default=True)
+ is_admin = BooleanField(default=False)
+ team = models.ForeignKey(Team, null=True, on_delete=models.CASCADE, related_name="team_members")
+ lead_for = models.ManyToManyField("engagements.Organisation", blank=True, related_name="lead_inspector")
+ designation = models.CharField(max_length=3, null=True, blank=True)
+
+ USERNAME_FIELD = "email"
+ # EMAIL_FIELD = "email"
+
+ objects = TeamMgr()
+
+ def __str__(self):
+ return self.email
+
+ def fullname(self):
+ return f"{self.first_name} {self.last_name}"
+
+ def has_perm(self, perm, obj=None):
+ "Does this user have a specific permission? Set True for now."
+ return True
+
+ def has_module_perms(self, app_label):
+ "Does user have permissions to view the app `app_label`? Yes for now."
+ return True
+
+ @property
+ def is_staff(self):
+ return self.is_admin