109 lines
5.0 KiB
Python
109 lines
5.0 KiB
Python
|
|
import uuid
|
||
|
|
|
||
|
|
import django.db.models.deletion
|
||
|
|
from django.db import migrations, models
|
||
|
|
|
||
|
|
|
||
|
|
def _create_model_if_missing(app_label, model_name):
|
||
|
|
def _operation(apps, schema_editor):
|
||
|
|
model = apps.get_model(app_label, model_name)
|
||
|
|
existing_tables = set(schema_editor.connection.introspection.table_names())
|
||
|
|
if model._meta.db_table in existing_tables:
|
||
|
|
return
|
||
|
|
schema_editor.create_model(model)
|
||
|
|
|
||
|
|
return _operation
|
||
|
|
|
||
|
|
|
||
|
|
class Migration(migrations.Migration):
|
||
|
|
initial = True
|
||
|
|
atomic = False
|
||
|
|
|
||
|
|
dependencies = [
|
||
|
|
("farm_hub", "0001_initial"),
|
||
|
|
]
|
||
|
|
|
||
|
|
operations = [
|
||
|
|
migrations.SeparateDatabaseAndState(
|
||
|
|
database_operations=[],
|
||
|
|
state_operations=[
|
||
|
|
migrations.CreateModel(
|
||
|
|
name="SensorCatalog",
|
||
|
|
fields=[
|
||
|
|
("id", models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name="ID")),
|
||
|
|
("uuid", models.UUIDField(db_index=True, default=uuid.uuid4, editable=False, unique=True)),
|
||
|
|
("code", models.CharField(db_index=True, max_length=255, unique=True)),
|
||
|
|
("name", models.CharField(db_index=True, max_length=255, unique=True)),
|
||
|
|
("description", models.TextField(blank=True, default="")),
|
||
|
|
("customizable_fields", models.JSONField(blank=True, default=list)),
|
||
|
|
("supported_power_sources", models.JSONField(blank=True, default=list)),
|
||
|
|
("returned_data_fields", models.JSONField(blank=True, default=list)),
|
||
|
|
("sample_payload", models.JSONField(blank=True, default=dict)),
|
||
|
|
("is_active", models.BooleanField(default=True)),
|
||
|
|
("created_at", models.DateTimeField(auto_now_add=True)),
|
||
|
|
("updated_at", models.DateTimeField(auto_now=True)),
|
||
|
|
],
|
||
|
|
options={"db_table": "sensor_catalogs", "ordering": ["code"]},
|
||
|
|
),
|
||
|
|
],
|
||
|
|
),
|
||
|
|
migrations.RunPython(
|
||
|
|
_create_model_if_missing("device_hub", "SensorCatalog"),
|
||
|
|
migrations.RunPython.noop,
|
||
|
|
),
|
||
|
|
migrations.SeparateDatabaseAndState(
|
||
|
|
database_operations=[],
|
||
|
|
state_operations=[
|
||
|
|
migrations.CreateModel(
|
||
|
|
name="FarmSensor",
|
||
|
|
fields=[
|
||
|
|
("id", models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name="ID")),
|
||
|
|
("uuid", models.UUIDField(db_index=True, default=uuid.uuid4, editable=False, unique=True)),
|
||
|
|
("name", models.CharField(max_length=255)),
|
||
|
|
("sensor_type", models.CharField(blank=True, default="", max_length=255)),
|
||
|
|
("is_active", models.BooleanField(default=True)),
|
||
|
|
("specifications", models.JSONField(blank=True, default=dict)),
|
||
|
|
("power_source", models.JSONField(blank=True, default=dict)),
|
||
|
|
("customization", models.JSONField(blank=True, default=dict)),
|
||
|
|
("created_at", models.DateTimeField(auto_now_add=True)),
|
||
|
|
("updated_at", models.DateTimeField(auto_now=True)),
|
||
|
|
(
|
||
|
|
"farm",
|
||
|
|
models.ForeignKey(
|
||
|
|
on_delete=django.db.models.deletion.CASCADE,
|
||
|
|
related_name="sensors",
|
||
|
|
to="farm_hub.farmhub",
|
||
|
|
),
|
||
|
|
),
|
||
|
|
],
|
||
|
|
options={"db_table": "farm_sensors", "ordering": ["-created_at"]},
|
||
|
|
),
|
||
|
|
],
|
||
|
|
),
|
||
|
|
migrations.RunPython(
|
||
|
|
_create_model_if_missing("device_hub", "FarmSensor"),
|
||
|
|
migrations.RunPython.noop,
|
||
|
|
),
|
||
|
|
migrations.SeparateDatabaseAndState(
|
||
|
|
database_operations=[],
|
||
|
|
state_operations=[
|
||
|
|
migrations.CreateModel(
|
||
|
|
name="SensorExternalRequestLog",
|
||
|
|
fields=[
|
||
|
|
("id", models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name="ID")),
|
||
|
|
("farm_uuid", models.UUIDField(db_index=True)),
|
||
|
|
("sensor_catalog_uuid", models.UUIDField(blank=True, db_index=True, null=True)),
|
||
|
|
("physical_device_uuid", models.UUIDField(db_index=True)),
|
||
|
|
("payload", models.JSONField(blank=True, default=dict)),
|
||
|
|
("created_at", models.DateTimeField(auto_now_add=True)),
|
||
|
|
],
|
||
|
|
options={"db_table": "sensor_external_request_logs", "ordering": ["-created_at", "-id"]},
|
||
|
|
),
|
||
|
|
],
|
||
|
|
),
|
||
|
|
migrations.RunPython(
|
||
|
|
_create_model_if_missing("device_hub", "SensorExternalRequestLog"),
|
||
|
|
migrations.RunPython.noop,
|
||
|
|
),
|
||
|
|
]
|