2026-04-02 10:25:25 +05:30
|
|
|
import secrets
|
|
|
|
|
|
2025-11-27 11:53:46 +05:30
|
|
|
from django.contrib.auth.models import AbstractUser
|
|
|
|
|
from django.db import models
|
|
|
|
|
|
2025-12-01 04:52:49 +05:30
|
|
|
from accounts.manager import UserManager
|
2026-03-15 00:29:17 +05:30
|
|
|
from partner.models import Partner
|
2026-04-02 10:25:25 +05:30
|
|
|
|
|
|
|
|
EVENTIFY_ID_CHARS = 'ABCDEFGHJKLMNPQRSTUVWXYZ23456789' # no I, O, 0, 1
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def generate_eventify_id():
|
|
|
|
|
return 'EVT-' + ''.join(secrets.choice(EVENTIFY_ID_CHARS) for _ in range(8))
|
|
|
|
|
|
|
|
|
|
|
2025-12-01 04:52:49 +05:30
|
|
|
ROLE_CHOICES = (
|
2025-12-09 03:59:57 +05:30
|
|
|
('admin', 'Admin'),
|
|
|
|
|
('manager', 'Manager'),
|
|
|
|
|
('staff', 'Staff'),
|
2026-03-15 00:29:17 +05:30
|
|
|
('customer', 'Customer'),
|
|
|
|
|
('partner', 'Partner'),
|
|
|
|
|
('partner_manager', 'Partner Manager'),
|
|
|
|
|
('partner_staff', 'Partner Staff'),
|
|
|
|
|
('partner_customer', 'Partner Customer'),
|
2025-12-01 04:52:49 +05:30
|
|
|
)
|
|
|
|
|
|
2025-11-27 11:53:46 +05:30
|
|
|
class User(AbstractUser):
|
2026-04-02 10:25:25 +05:30
|
|
|
eventify_id = models.CharField(
|
|
|
|
|
max_length=12,
|
|
|
|
|
unique=True,
|
|
|
|
|
editable=False,
|
|
|
|
|
db_index=True,
|
|
|
|
|
null=True,
|
|
|
|
|
blank=True,
|
|
|
|
|
)
|
|
|
|
|
|
2025-11-27 11:53:46 +05:30
|
|
|
phone_number = models.CharField(max_length=15, blank=True, null=True)
|
2025-12-01 04:52:49 +05:30
|
|
|
role = models.CharField(max_length=20, choices=ROLE_CHOICES, default='Staff')
|
2025-11-27 11:53:46 +05:30
|
|
|
|
2026-03-15 00:29:17 +05:30
|
|
|
partner = models.ForeignKey(Partner, on_delete=models.CASCADE, blank=True, null=True)
|
|
|
|
|
|
2025-11-27 11:53:46 +05:30
|
|
|
is_staff = models.BooleanField(default=False)
|
|
|
|
|
is_customer = models.BooleanField(default=False)
|
|
|
|
|
is_user = models.BooleanField(default=False)
|
|
|
|
|
|
2025-12-09 03:59:57 +05:30
|
|
|
# Location fields
|
|
|
|
|
pincode = models.CharField(max_length=10, blank=True, null=True)
|
|
|
|
|
district = models.CharField(max_length=100, blank=True, null=True)
|
|
|
|
|
state = models.CharField(max_length=100, blank=True, null=True)
|
|
|
|
|
country = models.CharField(max_length=100, blank=True, null=True)
|
|
|
|
|
place = models.CharField(max_length=200, blank=True, null=True)
|
|
|
|
|
|
|
|
|
|
# Location fields
|
|
|
|
|
latitude = models.DecimalField(max_digits=9, decimal_places=6, blank=True, null=True)
|
|
|
|
|
longitude = models.DecimalField(max_digits=9, decimal_places=6, blank=True, null=True)
|
|
|
|
|
|
2025-12-19 19:35:38 +05:30
|
|
|
profile_picture = models.ImageField(upload_to='profile_pictures/', blank=True, null=True, default='default.png')
|
|
|
|
|
|
2026-04-02 04:06:02 +00:00
|
|
|
allowed_modules = models.TextField(
|
|
|
|
|
blank=True, null=True,
|
2026-04-02 10:25:25 +05:30
|
|
|
help_text='Comma-separated module slugs this user can access',
|
2026-04-02 04:06:02 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
ALL_MODULES = ["dashboard", "partners", "events", "ad-control", "users", "reviews", "contributions", "financials", "settings"]
|
|
|
|
|
|
|
|
|
|
def get_allowed_modules(self):
|
|
|
|
|
ALL = ["dashboard", "partners", "events", "ad-control", "users", "reviews", "contributions", "financials", "settings"]
|
|
|
|
|
if self.is_superuser or self.role == "admin":
|
|
|
|
|
return ALL
|
|
|
|
|
if self.allowed_modules:
|
|
|
|
|
return [m.strip() for m in self.allowed_modules.split(",") if m.strip()]
|
|
|
|
|
if self.role == "manager":
|
|
|
|
|
return ALL
|
|
|
|
|
return []
|
|
|
|
|
|
2025-12-01 04:52:49 +05:30
|
|
|
objects = UserManager()
|
|
|
|
|
|
2026-04-02 10:25:25 +05:30
|
|
|
def save(self, *args, **kwargs):
|
|
|
|
|
if not self.eventify_id:
|
|
|
|
|
for _ in range(10):
|
|
|
|
|
candidate = generate_eventify_id()
|
|
|
|
|
if not User.objects.filter(eventify_id=candidate).exists():
|
|
|
|
|
self.eventify_id = candidate
|
|
|
|
|
break
|
|
|
|
|
super().save(*args, **kwargs)
|
|
|
|
|
|
2025-11-27 11:53:46 +05:30
|
|
|
def __str__(self):
|
|
|
|
|
return self.username
|