settings application
.env db params+global settings in admin model ECVI plugin module
This commit is contained in:
0
settings/__init__.py
Normal file
0
settings/__init__.py
Normal file
26
settings/admin.py
Normal file
26
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']
|
||||
6
settings/apps.py
Normal file
6
settings/apps.py
Normal file
@@ -0,0 +1,6 @@
|
||||
from django.apps import AppConfig
|
||||
|
||||
|
||||
class SettingsConfig(AppConfig):
|
||||
default_auto_field = 'django.db.models.BigAutoField'
|
||||
name = 'settings'
|
||||
30
settings/migrations/0001_initial.py
Normal file
30
settings/migrations/0001_initial.py
Normal file
@@ -0,0 +1,30 @@
|
||||
# Generated by Django 5.1.4 on 2024-12-14 02:10
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
initial = True
|
||||
|
||||
dependencies = [
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='LocalDatabase',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('name', models.CharField(max_length=255, verbose_name='Имя базы данных')),
|
||||
('host', models.CharField(default='localhost', max_length=255, verbose_name='Хост базы данных')),
|
||||
('port', models.IntegerField(default=5432, verbose_name='Порт базы данных')),
|
||||
('user', models.CharField(max_length=255, verbose_name='Пользователь базы данных')),
|
||||
('password', models.CharField(max_length=255, verbose_name='Пароль базы данных')),
|
||||
('is_active', models.BooleanField(default=True, verbose_name='Активна ли база данных')),
|
||||
],
|
||||
options={
|
||||
'verbose_name': 'Локальная база данных',
|
||||
'verbose_name_plural': 'Локальные базы данных',
|
||||
},
|
||||
),
|
||||
]
|
||||
33
settings/migrations/0002_emailsettings_telegramsettings.py
Normal file
33
settings/migrations/0002_emailsettings_telegramsettings.py
Normal file
@@ -0,0 +1,33 @@
|
||||
# Generated by Django 5.1.4 on 2024-12-14 02:12
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('settings', '0001_initial'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='EmailSettings',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('smtp_server', models.CharField(help_text='SMTP сервер для отправки почты', max_length=255)),
|
||||
('smtp_port', models.IntegerField(default=587, help_text='SMTP порт для почты')),
|
||||
('smtp_user', models.CharField(help_text='Имя пользователя для SMTP', max_length=255)),
|
||||
('smtp_password', models.CharField(help_text='Пароль для SMTP', max_length=255)),
|
||||
('from_email', models.EmailField(help_text='Email для отправки сообщений', max_length=254)),
|
||||
],
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name='TelegramSettings',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('bot_token', models.CharField(help_text='Токен вашего бота Telegram', max_length=255)),
|
||||
('chat_id', models.CharField(help_text='ID чата для отправки сообщений', max_length=255)),
|
||||
('username', models.CharField(blank=True, help_text='Имя пользователя для бота', max_length=255, null=True)),
|
||||
],
|
||||
),
|
||||
]
|
||||
19
settings/migrations/0003_localdatabase_database.py
Normal file
19
settings/migrations/0003_localdatabase_database.py
Normal file
@@ -0,0 +1,19 @@
|
||||
# Generated by Django 5.1.4 on 2024-12-14 02:31
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('settings', '0002_emailsettings_telegramsettings'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AddField(
|
||||
model_name='localdatabase',
|
||||
name='database',
|
||||
field=models.CharField(default=1, max_length=255, verbose_name='Название базы данных'),
|
||||
preserve_default=False,
|
||||
),
|
||||
]
|
||||
@@ -0,0 +1,35 @@
|
||||
# Generated by Django 5.1.4 on 2024-12-14 02:55
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('settings', '0003_localdatabase_database'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='GlobalHotelSettings',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('check_in_time', models.TimeField(help_text='Время заезда')),
|
||||
('check_out_time', models.TimeField(help_text='Время выезда')),
|
||||
('currency', models.CharField(help_text='Валюта', max_length=3)),
|
||||
('timezone', models.CharField(help_text='Часовой пояс', max_length=255)),
|
||||
],
|
||||
options={
|
||||
'verbose_name': 'Глобальные настройки отеля',
|
||||
'verbose_name_plural': 'Глобальные настройки отеля',
|
||||
},
|
||||
),
|
||||
migrations.AlterModelOptions(
|
||||
name='emailsettings',
|
||||
options={'verbose_name': 'Настройки почты', 'verbose_name_plural': 'Настройки почты'},
|
||||
),
|
||||
migrations.AlterModelOptions(
|
||||
name='telegramsettings',
|
||||
options={'verbose_name': 'Настройки Telegram', 'verbose_name_plural': 'Настройки Telegram'},
|
||||
),
|
||||
]
|
||||
26
settings/migrations/0005_globalsystemsettings.py
Normal file
26
settings/migrations/0005_globalsystemsettings.py
Normal file
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
0
settings/migrations/__init__.py
Normal file
0
settings/migrations/__init__.py
Normal file
79
settings/models.py
Normal file
79
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 = "Настройки почты"
|
||||
verbose_name_plural = "Настройки почты"
|
||||
|
||||
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 = "Глобальные настройки системы"
|
||||
|
||||
50
settings/settings.py
Normal file
50
settings/settings.py
Normal file
@@ -0,0 +1,50 @@
|
||||
# settings.py
|
||||
|
||||
from .models import LocalDatabase
|
||||
from decouple import config
|
||||
from django.conf import settings
|
||||
from .models import LocalDatabase
|
||||
|
||||
def load_database_settings():
|
||||
# Загружаем настройки из базы данных
|
||||
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,
|
||||
}
|
||||
3
settings/tests.py
Normal file
3
settings/tests.py
Normal file
@@ -0,0 +1,3 @@
|
||||
from django.test import TestCase
|
||||
|
||||
# Create your tests here.
|
||||
3
settings/views.py
Normal file
3
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