settings application

.env db params+global settings in admin model
ECVI plugin module
This commit is contained in:
2024-12-14 20:50:11 +09:00
parent 09eb249d68
commit 93994ed929
328 changed files with 190143 additions and 538 deletions

0
settings/__init__.py Normal file
View File

26
settings/admin.py Normal file
View 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
View File

@@ -0,0 +1,6 @@
from django.apps import AppConfig
class SettingsConfig(AppConfig):
default_auto_field = 'django.db.models.BigAutoField'
name = 'settings'

View 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': 'Локальные базы данных',
},
),
]

View 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)),
],
),
]

View 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,
),
]

View File

@@ -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'},
),
]

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

79
settings/models.py Normal file
View 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
View 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
View File

@@ -0,0 +1,3 @@
from django.test import TestCase
# Create your tests here.

3
settings/views.py Normal file
View File

@@ -0,0 +1,3 @@
from django.shortcuts import render
# Create your views here.