Django_Basic_Manufacturing/users/models.py

147 lines
4.6 KiB
Python

from django.contrib.auth.models import AbstractUser
from django.db import models
from django.utils.translation import gettext_lazy as _
class CustomUser(AbstractUser):
"""Custom user model with extended fields"""
phone = models.CharField(max_length=20, blank=True, null=True)
department = models.CharField(max_length=100, blank=True, null=True)
employee_id = models.CharField(max_length=20, blank=True, null=True, unique=True)
is_active = models.BooleanField(default=True)
date_joined = models.DateTimeField(auto_now_add=True)
last_login = models.DateTimeField(auto_now=True)
# Group relationship (one-to-one)
group = models.ForeignKey('UserGroup', on_delete=models.SET_NULL, null=True, blank=True, related_name='users')
# Profile picture
profile_picture = models.ImageField(
upload_to='profile_pictures/',
blank=True,
null=True
)
class Meta:
verbose_name = _('User')
verbose_name_plural = _('Users')
ordering = ['username']
def __str__(self):
if self.group:
return f"{self.username} ({self.group.name})"
return f"{self.username} (No Group)"
def get_full_name(self):
if self.first_name and self.last_name:
return f"{self.first_name} {self.last_name}"
return self.username
def has_manufacturing_permission(self):
"""Check if user has manufacturing permissions"""
# Check if user is superuser
if self.is_superuser:
return True
# Check group permissions
if self.group and self.group.has_permission('manufacturing'):
return True
return False
def has_inventory_permission(self):
"""Check if user has inventory permissions"""
# Check if user is superuser
if self.is_superuser:
return True
# Check group permissions
if self.group and self.group.has_permission('inventory'):
return True
return False
def has_purchase_permission(self):
"""Check if user has purchase permissions"""
# Check if user is superuser
if self.is_superuser:
return True
# Check group permissions
if self.group and self.group.has_permission('purchase'):
return True
return False
def has_sales_permission(self):
"""Check if user has sales permissions"""
# Check if user is superuser
if self.is_superuser:
return True
# Check group permissions
if self.group and self.group.has_permission('sales'):
return True
return False
def has_user_management_permission(self):
"""Check if user has user management permissions"""
# Check if user is superuser
if self.is_superuser:
return True
# Check group permissions
if self.group and self.group.has_permission('user_management'):
return True
return False
def has_reporting_permission(self):
"""Check if user has reporting permissions"""
# Check if user is superuser
if self.is_superuser:
return True
# Check group permissions
if self.group and self.group.has_permission('reporting'):
return True
return False
def has_dashboard_permission(self):
"""Check if user has dashboard permissions"""
# Check if user is superuser
if self.is_superuser:
return True
# Check group permissions
if self.group and self.group.has_permission('dashboard'):
return True
return False
class UserGroup(models.Model):
"""Custom user groups for specific permissions"""
name = models.CharField(max_length=100, unique=True)
description = models.TextField(blank=True)
permissions = models.JSONField(default=dict) # Store permissions as JSON
created_at = models.DateTimeField(auto_now_add=True)
updated_at = models.DateTimeField(auto_now=True)
class Meta:
ordering = ['name']
def __str__(self):
return self.name
def get_permissions(self):
"""Get permissions for this group"""
return self.permissions or {}
def has_permission(self, permission_name):
"""Check if group has specific permission"""
permissions = self.get_permissions()
return permissions.get(permission_name, False)