User_activity_log model
This commit is contained in:
@@ -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 = "Пользователи отелей"
|
||||||
|
|
||||||
@@ -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',
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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',)
|
||||||
|
|
||||||
@@ -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)}"))
|
|
||||||
@@ -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}"
|
||||||
Reference in New Issue
Block a user