Kyoo/Kyoo.Postgresql/Migrations/20210623174932_Triggers.Designer.cs
2021-06-23 20:15:39 +02:00

1198 lines
45 KiB
C#

// <auto-generated />
using System;
using System.Collections.Generic;
using Kyoo.Models;
using Kyoo.Postgresql;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Microsoft.EntityFrameworkCore.Migrations;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata;
namespace Kyoo.Postgresql.Migrations
{
[DbContext(typeof(PostgresContext))]
[Migration("20210623174932_Triggers")]
partial class Triggers
{
protected override void BuildTargetModel(ModelBuilder modelBuilder)
{
#pragma warning disable 612, 618
modelBuilder
.HasPostgresEnum(null, "item_type", new[] { "show", "movie", "collection" })
.HasPostgresEnum(null, "status", new[] { "finished", "airing", "planned", "unknown" })
.HasPostgresEnum(null, "stream_type", new[] { "unknown", "video", "audio", "subtitle", "attachment" })
.HasAnnotation("Relational:MaxIdentifierLength", 63)
.HasAnnotation("ProductVersion", "5.0.7")
.HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
modelBuilder.Entity("Kyoo.Models.Collection", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("integer")
.HasColumnName("id")
.HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
b.Property<string>("Name")
.HasColumnType("text")
.HasColumnName("name");
b.Property<string>("Overview")
.HasColumnType("text")
.HasColumnName("overview");
b.Property<string>("Poster")
.HasColumnType("text")
.HasColumnName("poster");
b.Property<string>("Slug")
.IsRequired()
.HasColumnType("text")
.HasColumnName("slug");
b.HasKey("ID")
.HasName("pk_collections");
b.HasIndex("Slug")
.IsUnique()
.HasDatabaseName("ix_collections_slug");
b.ToTable("collections");
});
modelBuilder.Entity("Kyoo.Models.Episode", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("integer")
.HasColumnName("id")
.HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
b.Property<int>("AbsoluteNumber")
.HasColumnType("integer")
.HasColumnName("absolute_number");
b.Property<int>("EpisodeNumber")
.HasColumnType("integer")
.HasColumnName("episode_number");
b.Property<string>("Overview")
.HasColumnType("text")
.HasColumnName("overview");
b.Property<string>("Path")
.HasColumnType("text")
.HasColumnName("path");
b.Property<DateTime?>("ReleaseDate")
.HasColumnType("timestamp without time zone")
.HasColumnName("release_date");
b.Property<int?>("SeasonID")
.HasColumnType("integer")
.HasColumnName("season_id");
b.Property<int>("SeasonNumber")
.HasColumnType("integer")
.HasColumnName("season_number");
b.Property<int>("ShowID")
.HasColumnType("integer")
.HasColumnName("show_id");
b.Property<string>("Slug")
.ValueGeneratedOnAddOrUpdate()
.HasColumnType("text")
.HasColumnName("slug");
b.Property<string>("Thumb")
.HasColumnType("text")
.HasColumnName("thumb");
b.Property<string>("Title")
.HasColumnType("text")
.HasColumnName("title");
b.HasKey("ID")
.HasName("pk_episodes");
b.HasIndex("SeasonID")
.HasDatabaseName("ix_episodes_season_id");
b.HasIndex("Slug")
.IsUnique()
.HasDatabaseName("ix_episodes_slug");
b.HasIndex("ShowID", "SeasonNumber", "EpisodeNumber", "AbsoluteNumber")
.IsUnique()
.HasDatabaseName("ix_episodes_show_id_season_number_episode_number_absolute_numb");
b.ToTable("episodes");
});
modelBuilder.Entity("Kyoo.Models.Genre", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("integer")
.HasColumnName("id")
.HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
b.Property<string>("Name")
.HasColumnType("text")
.HasColumnName("name");
b.Property<string>("Slug")
.IsRequired()
.HasColumnType("text")
.HasColumnName("slug");
b.HasKey("ID")
.HasName("pk_genres");
b.HasIndex("Slug")
.IsUnique()
.HasDatabaseName("ix_genres_slug");
b.ToTable("genres");
});
modelBuilder.Entity("Kyoo.Models.Library", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("integer")
.HasColumnName("id")
.HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
b.Property<string>("Name")
.HasColumnType("text")
.HasColumnName("name");
b.Property<string[]>("Paths")
.HasColumnType("text[]")
.HasColumnName("paths");
b.Property<string>("Slug")
.IsRequired()
.HasColumnType("text")
.HasColumnName("slug");
b.HasKey("ID")
.HasName("pk_libraries");
b.HasIndex("Slug")
.IsUnique()
.HasDatabaseName("ix_libraries_slug");
b.ToTable("libraries");
});
modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Collection, Kyoo.Models.Show>", b =>
{
b.Property<int>("FirstID")
.HasColumnType("integer")
.HasColumnName("first_id");
b.Property<int>("SecondID")
.HasColumnType("integer")
.HasColumnName("second_id");
b.HasKey("FirstID", "SecondID")
.HasName("pk_link_collection_show");
b.HasIndex("SecondID")
.HasDatabaseName("ix_link_collection_show_second_id");
b.ToTable("link_collection_show");
});
modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Library, Kyoo.Models.Collection>", b =>
{
b.Property<int>("FirstID")
.HasColumnType("integer")
.HasColumnName("first_id");
b.Property<int>("SecondID")
.HasColumnType("integer")
.HasColumnName("second_id");
b.HasKey("FirstID", "SecondID")
.HasName("pk_link_library_collection");
b.HasIndex("SecondID")
.HasDatabaseName("ix_link_library_collection_second_id");
b.ToTable("link_library_collection");
});
modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Library, Kyoo.Models.Provider>", b =>
{
b.Property<int>("FirstID")
.HasColumnType("integer")
.HasColumnName("first_id");
b.Property<int>("SecondID")
.HasColumnType("integer")
.HasColumnName("second_id");
b.HasKey("FirstID", "SecondID")
.HasName("pk_link_library_provider");
b.HasIndex("SecondID")
.HasDatabaseName("ix_link_library_provider_second_id");
b.ToTable("link_library_provider");
});
modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Library, Kyoo.Models.Show>", b =>
{
b.Property<int>("FirstID")
.HasColumnType("integer")
.HasColumnName("first_id");
b.Property<int>("SecondID")
.HasColumnType("integer")
.HasColumnName("second_id");
b.HasKey("FirstID", "SecondID")
.HasName("pk_link_library_show");
b.HasIndex("SecondID")
.HasDatabaseName("ix_link_library_show_second_id");
b.ToTable("link_library_show");
});
modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Show, Kyoo.Models.Genre>", b =>
{
b.Property<int>("FirstID")
.HasColumnType("integer")
.HasColumnName("first_id");
b.Property<int>("SecondID")
.HasColumnType("integer")
.HasColumnName("second_id");
b.HasKey("FirstID", "SecondID")
.HasName("pk_link_show_genre");
b.HasIndex("SecondID")
.HasDatabaseName("ix_link_show_genre_second_id");
b.ToTable("link_show_genre");
});
modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.User, Kyoo.Models.Show>", b =>
{
b.Property<int>("FirstID")
.HasColumnType("integer")
.HasColumnName("first_id");
b.Property<int>("SecondID")
.HasColumnType("integer")
.HasColumnName("second_id");
b.HasKey("FirstID", "SecondID")
.HasName("pk_link_user_show");
b.HasIndex("SecondID")
.HasDatabaseName("ix_link_user_show_second_id");
b.ToTable("link_user_show");
});
modelBuilder.Entity("Kyoo.Models.MetadataID<Kyoo.Models.Episode>", b =>
{
b.Property<int>("FirstID")
.HasColumnType("integer")
.HasColumnName("first_id");
b.Property<int>("SecondID")
.HasColumnType("integer")
.HasColumnName("second_id");
b.Property<string>("DataID")
.HasColumnType("text")
.HasColumnName("data_id");
b.Property<string>("Link")
.HasColumnType("text")
.HasColumnName("link");
b.HasKey("FirstID", "SecondID")
.HasName("pk_metadata_id_episode");
b.HasIndex("SecondID")
.HasDatabaseName("ix_metadata_id_episode_second_id");
b.ToTable("metadata_id_episode");
});
modelBuilder.Entity("Kyoo.Models.MetadataID<Kyoo.Models.People>", b =>
{
b.Property<int>("FirstID")
.HasColumnType("integer")
.HasColumnName("first_id");
b.Property<int>("SecondID")
.HasColumnType("integer")
.HasColumnName("second_id");
b.Property<string>("DataID")
.HasColumnType("text")
.HasColumnName("data_id");
b.Property<string>("Link")
.HasColumnType("text")
.HasColumnName("link");
b.HasKey("FirstID", "SecondID")
.HasName("pk_metadata_id_people");
b.HasIndex("SecondID")
.HasDatabaseName("ix_metadata_id_people_second_id");
b.ToTable("metadata_id_people");
});
modelBuilder.Entity("Kyoo.Models.MetadataID<Kyoo.Models.Season>", b =>
{
b.Property<int>("FirstID")
.HasColumnType("integer")
.HasColumnName("first_id");
b.Property<int>("SecondID")
.HasColumnType("integer")
.HasColumnName("second_id");
b.Property<string>("DataID")
.HasColumnType("text")
.HasColumnName("data_id");
b.Property<string>("Link")
.HasColumnType("text")
.HasColumnName("link");
b.HasKey("FirstID", "SecondID")
.HasName("pk_metadata_id_season");
b.HasIndex("SecondID")
.HasDatabaseName("ix_metadata_id_season_second_id");
b.ToTable("metadata_id_season");
});
modelBuilder.Entity("Kyoo.Models.MetadataID<Kyoo.Models.Show>", b =>
{
b.Property<int>("FirstID")
.HasColumnType("integer")
.HasColumnName("first_id");
b.Property<int>("SecondID")
.HasColumnType("integer")
.HasColumnName("second_id");
b.Property<string>("DataID")
.HasColumnType("text")
.HasColumnName("data_id");
b.Property<string>("Link")
.HasColumnType("text")
.HasColumnName("link");
b.HasKey("FirstID", "SecondID")
.HasName("pk_metadata_id_show");
b.HasIndex("SecondID")
.HasDatabaseName("ix_metadata_id_show_second_id");
b.ToTable("metadata_id_show");
});
modelBuilder.Entity("Kyoo.Models.People", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("integer")
.HasColumnName("id")
.HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
b.Property<string>("Name")
.HasColumnType("text")
.HasColumnName("name");
b.Property<string>("Poster")
.HasColumnType("text")
.HasColumnName("poster");
b.Property<string>("Slug")
.IsRequired()
.HasColumnType("text")
.HasColumnName("slug");
b.HasKey("ID")
.HasName("pk_people");
b.HasIndex("Slug")
.IsUnique()
.HasDatabaseName("ix_people_slug");
b.ToTable("people");
});
modelBuilder.Entity("Kyoo.Models.PeopleRole", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("integer")
.HasColumnName("id")
.HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
b.Property<bool>("ForPeople")
.HasColumnType("boolean")
.HasColumnName("for_people");
b.Property<int>("PeopleID")
.HasColumnType("integer")
.HasColumnName("people_id");
b.Property<string>("Role")
.HasColumnType("text")
.HasColumnName("role");
b.Property<int>("ShowID")
.HasColumnType("integer")
.HasColumnName("show_id");
b.Property<string>("Type")
.HasColumnType("text")
.HasColumnName("type");
b.HasKey("ID")
.HasName("pk_people_roles");
b.HasIndex("PeopleID")
.HasDatabaseName("ix_people_roles_people_id");
b.HasIndex("ShowID")
.HasDatabaseName("ix_people_roles_show_id");
b.ToTable("people_roles");
});
modelBuilder.Entity("Kyoo.Models.Provider", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("integer")
.HasColumnName("id")
.HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
b.Property<string>("Logo")
.HasColumnType("text")
.HasColumnName("logo");
b.Property<string>("LogoExtension")
.HasColumnType("text")
.HasColumnName("logo_extension");
b.Property<string>("Name")
.HasColumnType("text")
.HasColumnName("name");
b.Property<string>("Slug")
.IsRequired()
.HasColumnType("text")
.HasColumnName("slug");
b.HasKey("ID")
.HasName("pk_providers");
b.HasIndex("Slug")
.IsUnique()
.HasDatabaseName("ix_providers_slug");
b.ToTable("providers");
});
modelBuilder.Entity("Kyoo.Models.Season", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("integer")
.HasColumnName("id")
.HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
b.Property<DateTime?>("EndDate")
.HasColumnType("timestamp without time zone")
.HasColumnName("end_date");
b.Property<string>("Overview")
.HasColumnType("text")
.HasColumnName("overview");
b.Property<string>("Poster")
.HasColumnType("text")
.HasColumnName("poster");
b.Property<int>("SeasonNumber")
.HasColumnType("integer")
.HasColumnName("season_number");
b.Property<int>("ShowID")
.HasColumnType("integer")
.HasColumnName("show_id");
b.Property<string>("Slug")
.ValueGeneratedOnAddOrUpdate()
.HasColumnType("text")
.HasColumnName("slug");
b.Property<DateTime?>("StartDate")
.HasColumnType("timestamp without time zone")
.HasColumnName("start_date");
b.Property<string>("Title")
.HasColumnType("text")
.HasColumnName("title");
b.HasKey("ID")
.HasName("pk_seasons");
b.HasIndex("Slug")
.IsUnique()
.HasDatabaseName("ix_seasons_slug");
b.HasIndex("ShowID", "SeasonNumber")
.IsUnique()
.HasDatabaseName("ix_seasons_show_id_season_number");
b.ToTable("seasons");
});
modelBuilder.Entity("Kyoo.Models.Show", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("integer")
.HasColumnName("id")
.HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
b.Property<string[]>("Aliases")
.HasColumnType("text[]")
.HasColumnName("aliases");
b.Property<string>("Backdrop")
.HasColumnType("text")
.HasColumnName("backdrop");
b.Property<DateTime?>("EndAir")
.HasColumnType("timestamp without time zone")
.HasColumnName("end_air");
b.Property<bool>("IsMovie")
.HasColumnType("boolean")
.HasColumnName("is_movie");
b.Property<string>("Logo")
.HasColumnType("text")
.HasColumnName("logo");
b.Property<string>("Overview")
.HasColumnType("text")
.HasColumnName("overview");
b.Property<string>("Path")
.HasColumnType("text")
.HasColumnName("path");
b.Property<string>("Poster")
.HasColumnType("text")
.HasColumnName("poster");
b.Property<string>("Slug")
.IsRequired()
.HasColumnType("text")
.HasColumnName("slug");
b.Property<DateTime?>("StartAir")
.HasColumnType("timestamp without time zone")
.HasColumnName("start_air");
b.Property<Status?>("Status")
.HasColumnType("status")
.HasColumnName("status");
b.Property<int?>("StudioID")
.HasColumnType("integer")
.HasColumnName("studio_id");
b.Property<string>("Title")
.HasColumnType("text")
.HasColumnName("title");
b.Property<string>("TrailerUrl")
.HasColumnType("text")
.HasColumnName("trailer_url");
b.HasKey("ID")
.HasName("pk_shows");
b.HasIndex("Slug")
.IsUnique()
.HasDatabaseName("ix_shows_slug");
b.HasIndex("StudioID")
.HasDatabaseName("ix_shows_studio_id");
b.ToTable("shows");
});
modelBuilder.Entity("Kyoo.Models.Studio", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("integer")
.HasColumnName("id")
.HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
b.Property<string>("Name")
.HasColumnType("text")
.HasColumnName("name");
b.Property<string>("Slug")
.IsRequired()
.HasColumnType("text")
.HasColumnName("slug");
b.HasKey("ID")
.HasName("pk_studios");
b.HasIndex("Slug")
.IsUnique()
.HasDatabaseName("ix_studios_slug");
b.ToTable("studios");
});
modelBuilder.Entity("Kyoo.Models.Track", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("integer")
.HasColumnName("id")
.HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
b.Property<string>("Codec")
.HasColumnType("text")
.HasColumnName("codec");
b.Property<int>("EpisodeID")
.HasColumnType("integer")
.HasColumnName("episode_id");
b.Property<bool>("IsDefault")
.HasColumnType("boolean")
.HasColumnName("is_default");
b.Property<bool>("IsExternal")
.HasColumnType("boolean")
.HasColumnName("is_external");
b.Property<bool>("IsForced")
.HasColumnType("boolean")
.HasColumnName("is_forced");
b.Property<string>("Language")
.HasColumnType("text")
.HasColumnName("language");
b.Property<string>("Path")
.HasColumnType("text")
.HasColumnName("path");
b.Property<string>("Slug")
.ValueGeneratedOnAddOrUpdate()
.HasColumnType("text")
.HasColumnName("slug");
b.Property<string>("Title")
.HasColumnType("text")
.HasColumnName("title");
b.Property<int>("TrackIndex")
.HasColumnType("integer")
.HasColumnName("track_index");
b.Property<StreamType>("Type")
.HasColumnType("stream_type")
.HasColumnName("type");
b.HasKey("ID")
.HasName("pk_tracks");
b.HasIndex("Slug")
.IsUnique()
.HasDatabaseName("ix_tracks_slug");
b.HasIndex("EpisodeID", "Type", "Language", "TrackIndex", "IsForced")
.IsUnique()
.HasDatabaseName("ix_tracks_episode_id_type_language_track_index_is_forced");
b.ToTable("tracks");
});
modelBuilder.Entity("Kyoo.Models.User", b =>
{
b.Property<int>("ID")
.ValueGeneratedOnAdd()
.HasColumnType("integer")
.HasColumnName("id")
.HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
b.Property<string>("Email")
.HasColumnType("text")
.HasColumnName("email");
b.Property<Dictionary<string, string>>("ExtraData")
.HasColumnType("jsonb")
.HasColumnName("extra_data");
b.Property<string>("Password")
.HasColumnType("text")
.HasColumnName("password");
b.Property<string[]>("Permissions")
.HasColumnType("text[]")
.HasColumnName("permissions");
b.Property<string>("Slug")
.IsRequired()
.HasColumnType("text")
.HasColumnName("slug");
b.Property<string>("Username")
.HasColumnType("text")
.HasColumnName("username");
b.HasKey("ID")
.HasName("pk_users");
b.HasIndex("Slug")
.IsUnique()
.HasDatabaseName("ix_users_slug");
b.ToTable("users");
});
modelBuilder.Entity("Kyoo.Models.WatchedEpisode", b =>
{
b.Property<int>("FirstID")
.HasColumnType("integer")
.HasColumnName("first_id");
b.Property<int>("SecondID")
.HasColumnType("integer")
.HasColumnName("second_id");
b.Property<int>("WatchedPercentage")
.HasColumnType("integer")
.HasColumnName("watched_percentage");
b.HasKey("FirstID", "SecondID")
.HasName("pk_watched_episodes");
b.HasIndex("SecondID")
.HasDatabaseName("ix_watched_episodes_second_id");
b.ToTable("watched_episodes");
});
modelBuilder.Entity("Kyoo.Models.Episode", b =>
{
b.HasOne("Kyoo.Models.Season", "Season")
.WithMany("Episodes")
.HasForeignKey("SeasonID")
.HasConstraintName("fk_episodes_seasons_season_id")
.OnDelete(DeleteBehavior.Cascade);
b.HasOne("Kyoo.Models.Show", "Show")
.WithMany("Episodes")
.HasForeignKey("ShowID")
.HasConstraintName("fk_episodes_shows_show_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Season");
b.Navigation("Show");
});
modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Collection, Kyoo.Models.Show>", b =>
{
b.HasOne("Kyoo.Models.Collection", "First")
.WithMany("ShowLinks")
.HasForeignKey("FirstID")
.HasConstraintName("fk_link_collection_show_collections_first_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("Kyoo.Models.Show", "Second")
.WithMany("CollectionLinks")
.HasForeignKey("SecondID")
.HasConstraintName("fk_link_collection_show_shows_second_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("First");
b.Navigation("Second");
});
modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Library, Kyoo.Models.Collection>", b =>
{
b.HasOne("Kyoo.Models.Library", "First")
.WithMany("CollectionLinks")
.HasForeignKey("FirstID")
.HasConstraintName("fk_link_library_collection_libraries_first_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("Kyoo.Models.Collection", "Second")
.WithMany("LibraryLinks")
.HasForeignKey("SecondID")
.HasConstraintName("fk_link_library_collection_collections_second_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("First");
b.Navigation("Second");
});
modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Library, Kyoo.Models.Provider>", b =>
{
b.HasOne("Kyoo.Models.Library", "First")
.WithMany("ProviderLinks")
.HasForeignKey("FirstID")
.HasConstraintName("fk_link_library_provider_libraries_first_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("Kyoo.Models.Provider", "Second")
.WithMany("LibraryLinks")
.HasForeignKey("SecondID")
.HasConstraintName("fk_link_library_provider_providers_second_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("First");
b.Navigation("Second");
});
modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Library, Kyoo.Models.Show>", b =>
{
b.HasOne("Kyoo.Models.Library", "First")
.WithMany("ShowLinks")
.HasForeignKey("FirstID")
.HasConstraintName("fk_link_library_show_libraries_first_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("Kyoo.Models.Show", "Second")
.WithMany("LibraryLinks")
.HasForeignKey("SecondID")
.HasConstraintName("fk_link_library_show_shows_second_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("First");
b.Navigation("Second");
});
modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Show, Kyoo.Models.Genre>", b =>
{
b.HasOne("Kyoo.Models.Show", "First")
.WithMany("GenreLinks")
.HasForeignKey("FirstID")
.HasConstraintName("fk_link_show_genre_shows_first_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("Kyoo.Models.Genre", "Second")
.WithMany("ShowLinks")
.HasForeignKey("SecondID")
.HasConstraintName("fk_link_show_genre_genres_second_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("First");
b.Navigation("Second");
});
modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.User, Kyoo.Models.Show>", b =>
{
b.HasOne("Kyoo.Models.User", "First")
.WithMany("ShowLinks")
.HasForeignKey("FirstID")
.HasConstraintName("fk_link_user_show_users_first_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("Kyoo.Models.Show", "Second")
.WithMany()
.HasForeignKey("SecondID")
.HasConstraintName("fk_link_user_show_shows_second_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("First");
b.Navigation("Second");
});
modelBuilder.Entity("Kyoo.Models.MetadataID<Kyoo.Models.Episode>", b =>
{
b.HasOne("Kyoo.Models.Episode", "First")
.WithMany("ExternalIDs")
.HasForeignKey("FirstID")
.HasConstraintName("fk_metadata_id_episode_episodes_first_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("Kyoo.Models.Provider", "Second")
.WithMany()
.HasForeignKey("SecondID")
.HasConstraintName("fk_metadata_id_episode_providers_second_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("First");
b.Navigation("Second");
});
modelBuilder.Entity("Kyoo.Models.MetadataID<Kyoo.Models.People>", b =>
{
b.HasOne("Kyoo.Models.People", "First")
.WithMany("ExternalIDs")
.HasForeignKey("FirstID")
.HasConstraintName("fk_metadata_id_people_people_first_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("Kyoo.Models.Provider", "Second")
.WithMany()
.HasForeignKey("SecondID")
.HasConstraintName("fk_metadata_id_people_providers_second_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("First");
b.Navigation("Second");
});
modelBuilder.Entity("Kyoo.Models.MetadataID<Kyoo.Models.Season>", b =>
{
b.HasOne("Kyoo.Models.Season", "First")
.WithMany("ExternalIDs")
.HasForeignKey("FirstID")
.HasConstraintName("fk_metadata_id_season_seasons_first_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("Kyoo.Models.Provider", "Second")
.WithMany()
.HasForeignKey("SecondID")
.HasConstraintName("fk_metadata_id_season_providers_second_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("First");
b.Navigation("Second");
});
modelBuilder.Entity("Kyoo.Models.MetadataID<Kyoo.Models.Show>", b =>
{
b.HasOne("Kyoo.Models.Show", "First")
.WithMany("ExternalIDs")
.HasForeignKey("FirstID")
.HasConstraintName("fk_metadata_id_show_shows_first_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("Kyoo.Models.Provider", "Second")
.WithMany()
.HasForeignKey("SecondID")
.HasConstraintName("fk_metadata_id_show_providers_second_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("First");
b.Navigation("Second");
});
modelBuilder.Entity("Kyoo.Models.PeopleRole", b =>
{
b.HasOne("Kyoo.Models.People", "People")
.WithMany("Roles")
.HasForeignKey("PeopleID")
.HasConstraintName("fk_people_roles_people_people_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("Kyoo.Models.Show", "Show")
.WithMany("People")
.HasForeignKey("ShowID")
.HasConstraintName("fk_people_roles_shows_show_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("People");
b.Navigation("Show");
});
modelBuilder.Entity("Kyoo.Models.Season", b =>
{
b.HasOne("Kyoo.Models.Show", "Show")
.WithMany("Seasons")
.HasForeignKey("ShowID")
.HasConstraintName("fk_seasons_shows_show_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Show");
});
modelBuilder.Entity("Kyoo.Models.Show", b =>
{
b.HasOne("Kyoo.Models.Studio", "Studio")
.WithMany("Shows")
.HasForeignKey("StudioID")
.HasConstraintName("fk_shows_studios_studio_id");
b.Navigation("Studio");
});
modelBuilder.Entity("Kyoo.Models.Track", b =>
{
b.HasOne("Kyoo.Models.Episode", "Episode")
.WithMany("Tracks")
.HasForeignKey("EpisodeID")
.HasConstraintName("fk_tracks_episodes_episode_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Episode");
});
modelBuilder.Entity("Kyoo.Models.WatchedEpisode", b =>
{
b.HasOne("Kyoo.Models.User", "First")
.WithMany("CurrentlyWatching")
.HasForeignKey("FirstID")
.HasConstraintName("fk_watched_episodes_users_first_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("Kyoo.Models.Episode", "Second")
.WithMany()
.HasForeignKey("SecondID")
.HasConstraintName("fk_watched_episodes_episodes_second_id")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("First");
b.Navigation("Second");
});
modelBuilder.Entity("Kyoo.Models.Collection", b =>
{
b.Navigation("LibraryLinks");
b.Navigation("ShowLinks");
});
modelBuilder.Entity("Kyoo.Models.Episode", b =>
{
b.Navigation("ExternalIDs");
b.Navigation("Tracks");
});
modelBuilder.Entity("Kyoo.Models.Genre", b =>
{
b.Navigation("ShowLinks");
});
modelBuilder.Entity("Kyoo.Models.Library", b =>
{
b.Navigation("CollectionLinks");
b.Navigation("ProviderLinks");
b.Navigation("ShowLinks");
});
modelBuilder.Entity("Kyoo.Models.People", b =>
{
b.Navigation("ExternalIDs");
b.Navigation("Roles");
});
modelBuilder.Entity("Kyoo.Models.Provider", b =>
{
b.Navigation("LibraryLinks");
});
modelBuilder.Entity("Kyoo.Models.Season", b =>
{
b.Navigation("Episodes");
b.Navigation("ExternalIDs");
});
modelBuilder.Entity("Kyoo.Models.Show", b =>
{
b.Navigation("CollectionLinks");
b.Navigation("Episodes");
b.Navigation("ExternalIDs");
b.Navigation("GenreLinks");
b.Navigation("LibraryLinks");
b.Navigation("People");
b.Navigation("Seasons");
});
modelBuilder.Entity("Kyoo.Models.Studio", b =>
{
b.Navigation("Shows");
});
modelBuilder.Entity("Kyoo.Models.User", b =>
{
b.Navigation("CurrentlyWatching");
b.Navigation("ShowLinks");
});
#pragma warning restore 612, 618
}
}
}