mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-10-31 02:27:04 -04:00 
			
		
		
		
	* Started with some basic plumbing with comic info parsing updating Series/Volume. * We can now get chapter title from comicInfo.xml * Hooked in the ability to store people into the chapter metadata. * Removed no longer used imports, fixed up some foreign key constraints on deleting series with person linked. * Refactored Summary out of the UI for Series into SeriesMetadata. Updated application to .net 6. There is a bug in metadata code for updating. * Removed the parallel.ForEach with a normal foreach which lets us use async. For I/O heavy code, shouldn't change much. * Refactored scan code to only check extensions with comic info, fixed a bug on scan events not using correct method name, removed summary field (still buggy) * Fixed a bug where on cancelling a metadata request in modal, underlying button would get stuck in a disabled state. * Changed how metadata selects the first volume to read summary info from. It will now select the first non-special volume rather than Volume 1. * More debugging and found more bugs to fix * Redid all the migrations as one single one. Fixed a bug with GetChapterInfo returning null when ChapterMetadata didn't exist for that Chapter. Fixed an issue with mapper failing on GetChapterMetadata. Started work on adding people and a design for people. * Fixed a bug where checking if file modified now takes into account if file has been processed at least once. Introduced a bug in saving people to series. * Just made code compilable again * Fixed up code. Now people for series and chapters add correctly without any db issues. * Things are working, but I'm not happy with how the management of Person is. I need to take into account that 1 person needs to map to an image and role is arbitrary. * Started adding UI code to showcase chapter metadata * Updated workflow to be .NET 6 * WIP of updating card detail to show the information more clearly and without so many if statements * Removed ChatperMetadata and store on the Chapter itself. Much easier to use and less joins. * Implemented Genre on SeriesMetadata level * Genres and People are now removed from Series level if they are no longer on comicInfo * PeopleHelper is done with unit tests. Everything is working. * Unit tests in place for Genre Helper * Starting on CacheHelper * Finished tests for ShouldUpdateCoverImage. Fixed and added tests in ArchiveService/ScannerService. * CacheHelper is fully tested * Some DI cleanup * Scanner Service now calls GetComicInfo for books. Added ability to update Series Sort name from metadata files (mainly epub as comicinfo doesn't have a field) * Forgot to move a line of code * SortName now populates from metadata (epub only, ComicInfo has no tags) * Cards now show the chapter title name if it's set on hover, else will default back to title. * Fixed a major issue with how MangaFiles were being updated with LastModified, which messed up our logic for avoiding refreshes. * Woohoo, more tests and some refactors to be able to test more services wtih mock filesystem. Fixed an issue where SortName was getting set as first chapter, but the Series was in a group. * Refactored the MangaFile creation code into the DbFactory where we also setup the first LastModified update. * Has file changed bug is now finally fixed * Remove dead genres, refactor genre to use title instead of name. * Refactored out a directory from ShouldUpdateCoverImage() to keep the code clean * Unit tests for ComicInfo on BookService. * Refactored series detail into it's own component * Series-detail now received refresh metadata events to refresh what's on screen * Removed references to Artist on PersonRole as it has no metadata mapping * Security audit * Fixed a benchmark * Updated JWT Token generator to use new methods in .NET 6 * Updated all the docker and build commands to use net6.0 * Commented out sonar scan since it's not setup for net6.0 yet.
		
			
				
	
	
		
			1233 lines
		
	
	
		
			41 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			1233 lines
		
	
	
		
			41 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| // <auto-generated />
 | |
| using System;
 | |
| using API.Data;
 | |
| using Microsoft.EntityFrameworkCore;
 | |
| using Microsoft.EntityFrameworkCore.Infrastructure;
 | |
| using Microsoft.EntityFrameworkCore.Migrations;
 | |
| using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
 | |
| 
 | |
| #nullable disable
 | |
| 
 | |
| namespace API.Data.Migrations
 | |
| {
 | |
|     [DbContext(typeof(DataContext))]
 | |
|     [Migration("20211129231007_RemoveChapterMetadata")]
 | |
|     partial class RemoveChapterMetadata
 | |
|     {
 | |
|         protected override void BuildTargetModel(ModelBuilder modelBuilder)
 | |
|         {
 | |
| #pragma warning disable 612, 618
 | |
|             modelBuilder.HasAnnotation("ProductVersion", "6.0.0");
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppRole", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("ConcurrencyStamp")
 | |
|                         .IsConcurrencyToken()
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("Name")
 | |
|                         .HasMaxLength(256)
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("NormalizedName")
 | |
|                         .HasMaxLength(256)
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("NormalizedName")
 | |
|                         .IsUnique()
 | |
|                         .HasDatabaseName("RoleNameIndex");
 | |
| 
 | |
|                     b.ToTable("AspNetRoles", (string)null);
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppUser", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("AccessFailedCount")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("ApiKey")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("ConcurrencyStamp")
 | |
|                         .IsConcurrencyToken()
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<DateTime>("Created")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("Email")
 | |
|                         .HasMaxLength(256)
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<bool>("EmailConfirmed")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<DateTime>("LastActive")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<bool>("LockoutEnabled")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<DateTimeOffset?>("LockoutEnd")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("NormalizedEmail")
 | |
|                         .HasMaxLength(256)
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("NormalizedUserName")
 | |
|                         .HasMaxLength(256)
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("PasswordHash")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("PhoneNumber")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<bool>("PhoneNumberConfirmed")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<uint>("RowVersion")
 | |
|                         .IsConcurrencyToken()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("SecurityStamp")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<bool>("TwoFactorEnabled")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("UserName")
 | |
|                         .HasMaxLength(256)
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("NormalizedEmail")
 | |
|                         .HasDatabaseName("EmailIndex");
 | |
| 
 | |
|                     b.HasIndex("NormalizedUserName")
 | |
|                         .IsUnique()
 | |
|                         .HasDatabaseName("UserNameIndex");
 | |
| 
 | |
|                     b.ToTable("AspNetUsers", (string)null);
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppUserBookmark", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("AppUserId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("ChapterId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("Page")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("SeriesId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("VolumeId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("AppUserId");
 | |
| 
 | |
|                     b.ToTable("AppUserBookmark");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppUserPreferences", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("AppUserId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<bool>("AutoCloseMenu")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<bool>("BookReaderDarkMode")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("BookReaderFontFamily")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("BookReaderFontSize")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("BookReaderLineSpacing")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("BookReaderMargin")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("BookReaderReadingDirection")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<bool>("BookReaderTapToPaginate")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("PageSplitOption")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("ReaderMode")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("ReadingDirection")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("ScalingOption")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<bool>("SiteDarkMode")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("AppUserId")
 | |
|                         .IsUnique();
 | |
| 
 | |
|                     b.ToTable("AppUserPreferences");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppUserProgress", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("AppUserId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("BookScrollId")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("ChapterId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<DateTime>("Created")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<DateTime>("LastModified")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("PagesRead")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("SeriesId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("VolumeId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("AppUserId");
 | |
| 
 | |
|                     b.ToTable("AppUserProgresses");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppUserRating", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("AppUserId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("Rating")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("Review")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("SeriesId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("AppUserId");
 | |
| 
 | |
|                     b.ToTable("AppUserRating");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppUserRole", b =>
 | |
|                 {
 | |
|                     b.Property<int>("UserId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("RoleId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("UserId", "RoleId");
 | |
| 
 | |
|                     b.HasIndex("RoleId");
 | |
| 
 | |
|                     b.ToTable("AspNetUserRoles", (string)null);
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Chapter", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("CoverImage")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<bool>("CoverImageLocked")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<DateTime>("Created")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<bool>("IsSpecial")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<DateTime>("LastModified")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("Number")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("Pages")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("Range")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("Title")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("TitleName")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("VolumeId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("VolumeId");
 | |
| 
 | |
|                     b.ToTable("Chapter");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.CollectionTag", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("CoverImage")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<bool>("CoverImageLocked")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("NormalizedTitle")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<bool>("Promoted")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<uint>("RowVersion")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("Summary")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("Title")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("Id", "Promoted")
 | |
|                         .IsUnique();
 | |
| 
 | |
|                     b.ToTable("CollectionTag");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.FolderPath", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<DateTime>("LastScanned")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("LibraryId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("Path")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("LibraryId");
 | |
| 
 | |
|                     b.ToTable("FolderPath");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Genre", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("Name")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("NormalizedName")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("NormalizedName")
 | |
|                         .IsUnique();
 | |
| 
 | |
|                     b.ToTable("Genre");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Library", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("CoverImage")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<DateTime>("Created")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<DateTime>("LastModified")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<DateTime>("LastScanned")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("Name")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("Type")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.ToTable("Library");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.MangaFile", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("ChapterId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("FilePath")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("Format")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<DateTime>("LastModified")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("Pages")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("ChapterId");
 | |
| 
 | |
|                     b.ToTable("MangaFile");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Metadata.ChapterMetadata", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("ChapterId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("StoryArc")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("Title")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("Year")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("ChapterId");
 | |
| 
 | |
|                     b.ToTable("ChapterMetadata");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Metadata.SeriesMetadata", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<uint>("RowVersion")
 | |
|                         .IsConcurrencyToken()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("SeriesId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("Summary")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("SeriesId")
 | |
|                         .IsUnique();
 | |
| 
 | |
|                     b.HasIndex("Id", "SeriesId")
 | |
|                         .IsUnique();
 | |
| 
 | |
|                     b.ToTable("SeriesMetadata");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Person", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int?>("ChapterMetadataId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("Name")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("NormalizedName")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("Role")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("ChapterMetadataId");
 | |
| 
 | |
|                     b.ToTable("Person");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.ReadingList", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("AppUserId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<DateTime>("Created")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<DateTime>("LastModified")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<bool>("Promoted")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("Summary")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("Title")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("AppUserId");
 | |
| 
 | |
|                     b.ToTable("ReadingList");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.ReadingListItem", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("ChapterId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("Order")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("ReadingListId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("SeriesId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("VolumeId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("ChapterId");
 | |
| 
 | |
|                     b.HasIndex("ReadingListId");
 | |
| 
 | |
|                     b.HasIndex("SeriesId");
 | |
| 
 | |
|                     b.HasIndex("VolumeId");
 | |
| 
 | |
|                     b.ToTable("ReadingListItem");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Series", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("CoverImage")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<bool>("CoverImageLocked")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<DateTime>("Created")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("Format")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<DateTime>("LastModified")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("LibraryId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("LocalizedName")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("Name")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("NormalizedName")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("OriginalName")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("Pages")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("SortName")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("LibraryId");
 | |
| 
 | |
|                     b.HasIndex("Name", "NormalizedName", "LocalizedName", "LibraryId", "Format")
 | |
|                         .IsUnique();
 | |
| 
 | |
|                     b.ToTable("Series");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.ServerSetting", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Key")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<uint>("RowVersion")
 | |
|                         .IsConcurrencyToken()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("Value")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.HasKey("Key");
 | |
| 
 | |
|                     b.ToTable("ServerSetting");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Volume", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("CoverImage")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<DateTime>("Created")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<DateTime>("LastModified")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("Name")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("Number")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("Pages")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("SeriesId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("SeriesId");
 | |
| 
 | |
|                     b.ToTable("Volume");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("AppUserLibrary", b =>
 | |
|                 {
 | |
|                     b.Property<int>("AppUsersId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("LibrariesId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("AppUsersId", "LibrariesId");
 | |
| 
 | |
|                     b.HasIndex("LibrariesId");
 | |
| 
 | |
|                     b.ToTable("AppUserLibrary");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("ChapterPerson", b =>
 | |
|                 {
 | |
|                     b.Property<int>("ChapterMetadatasId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("PeopleId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("ChapterMetadatasId", "PeopleId");
 | |
| 
 | |
|                     b.HasIndex("PeopleId");
 | |
| 
 | |
|                     b.ToTable("ChapterPerson");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("CollectionTagSeriesMetadata", b =>
 | |
|                 {
 | |
|                     b.Property<int>("CollectionTagsId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("SeriesMetadatasId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("CollectionTagsId", "SeriesMetadatasId");
 | |
| 
 | |
|                     b.HasIndex("SeriesMetadatasId");
 | |
| 
 | |
|                     b.ToTable("CollectionTagSeriesMetadata");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("GenreSeriesMetadata", b =>
 | |
|                 {
 | |
|                     b.Property<int>("GenresId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("SeriesMetadatasId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("GenresId", "SeriesMetadatasId");
 | |
| 
 | |
|                     b.HasIndex("SeriesMetadatasId");
 | |
| 
 | |
|                     b.ToTable("GenreSeriesMetadata");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim<int>", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("ClaimType")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("ClaimValue")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("RoleId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("RoleId");
 | |
| 
 | |
|                     b.ToTable("AspNetRoleClaims", (string)null);
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim<int>", b =>
 | |
|                 {
 | |
|                     b.Property<int>("Id")
 | |
|                         .ValueGeneratedOnAdd()
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("ClaimType")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("ClaimValue")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("UserId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("Id");
 | |
| 
 | |
|                     b.HasIndex("UserId");
 | |
| 
 | |
|                     b.ToTable("AspNetUserClaims", (string)null);
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin<int>", b =>
 | |
|                 {
 | |
|                     b.Property<string>("LoginProvider")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("ProviderKey")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("ProviderDisplayName")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<int>("UserId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("LoginProvider", "ProviderKey");
 | |
| 
 | |
|                     b.HasIndex("UserId");
 | |
| 
 | |
|                     b.ToTable("AspNetUserLogins", (string)null);
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken<int>", b =>
 | |
|                 {
 | |
|                     b.Property<int>("UserId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<string>("LoginProvider")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("Name")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.Property<string>("Value")
 | |
|                         .HasColumnType("TEXT");
 | |
| 
 | |
|                     b.HasKey("UserId", "LoginProvider", "Name");
 | |
| 
 | |
|                     b.ToTable("AspNetUserTokens", (string)null);
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("PersonSeriesMetadata", b =>
 | |
|                 {
 | |
|                     b.Property<int>("PeopleId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.Property<int>("SeriesMetadatasId")
 | |
|                         .HasColumnType("INTEGER");
 | |
| 
 | |
|                     b.HasKey("PeopleId", "SeriesMetadatasId");
 | |
| 
 | |
|                     b.HasIndex("SeriesMetadatasId");
 | |
| 
 | |
|                     b.ToTable("PersonSeriesMetadata");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppUserBookmark", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.AppUser", "AppUser")
 | |
|                         .WithMany("Bookmarks")
 | |
|                         .HasForeignKey("AppUserId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("AppUser");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppUserPreferences", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.AppUser", "AppUser")
 | |
|                         .WithOne("UserPreferences")
 | |
|                         .HasForeignKey("API.Entities.AppUserPreferences", "AppUserId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("AppUser");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppUserProgress", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.AppUser", "AppUser")
 | |
|                         .WithMany("Progresses")
 | |
|                         .HasForeignKey("AppUserId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("AppUser");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppUserRating", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.AppUser", "AppUser")
 | |
|                         .WithMany("Ratings")
 | |
|                         .HasForeignKey("AppUserId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("AppUser");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppUserRole", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.AppRole", "Role")
 | |
|                         .WithMany("UserRoles")
 | |
|                         .HasForeignKey("RoleId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.HasOne("API.Entities.AppUser", "User")
 | |
|                         .WithMany("UserRoles")
 | |
|                         .HasForeignKey("UserId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("Role");
 | |
| 
 | |
|                     b.Navigation("User");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Chapter", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.Volume", "Volume")
 | |
|                         .WithMany("Chapters")
 | |
|                         .HasForeignKey("VolumeId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("Volume");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.FolderPath", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.Library", "Library")
 | |
|                         .WithMany("Folders")
 | |
|                         .HasForeignKey("LibraryId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("Library");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.MangaFile", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.Chapter", "Chapter")
 | |
|                         .WithMany("Files")
 | |
|                         .HasForeignKey("ChapterId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("Chapter");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Metadata.ChapterMetadata", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.Chapter", "Chapter")
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("ChapterId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("Chapter");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Metadata.SeriesMetadata", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.Series", "Series")
 | |
|                         .WithOne("Metadata")
 | |
|                         .HasForeignKey("API.Entities.Metadata.SeriesMetadata", "SeriesId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("Series");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Person", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.Metadata.ChapterMetadata", null)
 | |
|                         .WithMany("People")
 | |
|                         .HasForeignKey("ChapterMetadataId");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.ReadingList", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.AppUser", "AppUser")
 | |
|                         .WithMany("ReadingLists")
 | |
|                         .HasForeignKey("AppUserId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("AppUser");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.ReadingListItem", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.Chapter", "Chapter")
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("ChapterId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.HasOne("API.Entities.ReadingList", "ReadingList")
 | |
|                         .WithMany("Items")
 | |
|                         .HasForeignKey("ReadingListId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.HasOne("API.Entities.Series", "Series")
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("SeriesId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.HasOne("API.Entities.Volume", "Volume")
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("VolumeId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("Chapter");
 | |
| 
 | |
|                     b.Navigation("ReadingList");
 | |
| 
 | |
|                     b.Navigation("Series");
 | |
| 
 | |
|                     b.Navigation("Volume");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Series", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.Library", "Library")
 | |
|                         .WithMany("Series")
 | |
|                         .HasForeignKey("LibraryId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("Library");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Volume", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.Series", "Series")
 | |
|                         .WithMany("Volumes")
 | |
|                         .HasForeignKey("SeriesId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.Navigation("Series");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("AppUserLibrary", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.AppUser", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("AppUsersId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.HasOne("API.Entities.Library", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("LibrariesId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("ChapterPerson", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.Chapter", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("ChapterMetadatasId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.HasOne("API.Entities.Person", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("PeopleId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("CollectionTagSeriesMetadata", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.CollectionTag", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("CollectionTagsId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.HasOne("API.Entities.Metadata.SeriesMetadata", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("SeriesMetadatasId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("GenreSeriesMetadata", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.Genre", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("GenresId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.HasOne("API.Entities.Metadata.SeriesMetadata", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("SeriesMetadatasId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim<int>", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.AppRole", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("RoleId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim<int>", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.AppUser", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("UserId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin<int>", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.AppUser", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("UserId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken<int>", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.AppUser", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("UserId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("PersonSeriesMetadata", b =>
 | |
|                 {
 | |
|                     b.HasOne("API.Entities.Person", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("PeopleId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
| 
 | |
|                     b.HasOne("API.Entities.Metadata.SeriesMetadata", null)
 | |
|                         .WithMany()
 | |
|                         .HasForeignKey("SeriesMetadatasId")
 | |
|                         .OnDelete(DeleteBehavior.Cascade)
 | |
|                         .IsRequired();
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppRole", b =>
 | |
|                 {
 | |
|                     b.Navigation("UserRoles");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.AppUser", b =>
 | |
|                 {
 | |
|                     b.Navigation("Bookmarks");
 | |
| 
 | |
|                     b.Navigation("Progresses");
 | |
| 
 | |
|                     b.Navigation("Ratings");
 | |
| 
 | |
|                     b.Navigation("ReadingLists");
 | |
| 
 | |
|                     b.Navigation("UserPreferences");
 | |
| 
 | |
|                     b.Navigation("UserRoles");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Chapter", b =>
 | |
|                 {
 | |
|                     b.Navigation("Files");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Library", b =>
 | |
|                 {
 | |
|                     b.Navigation("Folders");
 | |
| 
 | |
|                     b.Navigation("Series");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Metadata.ChapterMetadata", b =>
 | |
|                 {
 | |
|                     b.Navigation("People");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.ReadingList", b =>
 | |
|                 {
 | |
|                     b.Navigation("Items");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Series", b =>
 | |
|                 {
 | |
|                     b.Navigation("Metadata");
 | |
| 
 | |
|                     b.Navigation("Volumes");
 | |
|                 });
 | |
| 
 | |
|             modelBuilder.Entity("API.Entities.Volume", b =>
 | |
|                 {
 | |
|                     b.Navigation("Chapters");
 | |
|                 });
 | |
| #pragma warning restore 612, 618
 | |
|         }
 | |
|     }
 | |
| }
 |