docker environ removed. Rollback to development
This commit is contained in:
0
app_settings/__init__.py
Normal file
0
app_settings/__init__.py
Normal file
26
app_settings/admin.py
Normal file
26
app_settings/admin.py
Normal file
@@ -0,0 +1,26 @@
|
||||
# settings/admin.py
|
||||
|
||||
from django.contrib import admin
|
||||
from .models import LocalDatabase, GlobalHotelSettings, GlobalSystemSettings, TelegramSettings, EmailSettings
|
||||
|
||||
@admin.register(LocalDatabase)
|
||||
class LocalDatabaseAdmin(admin.ModelAdmin):
|
||||
list_display = ['name', 'host', 'port', 'user', 'database', 'is_active']
|
||||
search_fields = ['name', 'host','user', 'database']
|
||||
|
||||
|
||||
admin.site.register(GlobalHotelSettings)
|
||||
class GlobalHotelSettingsAdmin(admin.ModelAdmin):
|
||||
list_display = ['checkin_time', 'checkout_time', 'global_timezone']
|
||||
list_filter = ['global_timezone']
|
||||
|
||||
admin.site.register(GlobalSystemSettings)
|
||||
class GlobalSystemSettingsAdmin(admin.ModelAdmin):
|
||||
list_display = ['system_name', 'system_version', 'server_timezone']
|
||||
admin.site.register(TelegramSettings)
|
||||
class TelegramSettingsAdmin(admin.ModelAdmin):
|
||||
list_display = ['bot_token', 'bot_username']
|
||||
|
||||
admin.site.register(EmailSettings) # Register your models here.
|
||||
class EmailSettingsAdmin(admin.ModelAdmin):
|
||||
list_display = ['email_host', 'email_port', 'email_host_user', 'email_host_password']
|
||||
50
app_settings/app_settings.py
Normal file
50
app_settings/app_settings.py
Normal file
@@ -0,0 +1,50 @@
|
||||
# settings.py
|
||||
|
||||
from decouple import config
|
||||
from django.conf import settings
|
||||
from django.apps import apps
|
||||
|
||||
def load_database_settings():
|
||||
# Загружаем настройки из базы данных
|
||||
LocalDatabase = apps.get_model('app_settings', 'LocalDatabase')
|
||||
local_db_settings = LocalDatabase.objects.all()
|
||||
|
||||
for db in local_db_settings:
|
||||
# Пример добавления дополнительной базы данных
|
||||
settings.DATABASES[db.name] = {
|
||||
'ENGINE': 'django.db.backends.mysql',
|
||||
'NAME': db.db_name,
|
||||
'USER': db.username,
|
||||
'PASSWORD': db.password,
|
||||
'HOST': db.host,
|
||||
'PORT': db.port,
|
||||
}
|
||||
|
||||
# Вызов этой функции при старте проекта, например, в файле wsgi.py
|
||||
load_database_settings()
|
||||
|
||||
# Чтение локальных баз данных
|
||||
local_databases = LocalDatabase.objects.filter(is_active=True)
|
||||
|
||||
# Основная база данных
|
||||
DATABASES = {
|
||||
'default': {
|
||||
'ENGINE': 'django.db.backends.postgresql',
|
||||
'NAME': config('DB_NAME'),
|
||||
'USER': config('DB_USER'),
|
||||
'PASSWORD': config('DB_PASSWORD'),
|
||||
'HOST': config('DB_HOST'),
|
||||
'PORT': config('DB_PORT'),
|
||||
},
|
||||
}
|
||||
|
||||
# Добавление локальных баз данных
|
||||
for db in local_databases:
|
||||
DATABASES[db.name] = {
|
||||
'ENGINE': 'django.db.backends.postgresql',
|
||||
'NAME': db.name,
|
||||
'USER': db.user,
|
||||
'PASSWORD': db.password,
|
||||
'HOST': db.host,
|
||||
'PORT': db.port,
|
||||
}
|
||||
7
app_settings/apps.py
Normal file
7
app_settings/apps.py
Normal file
@@ -0,0 +1,7 @@
|
||||
from django.apps import AppConfig
|
||||
|
||||
|
||||
class SettingsConfig(AppConfig):
|
||||
default_auto_field = 'django.db.models.BigAutoField'
|
||||
name = 'app_settings'
|
||||
verbose_name="Настройки системы"
|
||||
86
app_settings/migrations/0001_initial.py
Normal file
86
app_settings/migrations/0001_initial.py
Normal file
File diff suppressed because one or more lines are too long
0
app_settings/migrations/__init__.py
Normal file
0
app_settings/migrations/__init__.py
Normal file
79
app_settings/models.py
Normal file
79
app_settings/models.py
Normal file
@@ -0,0 +1,79 @@
|
||||
# settings/models.py
|
||||
|
||||
from django.db import models
|
||||
import pytz
|
||||
class LocalDatabase(models.Model):
|
||||
name = models.CharField(max_length=255, verbose_name="Имя базы данных")
|
||||
host = models.CharField(max_length=255, verbose_name="Хост базы данных", default="localhost")
|
||||
port = models.IntegerField(default=5432, verbose_name="Порт базы данных")
|
||||
user = models.CharField(max_length=255, verbose_name="Пользователь базы данных")
|
||||
database = models.CharField(max_length=255, verbose_name="Название базы данных")
|
||||
password = models.CharField(max_length=255, verbose_name="Пароль базы данных")
|
||||
is_active = models.BooleanField(default=True, verbose_name="Активна ли база данных")
|
||||
|
||||
def __str__(self):
|
||||
return self.name
|
||||
|
||||
class Meta:
|
||||
verbose_name = "База данных"
|
||||
verbose_name_plural = "Базы данных"
|
||||
|
||||
class TelegramSettings(models.Model):
|
||||
bot_token = models.CharField(max_length=255, help_text="Токен вашего бота Telegram")
|
||||
chat_id = models.CharField(max_length=255, help_text="ID чата для отправки сообщений")
|
||||
username = models.CharField(max_length=255, help_text="Имя пользователя для бота", blank=True, null=True)
|
||||
|
||||
def __str__(self):
|
||||
return f"Telegram Bot ({self.username})"
|
||||
|
||||
class Meta:
|
||||
verbose_name = "Telegram"
|
||||
verbose_name_plural = "Telegram"
|
||||
|
||||
|
||||
class EmailSettings(models.Model):
|
||||
smtp_server = models.CharField(max_length=255, help_text="SMTP сервер для отправки почты")
|
||||
smtp_port = models.IntegerField(default=587, help_text="SMTP порт для почты")
|
||||
smtp_user = models.CharField(max_length=255, help_text="Имя пользователя для SMTP")
|
||||
smtp_password = models.CharField(max_length=255, help_text="Пароль для SMTP")
|
||||
from_email = models.EmailField(help_text="Email для отправки сообщений")
|
||||
|
||||
class Meta:
|
||||
verbose_name = "E-mail"
|
||||
verbose_name_plural = "E-mails"
|
||||
|
||||
def __str__(self):
|
||||
return f"Email Settings for {self.from_email}"
|
||||
|
||||
class GlobalHotelSettings(models.Model):
|
||||
check_in_time = models.TimeField(help_text="Время заезда")
|
||||
check_out_time = models.TimeField(help_text="Время выезда")
|
||||
currency = models.CharField(max_length=3, help_text="Валюта")
|
||||
global_timezone = models.CharField(
|
||||
max_length=63,
|
||||
choices=[(tz, tz) for tz in pytz.all_timezones], # Список всех часовых поясов
|
||||
default='UTC', # Значение по умолчанию
|
||||
)
|
||||
|
||||
def __str__(self):
|
||||
return "Настройки отеля"
|
||||
|
||||
class Meta:
|
||||
verbose_name = "Настройки отеля"
|
||||
verbose_name_plural = "Настройки отеля"
|
||||
|
||||
class GlobalSystemSettings(models.Model):
|
||||
system_name = models.CharField(max_length=255, help_text="Название системы")
|
||||
system_version = models.CharField(max_length=255, help_text="Версия системы")
|
||||
server_timezone = models.CharField(
|
||||
max_length=63,
|
||||
choices=[(tz, tz) for tz in pytz.all_timezones], # Список всех часовых поясов
|
||||
default='UTC', # Значение по умолчанию
|
||||
)
|
||||
def __str__(self):
|
||||
return "Настройки системы"
|
||||
|
||||
class Meta:
|
||||
verbose_name = "Настройки системы"
|
||||
verbose_name_plural = "Настройки системы"
|
||||
|
||||
3
app_settings/tests.py
Normal file
3
app_settings/tests.py
Normal file
@@ -0,0 +1,3 @@
|
||||
from django.test import TestCase
|
||||
|
||||
# Create your tests here.
|
||||
3
app_settings/views.py
Normal file
3
app_settings/views.py
Normal file
@@ -0,0 +1,3 @@
|
||||
from django.shortcuts import render
|
||||
|
||||
# Create your views here.
|
||||
Reference in New Issue
Block a user