feat / AEB-62 add additional DB schema for objects logic

This commit is contained in:
Timofey
2025-10-06 14:55:46 +03:00
parent a822ea587c
commit 5a0bb27c95
11 changed files with 426 additions and 31 deletions

View File

@@ -0,0 +1,104 @@
# Generated by Django 5.2.7 on 2025-10-06 10:59
import django.db.models.deletion
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('sitemanagement', '0004_sensor_math_formula'),
]
operations = [
migrations.AlterField(
model_name='alert',
name='message',
field=models.CharField(max_length=255, verbose_name='Сообщение'),
),
migrations.AlterField(
model_name='alert',
name='metric',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='alerts', to='sitemanagement.metric', verbose_name='Метрика'),
),
migrations.AlterField(
model_name='alert',
name='resolved',
field=models.BooleanField(default=False, verbose_name='Статус обработки'),
),
migrations.AlterField(
model_name='alert',
name='sensor',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='alerts', to='sitemanagement.sensor', verbose_name='Датчик'),
),
migrations.AlterField(
model_name='alert',
name='sensor_type',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='alerts', to='sitemanagement.sensortype', verbose_name='Тип сенсора'),
),
migrations.AlterField(
model_name='alert',
name='severity',
field=models.CharField(choices=[('warning', 'Warning'), ('critical', 'Critical')], default='warning', max_length=20, verbose_name='Уровень тревоги'),
),
migrations.AlterField(
model_name='metric',
name='raw_value',
field=models.CharField(max_length=50, verbose_name='Исходное значение'),
),
migrations.AlterField(
model_name='metric',
name='sensor',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='metrics', to='sitemanagement.sensor', verbose_name='Датчик'),
),
migrations.AlterField(
model_name='metric',
name='status',
field=models.CharField(blank=True, max_length=20, null=True, verbose_name='Статус'),
),
migrations.AlterField(
model_name='metric',
name='value',
field=models.FloatField(blank=True, null=True, verbose_name='Преобразованное значение'),
),
migrations.AlterField(
model_name='sensor',
name='math_formula',
field=models.CharField(blank=True, max_length=255, null=True, verbose_name='Математическая формула'),
),
migrations.AlterField(
model_name='sensor',
name='name',
field=models.CharField(blank=True, max_length=50, null=True, verbose_name='Название'),
),
migrations.AlterField(
model_name='sensor',
name='sensor_type',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='sitemanagement.sensortype', verbose_name='Тип сенсора'),
),
migrations.AlterField(
model_name='sensor',
name='serial_number',
field=models.CharField(blank=True, max_length=50, null=True, verbose_name='Серийный номер'),
),
migrations.AlterField(
model_name='sensor',
name='signal_format',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='sitemanagement.signalformat', verbose_name='Формат сигнала'),
),
migrations.AlterField(
model_name='signalformat',
name='code',
field=models.CharField(max_length=50, verbose_name='Код'),
),
migrations.AlterField(
model_name='signalformat',
name='conversion_rule',
field=models.CharField(blank=True, max_length=255, null=True, verbose_name='Правило преобразования'),
),
migrations.AlterField(
model_name='signalformat',
name='unit',
field=models.CharField(blank=True, max_length=20, null=True, verbose_name='Единица измерения'),
),
]

View File

@@ -0,0 +1,50 @@
# Generated by Django 5.2.7 on 2025-10-06 11:28
import django.db.models.deletion
import sitemanagement.constants.image_file_path
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('sitemanagement', '0005_alter_alert_message_alter_alert_metric_and_more'),
]
operations = [
migrations.CreateModel(
name='Object',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('title', models.CharField(max_length=255, verbose_name='Название')),
('description', models.TextField(blank=True, null=True, verbose_name='Описание')),
('image', models.ImageField(blank=True, null=True, upload_to=sitemanagement.constants.image_file_path.register_object_upload_path, verbose_name='Изображение')),
('address', models.CharField(max_length=255, verbose_name='Адрес')),
('floors', models.PositiveSmallIntegerField(verbose_name='Количество этажей')),
('area', models.DecimalField(decimal_places=2, max_digits=10, verbose_name='Площадь')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
],
options={
'verbose_name': 'Объект',
'verbose_name_plural': 'Объекты',
'ordering': ['title'],
},
),
migrations.CreateModel(
name='Zone',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('name', models.CharField(max_length=255, verbose_name='Название')),
('created_at', models.DateTimeField(auto_now_add=True)),
('updated_at', models.DateTimeField(auto_now=True)),
('object', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='zones', to='sitemanagement.object', verbose_name='Объект')),
('sensors', models.ManyToManyField(related_name='zones', to='sitemanagement.sensor', verbose_name='Датчики')),
],
options={
'verbose_name': 'Зона',
'verbose_name_plural': 'Зоны',
'ordering': ['object', 'name'],
},
),
]