# Generated by Django 5.1.6 on 2025-12-26 14:30 import django.db.models.deletion import pgtrigger.compiler import pgtrigger.migrations from django.conf import settings from django.db import migrations, models class Migration(migrations.Migration): initial = True dependencies = [ ("contenttypes", "0002_remove_content_type_name"), ("django_cloudflareimages_toolkit", "0001_initial"), ("pghistory", "0006_delete_aggregateevent"), migrations.swappable_dependency(settings.AUTH_USER_MODEL), ] operations = [ migrations.CreateModel( name="Photo", fields=[ ("id", models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name="ID")), ("created_at", models.DateTimeField(auto_now_add=True)), ("updated_at", models.DateTimeField(auto_now=True)), ("object_id", models.PositiveIntegerField(help_text="ID of the item")), ("caption", models.CharField(blank=True, help_text="Photo caption", max_length=255)), ("is_public", models.BooleanField(default=True, help_text="Whether this photo is visible to others")), ("source", models.CharField(blank=True, help_text="Source/Credit if applicable", max_length=100)), ( "content_type", models.ForeignKey( help_text="Type of item this photo belongs to", on_delete=django.db.models.deletion.CASCADE, to="contenttypes.contenttype", ), ), ( "image", models.ForeignKey( help_text="Cloudflare Image reference", on_delete=django.db.models.deletion.CASCADE, related_name="photos_usage", to="django_cloudflareimages_toolkit.cloudflareimage", ), ), ( "user", models.ForeignKey( help_text="User who uploaded this photo", on_delete=django.db.models.deletion.CASCADE, related_name="photos", to=settings.AUTH_USER_MODEL, ), ), ], options={ "verbose_name": "Photo", "verbose_name_plural": "Photos", "ordering": ["-created_at"], "abstract": False, }, ), migrations.CreateModel( name="PhotoEvent", fields=[ ("pgh_id", models.AutoField(primary_key=True, serialize=False)), ("pgh_created_at", models.DateTimeField(auto_now_add=True)), ("pgh_label", models.TextField(help_text="The event label.")), ("id", models.BigIntegerField()), ("created_at", models.DateTimeField(auto_now_add=True)), ("updated_at", models.DateTimeField(auto_now=True)), ("object_id", models.PositiveIntegerField(help_text="ID of the item")), ("caption", models.CharField(blank=True, help_text="Photo caption", max_length=255)), ("is_public", models.BooleanField(default=True, help_text="Whether this photo is visible to others")), ("source", models.CharField(blank=True, help_text="Source/Credit if applicable", max_length=100)), ( "content_type", models.ForeignKey( db_constraint=False, help_text="Type of item this photo belongs to", on_delete=django.db.models.deletion.DO_NOTHING, related_name="+", related_query_name="+", to="contenttypes.contenttype", ), ), ( "image", models.ForeignKey( db_constraint=False, help_text="Cloudflare Image reference", on_delete=django.db.models.deletion.DO_NOTHING, related_name="+", related_query_name="+", to="django_cloudflareimages_toolkit.cloudflareimage", ), ), ( "pgh_context", models.ForeignKey( db_constraint=False, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name="+", to="pghistory.context", ), ), ( "pgh_obj", models.ForeignKey( db_constraint=False, on_delete=django.db.models.deletion.DO_NOTHING, related_name="events", to="media.photo", ), ), ( "user", models.ForeignKey( db_constraint=False, help_text="User who uploaded this photo", on_delete=django.db.models.deletion.DO_NOTHING, related_name="+", related_query_name="+", to=settings.AUTH_USER_MODEL, ), ), ], options={ "abstract": False, }, ), migrations.AddIndex( model_name="photo", index=models.Index(fields=["content_type", "object_id"], name="media_photo_content_0187f5_idx"), ), pgtrigger.migrations.AddTrigger( model_name="photo", trigger=pgtrigger.compiler.Trigger( name="insert_insert", sql=pgtrigger.compiler.UpsertTriggerSql( func='INSERT INTO "media_photoevent" ("caption", "content_type_id", "created_at", "id", "image_id", "is_public", "object_id", "pgh_context_id", "pgh_created_at", "pgh_label", "pgh_obj_id", "source", "updated_at", "user_id") VALUES (NEW."caption", NEW."content_type_id", NEW."created_at", NEW."id", NEW."image_id", NEW."is_public", NEW."object_id", _pgh_attach_context(), NOW(), \'insert\', NEW."id", NEW."source", NEW."updated_at", NEW."user_id"); RETURN NULL;', hash="05c2d557f631f80ebd4b37ffb1ba9a539fa54244", operation="INSERT", pgid="pgtrigger_insert_insert_e1ca0", table="media_photo", when="AFTER", ), ), ), pgtrigger.migrations.AddTrigger( model_name="photo", trigger=pgtrigger.compiler.Trigger( name="update_update", sql=pgtrigger.compiler.UpsertTriggerSql( condition="WHEN (OLD.* IS DISTINCT FROM NEW.*)", func='INSERT INTO "media_photoevent" ("caption", "content_type_id", "created_at", "id", "image_id", "is_public", "object_id", "pgh_context_id", "pgh_created_at", "pgh_label", "pgh_obj_id", "source", "updated_at", "user_id") VALUES (NEW."caption", NEW."content_type_id", NEW."created_at", NEW."id", NEW."image_id", NEW."is_public", NEW."object_id", _pgh_attach_context(), NOW(), \'update\', NEW."id", NEW."source", NEW."updated_at", NEW."user_id"); RETURN NULL;', hash="9a4caabe540c0fd782b9c148444c364e385327f4", operation="UPDATE", pgid="pgtrigger_update_update_6ff7d", table="media_photo", when="AFTER", ), ), ), ]