diff options
Diffstat (limited to 'Migrations')
| -rw-r--r-- | Migrations/20230905172129_UploadedFileMetadata.Designer.cs | 323 | ||||
| -rw-r--r-- | Migrations/20230905172129_UploadedFileMetadata.cs | 132 | ||||
| -rw-r--r-- | Migrations/HBContextModelSnapshot.cs | 26 |
3 files changed, 466 insertions, 15 deletions
diff --git a/Migrations/20230905172129_UploadedFileMetadata.Designer.cs b/Migrations/20230905172129_UploadedFileMetadata.Designer.cs new file mode 100644 index 0000000..692d0b6 --- /dev/null +++ b/Migrations/20230905172129_UploadedFileMetadata.Designer.cs @@ -0,0 +1,323 @@ +// <auto-generated /> +using System; +using HyperBooru; +using Microsoft.EntityFrameworkCore; +using Microsoft.EntityFrameworkCore.Infrastructure; +using Microsoft.EntityFrameworkCore.Migrations; +using Microsoft.EntityFrameworkCore.Storage.ValueConversion; +using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata; + +#nullable disable + +namespace HyperBooru.Migrations +{ + [DbContext(typeof(HBContext))] + [Migration("20230905172129_UploadedFileMetadata")] + partial class UploadedFileMetadata + { + /// <inheritdoc /> + protected override void BuildTargetModel(ModelBuilder modelBuilder) + { +#pragma warning disable 612, 618 + modelBuilder + .HasAnnotation("ProductVersion", "7.0.10") + .HasAnnotation("Relational:MaxIdentifierLength", 63); + + NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder); + + modelBuilder.Entity("HyperBooru.HBObject", b => + { + b.Property<int>("ObjectId") + .ValueGeneratedOnAdd() + .HasColumnType("integer"); + + NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("ObjectId")); + + b.Property<Guid>("Guid") + .HasColumnType("uuid"); + + b.HasKey("ObjectId"); + + b.HasIndex("Guid"); + + b.ToTable("Objects", (string)null); + + b.UseTptMappingStrategy(); + }); + + modelBuilder.Entity("HyperBooru.OcrData", b => + { + b.Property<int>("OcrDataId") + .ValueGeneratedOnAdd() + .HasColumnType("integer"); + + NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("OcrDataId")); + + b.Property<int>("MediaId") + .HasColumnType("integer"); + + b.Property<string>("SearchableText") + .IsRequired() + .HasColumnType("text"); + + b.Property<string>("Text") + .IsRequired() + .HasColumnType("text"); + + b.Property<DateTime>("Timestamp") + .HasColumnType("timestamp with time zone"); + + b.HasKey("OcrDataId"); + + b.HasIndex("MediaId") + .IsUnique(); + + b.ToTable("OcrData"); + }); + + modelBuilder.Entity("TagDefinitionTagDefinition", b => + { + b.Property<int>("ImplicitTagsObjectId") + .HasColumnType("integer"); + + b.Property<int>("TagDefinitionObjectId") + .HasColumnType("integer"); + + b.HasKey("ImplicitTagsObjectId", "TagDefinitionObjectId"); + + b.HasIndex("TagDefinitionObjectId"); + + b.ToTable("TagDefinitionTagDefinition"); + }); + + modelBuilder.Entity("HyperBooru.Media", b => + { + b.HasBaseType("HyperBooru.HBObject"); + + b.Property<int>("CurrentUploadedFileId") + .HasColumnType("integer"); + + b.Property<string>("LongDescription") + .HasColumnType("text"); + + b.Property<string>("ShortDescription") + .HasColumnType("text"); + + b.HasIndex("CurrentUploadedFileId") + .IsUnique(); + + b.ToTable("Media", (string)null); + }); + + modelBuilder.Entity("HyperBooru.Tag", b => + { + b.HasBaseType("HyperBooru.HBObject"); + + b.Property<DateTime>("CreateTime") + .HasColumnType("timestamp with time zone"); + + b.Property<int>("TagDefinitionId") + .HasColumnType("integer"); + + b.Property<int>("TargetObjectId") + .HasColumnType("integer"); + + b.HasIndex("TagDefinitionId"); + + b.HasIndex("TargetObjectId"); + + b.ToTable("Tags", (string)null); + }); + + modelBuilder.Entity("HyperBooru.TagDefinition", b => + { + b.HasBaseType("HyperBooru.HBObject"); + + b.Property<string>("Alias") + .HasColumnType("text"); + + b.Property<string>("Name") + .IsRequired() + .HasColumnType("text"); + + b.Property<string>("Namespace") + .HasColumnType("text"); + + b.Property<int>("Source") + .HasColumnType("integer"); + + b.ToTable("TagDefinitions", (string)null); + + b.HasData( + new + { + ObjectId = -1, + Guid = new Guid("ebdad4f8-455a-4351-8017-1d4854d6fa38"), + Name = "nsfw", + Source = 0 + }, + new + { + ObjectId = -2, + Guid = new Guid("ea212801-5bcc-4c0e-814f-fb9d30db58bc"), + Name = "ingest", + Source = 0 + }); + }); + + modelBuilder.Entity("HyperBooru.UploadedFile", b => + { + b.HasBaseType("HyperBooru.HBObject"); + + b.Property<string>("Checksum") + .IsRequired() + .HasColumnType("text"); + + b.Property<bool>("ChecksumVerified") + .HasColumnType("boolean"); + + b.Property<DateTime?>("CreateTime") + .HasColumnType("timestamp with time zone"); + + b.Property<string>("Filename") + .HasColumnType("text"); + + b.Property<int?>("Height") + .HasColumnType("integer"); + + b.Property<DateTime?>("LastAccessTime") + .HasColumnType("timestamp with time zone"); + + b.Property<DateTime?>("LastWriteTime") + .HasColumnType("timestamp with time zone"); + + b.Property<long>("Length") + .HasColumnType("bigint"); + + b.Property<int>("MediaObjectId") + .HasColumnType("integer"); + + b.Property<string>("MimeType") + .IsRequired() + .HasColumnType("text"); + + b.Property<DateTime>("UploadTime") + .HasColumnType("timestamp with time zone"); + + b.Property<int?>("Width") + .HasColumnType("integer"); + + b.HasIndex("MediaObjectId"); + + b.ToTable("UploadedFiles", (string)null); + }); + + modelBuilder.Entity("HyperBooru.OcrData", b => + { + b.HasOne("HyperBooru.Media", "Media") + .WithOne("OcrData") + .HasForeignKey("HyperBooru.OcrData", "MediaId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.Navigation("Media"); + }); + + modelBuilder.Entity("TagDefinitionTagDefinition", b => + { + b.HasOne("HyperBooru.TagDefinition", null) + .WithMany() + .HasForeignKey("ImplicitTagsObjectId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.HasOne("HyperBooru.TagDefinition", null) + .WithMany() + .HasForeignKey("TagDefinitionObjectId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + }); + + modelBuilder.Entity("HyperBooru.Media", b => + { + b.HasOne("HyperBooru.UploadedFile", "CurrentUploadedFile") + .WithOne() + .HasForeignKey("HyperBooru.Media", "CurrentUploadedFileId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.HasOne("HyperBooru.HBObject", null) + .WithOne() + .HasForeignKey("HyperBooru.Media", "ObjectId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.Navigation("CurrentUploadedFile"); + }); + + modelBuilder.Entity("HyperBooru.Tag", b => + { + b.HasOne("HyperBooru.HBObject", null) + .WithOne() + .HasForeignKey("HyperBooru.Tag", "ObjectId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.HasOne("HyperBooru.TagDefinition", "TagDefinition") + .WithMany() + .HasForeignKey("TagDefinitionId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.HasOne("HyperBooru.HBObject", "Target") + .WithMany("Tags") + .HasForeignKey("TargetObjectId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.Navigation("TagDefinition"); + + b.Navigation("Target"); + }); + + modelBuilder.Entity("HyperBooru.TagDefinition", b => + { + b.HasOne("HyperBooru.HBObject", null) + .WithOne() + .HasForeignKey("HyperBooru.TagDefinition", "ObjectId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + }); + + modelBuilder.Entity("HyperBooru.UploadedFile", b => + { + b.HasOne("HyperBooru.Media", "Media") + .WithMany("UploadedFiles") + .HasForeignKey("MediaObjectId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.HasOne("HyperBooru.HBObject", null) + .WithOne() + .HasForeignKey("HyperBooru.UploadedFile", "ObjectId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.Navigation("Media"); + }); + + modelBuilder.Entity("HyperBooru.HBObject", b => + { + b.Navigation("Tags"); + }); + + modelBuilder.Entity("HyperBooru.Media", b => + { + b.Navigation("OcrData"); + + b.Navigation("UploadedFiles"); + }); +#pragma warning restore 612, 618 + } + } +} diff --git a/Migrations/20230905172129_UploadedFileMetadata.cs b/Migrations/20230905172129_UploadedFileMetadata.cs new file mode 100644 index 0000000..549ede8 --- /dev/null +++ b/Migrations/20230905172129_UploadedFileMetadata.cs @@ -0,0 +1,132 @@ +using Microsoft.EntityFrameworkCore.Migrations; + +#nullable disable + +namespace HyperBooru.Migrations +{ + /// <inheritdoc /> + public partial class UploadedFileMetadata : Migration + { + /// <inheritdoc /> + protected override void Up(MigrationBuilder migrationBuilder) + { + migrationBuilder.RenameColumn( + name: "OriginalChecksum", + table: "UploadedFiles", + newName: "Checksum"); + + migrationBuilder.AddColumn<string>( + name: "MimeType", + table: "UploadedFiles", + type: "text", + nullable: true); + + migrationBuilder.AddColumn<int>( + name: "Height", + table: "UploadedFiles", + type: "integer", + nullable: true); + + migrationBuilder.AddColumn<int>( + name: "Width", + table: "UploadedFiles", + type: "integer", + nullable: true); + + migrationBuilder.Sql(@" + UPDATE + ""UploadedFiles"" + SET + ""MimeType"" = m.""MimeType"", + ""Width"" = m.""Width"", + ""Height"" = m.""Height"" + FROM + (SELECT + ""ObjectId"", + ""MimeType"", + ""Width"", + ""Height"" + FROM + ""Media"") AS m + WHERE + ""UploadedFiles"".""MediaObjectId"" = m.""ObjectId"""); + + migrationBuilder.Sql(@" + ALTER TABLE + ""UploadedFiles"" + ALTER COLUMN + ""MimeType"" + SET NOT NULL"); + + migrationBuilder.AlterColumn<string>( + name: "MimeType", + table: "UploadedFiles", + nullable: false); + + migrationBuilder.DropColumn( + name: "Checksum", + table: "Media"); + + migrationBuilder.DropColumn( + name: "Height", + table: "Media"); + + migrationBuilder.DropColumn( + name: "MimeType", + table: "Media"); + + migrationBuilder.DropColumn( + name: "Width", + table: "Media"); + } + + /// <inheritdoc /> + protected override void Down(MigrationBuilder migrationBuilder) + { + migrationBuilder.DropColumn( + name: "Checksum", + table: "UploadedFiles"); + + migrationBuilder.DropColumn( + name: "Height", + table: "UploadedFiles"); + + migrationBuilder.DropColumn( + name: "Width", + table: "UploadedFiles"); + + migrationBuilder.RenameColumn( + name: "MimeType", + table: "UploadedFiles", + newName: "OriginalChecksum"); + + migrationBuilder.AddColumn<string>( + name: "Checksum", + table: "Media", + type: "text", + nullable: false, + defaultValue: ""); + + migrationBuilder.AddColumn<int>( + name: "Height", + table: "Media", + type: "integer", + nullable: false, + defaultValue: 0); + + migrationBuilder.AddColumn<string>( + name: "MimeType", + table: "Media", + type: "text", + nullable: false, + defaultValue: ""); + + migrationBuilder.AddColumn<int>( + name: "Width", + table: "Media", + type: "integer", + nullable: false, + defaultValue: 0); + } + } +} diff --git a/Migrations/HBContextModelSnapshot.cs b/Migrations/HBContextModelSnapshot.cs index 81ee485..a24b920 100644 --- a/Migrations/HBContextModelSnapshot.cs +++ b/Migrations/HBContextModelSnapshot.cs @@ -91,29 +91,15 @@ namespace HyperBooru.Migrations { b.HasBaseType("HyperBooru.HBObject"); - b.Property<string>("Checksum") - .IsRequired() - .HasColumnType("text"); - b.Property<int>("CurrentUploadedFileId") .HasColumnType("integer"); - b.Property<int>("Height") - .HasColumnType("integer"); - b.Property<string>("LongDescription") .HasColumnType("text"); - b.Property<string>("MimeType") - .IsRequired() - .HasColumnType("text"); - b.Property<string>("ShortDescription") .HasColumnType("text"); - b.Property<int>("Width") - .HasColumnType("integer"); - b.HasIndex("CurrentUploadedFileId") .IsUnique(); @@ -180,6 +166,10 @@ namespace HyperBooru.Migrations { b.HasBaseType("HyperBooru.HBObject"); + b.Property<string>("Checksum") + .IsRequired() + .HasColumnType("text"); + b.Property<bool>("ChecksumVerified") .HasColumnType("boolean"); @@ -189,6 +179,9 @@ namespace HyperBooru.Migrations b.Property<string>("Filename") .HasColumnType("text"); + b.Property<int?>("Height") + .HasColumnType("integer"); + b.Property<DateTime?>("LastAccessTime") .HasColumnType("timestamp with time zone"); @@ -201,13 +194,16 @@ namespace HyperBooru.Migrations b.Property<int>("MediaObjectId") .HasColumnType("integer"); - b.Property<string>("OriginalChecksum") + b.Property<string>("MimeType") .IsRequired() .HasColumnType("text"); b.Property<DateTime>("UploadTime") .HasColumnType("timestamp with time zone"); + b.Property<int?>("Width") + .HasColumnType("integer"); + b.HasIndex("MediaObjectId"); b.ToTable("UploadedFiles", (string)null); |
