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

@@ -2,22 +2,33 @@ from django.db import models
from users.models import User from users.models import User
class Hotel(models.Model): class Hotel(models.Model):
name = models.CharField(max_length=255, verbose_name="Hotel Name") name = models.CharField(max_length=255, verbose_name="Название отеля")
pms_type = models.CharField( pms_type = models.CharField(
max_length=50, max_length=50,
choices=[('bnovo', 'Bnovo'), ('travelline', 'Travel Line')], choices=[('bnovo', 'Bnovo'), ('travelline', 'Travel Line')],
verbose_name="PMS Type" verbose_name="PMS система"
) )
api_key = models.CharField(max_length=255, blank=True, null=True, verbose_name="API Key") api_key = models.CharField(max_length=255, blank=True, null=True, verbose_name="API ключ")
public_key = models.CharField(max_length=255, blank=True, null=True, verbose_name="Public Key") public_key = models.CharField(max_length=255, blank=True, null=True, verbose_name="Публичный ключ")
created_at = models.DateTimeField(auto_now_add=True, verbose_name="Created At") created_at = models.DateTimeField(auto_now_add=True, verbose_name="Создан")
def __str__(self): def __str__(self):
return self.name return self.name
class Meta:
verbose_name = "Отель"
verbose_name_plural = "Отели"
class UserHotel(models.Model): class UserHotel(models.Model):
user = models.ForeignKey(User, on_delete=models.CASCADE, verbose_name="User") user = models.ForeignKey(User, on_delete=models.CASCADE, verbose_name="Пользователь")
hotel = models.ForeignKey(Hotel, on_delete=models.CASCADE, verbose_name="Hotel") hotel = models.ForeignKey(Hotel, on_delete=models.CASCADE, verbose_name="Отель")
def __str__(self): def __str__(self):
return f"{self.user.username} - {self.hotel.name}" return f"{self.user.username} - {self.hotel.name}"
class Meta:
verbose_name = "Пользователь отеля"
verbose_name_plural = "Пользователи отелей"

View File

@@ -87,9 +87,9 @@ DATABASES = {
'wordpress': { 'wordpress': {
'ENGINE': 'django.db.backends.mysql', 'ENGINE': 'django.db.backends.mysql',
'NAME': 'u1510415_wp832', 'NAME': 'u1510415_wp832',
'USER': 'root', 'USER': 'u1510415_wp832',
'PASSWORD': 'R0sebud', 'PASSWORD': 'yZ1gV6kH6lzD2cQ3',
'HOST': '0.0.0.0', 'HOST': 'server231.hosting.reg.ru',
'PORT': '3306', 'PORT': '3306',
}, },
} }

View File

@@ -1,5 +1,5 @@
from django.contrib import admin from django.contrib import admin
from .models import User, UserConfirmation from .models import User, UserConfirmation, UserActivityLog
@admin.register(User) @admin.register(User)
class UserAdmin(admin.ModelAdmin): class UserAdmin(admin.ModelAdmin):
@@ -13,3 +13,11 @@ class UserConfirmationAdmin(admin.ModelAdmin):
list_display = ('user', 'confirmation_code', 'created_at') list_display = ('user', 'confirmation_code', 'created_at')
search_fields = ('user__username', 'confirmation_code') search_fields = ('user__username', 'confirmation_code')
list_filter = ('created_at',) list_filter = ('created_at',)
@admin.register(UserActivityLog)
class UserActivityLogAdmin(admin.ModelAdmin):
list_display = ( 'id', 'user_id', 'ip', 'timestamp', 'date_time', 'agent', 'platform', 'version', 'model', 'device', 'UAString', 'location', 'page_id', 'url_parameters', 'page_title', 'type', 'last_counter', 'hits', 'honeypot', 'reply', 'page_url')
search_fields = ('user_id', 'ip', 'datetime', 'agent', 'platform', 'version', 'model', 'device', 'UAString', 'location', 'page_id', 'url_parameters', 'page_title', 'type', 'last_counter', 'hits', 'honeypot', 'reply', 'page_url')
list_filter = ('page_title', 'user_id', 'ip')
ordering = ('-id',)

View File

@@ -1,29 +0,0 @@
from django.core.management.base import BaseCommand
from users.models import WordPressUserActivityLog
from users.models import LocalUserActivityLog
from asgiref.sync import sync_to_async
class Command(BaseCommand):
help = "Синхронизация данных из WordPress в локальную базу данных"
def handle(self, *args, **kwargs):
self.stdout.write("Начало синхронизации данных...")
try:
# Получаем данные из WordPress
wordpress_logs = WordPressUserActivityLog.objects.using('wordpress').all()
for log in wordpress_logs:
# Сохраняем данные в локальную базу
LocalUserActivityLog.objects.update_or_create(
id=log.id, # Используем уникальный идентификатор
defaults={
'user_id': log.user_id,
'activity_type': log.activity_type,
'timestamp': log.timestamp,
'additional_data': log.additional_data,
},
)
self.stdout.write(self.style.SUCCESS("Синхронизация завершена успешно!"))
except Exception as e:
self.stderr.write(self.style.ERROR(f"Ошибка синхронизации: {str(e)}"))

View File

@@ -4,29 +4,29 @@ import uuid
class User(AbstractUser): class User(AbstractUser):
TELEGRAM_ROLES = [ TELEGRAM_ROLES = [
('admin', 'Administrator'), ('admin', 'Администратор системы'),
('hotel_user', 'Hotel User'), ('hotel_user', 'Сотрудник отеля'),
] ]
telegram_id = models.BigIntegerField( telegram_id = models.BigIntegerField(
unique=True, unique=True,
null=True, null=True,
blank=True, blank=True,
verbose_name="Telegram ID" verbose_name="ID Телеграм"
) )
chat_id = models.BigIntegerField( chat_id = models.BigIntegerField(
unique=True, unique=True,
null=True, null=True,
blank=True, blank=True,
verbose_name="Chat ID" verbose_name="ID чата в телеграм"
) )
role = models.CharField( role = models.CharField(
max_length=20, max_length=20,
choices=TELEGRAM_ROLES, choices=TELEGRAM_ROLES,
default='hotel_user', 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( groups = models.ManyToManyField(
'auth.Group', 'auth.Group',
@@ -42,14 +42,23 @@ class User(AbstractUser):
def __str__(self): def __str__(self):
return self.username or f"Telegram User {self.telegram_id}" return self.username or f"Telegram User {self.telegram_id}"
class Meta:
verbose_name = "Пользователь"
verbose_name_plural = "Пользователи"
class UserConfirmation(models.Model): class UserConfirmation(models.Model):
user = models.ForeignKey(User, on_delete=models.CASCADE, verbose_name="User") user = models.ForeignKey(User, on_delete=models.CASCADE, verbose_name="Пользователь")
confirmation_code = models.UUIDField(default=uuid.uuid4, verbose_name="Confirmation Code") confirmation_code = models.UUIDField(default=uuid.uuid4, verbose_name="Код подтверждения")
created_at = models.DateTimeField(auto_now_add=True, verbose_name="Created At") created_at = models.DateTimeField(auto_now_add=True, verbose_name="Создан: ")
def __str__(self): def __str__(self):
return f"Confirmation for {self.user.username} - {self.confirmation_code}" return f"Confirmation for {self.user.username} - {self.confirmation_code}"
class Meta:
verbose_name = "Подтверждение пользователя"
verbose_name_plural = "Подтверждения пользователей"
class WordPressUserActivityLog(models.Model): class WordPressUserActivityLog(models.Model):
id = models.AutoField(primary_key=True) id = models.AutoField(primary_key=True)
user_id = models.IntegerField() user_id = models.IntegerField()
@@ -71,3 +80,36 @@ class LocalUserActivityLog(models.Model):
def __str__(self): 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}"