mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-11-04 03:27:05 -05:00 
			
		
		
		
	* Readme refactored to be more clean and clear, taking inspiration from wiki.js's readme. * Initial backend for Collections and basic metadata implemented. * More build flavors for Raspberry Pi users and updated Install since we don't need users to set their own JWT Token Key. Update a typo in appsettings.json file for prod. * Fixed #224. Sort before getting a First?Last() chatper * The rough ability to add and get series metadata and tags. * Fix a bug on getting metadata for when it doesn't exist. * Fixed a bug where flattening directories with some unique filenames could cause reading order of images to be out of order. * Added a seed code to ensure all series have SeriesMetdata * Ensure all instances of opening an epub is using "using" so we don't lock the file. When we have a malformed html file, log the issues and inform the user we can't open the file. * Book reader now handles @Import "" statements in CSS and inlines the css into css file that references them. This allows for them to be scoped. In addition, if the html or body tag had classes, we now send back a single div with those classes. * Fixed GetSeriesDtoForCollectionAsync which was not properly returning series * Implemented cover image for collection tag. Fixed an issue in metadata update call. * Add check for user access when resolving series for a collection tag. When asking for all tags, if the user is not an admin, only give promotoed tags back. * Implemented updateTag api * Implemented the ability to update series the tags have access to. * Cleanup, sorting, and null check * More sorting changes * Ensure we can delete tags when editing a series tags * Fix order of update to make sure a tag is properly deleted * Code smells
		
			
				
	
	
		
			856 lines
		
	
	
		
			28 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			856 lines
		
	
	
		
			28 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
// <auto-generated />
 | 
						|
using System;
 | 
						|
using API.Data;
 | 
						|
using Microsoft.EntityFrameworkCore;
 | 
						|
using Microsoft.EntityFrameworkCore.Infrastructure;
 | 
						|
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
 | 
						|
 | 
						|
namespace API.Data.Migrations
 | 
						|
{
 | 
						|
    [DbContext(typeof(DataContext))]
 | 
						|
    partial class DataContextModelSnapshot : ModelSnapshot
 | 
						|
    {
 | 
						|
        protected override void BuildModel(ModelBuilder modelBuilder)
 | 
						|
        {
 | 
						|
#pragma warning disable 612, 618
 | 
						|
            modelBuilder
 | 
						|
                .HasAnnotation("ProductVersion", "5.0.4");
 | 
						|
 | 
						|
            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");
 | 
						|
                });
 | 
						|
 | 
						|
            modelBuilder.Entity("API.Entities.AppUser", b =>
 | 
						|
                {
 | 
						|
                    b.Property<int>("Id")
 | 
						|
                        .ValueGeneratedOnAdd()
 | 
						|
                        .HasColumnType("INTEGER");
 | 
						|
 | 
						|
                    b.Property<int>("AccessFailedCount")
 | 
						|
                        .HasColumnType("INTEGER");
 | 
						|
 | 
						|
                    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");
 | 
						|
                });
 | 
						|
 | 
						|
            modelBuilder.Entity("API.Entities.AppUserPreferences", b =>
 | 
						|
                {
 | 
						|
                    b.Property<int>("Id")
 | 
						|
                        .ValueGeneratedOnAdd()
 | 
						|
                        .HasColumnType("INTEGER");
 | 
						|
 | 
						|
                    b.Property<int>("AppUserId")
 | 
						|
                        .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<bool>("BookReaderTapToPaginate")
 | 
						|
                        .HasColumnType("INTEGER");
 | 
						|
 | 
						|
                    b.Property<int>("PageSplitOption")
 | 
						|
                        .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<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");
 | 
						|
                });
 | 
						|
 | 
						|
            modelBuilder.Entity("API.Entities.Chapter", b =>
 | 
						|
                {
 | 
						|
                    b.Property<int>("Id")
 | 
						|
                        .ValueGeneratedOnAdd()
 | 
						|
                        .HasColumnType("INTEGER");
 | 
						|
 | 
						|
                    b.Property<byte[]>("CoverImage")
 | 
						|
                        .HasColumnType("BLOB");
 | 
						|
 | 
						|
                    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<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<byte[]>("CoverImage")
 | 
						|
                        .HasColumnType("BLOB");
 | 
						|
 | 
						|
                    b.Property<string>("NormalizedTitle")
 | 
						|
                        .HasColumnType("TEXT");
 | 
						|
 | 
						|
                    b.Property<bool>("Promoted")
 | 
						|
                        .HasColumnType("INTEGER");
 | 
						|
 | 
						|
                    b.Property<uint>("RowVersion")
 | 
						|
                        .IsConcurrencyToken()
 | 
						|
                        .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.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<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.Series", b =>
 | 
						|
                {
 | 
						|
                    b.Property<int>("Id")
 | 
						|
                        .ValueGeneratedOnAdd()
 | 
						|
                        .HasColumnType("INTEGER");
 | 
						|
 | 
						|
                    b.Property<byte[]>("CoverImage")
 | 
						|
                        .HasColumnType("BLOB");
 | 
						|
 | 
						|
                    b.Property<DateTime>("Created")
 | 
						|
                        .HasColumnType("TEXT");
 | 
						|
 | 
						|
                    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.Property<string>("Summary")
 | 
						|
                        .HasColumnType("TEXT");
 | 
						|
 | 
						|
                    b.HasKey("Id");
 | 
						|
 | 
						|
                    b.HasIndex("LibraryId");
 | 
						|
 | 
						|
                    b.HasIndex("Name", "NormalizedName", "LocalizedName", "LibraryId")
 | 
						|
                        .IsUnique();
 | 
						|
 | 
						|
                    b.ToTable("Series");
 | 
						|
                });
 | 
						|
 | 
						|
            modelBuilder.Entity("API.Entities.SeriesMetadata", b =>
 | 
						|
                {
 | 
						|
                    b.Property<int>("Id")
 | 
						|
                        .ValueGeneratedOnAdd()
 | 
						|
                        .HasColumnType("INTEGER");
 | 
						|
 | 
						|
                    b.Property<uint>("RowVersion")
 | 
						|
                        .IsConcurrencyToken()
 | 
						|
                        .HasColumnType("INTEGER");
 | 
						|
 | 
						|
                    b.Property<int>("SeriesId")
 | 
						|
                        .HasColumnType("INTEGER");
 | 
						|
 | 
						|
                    b.HasKey("Id");
 | 
						|
 | 
						|
                    b.HasIndex("SeriesId")
 | 
						|
                        .IsUnique();
 | 
						|
 | 
						|
                    b.HasIndex("Id", "SeriesId")
 | 
						|
                        .IsUnique();
 | 
						|
 | 
						|
                    b.ToTable("SeriesMetadata");
 | 
						|
                });
 | 
						|
 | 
						|
            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<byte[]>("CoverImage")
 | 
						|
                        .HasColumnType("BLOB");
 | 
						|
 | 
						|
                    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("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("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");
 | 
						|
                });
 | 
						|
 | 
						|
            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");
 | 
						|
                });
 | 
						|
 | 
						|
            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");
 | 
						|
                });
 | 
						|
 | 
						|
            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");
 | 
						|
                });
 | 
						|
 | 
						|
            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.Series", b =>
 | 
						|
                {
 | 
						|
                    b.HasOne("API.Entities.Library", "Library")
 | 
						|
                        .WithMany("Series")
 | 
						|
                        .HasForeignKey("LibraryId")
 | 
						|
                        .OnDelete(DeleteBehavior.Cascade)
 | 
						|
                        .IsRequired();
 | 
						|
 | 
						|
                    b.Navigation("Library");
 | 
						|
                });
 | 
						|
 | 
						|
            modelBuilder.Entity("API.Entities.SeriesMetadata", b =>
 | 
						|
                {
 | 
						|
                    b.HasOne("API.Entities.Series", "Series")
 | 
						|
                        .WithOne("Metadata")
 | 
						|
                        .HasForeignKey("API.Entities.SeriesMetadata", "SeriesId")
 | 
						|
                        .OnDelete(DeleteBehavior.Cascade)
 | 
						|
                        .IsRequired();
 | 
						|
 | 
						|
                    b.Navigation("Series");
 | 
						|
                });
 | 
						|
 | 
						|
            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("CollectionTagSeriesMetadata", b =>
 | 
						|
                {
 | 
						|
                    b.HasOne("API.Entities.CollectionTag", null)
 | 
						|
                        .WithMany()
 | 
						|
                        .HasForeignKey("CollectionTagsId")
 | 
						|
                        .OnDelete(DeleteBehavior.Cascade)
 | 
						|
                        .IsRequired();
 | 
						|
 | 
						|
                    b.HasOne("API.Entities.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("API.Entities.AppRole", b =>
 | 
						|
                {
 | 
						|
                    b.Navigation("UserRoles");
 | 
						|
                });
 | 
						|
 | 
						|
            modelBuilder.Entity("API.Entities.AppUser", b =>
 | 
						|
                {
 | 
						|
                    b.Navigation("Progresses");
 | 
						|
 | 
						|
                    b.Navigation("Ratings");
 | 
						|
 | 
						|
                    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.Series", b =>
 | 
						|
                {
 | 
						|
                    b.Navigation("Metadata");
 | 
						|
 | 
						|
                    b.Navigation("Volumes");
 | 
						|
                });
 | 
						|
 | 
						|
            modelBuilder.Entity("API.Entities.Volume", b =>
 | 
						|
                {
 | 
						|
                    b.Navigation("Chapters");
 | 
						|
                });
 | 
						|
#pragma warning restore 612, 618
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |