Files
MTCBD/backend/analytics/models.py
2026-02-23 20:31:53 +05:30

46 lines
1.8 KiB
Python

from django.db import models
from django.conf import settings
from tenants.managers import TenantScopedManager
from tenants.models import Tenant
class AuditLog(models.Model):
tenant = models.ForeignKey(Tenant, on_delete=models.CASCADE, related_name='audit_logs')
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.SET_NULL, null=True, related_name='audit_logs')
action = models.CharField(max_length=50) # created, updated, deleted
model_name = models.CharField(max_length=100)
object_id = models.CharField(max_length=255)
changes = models.JSONField(default=dict, blank=True)
ip_address = models.GenericIPAddressField(null=True, blank=True)
created_at = models.DateTimeField(auto_now_add=True)
objects = TenantScopedManager()
class Meta:
ordering = ['-created_at']
indexes = [
models.Index(fields=['tenant', 'created_at']),
]
def __str__(self):
return f"{self.action} on {self.model_name}:{self.object_id} by {self.user}"
class ActivityLog(models.Model):
tenant = models.ForeignKey(Tenant, on_delete=models.CASCADE, related_name='activity_logs')
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.SET_NULL, null=True, related_name='activity_logs')
action = models.CharField(max_length=100)
target_type = models.CharField(max_length=100)
target_id = models.CharField(max_length=255)
metadata = models.JSONField(default=dict, blank=True)
created_at = models.DateTimeField(auto_now_add=True)
objects = TenantScopedManager()
class Meta:
ordering = ['-created_at']
indexes = [
models.Index(fields=['tenant', 'created_at']),
]
def __str__(self):
return f"{self.user} {self.action} {self.target_type}:{self.target_id}"