hotel import template
This commit is contained in:
@@ -3,7 +3,7 @@ from hotels.models import Hotel, Reservation
|
||||
|
||||
|
||||
class UserActivityLog(models.Model):
|
||||
id = models.BigIntegerField(primary_key=True)
|
||||
external_id = models.CharField(max_length=255, null=True, blank=True)
|
||||
user_id = models.BigIntegerField(verbose_name="ID пользователя")
|
||||
ip = models.GenericIPAddressField(verbose_name="IP-адрес")
|
||||
created = models.DateTimeField(verbose_name="Дата создания")
|
||||
@@ -41,8 +41,8 @@ class ExternalDBSettings(models.Model):
|
||||
port = models.PositiveIntegerField(default=3306, help_text="Порт сервера базы данных.")
|
||||
user = models.CharField(max_length=255, help_text="Имя пользователя базы данных.")
|
||||
password = models.CharField(max_length=255, help_text="Пароль для подключения.")
|
||||
database = models.CharField(max_length=255, default="", help_text="Имя базы данных.")
|
||||
table_name = models.CharField(max_length=255, blank=True, null=True, help_text="Имя таблицы для загрузки данных.")
|
||||
database = models.CharField(max_length=255, default="u1510415_wp832", help_text="Имя базы данных.")
|
||||
table_name = models.CharField(max_length=255, blank=True, default="wpts_user_activity_log", null=True, help_text="Имя таблицы для загрузки данных.")
|
||||
selected_fields = models.TextField(blank=True, null=True, help_text="Список полей для загрузки (через запятую).")
|
||||
is_active = models.BooleanField(default=True, help_text="Флаг активности подключения.")
|
||||
created_at = models.DateTimeField(auto_now_add=True)
|
||||
@@ -52,7 +52,7 @@ class ExternalDBSettings(models.Model):
|
||||
return f"{self.name} ({self.host}:{self.port})"
|
||||
|
||||
class Meta:
|
||||
verbose_name = "Настройки подключения к БД"
|
||||
verbose_name = "Настройка подключения к БД"
|
||||
verbose_name_plural = "Настройки подключений к БД"
|
||||
|
||||
|
||||
@@ -121,3 +121,33 @@ class RoomDiscrepancy(models.Model):
|
||||
))
|
||||
|
||||
RoomDiscrepancy.objects.bulk_create(discrepancies)
|
||||
|
||||
from urllib.parse import unquote
|
||||
from html import unescape
|
||||
|
||||
class ImportedHotel(models.Model):
|
||||
external_id = models.CharField(max_length=255, unique=True, verbose_name="Внешний ID отеля")
|
||||
name = models.CharField(max_length=255, verbose_name="Имя отеля")
|
||||
display_name = models.CharField(max_length=255, null=True, blank=True, verbose_name="Отображаемое имя")
|
||||
created = models.DateTimeField(auto_now_add=True, verbose_name="Дата создания")
|
||||
updated = models.DateTimeField(auto_now=True, verbose_name="Дата обновления")
|
||||
imported = models.BooleanField(default=False, verbose_name="Импортирован в основную базу")
|
||||
|
||||
def __str__(self):
|
||||
return f"{self.display_name or self.name} ({self.external_id})"
|
||||
|
||||
class Meta:
|
||||
verbose_name = "Импортированный отель"
|
||||
verbose_name_plural = "Импортированные отели"
|
||||
|
||||
def set_display_name_from_page_title(self, page_title):
|
||||
"""
|
||||
Декодирует HTML-сущности, URL-кодировку и устанавливает display_name.
|
||||
"""
|
||||
if page_title:
|
||||
decoded = unquote(unescape(page_title))
|
||||
self.display_name = decoded
|
||||
else:
|
||||
self.display_name = self.name
|
||||
self.save()
|
||||
|
||||
|
||||
Reference in New Issue
Block a user