// using System; using API.Schema.Contexts; using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Infrastructure; using Microsoft.EntityFrameworkCore.Storage.ValueConversion; using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata; #nullable disable namespace API.Migrations.pgsql { [DbContext(typeof(PgsqlContext))] partial class PgsqlContextModelSnapshot : ModelSnapshot { protected override void BuildModel(ModelBuilder modelBuilder) { #pragma warning disable 612, 618 modelBuilder .HasAnnotation("ProductVersion", "9.0.3") .HasAnnotation("Relational:MaxIdentifierLength", 63); NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder); modelBuilder.Entity("API.Schema.Author", b => { b.Property("AuthorId") .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("AuthorName") .IsRequired() .HasMaxLength(128) .HasColumnType("character varying(128)"); b.HasKey("AuthorId"); b.ToTable("Authors"); }); modelBuilder.Entity("API.Schema.Chapter", b => { b.Property("ChapterId") .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("ChapterNumber") .IsRequired() .HasMaxLength(10) .HasColumnType("character varying(10)"); b.Property("Downloaded") .HasColumnType("boolean"); b.Property("FileName") .IsRequired() .HasMaxLength(256) .HasColumnType("character varying(256)"); b.Property("ParentMangaId") .IsRequired() .HasColumnType("character varying(64)"); b.Property("Title") .HasMaxLength(256) .HasColumnType("character varying(256)"); b.Property("Url") .IsRequired() .HasMaxLength(2048) .HasColumnType("character varying(2048)"); b.Property("VolumeNumber") .HasColumnType("integer"); b.HasKey("ChapterId"); b.HasIndex("ParentMangaId"); b.ToTable("Chapters"); }); modelBuilder.Entity("API.Schema.Jobs.Job", b => { b.Property("JobId") .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("Enabled") .HasColumnType("boolean"); b.Property("JobType") .HasColumnType("smallint"); b.Property("LastExecution") .HasColumnType("timestamp with time zone"); b.Property("ParentJobId") .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("RecurrenceMs") .HasColumnType("numeric(20,0)"); b.Property("state") .HasColumnType("smallint"); b.HasKey("JobId"); b.HasIndex("ParentJobId"); b.ToTable("Jobs"); b.HasDiscriminator("JobType"); b.UseTphMappingStrategy(); }); modelBuilder.Entity("API.Schema.LocalLibrary", b => { b.Property("LocalLibraryId") .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("BasePath") .IsRequired() .HasMaxLength(256) .HasColumnType("character varying(256)"); b.Property("LibraryName") .IsRequired() .HasMaxLength(512) .HasColumnType("character varying(512)"); b.HasKey("LocalLibraryId"); b.ToTable("LocalLibraries"); }); modelBuilder.Entity("API.Schema.Manga", b => { b.Property("MangaId") .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("CoverFileNameInCache") .HasMaxLength(512) .HasColumnType("character varying(512)"); b.Property("CoverUrl") .IsRequired() .HasMaxLength(512) .HasColumnType("character varying(512)"); b.Property("Description") .IsRequired() .HasColumnType("text"); b.Property("DirectoryName") .IsRequired() .HasMaxLength(1024) .HasColumnType("character varying(1024)"); b.Property("IdOnConnectorSite") .IsRequired() .HasMaxLength(256) .HasColumnType("character varying(256)"); b.Property("IgnoreChaptersBefore") .HasColumnType("real"); b.Property("LibraryId") .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("MangaConnectorName") .IsRequired() .HasMaxLength(32) .HasColumnType("character varying(32)"); b.Property("Name") .IsRequired() .HasMaxLength(512) .HasColumnType("character varying(512)"); b.Property("OriginalLanguage") .HasMaxLength(8) .HasColumnType("character varying(8)"); b.Property("ReleaseStatus") .HasColumnType("smallint"); b.Property("WebsiteUrl") .IsRequired() .HasMaxLength(512) .HasColumnType("character varying(512)"); b.Property("Year") .HasColumnType("bigint"); b.HasKey("MangaId"); b.HasIndex("LibraryId"); b.HasIndex("MangaConnectorName"); b.ToTable("Mangas"); }); modelBuilder.Entity("API.Schema.MangaConnectors.MangaConnector", b => { b.Property("Name") .HasMaxLength(32) .HasColumnType("character varying(32)"); b.PrimitiveCollection("BaseUris") .IsRequired() .HasMaxLength(256) .HasColumnType("text[]"); b.Property("Enabled") .HasColumnType("boolean"); b.Property("IconUrl") .IsRequired() .HasMaxLength(2048) .HasColumnType("character varying(2048)"); b.PrimitiveCollection("SupportedLanguages") .IsRequired() .HasMaxLength(8) .HasColumnType("text[]"); b.HasKey("Name"); b.ToTable("MangaConnectors"); b.HasDiscriminator("Name").HasValue("MangaConnector"); b.UseTphMappingStrategy(); }); modelBuilder.Entity("API.Schema.MangaTag", b => { b.Property("Tag") .HasMaxLength(64) .HasColumnType("character varying(64)"); b.HasKey("Tag"); b.ToTable("Tags"); }); modelBuilder.Entity("AuthorToManga", b => { b.Property("AuthorIds") .HasColumnType("character varying(64)"); b.Property("MangaIds") .HasColumnType("character varying(64)"); b.HasKey("AuthorIds", "MangaIds"); b.HasIndex("MangaIds"); b.ToTable("AuthorToManga"); }); modelBuilder.Entity("JobJob", b => { b.Property("DependsOnJobsJobId") .HasColumnType("character varying(64)"); b.Property("JobId") .HasColumnType("character varying(64)"); b.HasKey("DependsOnJobsJobId", "JobId"); b.HasIndex("JobId"); b.ToTable("JobJob"); }); modelBuilder.Entity("MangaTagToManga", b => { b.Property("MangaTagIds") .HasColumnType("character varying(64)"); b.Property("MangaIds") .HasColumnType("character varying(64)"); b.HasKey("MangaTagIds", "MangaIds"); b.HasIndex("MangaIds"); b.ToTable("MangaTagToManga"); }); modelBuilder.Entity("API.Schema.Jobs.DownloadAvailableChaptersJob", b => { b.HasBaseType("API.Schema.Jobs.Job"); b.Property("MangaId") .IsRequired() .HasMaxLength(64) .HasColumnType("character varying(64)"); b.HasIndex("MangaId"); b.ToTable("Jobs", t => { t.Property("MangaId") .HasColumnName("DownloadAvailableChaptersJob_MangaId"); }); b.HasDiscriminator().HasValue((byte)1); }); modelBuilder.Entity("API.Schema.Jobs.DownloadMangaCoverJob", b => { b.HasBaseType("API.Schema.Jobs.Job"); b.Property("MangaId") .IsRequired() .HasMaxLength(64) .HasColumnType("character varying(64)"); b.HasIndex("MangaId"); b.HasDiscriminator().HasValue((byte)4); }); modelBuilder.Entity("API.Schema.Jobs.DownloadSingleChapterJob", b => { b.HasBaseType("API.Schema.Jobs.Job"); b.Property("ChapterId") .IsRequired() .HasMaxLength(64) .HasColumnType("character varying(64)"); b.HasIndex("ChapterId"); b.HasDiscriminator().HasValue((byte)0); }); modelBuilder.Entity("API.Schema.Jobs.MoveFileOrFolderJob", b => { b.HasBaseType("API.Schema.Jobs.Job"); b.Property("FromLocation") .IsRequired() .HasMaxLength(256) .HasColumnType("character varying(256)"); b.Property("ToLocation") .IsRequired() .HasMaxLength(256) .HasColumnType("character varying(256)"); b.HasDiscriminator().HasValue((byte)3); }); modelBuilder.Entity("API.Schema.Jobs.MoveMangaLibraryJob", b => { b.HasBaseType("API.Schema.Jobs.Job"); b.Property("MangaId") .IsRequired() .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("ToLibraryId") .IsRequired() .HasMaxLength(64) .HasColumnType("character varying(64)"); b.HasIndex("MangaId"); b.HasIndex("ToLibraryId"); b.ToTable("Jobs", t => { t.Property("MangaId") .HasColumnName("MoveMangaLibraryJob_MangaId"); }); b.HasDiscriminator().HasValue((byte)7); }); modelBuilder.Entity("API.Schema.Jobs.RetrieveChaptersJob", b => { b.HasBaseType("API.Schema.Jobs.Job"); b.Property("Language") .IsRequired() .HasMaxLength(8) .HasColumnType("character varying(8)"); b.Property("MangaId") .IsRequired() .HasMaxLength(64) .HasColumnType("character varying(64)"); b.HasIndex("MangaId"); b.ToTable("Jobs", t => { t.Property("MangaId") .HasColumnName("RetrieveChaptersJob_MangaId"); }); b.HasDiscriminator().HasValue((byte)5); }); modelBuilder.Entity("API.Schema.Jobs.UpdateFilesDownloadedJob", b => { b.HasBaseType("API.Schema.Jobs.Job"); b.Property("MangaId") .IsRequired() .HasMaxLength(64) .HasColumnType("character varying(64)"); b.HasIndex("MangaId"); b.ToTable("Jobs", t => { t.Property("MangaId") .HasColumnName("UpdateFilesDownloadedJob_MangaId"); }); b.HasDiscriminator().HasValue((byte)6); }); modelBuilder.Entity("API.Schema.MangaConnectors.Global", b => { b.HasBaseType("API.Schema.MangaConnectors.MangaConnector"); b.HasDiscriminator().HasValue("Global"); }); modelBuilder.Entity("API.Schema.MangaConnectors.MangaDex", b => { b.HasBaseType("API.Schema.MangaConnectors.MangaConnector"); b.HasDiscriminator().HasValue("MangaDex"); }); modelBuilder.Entity("API.Schema.Chapter", b => { b.HasOne("API.Schema.Manga", "ParentManga") .WithMany("Chapters") .HasForeignKey("ParentMangaId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("ParentManga"); }); modelBuilder.Entity("API.Schema.Jobs.Job", b => { b.HasOne("API.Schema.Jobs.Job", "ParentJob") .WithMany() .HasForeignKey("ParentJobId") .OnDelete(DeleteBehavior.Cascade); b.Navigation("ParentJob"); }); modelBuilder.Entity("API.Schema.Manga", b => { b.HasOne("API.Schema.LocalLibrary", "Library") .WithMany() .HasForeignKey("LibraryId") .OnDelete(DeleteBehavior.SetNull); b.HasOne("API.Schema.MangaConnectors.MangaConnector", "MangaConnector") .WithMany() .HasForeignKey("MangaConnectorName") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.OwnsMany("API.Schema.Link", "Links", b1 => { b1.Property("LinkId") .HasMaxLength(64) .HasColumnType("character varying(64)"); b1.Property("LinkProvider") .IsRequired() .HasMaxLength(64) .HasColumnType("character varying(64)"); b1.Property("LinkUrl") .IsRequired() .HasMaxLength(2048) .HasColumnType("character varying(2048)"); b1.Property("MangaId") .IsRequired() .HasColumnType("character varying(64)"); b1.HasKey("LinkId"); b1.HasIndex("MangaId"); b1.ToTable("Link"); b1.WithOwner() .HasForeignKey("MangaId"); }); b.OwnsMany("API.Schema.MangaAltTitle", "AltTitles", b1 => { b1.Property("AltTitleId") .HasMaxLength(64) .HasColumnType("character varying(64)"); b1.Property("Language") .IsRequired() .HasMaxLength(8) .HasColumnType("character varying(8)"); b1.Property("MangaId") .IsRequired() .HasColumnType("character varying(64)"); b1.Property("Title") .IsRequired() .HasMaxLength(256) .HasColumnType("character varying(256)"); b1.HasKey("AltTitleId"); b1.HasIndex("MangaId"); b1.ToTable("MangaAltTitle"); b1.WithOwner() .HasForeignKey("MangaId"); }); b.Navigation("AltTitles"); b.Navigation("Library"); b.Navigation("Links"); b.Navigation("MangaConnector"); }); modelBuilder.Entity("AuthorToManga", b => { b.HasOne("API.Schema.Author", null) .WithMany() .HasForeignKey("AuthorIds") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("API.Schema.Manga", null) .WithMany() .HasForeignKey("MangaIds") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("JobJob", b => { b.HasOne("API.Schema.Jobs.Job", null) .WithMany() .HasForeignKey("DependsOnJobsJobId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("API.Schema.Jobs.Job", null) .WithMany() .HasForeignKey("JobId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("MangaTagToManga", b => { b.HasOne("API.Schema.Manga", null) .WithMany() .HasForeignKey("MangaIds") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("API.Schema.MangaTag", null) .WithMany() .HasForeignKey("MangaTagIds") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("API.Schema.Jobs.DownloadAvailableChaptersJob", b => { b.HasOne("API.Schema.Manga", "Manga") .WithMany() .HasForeignKey("MangaId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Manga"); }); modelBuilder.Entity("API.Schema.Jobs.DownloadMangaCoverJob", b => { b.HasOne("API.Schema.Manga", "Manga") .WithMany() .HasForeignKey("MangaId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Manga"); }); modelBuilder.Entity("API.Schema.Jobs.DownloadSingleChapterJob", b => { b.HasOne("API.Schema.Chapter", "Chapter") .WithMany() .HasForeignKey("ChapterId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Chapter"); }); modelBuilder.Entity("API.Schema.Jobs.MoveMangaLibraryJob", b => { b.HasOne("API.Schema.Manga", "Manga") .WithMany() .HasForeignKey("MangaId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("API.Schema.LocalLibrary", "ToLibrary") .WithMany() .HasForeignKey("ToLibraryId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Manga"); b.Navigation("ToLibrary"); }); modelBuilder.Entity("API.Schema.Jobs.RetrieveChaptersJob", b => { b.HasOne("API.Schema.Manga", "Manga") .WithMany() .HasForeignKey("MangaId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Manga"); }); modelBuilder.Entity("API.Schema.Jobs.UpdateFilesDownloadedJob", b => { b.HasOne("API.Schema.Manga", "Manga") .WithMany() .HasForeignKey("MangaId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Manga"); }); modelBuilder.Entity("API.Schema.Manga", b => { b.Navigation("Chapters"); }); #pragma warning restore 612, 618 } } }