User_activity_log model

This commit is contained in:
2024-12-06 15:05:00 +09:00
parent 7309aef349
commit c77f46fdff
5 changed files with 85 additions and 53 deletions

View File

@@ -4,29 +4,29 @@ import uuid
class User(AbstractUser):
TELEGRAM_ROLES = [
('admin', 'Administrator'),
('hotel_user', 'Hotel User'),
('admin', 'Администратор системы'),
('hotel_user', 'Сотрудник отеля'),
]
telegram_id = models.BigIntegerField(
unique=True,
null=True,
blank=True,
verbose_name="Telegram ID"
verbose_name="ID Телеграм"
)
chat_id = models.BigIntegerField(
unique=True,
null=True,
blank=True,
verbose_name="Chat ID"
verbose_name="ID чата в телеграм"
)
role = models.CharField(
max_length=20,
choices=TELEGRAM_ROLES,
default='hotel_user',
verbose_name="Role"
verbose_name="Роль"
)
confirmed = models.BooleanField(default=False, verbose_name="Confirmed")
confirmed = models.BooleanField(default=False, verbose_name="Подтвержден")
groups = models.ManyToManyField(
'auth.Group',
@@ -41,15 +41,24 @@ class User(AbstractUser):
def __str__(self):
return self.username or f"Telegram User {self.telegram_id}"
class Meta:
verbose_name = "Пользователь"
verbose_name_plural = "Пользователи"
class UserConfirmation(models.Model):
user = models.ForeignKey(User, on_delete=models.CASCADE, verbose_name="User")
confirmation_code = models.UUIDField(default=uuid.uuid4, verbose_name="Confirmation Code")
created_at = models.DateTimeField(auto_now_add=True, verbose_name="Created At")
user = models.ForeignKey(User, on_delete=models.CASCADE, verbose_name="Пользователь")
confirmation_code = models.UUIDField(default=uuid.uuid4, verbose_name="Код подтверждения")
created_at = models.DateTimeField(auto_now_add=True, verbose_name="Создан: ")
def __str__(self):
return f"Confirmation for {self.user.username} - {self.confirmation_code}"
class Meta:
verbose_name = "Подтверждение пользователя"
verbose_name_plural = "Подтверждения пользователей"
class WordPressUserActivityLog(models.Model):
id = models.AutoField(primary_key=True)
user_id = models.IntegerField()
@@ -70,4 +79,37 @@ class LocalUserActivityLog(models.Model):
additional_data = models.JSONField(null=True, blank=True)
def __str__(self):
return f"User {self.user_id} - {self.activity_type}"
return f"User {self.user_id} - {self.activity_type}"
class UserActivityLog(models.Model):
id = models.BigAutoField(primary_key=True, verbose_name="ID")
user_id = models.BigIntegerField( verbose_name="ID пользователя")
ip = models.CharField(max_length=100, null=True, blank=True, verbose_name="IP адрес")
created = models.DateTimeField(auto_now_add=True, verbose_name="Создан")
timestamp = models.IntegerField(verbose_name="Время")
date_time = models.DateTimeField(verbose_name="Дата")
referred = models.CharField(max_length=255, null=True, blank=True)
agent = models.CharField(max_length=255, null=True, blank=True, verbose_name="Браузер")
platform = models.CharField(max_length=255, null=True, blank=True)
version = models.CharField(max_length=50, null=True, blank=True)
model = models.CharField(max_length=255, null=True, blank=True)
device = models.CharField(max_length=50, null=True, blank=True)
UAString = models.TextField(null=True, blank=True)
location = models.CharField(max_length=255, null=True, blank=True)
page_id = models.BigIntegerField(null=True, blank=True)
url_parameters = models.TextField(null=True, blank=True)
page_title = models.CharField(max_length=255, null=True, blank=True)
type = models.CharField(max_length=50, null=True, blank=True)
last_counter = models.IntegerField(null=True, blank=True)
hits = models.IntegerField(null=True, blank=True)
honeypot = models.BooleanField(null=True, blank=True)
reply = models.BooleanField(null=True, blank=True)
page_url = models.CharField(max_length=255, null=True, blank=True)
class Meta:
db_table = 'user_activity_log' # Название таблицы в локальной базе
verbose_name = 'Журнал активности'
verbose_name_plural = 'Журналы активности'
def __str__(self):
return f"User {self.user_id} - {self.type} - {self.date_time}"