mirror of
				https://github.com/zoriya/Kyoo.git
				synced 2025-10-26 16:22:36 -04:00 
			
		
		
		
	Fixing postgres migrations
This commit is contained in:
		
							parent
							
								
									feb643da2e
								
							
						
					
					
						commit
						b2151a0dde
					
				| @ -72,6 +72,13 @@ namespace Kyoo.Controllers | |||||||
| 		/// </summary> | 		/// </summary> | ||||||
| 		/// <param name="app">The Asp.Net application builder. On most case it is not needed but you can use it to add asp net functionalities.</param> | 		/// <param name="app">The Asp.Net application builder. On most case it is not needed but you can use it to add asp net functionalities.</param> | ||||||
| 		void ConfigureAspNet(IApplicationBuilder app) {} | 		void ConfigureAspNet(IApplicationBuilder app) {} | ||||||
|  | 		 | ||||||
|  | 		/// <summary> | ||||||
|  | 		/// An optional function to execute and initialize your plugin. | ||||||
|  | 		/// It can be used to initialize a database connection, fill initial data or anything. | ||||||
|  | 		/// </summary> | ||||||
|  | 		/// <param name="provider">A service provider to request services</param> | ||||||
|  | 		void Initialize(IServiceProvider provider) {} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	/// <summary> | 	/// <summary> | ||||||
|  | |||||||
| @ -151,7 +151,7 @@ namespace Kyoo.Controllers | |||||||
| 		public string HelpMessage { get; } | 		public string HelpMessage { get; } | ||||||
| 		 | 		 | ||||||
| 		/// <summary> | 		/// <summary> | ||||||
| 		/// Should this task be automatically runned at app startup? | 		/// Should this task be automatically run at app startup? | ||||||
| 		/// </summary> | 		/// </summary> | ||||||
| 		public bool RunOnStartup { get; } | 		public bool RunOnStartup { get; } | ||||||
| 		 | 		 | ||||||
| @ -165,7 +165,7 @@ namespace Kyoo.Controllers | |||||||
| 		/// Start this task. | 		/// Start this task. | ||||||
| 		/// </summary> | 		/// </summary> | ||||||
| 		/// <param name="arguments">The list of parameters.</param> | 		/// <param name="arguments">The list of parameters.</param> | ||||||
| 		/// <param name="cancellationToken">A token to request the task's cancelation. | 		/// <param name="cancellationToken">A token to request the task's cancellation. | ||||||
| 		/// If this task is not cancelled quickly, it might be killed by the runner.</param> | 		/// If this task is not cancelled quickly, it might be killed by the runner.</param> | ||||||
| 		/// <remarks> | 		/// <remarks> | ||||||
| 		/// Your task can have any service as a public field and use the <see cref="InjectedAttribute"/>, | 		/// Your task can have any service as a public field and use the <see cref="InjectedAttribute"/>, | ||||||
|  | |||||||
| @ -30,10 +30,5 @@ namespace Kyoo.Controllers | |||||||
| 		/// </summary> | 		/// </summary> | ||||||
| 		/// <returns>A list of every tasks that this instance know.</returns> | 		/// <returns>A list of every tasks that this instance know.</returns> | ||||||
| 		ICollection<ITask> GetAllTasks(); | 		ICollection<ITask> GetAllTasks(); | ||||||
| 
 |  | ||||||
| 		/// <summary> |  | ||||||
| 		/// Reload tasks and run startup tasks. |  | ||||||
| 		/// </summary> |  | ||||||
| 		void ReloadTasks(); |  | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| @ -1,4 +1,5 @@ | |||||||
| using System; | using System; | ||||||
|  | using JetBrains.Annotations; | ||||||
| using Kyoo.Controllers; | using Kyoo.Controllers; | ||||||
| 
 | 
 | ||||||
| namespace Kyoo.Models.Attributes | namespace Kyoo.Models.Attributes | ||||||
| @ -10,5 +11,6 @@ namespace Kyoo.Models.Attributes | |||||||
| 	/// It should only be used on <see cref="ITask"/> and will be injected before calling <see cref="ITask.Run"/> | 	/// It should only be used on <see cref="ITask"/> and will be injected before calling <see cref="ITask.Run"/> | ||||||
| 	/// </remarks> | 	/// </remarks> | ||||||
| 	[AttributeUsage(AttributeTargets.Property)] | 	[AttributeUsage(AttributeTargets.Property)] | ||||||
|  | 	[MeansImplicitUse(ImplicitUseKindFlags.Assign)] | ||||||
| 	public class InjectedAttribute : Attribute { } | 	public class InjectedAttribute : Attribute { } | ||||||
| } | } | ||||||
| @ -16,17 +16,17 @@ | |||||||
| 	</PropertyGroup> | 	</PropertyGroup> | ||||||
| 
 | 
 | ||||||
| 	<ItemGroup> | 	<ItemGroup> | ||||||
|  | 		<PackageReference Include="Microsoft.EntityFrameworkCore.Design" Version="5.0.5"> | ||||||
|  | 			<PrivateAssets>all</PrivateAssets> | ||||||
|  | 			<IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets> | ||||||
|  | 		</PackageReference> | ||||||
| 		<PackageReference Include="Npgsql.EntityFrameworkCore.PostgreSQL" Version="5.0.5.1" /> | 		<PackageReference Include="Npgsql.EntityFrameworkCore.PostgreSQL" Version="5.0.5.1" /> | ||||||
| 	</ItemGroup> | 	</ItemGroup> | ||||||
| 
 | 
 | ||||||
| 	<ItemGroup> | 	<ItemGroup> | ||||||
| 	  <ProjectReference Include="../Kyoo.CommonAPI/Kyoo.CommonAPI.csproj"> | 	  <ProjectReference Include="../Kyoo.CommonAPI/Kyoo.CommonAPI.csproj"> | ||||||
| 		  <PrivateAssets>all</PrivateAssets> |  | ||||||
| 		  <Private>false</Private> |  | ||||||
| 	  </ProjectReference> | 	  </ProjectReference> | ||||||
| 		<ProjectReference Include="../Kyoo.Common/Kyoo.Common.csproj"> | 		<ProjectReference Include="../Kyoo.Common/Kyoo.Common.csproj"> | ||||||
| 			<PrivateAssets>all</PrivateAssets> |  | ||||||
| 			<Private>false</Private> |  | ||||||
| 		</ProjectReference> | 		</ProjectReference> | ||||||
| 	</ItemGroup> | 	</ItemGroup> | ||||||
| </Project> | </Project> | ||||||
|  | |||||||
							
								
								
									
										786
									
								
								Kyoo.Postgresql/Migrations/20210505182627_Initial.Designer.cs
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										786
									
								
								Kyoo.Postgresql/Migrations/20210505182627_Initial.Designer.cs
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @ -0,0 +1,786 @@ | |||||||
|  | // <auto-generated /> | ||||||
|  | using System; | ||||||
|  | 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("20210505182627_Initial")] | ||||||
|  |     partial class Initial | ||||||
|  |     { | ||||||
|  |         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.5") | ||||||
|  |                 .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Collection", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Name") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Overview") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Poster") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Collections"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Episode", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("AbsoluteNumber") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("EpisodeNumber") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Overview") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Path") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<DateTime?>("ReleaseDate") | ||||||
|  |                         .HasColumnType("timestamp without time zone"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("Runtime") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("SeasonID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SeasonNumber") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("ShowID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Thumb") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Title") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SeasonID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("ShowID", "SeasonNumber", "EpisodeNumber", "AbsoluteNumber") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Episodes"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Genre", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Name") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Genres"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Library", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Name") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string[]>("Paths") | ||||||
|  |                         .HasColumnType("text[]"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Libraries"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Collection, Kyoo.Models.Show>", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("FirstID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SecondID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("FirstID", "SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Link<Collection, Show>"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Library, Kyoo.Models.Collection>", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("FirstID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SecondID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("FirstID", "SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Link<Library, Collection>"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Library, Kyoo.Models.Provider>", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("FirstID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SecondID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("FirstID", "SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Link<Library, Provider>"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Library, Kyoo.Models.Show>", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("FirstID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SecondID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("FirstID", "SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Link<Library, Show>"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Show, Kyoo.Models.Genre>", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("FirstID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SecondID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("FirstID", "SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Link<Show, Genre>"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.MetadataID", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("DataID") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("EpisodeID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Link") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("PeopleID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("ProviderID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("SeasonID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("ShowID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("EpisodeID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("PeopleID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("ProviderID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SeasonID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("ShowID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("MetadataIds"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.People", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Name") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Poster") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("People"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.PeopleRole", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("PeopleID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Role") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("ShowID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Type") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("PeopleID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("ShowID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("PeopleRoles"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Provider", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Logo") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("LogoExtension") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Name") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Providers"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Season", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Overview") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Poster") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SeasonNumber") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("ShowID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Title") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("Year") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("ShowID", "SeasonNumber") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Seasons"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Show", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string[]>("Aliases") | ||||||
|  |                         .HasColumnType("text[]"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Backdrop") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("EndYear") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<bool>("IsMovie") | ||||||
|  |                         .HasColumnType("boolean"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Logo") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Overview") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Path") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Poster") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("StartYear") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<Status?>("Status") | ||||||
|  |                         .HasColumnType("status"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("StudioID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Title") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("TrailerUrl") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("StudioID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Shows"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Studio", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Name") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Studios"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Track", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Codec") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("EpisodeID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<bool>("IsDefault") | ||||||
|  |                         .HasColumnType("boolean"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<bool>("IsExternal") | ||||||
|  |                         .HasColumnType("boolean"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<bool>("IsForced") | ||||||
|  |                         .HasColumnType("boolean"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Language") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Path") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Title") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("TrackIndex") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<StreamType>("Type") | ||||||
|  |                         .HasColumnType("stream_type"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("EpisodeID", "Type", "Language", "TrackIndex", "IsForced") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Tracks"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Episode", b => | ||||||
|  |                 { | ||||||
|  |                     b.HasOne("Kyoo.Models.Season", "Season") | ||||||
|  |                         .WithMany("Episodes") | ||||||
|  |                         .HasForeignKey("SeasonID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Show", "Show") | ||||||
|  |                         .WithMany("Episodes") | ||||||
|  |                         .HasForeignKey("ShowID") | ||||||
|  |                         .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") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Show", "Second") | ||||||
|  |                         .WithMany("CollectionLinks") | ||||||
|  |                         .HasForeignKey("SecondID") | ||||||
|  |                         .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") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Collection", "Second") | ||||||
|  |                         .WithMany("LibraryLinks") | ||||||
|  |                         .HasForeignKey("SecondID") | ||||||
|  |                         .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") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Provider", "Second") | ||||||
|  |                         .WithMany("LibraryLinks") | ||||||
|  |                         .HasForeignKey("SecondID") | ||||||
|  |                         .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") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Show", "Second") | ||||||
|  |                         .WithMany("LibraryLinks") | ||||||
|  |                         .HasForeignKey("SecondID") | ||||||
|  |                         .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") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Genre", "Second") | ||||||
|  |                         .WithMany("ShowLinks") | ||||||
|  |                         .HasForeignKey("SecondID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("First"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Second"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.MetadataID", b => | ||||||
|  |                 { | ||||||
|  |                     b.HasOne("Kyoo.Models.Episode", "Episode") | ||||||
|  |                         .WithMany("ExternalIDs") | ||||||
|  |                         .HasForeignKey("EpisodeID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.People", "People") | ||||||
|  |                         .WithMany("ExternalIDs") | ||||||
|  |                         .HasForeignKey("PeopleID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Provider", "Provider") | ||||||
|  |                         .WithMany("MetadataLinks") | ||||||
|  |                         .HasForeignKey("ProviderID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Season", "Season") | ||||||
|  |                         .WithMany("ExternalIDs") | ||||||
|  |                         .HasForeignKey("SeasonID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Show", "Show") | ||||||
|  |                         .WithMany("ExternalIDs") | ||||||
|  |                         .HasForeignKey("ShowID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Episode"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("People"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Provider"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Season"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Show"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.PeopleRole", b => | ||||||
|  |                 { | ||||||
|  |                     b.HasOne("Kyoo.Models.People", "People") | ||||||
|  |                         .WithMany("Roles") | ||||||
|  |                         .HasForeignKey("PeopleID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Show", "Show") | ||||||
|  |                         .WithMany("People") | ||||||
|  |                         .HasForeignKey("ShowID") | ||||||
|  |                         .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") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Show"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Show", b => | ||||||
|  |                 { | ||||||
|  |                     b.HasOne("Kyoo.Models.Studio", "Studio") | ||||||
|  |                         .WithMany("Shows") | ||||||
|  |                         .HasForeignKey("StudioID"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Studio"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Track", b => | ||||||
|  |                 { | ||||||
|  |                     b.HasOne("Kyoo.Models.Episode", "Episode") | ||||||
|  |                         .WithMany("Tracks") | ||||||
|  |                         .HasForeignKey("EpisodeID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Episode"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             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"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("MetadataLinks"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             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"); | ||||||
|  |                 }); | ||||||
|  | #pragma warning restore 612, 618 | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										608
									
								
								Kyoo.Postgresql/Migrations/20210505182627_Initial.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										608
									
								
								Kyoo.Postgresql/Migrations/20210505182627_Initial.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,608 @@ | |||||||
|  | using System; | ||||||
|  | using Kyoo.Models; | ||||||
|  | using Microsoft.EntityFrameworkCore.Migrations; | ||||||
|  | using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata; | ||||||
|  | 
 | ||||||
|  | namespace Kyoo.Postgresql.Migrations | ||||||
|  | { | ||||||
|  |     public partial class Initial : Migration | ||||||
|  |     { | ||||||
|  |         protected override void Up(MigrationBuilder migrationBuilder) | ||||||
|  |         { | ||||||
|  |             migrationBuilder.AlterDatabase() | ||||||
|  |                 .Annotation("Npgsql:Enum:item_type", "show,movie,collection") | ||||||
|  |                 .Annotation("Npgsql:Enum:status", "finished,airing,planned,unknown") | ||||||
|  |                 .Annotation("Npgsql:Enum:stream_type", "unknown,video,audio,subtitle,attachment"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Collections", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     ID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                         .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), | ||||||
|  |                     Slug = table.Column<string>(type: "text", nullable: false), | ||||||
|  |                     Name = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Poster = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Overview = table.Column<string>(type: "text", nullable: true) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Collections", x => x.ID); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Genres", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     ID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                         .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), | ||||||
|  |                     Slug = table.Column<string>(type: "text", nullable: false), | ||||||
|  |                     Name = table.Column<string>(type: "text", nullable: true) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Genres", x => x.ID); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Libraries", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     ID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                         .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), | ||||||
|  |                     Slug = table.Column<string>(type: "text", nullable: false), | ||||||
|  |                     Name = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Paths = table.Column<string[]>(type: "text[]", nullable: true) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Libraries", x => x.ID); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "People", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     ID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                         .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), | ||||||
|  |                     Slug = table.Column<string>(type: "text", nullable: false), | ||||||
|  |                     Name = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Poster = table.Column<string>(type: "text", nullable: true) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_People", x => x.ID); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Providers", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     ID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                         .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), | ||||||
|  |                     Slug = table.Column<string>(type: "text", nullable: false), | ||||||
|  |                     Name = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Logo = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     LogoExtension = table.Column<string>(type: "text", nullable: true) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Providers", x => x.ID); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Studios", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     ID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                         .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), | ||||||
|  |                     Slug = table.Column<string>(type: "text", nullable: false), | ||||||
|  |                     Name = table.Column<string>(type: "text", nullable: true) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Studios", x => x.ID); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Link<Library, Collection>", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     FirstID = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     SecondID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Link<Library, Collection>", x => new { x.FirstID, x.SecondID }); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Link<Library, Collection>_Collections_SecondID", | ||||||
|  |                         column: x => x.SecondID, | ||||||
|  |                         principalTable: "Collections", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Link<Library, Collection>_Libraries_FirstID", | ||||||
|  |                         column: x => x.FirstID, | ||||||
|  |                         principalTable: "Libraries", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Link<Library, Provider>", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     FirstID = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     SecondID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Link<Library, Provider>", x => new { x.FirstID, x.SecondID }); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Link<Library, Provider>_Libraries_FirstID", | ||||||
|  |                         column: x => x.FirstID, | ||||||
|  |                         principalTable: "Libraries", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Link<Library, Provider>_Providers_SecondID", | ||||||
|  |                         column: x => x.SecondID, | ||||||
|  |                         principalTable: "Providers", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Shows", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     ID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                         .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), | ||||||
|  |                     Slug = table.Column<string>(type: "text", nullable: false), | ||||||
|  |                     Title = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Aliases = table.Column<string[]>(type: "text[]", nullable: true), | ||||||
|  |                     Path = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Overview = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Status = table.Column<Status>(type: "status", nullable: true), | ||||||
|  |                     TrailerUrl = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     StartYear = table.Column<int>(type: "integer", nullable: true), | ||||||
|  |                     EndYear = table.Column<int>(type: "integer", nullable: true), | ||||||
|  |                     Poster = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Logo = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Backdrop = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     IsMovie = table.Column<bool>(type: "boolean", nullable: false), | ||||||
|  |                     StudioID = table.Column<int>(type: "integer", nullable: true) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Shows", x => x.ID); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Shows_Studios_StudioID", | ||||||
|  |                         column: x => x.StudioID, | ||||||
|  |                         principalTable: "Studios", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Restrict); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Link<Collection, Show>", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     FirstID = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     SecondID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Link<Collection, Show>", x => new { x.FirstID, x.SecondID }); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Link<Collection, Show>_Collections_FirstID", | ||||||
|  |                         column: x => x.FirstID, | ||||||
|  |                         principalTable: "Collections", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Link<Collection, Show>_Shows_SecondID", | ||||||
|  |                         column: x => x.SecondID, | ||||||
|  |                         principalTable: "Shows", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Link<Library, Show>", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     FirstID = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     SecondID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Link<Library, Show>", x => new { x.FirstID, x.SecondID }); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Link<Library, Show>_Libraries_FirstID", | ||||||
|  |                         column: x => x.FirstID, | ||||||
|  |                         principalTable: "Libraries", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Link<Library, Show>_Shows_SecondID", | ||||||
|  |                         column: x => x.SecondID, | ||||||
|  |                         principalTable: "Shows", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Link<Show, Genre>", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     FirstID = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     SecondID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Link<Show, Genre>", x => new { x.FirstID, x.SecondID }); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Link<Show, Genre>_Genres_SecondID", | ||||||
|  |                         column: x => x.SecondID, | ||||||
|  |                         principalTable: "Genres", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Link<Show, Genre>_Shows_FirstID", | ||||||
|  |                         column: x => x.FirstID, | ||||||
|  |                         principalTable: "Shows", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "PeopleRoles", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     ID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                         .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), | ||||||
|  |                     PeopleID = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     ShowID = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     Role = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Type = table.Column<string>(type: "text", nullable: true) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_PeopleRoles", x => x.ID); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_PeopleRoles_People_PeopleID", | ||||||
|  |                         column: x => x.PeopleID, | ||||||
|  |                         principalTable: "People", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_PeopleRoles_Shows_ShowID", | ||||||
|  |                         column: x => x.ShowID, | ||||||
|  |                         principalTable: "Shows", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Seasons", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     ID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                         .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), | ||||||
|  |                     ShowID = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     SeasonNumber = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     Title = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Overview = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Year = table.Column<int>(type: "integer", nullable: true), | ||||||
|  |                     Poster = table.Column<string>(type: "text", nullable: true) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Seasons", x => x.ID); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Seasons_Shows_ShowID", | ||||||
|  |                         column: x => x.ShowID, | ||||||
|  |                         principalTable: "Shows", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Episodes", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     ID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                         .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), | ||||||
|  |                     ShowID = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     SeasonID = table.Column<int>(type: "integer", nullable: true), | ||||||
|  |                     SeasonNumber = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     EpisodeNumber = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     AbsoluteNumber = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     Path = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Thumb = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Title = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Overview = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     ReleaseDate = table.Column<DateTime>(type: "timestamp without time zone", nullable: true), | ||||||
|  |                     Runtime = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Episodes", x => x.ID); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Episodes_Seasons_SeasonID", | ||||||
|  |                         column: x => x.SeasonID, | ||||||
|  |                         principalTable: "Seasons", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Restrict); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Episodes_Shows_ShowID", | ||||||
|  |                         column: x => x.ShowID, | ||||||
|  |                         principalTable: "Shows", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "MetadataIds", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     ID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                         .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), | ||||||
|  |                     ProviderID = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     ShowID = table.Column<int>(type: "integer", nullable: true), | ||||||
|  |                     EpisodeID = table.Column<int>(type: "integer", nullable: true), | ||||||
|  |                     SeasonID = table.Column<int>(type: "integer", nullable: true), | ||||||
|  |                     PeopleID = table.Column<int>(type: "integer", nullable: true), | ||||||
|  |                     DataID = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Link = table.Column<string>(type: "text", nullable: true) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_MetadataIds", x => x.ID); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_MetadataIds_Episodes_EpisodeID", | ||||||
|  |                         column: x => x.EpisodeID, | ||||||
|  |                         principalTable: "Episodes", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_MetadataIds_People_PeopleID", | ||||||
|  |                         column: x => x.PeopleID, | ||||||
|  |                         principalTable: "People", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_MetadataIds_Providers_ProviderID", | ||||||
|  |                         column: x => x.ProviderID, | ||||||
|  |                         principalTable: "Providers", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_MetadataIds_Seasons_SeasonID", | ||||||
|  |                         column: x => x.SeasonID, | ||||||
|  |                         principalTable: "Seasons", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_MetadataIds_Shows_ShowID", | ||||||
|  |                         column: x => x.ShowID, | ||||||
|  |                         principalTable: "Shows", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateTable( | ||||||
|  |                 name: "Tracks", | ||||||
|  |                 columns: table => new | ||||||
|  |                 { | ||||||
|  |                     ID = table.Column<int>(type: "integer", nullable: false) | ||||||
|  |                         .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), | ||||||
|  |                     EpisodeID = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     TrackIndex = table.Column<int>(type: "integer", nullable: false), | ||||||
|  |                     IsDefault = table.Column<bool>(type: "boolean", nullable: false), | ||||||
|  |                     IsForced = table.Column<bool>(type: "boolean", nullable: false), | ||||||
|  |                     IsExternal = table.Column<bool>(type: "boolean", nullable: false), | ||||||
|  |                     Title = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Language = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Codec = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Path = table.Column<string>(type: "text", nullable: true), | ||||||
|  |                     Type = table.Column<StreamType>(type: "stream_type", nullable: false) | ||||||
|  |                 }, | ||||||
|  |                 constraints: table => | ||||||
|  |                 { | ||||||
|  |                     table.PrimaryKey("PK_Tracks", x => x.ID); | ||||||
|  |                     table.ForeignKey( | ||||||
|  |                         name: "FK_Tracks_Episodes_EpisodeID", | ||||||
|  |                         column: x => x.EpisodeID, | ||||||
|  |                         principalTable: "Episodes", | ||||||
|  |                         principalColumn: "ID", | ||||||
|  |                         onDelete: ReferentialAction.Cascade); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Collections_Slug", | ||||||
|  |                 table: "Collections", | ||||||
|  |                 column: "Slug", | ||||||
|  |                 unique: true); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Episodes_SeasonID", | ||||||
|  |                 table: "Episodes", | ||||||
|  |                 column: "SeasonID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Episodes_ShowID_SeasonNumber_EpisodeNumber_AbsoluteNumber", | ||||||
|  |                 table: "Episodes", | ||||||
|  |                 columns: new[] { "ShowID", "SeasonNumber", "EpisodeNumber", "AbsoluteNumber" }, | ||||||
|  |                 unique: true); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Genres_Slug", | ||||||
|  |                 table: "Genres", | ||||||
|  |                 column: "Slug", | ||||||
|  |                 unique: true); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Libraries_Slug", | ||||||
|  |                 table: "Libraries", | ||||||
|  |                 column: "Slug", | ||||||
|  |                 unique: true); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Link<Collection, Show>_SecondID", | ||||||
|  |                 table: "Link<Collection, Show>", | ||||||
|  |                 column: "SecondID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Link<Library, Collection>_SecondID", | ||||||
|  |                 table: "Link<Library, Collection>", | ||||||
|  |                 column: "SecondID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Link<Library, Provider>_SecondID", | ||||||
|  |                 table: "Link<Library, Provider>", | ||||||
|  |                 column: "SecondID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Link<Library, Show>_SecondID", | ||||||
|  |                 table: "Link<Library, Show>", | ||||||
|  |                 column: "SecondID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Link<Show, Genre>_SecondID", | ||||||
|  |                 table: "Link<Show, Genre>", | ||||||
|  |                 column: "SecondID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_MetadataIds_EpisodeID", | ||||||
|  |                 table: "MetadataIds", | ||||||
|  |                 column: "EpisodeID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_MetadataIds_PeopleID", | ||||||
|  |                 table: "MetadataIds", | ||||||
|  |                 column: "PeopleID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_MetadataIds_ProviderID", | ||||||
|  |                 table: "MetadataIds", | ||||||
|  |                 column: "ProviderID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_MetadataIds_SeasonID", | ||||||
|  |                 table: "MetadataIds", | ||||||
|  |                 column: "SeasonID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_MetadataIds_ShowID", | ||||||
|  |                 table: "MetadataIds", | ||||||
|  |                 column: "ShowID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_People_Slug", | ||||||
|  |                 table: "People", | ||||||
|  |                 column: "Slug", | ||||||
|  |                 unique: true); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_PeopleRoles_PeopleID", | ||||||
|  |                 table: "PeopleRoles", | ||||||
|  |                 column: "PeopleID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_PeopleRoles_ShowID", | ||||||
|  |                 table: "PeopleRoles", | ||||||
|  |                 column: "ShowID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Providers_Slug", | ||||||
|  |                 table: "Providers", | ||||||
|  |                 column: "Slug", | ||||||
|  |                 unique: true); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Seasons_ShowID_SeasonNumber", | ||||||
|  |                 table: "Seasons", | ||||||
|  |                 columns: new[] { "ShowID", "SeasonNumber" }, | ||||||
|  |                 unique: true); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Shows_Slug", | ||||||
|  |                 table: "Shows", | ||||||
|  |                 column: "Slug", | ||||||
|  |                 unique: true); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Shows_StudioID", | ||||||
|  |                 table: "Shows", | ||||||
|  |                 column: "StudioID"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Studios_Slug", | ||||||
|  |                 table: "Studios", | ||||||
|  |                 column: "Slug", | ||||||
|  |                 unique: true); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.CreateIndex( | ||||||
|  |                 name: "IX_Tracks_EpisodeID_Type_Language_TrackIndex_IsForced", | ||||||
|  |                 table: "Tracks", | ||||||
|  |                 columns: new[] { "EpisodeID", "Type", "Language", "TrackIndex", "IsForced" }, | ||||||
|  |                 unique: true); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         protected override void Down(MigrationBuilder migrationBuilder) | ||||||
|  |         { | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Link<Collection, Show>"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Link<Library, Collection>"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Link<Library, Provider>"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Link<Library, Show>"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Link<Show, Genre>"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "MetadataIds"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "PeopleRoles"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Tracks"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Collections"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Libraries"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Genres"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Providers"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "People"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Episodes"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Seasons"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Shows"); | ||||||
|  | 
 | ||||||
|  |             migrationBuilder.DropTable( | ||||||
|  |                 name: "Studios"); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										784
									
								
								Kyoo.Postgresql/Migrations/PostgresContextModelSnapshot.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										784
									
								
								Kyoo.Postgresql/Migrations/PostgresContextModelSnapshot.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,784 @@ | |||||||
|  | // <auto-generated /> | ||||||
|  | using System; | ||||||
|  | using Kyoo.Models; | ||||||
|  | using Kyoo.Postgresql; | ||||||
|  | using Microsoft.EntityFrameworkCore; | ||||||
|  | using Microsoft.EntityFrameworkCore.Infrastructure; | ||||||
|  | using Microsoft.EntityFrameworkCore.Storage.ValueConversion; | ||||||
|  | using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata; | ||||||
|  | 
 | ||||||
|  | namespace Kyoo.Postgresql.Migrations | ||||||
|  | { | ||||||
|  |     [DbContext(typeof(PostgresContext))] | ||||||
|  |     partial class PostgresContextModelSnapshot : ModelSnapshot | ||||||
|  |     { | ||||||
|  |         protected override void BuildModel(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.5") | ||||||
|  |                 .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Collection", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Name") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Overview") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Poster") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Collections"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Episode", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("AbsoluteNumber") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("EpisodeNumber") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Overview") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Path") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<DateTime?>("ReleaseDate") | ||||||
|  |                         .HasColumnType("timestamp without time zone"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("Runtime") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("SeasonID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SeasonNumber") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("ShowID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Thumb") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Title") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SeasonID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("ShowID", "SeasonNumber", "EpisodeNumber", "AbsoluteNumber") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Episodes"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Genre", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Name") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Genres"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Library", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Name") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string[]>("Paths") | ||||||
|  |                         .HasColumnType("text[]"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Libraries"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Collection, Kyoo.Models.Show>", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("FirstID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SecondID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("FirstID", "SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Link<Collection, Show>"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Library, Kyoo.Models.Collection>", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("FirstID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SecondID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("FirstID", "SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Link<Library, Collection>"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Library, Kyoo.Models.Provider>", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("FirstID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SecondID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("FirstID", "SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Link<Library, Provider>"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Library, Kyoo.Models.Show>", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("FirstID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SecondID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("FirstID", "SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Link<Library, Show>"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Link<Kyoo.Models.Show, Kyoo.Models.Genre>", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("FirstID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SecondID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("FirstID", "SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SecondID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Link<Show, Genre>"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.MetadataID", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("DataID") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("EpisodeID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Link") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("PeopleID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("ProviderID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("SeasonID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("ShowID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("EpisodeID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("PeopleID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("ProviderID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("SeasonID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("ShowID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("MetadataIds"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.People", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Name") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Poster") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("People"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.PeopleRole", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("PeopleID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Role") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("ShowID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Type") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("PeopleID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("ShowID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("PeopleRoles"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Provider", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Logo") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("LogoExtension") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Name") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Providers"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Season", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Overview") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Poster") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("SeasonNumber") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("ShowID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Title") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("Year") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("ShowID", "SeasonNumber") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Seasons"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Show", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string[]>("Aliases") | ||||||
|  |                         .HasColumnType("text[]"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Backdrop") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("EndYear") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<bool>("IsMovie") | ||||||
|  |                         .HasColumnType("boolean"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Logo") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Overview") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Path") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Poster") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("StartYear") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<Status?>("Status") | ||||||
|  |                         .HasColumnType("status"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int?>("StudioID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Title") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("TrailerUrl") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("StudioID"); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Shows"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Studio", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Name") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Slug") | ||||||
|  |                         .IsRequired() | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("Slug") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Studios"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Track", b => | ||||||
|  |                 { | ||||||
|  |                     b.Property<int>("ID") | ||||||
|  |                         .ValueGeneratedOnAdd() | ||||||
|  |                         .HasColumnType("integer") | ||||||
|  |                         .HasAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Codec") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("EpisodeID") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<bool>("IsDefault") | ||||||
|  |                         .HasColumnType("boolean"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<bool>("IsExternal") | ||||||
|  |                         .HasColumnType("boolean"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<bool>("IsForced") | ||||||
|  |                         .HasColumnType("boolean"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Language") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Path") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<string>("Title") | ||||||
|  |                         .HasColumnType("text"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<int>("TrackIndex") | ||||||
|  |                         .HasColumnType("integer"); | ||||||
|  | 
 | ||||||
|  |                     b.Property<StreamType>("Type") | ||||||
|  |                         .HasColumnType("stream_type"); | ||||||
|  | 
 | ||||||
|  |                     b.HasKey("ID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasIndex("EpisodeID", "Type", "Language", "TrackIndex", "IsForced") | ||||||
|  |                         .IsUnique(); | ||||||
|  | 
 | ||||||
|  |                     b.ToTable("Tracks"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Episode", b => | ||||||
|  |                 { | ||||||
|  |                     b.HasOne("Kyoo.Models.Season", "Season") | ||||||
|  |                         .WithMany("Episodes") | ||||||
|  |                         .HasForeignKey("SeasonID"); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Show", "Show") | ||||||
|  |                         .WithMany("Episodes") | ||||||
|  |                         .HasForeignKey("ShowID") | ||||||
|  |                         .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") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Show", "Second") | ||||||
|  |                         .WithMany("CollectionLinks") | ||||||
|  |                         .HasForeignKey("SecondID") | ||||||
|  |                         .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") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Collection", "Second") | ||||||
|  |                         .WithMany("LibraryLinks") | ||||||
|  |                         .HasForeignKey("SecondID") | ||||||
|  |                         .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") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Provider", "Second") | ||||||
|  |                         .WithMany("LibraryLinks") | ||||||
|  |                         .HasForeignKey("SecondID") | ||||||
|  |                         .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") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Show", "Second") | ||||||
|  |                         .WithMany("LibraryLinks") | ||||||
|  |                         .HasForeignKey("SecondID") | ||||||
|  |                         .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") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Genre", "Second") | ||||||
|  |                         .WithMany("ShowLinks") | ||||||
|  |                         .HasForeignKey("SecondID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("First"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Second"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.MetadataID", b => | ||||||
|  |                 { | ||||||
|  |                     b.HasOne("Kyoo.Models.Episode", "Episode") | ||||||
|  |                         .WithMany("ExternalIDs") | ||||||
|  |                         .HasForeignKey("EpisodeID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.People", "People") | ||||||
|  |                         .WithMany("ExternalIDs") | ||||||
|  |                         .HasForeignKey("PeopleID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Provider", "Provider") | ||||||
|  |                         .WithMany("MetadataLinks") | ||||||
|  |                         .HasForeignKey("ProviderID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Season", "Season") | ||||||
|  |                         .WithMany("ExternalIDs") | ||||||
|  |                         .HasForeignKey("SeasonID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Show", "Show") | ||||||
|  |                         .WithMany("ExternalIDs") | ||||||
|  |                         .HasForeignKey("ShowID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Episode"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("People"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Provider"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Season"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Show"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.PeopleRole", b => | ||||||
|  |                 { | ||||||
|  |                     b.HasOne("Kyoo.Models.People", "People") | ||||||
|  |                         .WithMany("Roles") | ||||||
|  |                         .HasForeignKey("PeopleID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.HasOne("Kyoo.Models.Show", "Show") | ||||||
|  |                         .WithMany("People") | ||||||
|  |                         .HasForeignKey("ShowID") | ||||||
|  |                         .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") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Show"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Show", b => | ||||||
|  |                 { | ||||||
|  |                     b.HasOne("Kyoo.Models.Studio", "Studio") | ||||||
|  |                         .WithMany("Shows") | ||||||
|  |                         .HasForeignKey("StudioID"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Studio"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             modelBuilder.Entity("Kyoo.Models.Track", b => | ||||||
|  |                 { | ||||||
|  |                     b.HasOne("Kyoo.Models.Episode", "Episode") | ||||||
|  |                         .WithMany("Tracks") | ||||||
|  |                         .HasForeignKey("EpisodeID") | ||||||
|  |                         .OnDelete(DeleteBehavior.Cascade) | ||||||
|  |                         .IsRequired(); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("Episode"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             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"); | ||||||
|  | 
 | ||||||
|  |                     b.Navigation("MetadataLinks"); | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             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"); | ||||||
|  |                 }); | ||||||
|  | #pragma warning restore 612, 618 | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -69,7 +69,10 @@ namespace Kyoo.Postgresql | |||||||
| 		{ | 		{ | ||||||
| 			if (!_skipConfigure) | 			if (!_skipConfigure) | ||||||
| 			{ | 			{ | ||||||
|  | 				if (_connection != null) | ||||||
| 					optionsBuilder.UseNpgsql(_connection); | 					optionsBuilder.UseNpgsql(_connection); | ||||||
|  | 				else | ||||||
|  | 					optionsBuilder.UseNpgsql(); | ||||||
| 				if (_debugMode) | 				if (_debugMode) | ||||||
| 					optionsBuilder.EnableDetailedErrors().EnableSensitiveDataLogging(); | 					optionsBuilder.EnableDetailedErrors().EnableSensitiveDataLogging(); | ||||||
| 			} | 			} | ||||||
|  | |||||||
| @ -71,5 +71,12 @@ namespace Kyoo.Postgresql | |||||||
| 			// 	_environment.IsDevelopment())); | 			// 	_environment.IsDevelopment())); | ||||||
| 			// services.AddScoped<DbContext>(x => x.GetRequiredService<PostgresContext>()); | 			// services.AddScoped<DbContext>(x => x.GetRequiredService<PostgresContext>()); | ||||||
| 		} | 		} | ||||||
|  | 
 | ||||||
|  | 		/// <inheritdoc /> | ||||||
|  | 		public void Initialize(IServiceProvider provider) | ||||||
|  | 		{ | ||||||
|  | 			DatabaseContext context = provider.GetRequiredService<DatabaseContext>(); | ||||||
|  | 			context.Database.Migrate(); | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| @ -4,9 +4,11 @@ using System.Linq; | |||||||
| using System.Reflection; | using System.Reflection; | ||||||
| using System.Threading; | using System.Threading; | ||||||
| using System.Threading.Tasks; | using System.Threading.Tasks; | ||||||
|  | using JetBrains.Annotations; | ||||||
| using Kyoo.Models.Attributes; | using Kyoo.Models.Attributes; | ||||||
| using Kyoo.Models.Exceptions; | using Kyoo.Models.Exceptions; | ||||||
| using Microsoft.Extensions.Configuration; | using Microsoft.Extensions.Configuration; | ||||||
|  | using Microsoft.Extensions.DependencyInjection; | ||||||
| using Microsoft.Extensions.Hosting; | using Microsoft.Extensions.Hosting; | ||||||
| using Microsoft.Extensions.Logging; | using Microsoft.Extensions.Logging; | ||||||
| 
 | 
 | ||||||
| @ -34,7 +36,7 @@ namespace Kyoo.Controllers | |||||||
| 		/// <summary> | 		/// <summary> | ||||||
| 		/// The list of tasks and their next scheduled run. | 		/// The list of tasks and their next scheduled run. | ||||||
| 		/// </summary> | 		/// </summary> | ||||||
| 		private List<(ITask task, DateTime scheduledDate)> _tasks; | 		private readonly List<(ITask task, DateTime scheduledDate)> _tasks; | ||||||
| 		/// <summary> | 		/// <summary> | ||||||
| 		/// The queue of tasks that should be run as soon as possible. | 		/// The queue of tasks that should be run as soon as possible. | ||||||
| 		/// </summary> | 		/// </summary> | ||||||
| @ -64,7 +66,7 @@ namespace Kyoo.Controllers | |||||||
| 			_provider = provider; | 			_provider = provider; | ||||||
| 			_configuration = configuration.GetSection("scheduledTasks"); | 			_configuration = configuration.GetSection("scheduledTasks"); | ||||||
| 			_logger = logger; | 			_logger = logger; | ||||||
| 			_tasks = tasks.Select(x => (x, DateTime.Now + GetTaskDelay(x.Slug))).ToList(); | 			_tasks = tasks.Select(x => (x, GetNextTaskDate(x.Slug))).ToList(); | ||||||
| 			 | 			 | ||||||
| 			if (_tasks.Any()) | 			if (_tasks.Any()) | ||||||
| 				_logger.LogTrace("Task manager initiated with: {Tasks}", _tasks.Select(x => x.task.Name)); | 				_logger.LogTrace("Task manager initiated with: {Tasks}", _tasks.Select(x => x.task.Name)); | ||||||
| @ -155,8 +157,10 @@ namespace Kyoo.Controllers | |||||||
| 					return x.CreateValue(value ?? x.DefaultValue); | 					return x.CreateValue(value ?? x.DefaultValue); | ||||||
| 				})); | 				})); | ||||||
| 
 | 
 | ||||||
| 			InjectServices(task); | 			using IServiceScope scope = _provider.CreateScope(); | ||||||
|  | 			InjectServices(task, x => scope.ServiceProvider.GetRequiredService(x)); | ||||||
| 			await task.Run(args, _taskToken.Token); | 			await task.Run(args, _taskToken.Token); | ||||||
|  | 			InjectServices(task, _ => null); | ||||||
| 			_logger.LogInformation("Task finished: {Task}", task.Name); | 			_logger.LogInformation("Task finished: {Task}", task.Name); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| @ -164,17 +168,15 @@ namespace Kyoo.Controllers | |||||||
| 		/// Inject services into the <see cref="InjectedAttribute"/> marked properties of the given object. | 		/// Inject services into the <see cref="InjectedAttribute"/> marked properties of the given object. | ||||||
| 		/// </summary> | 		/// </summary> | ||||||
| 		/// <param name="obj">The object to inject</param> | 		/// <param name="obj">The object to inject</param> | ||||||
| 		private void InjectServices(ITask obj) | 		/// <param name="retrieve">The function used to retrieve services. (The function is called immediately)</param> | ||||||
|  | 		private static void InjectServices(ITask obj, [InstantHandle] Func<Type, object> retrieve) | ||||||
| 		{ | 		{ | ||||||
| 			IEnumerable<PropertyInfo> properties = obj.GetType().GetProperties() | 			IEnumerable<PropertyInfo> properties = obj.GetType().GetProperties() | ||||||
| 				.Where(x => x.GetCustomAttribute<InjectedAttribute>() != null) | 				.Where(x => x.GetCustomAttribute<InjectedAttribute>() != null) | ||||||
| 				.Where(x => x.CanWrite); | 				.Where(x => x.CanWrite); | ||||||
| 
 | 
 | ||||||
| 			foreach (PropertyInfo property in properties) | 			foreach (PropertyInfo property in properties) | ||||||
| 			{ | 				property.SetValue(obj, retrieve(property.PropertyType)); | ||||||
| 				object value = _provider.GetService(property.PropertyType); |  | ||||||
| 				property.SetValue(obj, value); |  | ||||||
| 			} |  | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		/// <summary> | 		/// <summary> | ||||||
| @ -197,7 +199,7 @@ namespace Kyoo.Controllers | |||||||
| 		private void EnqueueStartupTasks() | 		private void EnqueueStartupTasks() | ||||||
| 		{ | 		{ | ||||||
| 			IEnumerable<ITask> startupTasks = _tasks.Select(x => x.task) | 			IEnumerable<ITask> startupTasks = _tasks.Select(x => x.task) | ||||||
| 				.Where(x => x.RunOnStartup && x.Priority != int.MaxValue) | 				.Where(x => x.RunOnStartup) | ||||||
| 				.OrderByDescending(x => x.Priority); | 				.OrderByDescending(x => x.Priority); | ||||||
| 			foreach (ITask task in startupTasks) | 			foreach (ITask task in startupTasks) | ||||||
| 				_queuedTasks.Enqueue((task, new Dictionary<string, object>())); | 				_queuedTasks.Enqueue((task, new Dictionary<string, object>())); | ||||||
| @ -212,20 +214,20 @@ namespace Kyoo.Controllers | |||||||
| 			if (index == -1) | 			if (index == -1) | ||||||
| 				throw new ItemNotFoundException($"No task found with the slug {taskSlug}"); | 				throw new ItemNotFoundException($"No task found with the slug {taskSlug}"); | ||||||
| 			_queuedTasks.Enqueue((_tasks[index].task, arguments)); | 			_queuedTasks.Enqueue((_tasks[index].task, arguments)); | ||||||
| 			_tasks[index] = (_tasks[index].task, DateTime.Now + GetTaskDelay(taskSlug)); | 			_tasks[index] = (_tasks[index].task, GetNextTaskDate(taskSlug)); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		/// <summary> | 		/// <summary> | ||||||
| 		/// Get the delay of a task | 		/// Get the next date of the execution of the given task. | ||||||
| 		/// </summary> | 		/// </summary> | ||||||
| 		/// <param name="taskSlug">The slug of the task</param> | 		/// <param name="taskSlug">The slug of the task</param> | ||||||
| 		/// <returns>The delay of the task.</returns> | 		/// <returns>The next date.</returns> | ||||||
| 		private TimeSpan GetTaskDelay(string taskSlug) | 		private DateTime GetNextTaskDate(string taskSlug) | ||||||
| 		{ | 		{ | ||||||
| 			TimeSpan delay = _configuration.GetValue<TimeSpan>(taskSlug); | 			TimeSpan delay = _configuration.GetValue<TimeSpan>(taskSlug); | ||||||
| 			if (delay == default) | 			if (delay == default) | ||||||
| 				delay = TimeSpan.MaxValue; | 				return DateTime.MaxValue; | ||||||
| 			return delay; | 			return DateTime.Now + delay; | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		/// <inheritdoc /> | 		/// <inheritdoc /> | ||||||
| @ -239,12 +241,5 @@ namespace Kyoo.Controllers | |||||||
| 		{ | 		{ | ||||||
| 			return _tasks.Select(x => x.task).ToArray(); | 			return _tasks.Select(x => x.task).ToArray(); | ||||||
| 		} | 		} | ||||||
| 
 |  | ||||||
| 		/// <inheritdoc /> |  | ||||||
| 		public void ReloadTasks() |  | ||||||
| 		{ |  | ||||||
| 			// _tasks = _provider.Resolve<IEnumerable<ITask>>().Select(x => (x, DateTime.Now + GetTaskDelay(x.Slug))).ToList(); |  | ||||||
| 			EnqueueStartupTasks(); |  | ||||||
| 		} |  | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| @ -3,6 +3,7 @@ using System.IO; | |||||||
| using Kyoo.Controllers; | using Kyoo.Controllers; | ||||||
| using Kyoo.Models; | using Kyoo.Models; | ||||||
| using Kyoo.Postgresql; | using Kyoo.Postgresql; | ||||||
|  | using Kyoo.Tasks; | ||||||
| using Microsoft.AspNetCore.Builder; | using Microsoft.AspNetCore.Builder; | ||||||
| using Microsoft.AspNetCore.Hosting; | using Microsoft.AspNetCore.Hosting; | ||||||
| using Microsoft.AspNetCore.SpaServices.AngularCli; | using Microsoft.AspNetCore.SpaServices.AngularCli; | ||||||
| @ -85,9 +86,10 @@ namespace Kyoo | |||||||
| 			// 		}); | 			// 		}); | ||||||
| 			// }); | 			// }); | ||||||
| 			// services.AddAuthentication() | 			// services.AddAuthentication() | ||||||
|  | 			services.AddTransient(typeof(Lazy<>), typeof(LazyDi<>)); | ||||||
| 			 | 			 | ||||||
| 			services.AddSingleton(_plugins); | 			services.AddSingleton(_plugins); | ||||||
| 			services.AddTransient(typeof(Lazy<>), typeof(LazyDi<>)); | 			services.AddTask<PluginInitializer>(); | ||||||
| 			_plugins.ConfigureServices(services); | 			_plugins.ConfigureServices(services); | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
|  | |||||||
							
								
								
									
										60
									
								
								Kyoo/Tasks/PluginInitializer.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								Kyoo/Tasks/PluginInitializer.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,60 @@ | |||||||
|  | using System; | ||||||
|  | using System.Threading; | ||||||
|  | using System.Threading.Tasks; | ||||||
|  | using Kyoo.Controllers; | ||||||
|  | using Kyoo.Models.Attributes; | ||||||
|  | 
 | ||||||
|  | namespace Kyoo.Tasks | ||||||
|  | { | ||||||
|  | 	/// <summary> | ||||||
|  | 	/// A task run on Kyoo's startup to initialize plugins | ||||||
|  | 	/// </summary> | ||||||
|  | 	public class PluginInitializer : ITask | ||||||
|  | 	{ | ||||||
|  | 		/// <inheritdoc /> | ||||||
|  | 		public string Slug => "plugin-init"; | ||||||
|  | 		 | ||||||
|  | 		/// <inheritdoc /> | ||||||
|  | 		public string Name => "PluginInitializer"; | ||||||
|  | 
 | ||||||
|  | 		/// <inheritdoc /> | ||||||
|  | 		public string Description => "A task to initialize plugins."; | ||||||
|  | 
 | ||||||
|  | 		/// <inheritdoc /> | ||||||
|  | 		public string HelpMessage => null; | ||||||
|  | 
 | ||||||
|  | 		/// <inheritdoc /> | ||||||
|  | 		public bool RunOnStartup => true; | ||||||
|  | 
 | ||||||
|  | 		/// <inheritdoc /> | ||||||
|  | 		public int Priority => int.MaxValue; | ||||||
|  | 		 | ||||||
|  | 		 | ||||||
|  | 		/// <summary> | ||||||
|  | 		/// The plugin manager used to retrieve plugins to initialize them. | ||||||
|  | 		/// </summary> | ||||||
|  | 		[Injected] public IPluginManager PluginManager { private get; set; } | ||||||
|  | 		/// <summary> | ||||||
|  | 		/// The service provider given to each <see cref="IPlugin.Initialize"/> method. | ||||||
|  | 		/// </summary> | ||||||
|  | 		[Injected] public IServiceProvider Provider { private get; set; } | ||||||
|  | 		 | ||||||
|  | 		/// <inheritdoc /> | ||||||
|  | 		public Task Run(TaskParameters arguments, CancellationToken cancellationToken) | ||||||
|  | 		{ | ||||||
|  | 			foreach (IPlugin plugin in PluginManager.GetAllPlugins()) | ||||||
|  | 				plugin.Initialize(Provider); | ||||||
|  | 			return Task.CompletedTask; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		public TaskParameters GetParameters() | ||||||
|  | 		{ | ||||||
|  | 			return new(); | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		public int? Progress() | ||||||
|  | 		{ | ||||||
|  | 			return null; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user