diff --git a/back/src/Kyoo.Abstractions/Models/Resources/Episode.cs b/back/src/Kyoo.Abstractions/Models/Resources/Episode.cs
index 75fe4746..536decaf 100644
--- a/back/src/Kyoo.Abstractions/Models/Resources/Episode.cs
+++ b/back/src/Kyoo.Abstractions/Models/Resources/Episode.cs
@@ -151,7 +151,7 @@ public class Episode : IQuery, IResource, IMetadata, IThumbnails, IAddedDate, IN
///
/// The release date of this episode. It can be null if unknown.
///
- public DateTime? ReleaseDate { get; set; }
+ public DateOnly? ReleaseDate { get; set; }
///
public DateTime AddedDate { get; set; }
diff --git a/back/src/Kyoo.Abstractions/Models/Resources/Movie.cs b/back/src/Kyoo.Abstractions/Models/Resources/Movie.cs
index 3223c5e8..e70371b1 100644
--- a/back/src/Kyoo.Abstractions/Models/Resources/Movie.cs
+++ b/back/src/Kyoo.Abstractions/Models/Resources/Movie.cs
@@ -104,7 +104,7 @@ public class Movie
///
/// The date this movie aired.
///
- public DateTime? AirDate { get; set; }
+ public DateOnly? AirDate { get; set; }
///
public DateTime AddedDate { get; set; }
@@ -120,11 +120,11 @@ public class Movie
[JsonIgnore]
[Column("air_date")]
- public DateTime? StartAir => AirDate;
+ public DateOnly? StartAir => AirDate;
[JsonIgnore]
[Column("air_date")]
- public DateTime? EndAir => AirDate;
+ public DateOnly? EndAir => AirDate;
///
/// A video of a few minutes that tease the content.
diff --git a/back/src/Kyoo.Abstractions/Models/Resources/Season.cs b/back/src/Kyoo.Abstractions/Models/Resources/Season.cs
index e88680a9..8d3e0489 100644
--- a/back/src/Kyoo.Abstractions/Models/Resources/Season.cs
+++ b/back/src/Kyoo.Abstractions/Models/Resources/Season.cs
@@ -97,7 +97,7 @@ public class Season : IQuery, IResource, IMetadata, IThumbnails, IAddedDate
///
/// The starting air date of this season.
///
- public DateTime? StartDate { get; set; }
+ public DateOnly? StartDate { get; set; }
///
public DateTime AddedDate { get; set; }
@@ -105,7 +105,7 @@ public class Season : IQuery, IResource, IMetadata, IThumbnails, IAddedDate
///
/// The ending date of this season.
///
- public DateTime? EndDate { get; set; }
+ public DateOnly? EndDate { get; set; }
///
public Image? Poster { get; set; }
diff --git a/back/src/Kyoo.Abstractions/Models/Resources/Show.cs b/back/src/Kyoo.Abstractions/Models/Resources/Show.cs
index 6967a1e7..edee8866 100644
--- a/back/src/Kyoo.Abstractions/Models/Resources/Show.cs
+++ b/back/src/Kyoo.Abstractions/Models/Resources/Show.cs
@@ -94,13 +94,13 @@ public class Show
///
/// The date this show started airing. It can be null if this is unknown.
///
- public DateTime? StartAir { get; set; }
+ public DateOnly? StartAir { get; set; }
///
/// The date this show finished airing.
/// It can also be null if this is unknown.
///
- public DateTime? EndAir { get; set; }
+ public DateOnly? EndAir { get; set; }
///
public DateTime AddedDate { get; set; }
@@ -121,7 +121,7 @@ public class Show
[JsonIgnore]
[Column("start_air")]
- public DateTime? AirDate => StartAir;
+ public DateOnly? AirDate => StartAir;
///
public Dictionary ExternalId { get; set; } = new();
diff --git a/back/src/Kyoo.Postgresql/Migrations/20240324174638_UseDateOnly.Designer.cs b/back/src/Kyoo.Postgresql/Migrations/20240324174638_UseDateOnly.Designer.cs
new file mode 100644
index 00000000..b8e4163f
--- /dev/null
+++ b/back/src/Kyoo.Postgresql/Migrations/20240324174638_UseDateOnly.Designer.cs
@@ -0,0 +1,1317 @@
+//
+using System;
+using System.Collections.Generic;
+using Kyoo.Abstractions.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;
+
+#nullable disable
+
+namespace Kyoo.Postgresql.Migrations
+{
+ [DbContext(typeof(PostgresContext))]
+ [Migration("20240324174638_UseDateOnly")]
+ partial class UseDateOnly
+ {
+ ///
+ protected override void BuildTargetModel(ModelBuilder modelBuilder)
+ {
+#pragma warning disable 612, 618
+ modelBuilder
+ .HasAnnotation("ProductVersion", "8.0.3")
+ .HasAnnotation("Relational:MaxIdentifierLength", 63);
+
+ NpgsqlModelBuilderExtensions.HasPostgresEnum(modelBuilder, "genre", new[] { "action", "adventure", "animation", "comedy", "crime", "documentary", "drama", "family", "fantasy", "history", "horror", "music", "mystery", "romance", "science_fiction", "thriller", "war", "western" });
+ NpgsqlModelBuilderExtensions.HasPostgresEnum(modelBuilder, "status", new[] { "unknown", "finished", "airing", "planned" });
+ NpgsqlModelBuilderExtensions.HasPostgresEnum(modelBuilder, "watch_status", new[] { "completed", "watching", "droped", "planned", "deleted" });
+ NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder);
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Collection", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("AddedDate")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("added_date")
+ .HasDefaultValueSql("now() at time zone 'utc'");
+
+ b.Property("ExternalId")
+ .IsRequired()
+ .HasColumnType("json")
+ .HasColumnName("external_id");
+
+ b.Property("Name")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("name");
+
+ b.Property("Overview")
+ .HasColumnType("text")
+ .HasColumnName("overview");
+
+ b.Property("Slug")
+ .IsRequired()
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)")
+ .HasColumnName("slug");
+
+ b.HasKey("Id")
+ .HasName("pk_collections");
+
+ b.HasIndex("Slug")
+ .IsUnique()
+ .HasDatabaseName("ix_collections_slug");
+
+ b.ToTable("collections", (string)null);
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Episode", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("AbsoluteNumber")
+ .HasColumnType("integer")
+ .HasColumnName("absolute_number");
+
+ b.Property("AddedDate")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("added_date")
+ .HasDefaultValueSql("now() at time zone 'utc'");
+
+ b.Property("EpisodeNumber")
+ .HasColumnType("integer")
+ .HasColumnName("episode_number");
+
+ b.Property("ExternalId")
+ .IsRequired()
+ .HasColumnType("json")
+ .HasColumnName("external_id");
+
+ b.Property("Name")
+ .HasColumnType("text")
+ .HasColumnName("name");
+
+ b.Property("Overview")
+ .HasColumnType("text")
+ .HasColumnName("overview");
+
+ b.Property("Path")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("path");
+
+ b.Property("ReleaseDate")
+ .HasColumnType("date")
+ .HasColumnName("release_date");
+
+ b.Property("Runtime")
+ .HasColumnType("integer")
+ .HasColumnName("runtime");
+
+ b.Property("SeasonId")
+ .HasColumnType("uuid")
+ .HasColumnName("season_id");
+
+ b.Property("SeasonNumber")
+ .HasColumnType("integer")
+ .HasColumnName("season_number");
+
+ b.Property("ShowId")
+ .HasColumnType("uuid")
+ .HasColumnName("show_id");
+
+ b.Property("Slug")
+ .IsRequired()
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)")
+ .HasColumnName("slug");
+
+ b.HasKey("Id")
+ .HasName("pk_episodes");
+
+ b.HasIndex("SeasonId")
+ .HasDatabaseName("ix_episodes_season_id");
+
+ b.HasIndex("Slug")
+ .IsUnique()
+ .HasDatabaseName("ix_episodes_slug");
+
+ b.HasIndex("ShowId", "SeasonNumber", "EpisodeNumber", "AbsoluteNumber")
+ .IsUnique()
+ .HasDatabaseName("ix_episodes_show_id_season_number_episode_number_absolute_numb");
+
+ b.ToTable("episodes", (string)null);
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.EpisodeWatchStatus", b =>
+ {
+ b.Property("UserId")
+ .HasColumnType("uuid")
+ .HasColumnName("user_id");
+
+ b.Property("EpisodeId")
+ .HasColumnType("uuid")
+ .HasColumnName("episode_id");
+
+ b.Property("AddedDate")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("added_date")
+ .HasDefaultValueSql("now() at time zone 'utc'");
+
+ b.Property("PlayedDate")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("played_date");
+
+ b.Property("Status")
+ .HasColumnType("watch_status")
+ .HasColumnName("status");
+
+ b.Property("WatchedPercent")
+ .HasColumnType("integer")
+ .HasColumnName("watched_percent");
+
+ b.Property("WatchedTime")
+ .HasColumnType("integer")
+ .HasColumnName("watched_time");
+
+ b.HasKey("UserId", "EpisodeId")
+ .HasName("pk_episode_watch_status");
+
+ b.HasIndex("EpisodeId")
+ .HasDatabaseName("ix_episode_watch_status_episode_id");
+
+ b.ToTable("episode_watch_status", (string)null);
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Issue", b =>
+ {
+ b.Property("Domain")
+ .HasColumnType("text")
+ .HasColumnName("domain");
+
+ b.Property("Cause")
+ .HasColumnType("text")
+ .HasColumnName("cause");
+
+ b.Property("AddedDate")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("added_date")
+ .HasDefaultValueSql("now() at time zone 'utc'");
+
+ b.Property("Extra")
+ .IsRequired()
+ .HasColumnType("json")
+ .HasColumnName("extra");
+
+ b.Property("Reason")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("reason");
+
+ b.HasKey("Domain", "Cause")
+ .HasName("pk_issues");
+
+ b.ToTable("issues", (string)null);
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Movie", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("AddedDate")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("added_date")
+ .HasDefaultValueSql("now() at time zone 'utc'");
+
+ b.Property("AirDate")
+ .HasColumnType("date")
+ .HasColumnName("air_date");
+
+ b.Property("Aliases")
+ .IsRequired()
+ .HasColumnType("text[]")
+ .HasColumnName("aliases");
+
+ b.Property("ExternalId")
+ .IsRequired()
+ .HasColumnType("json")
+ .HasColumnName("external_id");
+
+ b.Property("Genres")
+ .IsRequired()
+ .HasColumnType("genre[]")
+ .HasColumnName("genres");
+
+ b.Property("Name")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("name");
+
+ b.Property("Overview")
+ .HasColumnType("text")
+ .HasColumnName("overview");
+
+ b.Property("Path")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("path");
+
+ b.Property("Rating")
+ .HasColumnType("integer")
+ .HasColumnName("rating");
+
+ b.Property("Runtime")
+ .HasColumnType("integer")
+ .HasColumnName("runtime");
+
+ b.Property("Slug")
+ .IsRequired()
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)")
+ .HasColumnName("slug");
+
+ b.Property("Status")
+ .HasColumnType("status")
+ .HasColumnName("status");
+
+ b.Property("StudioId")
+ .HasColumnType("uuid")
+ .HasColumnName("studio_id");
+
+ b.Property("Tagline")
+ .HasColumnType("text")
+ .HasColumnName("tagline");
+
+ b.Property("Tags")
+ .IsRequired()
+ .HasColumnType("text[]")
+ .HasColumnName("tags");
+
+ b.Property("Trailer")
+ .HasColumnType("text")
+ .HasColumnName("trailer");
+
+ b.HasKey("Id")
+ .HasName("pk_movies");
+
+ b.HasIndex("Slug")
+ .IsUnique()
+ .HasDatabaseName("ix_movies_slug");
+
+ b.HasIndex("StudioId")
+ .HasDatabaseName("ix_movies_studio_id");
+
+ b.ToTable("movies", (string)null);
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.MovieWatchStatus", b =>
+ {
+ b.Property("UserId")
+ .HasColumnType("uuid")
+ .HasColumnName("user_id");
+
+ b.Property("MovieId")
+ .HasColumnType("uuid")
+ .HasColumnName("movie_id");
+
+ b.Property("AddedDate")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("added_date")
+ .HasDefaultValueSql("now() at time zone 'utc'");
+
+ b.Property("PlayedDate")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("played_date");
+
+ b.Property("Status")
+ .HasColumnType("watch_status")
+ .HasColumnName("status");
+
+ b.Property("WatchedPercent")
+ .HasColumnType("integer")
+ .HasColumnName("watched_percent");
+
+ b.Property("WatchedTime")
+ .HasColumnType("integer")
+ .HasColumnName("watched_time");
+
+ b.HasKey("UserId", "MovieId")
+ .HasName("pk_movie_watch_status");
+
+ b.HasIndex("MovieId")
+ .HasDatabaseName("ix_movie_watch_status_movie_id");
+
+ b.ToTable("movie_watch_status", (string)null);
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Season", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("AddedDate")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("added_date")
+ .HasDefaultValueSql("now() at time zone 'utc'");
+
+ b.Property("EndDate")
+ .HasColumnType("date")
+ .HasColumnName("end_date");
+
+ b.Property("ExternalId")
+ .IsRequired()
+ .HasColumnType("json")
+ .HasColumnName("external_id");
+
+ b.Property("Name")
+ .HasColumnType("text")
+ .HasColumnName("name");
+
+ b.Property("Overview")
+ .HasColumnType("text")
+ .HasColumnName("overview");
+
+ b.Property("SeasonNumber")
+ .HasColumnType("integer")
+ .HasColumnName("season_number");
+
+ b.Property("ShowId")
+ .HasColumnType("uuid")
+ .HasColumnName("show_id");
+
+ b.Property("Slug")
+ .IsRequired()
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)")
+ .HasColumnName("slug");
+
+ b.Property("StartDate")
+ .HasColumnType("date")
+ .HasColumnName("start_date");
+
+ b.HasKey("Id")
+ .HasName("pk_seasons");
+
+ b.HasIndex("Slug")
+ .IsUnique()
+ .HasDatabaseName("ix_seasons_slug");
+
+ b.HasIndex("ShowId", "SeasonNumber")
+ .IsUnique()
+ .HasDatabaseName("ix_seasons_show_id_season_number");
+
+ b.ToTable("seasons", (string)null);
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Show", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("AddedDate")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("added_date")
+ .HasDefaultValueSql("now() at time zone 'utc'");
+
+ b.Property>("Aliases")
+ .IsRequired()
+ .HasColumnType("text[]")
+ .HasColumnName("aliases");
+
+ b.Property("EndAir")
+ .HasColumnType("date")
+ .HasColumnName("end_air");
+
+ b.Property("ExternalId")
+ .IsRequired()
+ .HasColumnType("json")
+ .HasColumnName("external_id");
+
+ b.Property>("Genres")
+ .IsRequired()
+ .HasColumnType("genre[]")
+ .HasColumnName("genres");
+
+ b.Property("Name")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("name");
+
+ b.Property("Overview")
+ .HasColumnType("text")
+ .HasColumnName("overview");
+
+ b.Property("Rating")
+ .HasColumnType("integer")
+ .HasColumnName("rating");
+
+ b.Property("Slug")
+ .IsRequired()
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)")
+ .HasColumnName("slug");
+
+ b.Property("StartAir")
+ .HasColumnType("date")
+ .HasColumnName("start_air");
+
+ b.Property("Status")
+ .HasColumnType("status")
+ .HasColumnName("status");
+
+ b.Property("StudioId")
+ .HasColumnType("uuid")
+ .HasColumnName("studio_id");
+
+ b.Property("Tagline")
+ .HasColumnType("text")
+ .HasColumnName("tagline");
+
+ b.Property>("Tags")
+ .IsRequired()
+ .HasColumnType("text[]")
+ .HasColumnName("tags");
+
+ b.Property("Trailer")
+ .HasColumnType("text")
+ .HasColumnName("trailer");
+
+ b.HasKey("Id")
+ .HasName("pk_shows");
+
+ b.HasIndex("Slug")
+ .IsUnique()
+ .HasDatabaseName("ix_shows_slug");
+
+ b.HasIndex("StudioId")
+ .HasDatabaseName("ix_shows_studio_id");
+
+ b.ToTable("shows", (string)null);
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.ShowWatchStatus", b =>
+ {
+ b.Property("UserId")
+ .HasColumnType("uuid")
+ .HasColumnName("user_id");
+
+ b.Property("ShowId")
+ .HasColumnType("uuid")
+ .HasColumnName("show_id");
+
+ b.Property("AddedDate")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("added_date")
+ .HasDefaultValueSql("now() at time zone 'utc'");
+
+ b.Property("NextEpisodeId")
+ .HasColumnType("uuid")
+ .HasColumnName("next_episode_id");
+
+ b.Property("PlayedDate")
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("played_date");
+
+ b.Property("Status")
+ .HasColumnType("watch_status")
+ .HasColumnName("status");
+
+ b.Property("UnseenEpisodesCount")
+ .HasColumnType("integer")
+ .HasColumnName("unseen_episodes_count");
+
+ b.Property("WatchedPercent")
+ .HasColumnType("integer")
+ .HasColumnName("watched_percent");
+
+ b.Property("WatchedTime")
+ .HasColumnType("integer")
+ .HasColumnName("watched_time");
+
+ b.HasKey("UserId", "ShowId")
+ .HasName("pk_show_watch_status");
+
+ b.HasIndex("NextEpisodeId")
+ .HasDatabaseName("ix_show_watch_status_next_episode_id");
+
+ b.HasIndex("ShowId")
+ .HasDatabaseName("ix_show_watch_status_show_id");
+
+ b.ToTable("show_watch_status", (string)null);
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Studio", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("ExternalId")
+ .IsRequired()
+ .HasColumnType("json")
+ .HasColumnName("external_id");
+
+ b.Property("Name")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("name");
+
+ b.Property("Slug")
+ .IsRequired()
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)")
+ .HasColumnName("slug");
+
+ b.HasKey("Id")
+ .HasName("pk_studios");
+
+ b.HasIndex("Slug")
+ .IsUnique()
+ .HasDatabaseName("ix_studios_slug");
+
+ b.ToTable("studios", (string)null);
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.User", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b.Property("AddedDate")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("timestamp with time zone")
+ .HasColumnName("added_date")
+ .HasDefaultValueSql("now() at time zone 'utc'");
+
+ b.Property("Email")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("email");
+
+ b.Property("ExternalId")
+ .IsRequired()
+ .HasColumnType("json")
+ .HasColumnName("external_id");
+
+ b.Property("Password")
+ .HasColumnType("text")
+ .HasColumnName("password");
+
+ b.Property("Permissions")
+ .IsRequired()
+ .HasColumnType("text[]")
+ .HasColumnName("permissions");
+
+ b.Property("Settings")
+ .IsRequired()
+ .HasColumnType("json")
+ .HasColumnName("settings");
+
+ b.Property("Slug")
+ .IsRequired()
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)")
+ .HasColumnName("slug");
+
+ b.Property("Username")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("username");
+
+ b.HasKey("Id")
+ .HasName("pk_users");
+
+ b.HasIndex("Slug")
+ .IsUnique()
+ .HasDatabaseName("ix_users_slug");
+
+ b.HasIndex("Username")
+ .IsUnique()
+ .HasDatabaseName("ix_users_username");
+
+ b.ToTable("users", (string)null);
+ });
+
+ modelBuilder.Entity("link_collection_movie", b =>
+ {
+ b.Property("collection_id")
+ .HasColumnType("uuid")
+ .HasColumnName("collection_id");
+
+ b.Property("movie_id")
+ .HasColumnType("uuid")
+ .HasColumnName("movie_id");
+
+ b.HasKey("collection_id", "movie_id")
+ .HasName("pk_link_collection_movie");
+
+ b.HasIndex("movie_id")
+ .HasDatabaseName("ix_link_collection_movie_movie_id");
+
+ b.ToTable("link_collection_movie", (string)null);
+ });
+
+ modelBuilder.Entity("link_collection_show", b =>
+ {
+ b.Property("collection_id")
+ .HasColumnType("uuid")
+ .HasColumnName("collection_id");
+
+ b.Property("show_id")
+ .HasColumnType("uuid")
+ .HasColumnName("show_id");
+
+ b.HasKey("collection_id", "show_id")
+ .HasName("pk_link_collection_show");
+
+ b.HasIndex("show_id")
+ .HasDatabaseName("ix_link_collection_show_show_id");
+
+ b.ToTable("link_collection_show", (string)null);
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Collection", b =>
+ {
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Logo", b1 =>
+ {
+ b1.Property("CollectionId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("logo_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("logo_source");
+
+ b1.HasKey("CollectionId");
+
+ b1.ToTable("collections");
+
+ b1.WithOwner()
+ .HasForeignKey("CollectionId")
+ .HasConstraintName("fk_collections_collections_id");
+ });
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Poster", b1 =>
+ {
+ b1.Property("CollectionId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("poster_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("poster_source");
+
+ b1.HasKey("CollectionId");
+
+ b1.ToTable("collections");
+
+ b1.WithOwner()
+ .HasForeignKey("CollectionId")
+ .HasConstraintName("fk_collections_collections_id");
+ });
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Thumbnail", b1 =>
+ {
+ b1.Property("CollectionId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("thumbnail_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("thumbnail_source");
+
+ b1.HasKey("CollectionId");
+
+ b1.ToTable("collections");
+
+ b1.WithOwner()
+ .HasForeignKey("CollectionId")
+ .HasConstraintName("fk_collections_collections_id");
+ });
+
+ b.Navigation("Logo");
+
+ b.Navigation("Poster");
+
+ b.Navigation("Thumbnail");
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Episode", b =>
+ {
+ b.HasOne("Kyoo.Abstractions.Models.Season", "Season")
+ .WithMany("Episodes")
+ .HasForeignKey("SeasonId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .HasConstraintName("fk_episodes_seasons_season_id");
+
+ b.HasOne("Kyoo.Abstractions.Models.Show", "Show")
+ .WithMany("Episodes")
+ .HasForeignKey("ShowId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_episodes_shows_show_id");
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Logo", b1 =>
+ {
+ b1.Property("EpisodeId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("logo_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("logo_source");
+
+ b1.HasKey("EpisodeId");
+
+ b1.ToTable("episodes");
+
+ b1.WithOwner()
+ .HasForeignKey("EpisodeId")
+ .HasConstraintName("fk_episodes_episodes_id");
+ });
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Poster", b1 =>
+ {
+ b1.Property("EpisodeId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("poster_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("poster_source");
+
+ b1.HasKey("EpisodeId");
+
+ b1.ToTable("episodes");
+
+ b1.WithOwner()
+ .HasForeignKey("EpisodeId")
+ .HasConstraintName("fk_episodes_episodes_id");
+ });
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Thumbnail", b1 =>
+ {
+ b1.Property("EpisodeId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("thumbnail_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("thumbnail_source");
+
+ b1.HasKey("EpisodeId");
+
+ b1.ToTable("episodes");
+
+ b1.WithOwner()
+ .HasForeignKey("EpisodeId")
+ .HasConstraintName("fk_episodes_episodes_id");
+ });
+
+ b.Navigation("Logo");
+
+ b.Navigation("Poster");
+
+ b.Navigation("Season");
+
+ b.Navigation("Show");
+
+ b.Navigation("Thumbnail");
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.EpisodeWatchStatus", b =>
+ {
+ b.HasOne("Kyoo.Abstractions.Models.Episode", "Episode")
+ .WithMany("Watched")
+ .HasForeignKey("EpisodeId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_episode_watch_status_episodes_episode_id");
+
+ b.HasOne("Kyoo.Abstractions.Models.User", "User")
+ .WithMany()
+ .HasForeignKey("UserId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_episode_watch_status_users_user_id");
+
+ b.Navigation("Episode");
+
+ b.Navigation("User");
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Movie", b =>
+ {
+ b.HasOne("Kyoo.Abstractions.Models.Studio", "Studio")
+ .WithMany("Movies")
+ .HasForeignKey("StudioId")
+ .OnDelete(DeleteBehavior.SetNull)
+ .HasConstraintName("fk_movies_studios_studio_id");
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Logo", b1 =>
+ {
+ b1.Property("MovieId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("logo_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("logo_source");
+
+ b1.HasKey("MovieId");
+
+ b1.ToTable("movies");
+
+ b1.WithOwner()
+ .HasForeignKey("MovieId")
+ .HasConstraintName("fk_movies_movies_id");
+ });
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Poster", b1 =>
+ {
+ b1.Property("MovieId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("poster_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("poster_source");
+
+ b1.HasKey("MovieId");
+
+ b1.ToTable("movies");
+
+ b1.WithOwner()
+ .HasForeignKey("MovieId")
+ .HasConstraintName("fk_movies_movies_id");
+ });
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Thumbnail", b1 =>
+ {
+ b1.Property("MovieId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("thumbnail_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("thumbnail_source");
+
+ b1.HasKey("MovieId");
+
+ b1.ToTable("movies");
+
+ b1.WithOwner()
+ .HasForeignKey("MovieId")
+ .HasConstraintName("fk_movies_movies_id");
+ });
+
+ b.Navigation("Logo");
+
+ b.Navigation("Poster");
+
+ b.Navigation("Studio");
+
+ b.Navigation("Thumbnail");
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.MovieWatchStatus", b =>
+ {
+ b.HasOne("Kyoo.Abstractions.Models.Movie", "Movie")
+ .WithMany("Watched")
+ .HasForeignKey("MovieId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_movie_watch_status_movies_movie_id");
+
+ b.HasOne("Kyoo.Abstractions.Models.User", "User")
+ .WithMany()
+ .HasForeignKey("UserId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_movie_watch_status_users_user_id");
+
+ b.Navigation("Movie");
+
+ b.Navigation("User");
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Season", b =>
+ {
+ b.HasOne("Kyoo.Abstractions.Models.Show", "Show")
+ .WithMany("Seasons")
+ .HasForeignKey("ShowId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_seasons_shows_show_id");
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Logo", b1 =>
+ {
+ b1.Property("SeasonId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("logo_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("logo_source");
+
+ b1.HasKey("SeasonId");
+
+ b1.ToTable("seasons");
+
+ b1.WithOwner()
+ .HasForeignKey("SeasonId")
+ .HasConstraintName("fk_seasons_seasons_id");
+ });
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Poster", b1 =>
+ {
+ b1.Property("SeasonId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("poster_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("poster_source");
+
+ b1.HasKey("SeasonId");
+
+ b1.ToTable("seasons");
+
+ b1.WithOwner()
+ .HasForeignKey("SeasonId")
+ .HasConstraintName("fk_seasons_seasons_id");
+ });
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Thumbnail", b1 =>
+ {
+ b1.Property("SeasonId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("thumbnail_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("thumbnail_source");
+
+ b1.HasKey("SeasonId");
+
+ b1.ToTable("seasons");
+
+ b1.WithOwner()
+ .HasForeignKey("SeasonId")
+ .HasConstraintName("fk_seasons_seasons_id");
+ });
+
+ b.Navigation("Logo");
+
+ b.Navigation("Poster");
+
+ b.Navigation("Show");
+
+ b.Navigation("Thumbnail");
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Show", b =>
+ {
+ b.HasOne("Kyoo.Abstractions.Models.Studio", "Studio")
+ .WithMany("Shows")
+ .HasForeignKey("StudioId")
+ .OnDelete(DeleteBehavior.SetNull)
+ .HasConstraintName("fk_shows_studios_studio_id");
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Logo", b1 =>
+ {
+ b1.Property("ShowId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("logo_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("logo_source");
+
+ b1.HasKey("ShowId");
+
+ b1.ToTable("shows");
+
+ b1.WithOwner()
+ .HasForeignKey("ShowId")
+ .HasConstraintName("fk_shows_shows_id");
+ });
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Poster", b1 =>
+ {
+ b1.Property("ShowId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("poster_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("poster_source");
+
+ b1.HasKey("ShowId");
+
+ b1.ToTable("shows");
+
+ b1.WithOwner()
+ .HasForeignKey("ShowId")
+ .HasConstraintName("fk_shows_shows_id");
+ });
+
+ b.OwnsOne("Kyoo.Abstractions.Models.Image", "Thumbnail", b1 =>
+ {
+ b1.Property("ShowId")
+ .HasColumnType("uuid")
+ .HasColumnName("id");
+
+ b1.Property("Blurhash")
+ .IsRequired()
+ .HasMaxLength(32)
+ .HasColumnType("character varying(32)")
+ .HasColumnName("thumbnail_blurhash");
+
+ b1.Property("Source")
+ .IsRequired()
+ .HasColumnType("text")
+ .HasColumnName("thumbnail_source");
+
+ b1.HasKey("ShowId");
+
+ b1.ToTable("shows");
+
+ b1.WithOwner()
+ .HasForeignKey("ShowId")
+ .HasConstraintName("fk_shows_shows_id");
+ });
+
+ b.Navigation("Logo");
+
+ b.Navigation("Poster");
+
+ b.Navigation("Studio");
+
+ b.Navigation("Thumbnail");
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.ShowWatchStatus", b =>
+ {
+ b.HasOne("Kyoo.Abstractions.Models.Episode", "NextEpisode")
+ .WithMany()
+ .HasForeignKey("NextEpisodeId")
+ .OnDelete(DeleteBehavior.SetNull)
+ .HasConstraintName("fk_show_watch_status_episodes_next_episode_id");
+
+ b.HasOne("Kyoo.Abstractions.Models.Show", "Show")
+ .WithMany("Watched")
+ .HasForeignKey("ShowId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_show_watch_status_shows_show_id");
+
+ b.HasOne("Kyoo.Abstractions.Models.User", "User")
+ .WithMany()
+ .HasForeignKey("UserId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_show_watch_status_users_user_id");
+
+ b.Navigation("NextEpisode");
+
+ b.Navigation("Show");
+
+ b.Navigation("User");
+ });
+
+ modelBuilder.Entity("link_collection_movie", b =>
+ {
+ b.HasOne("Kyoo.Abstractions.Models.Collection", null)
+ .WithMany()
+ .HasForeignKey("collection_id")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_link_collection_movie_collections_collection_id");
+
+ b.HasOne("Kyoo.Abstractions.Models.Movie", null)
+ .WithMany()
+ .HasForeignKey("movie_id")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_link_collection_movie_movies_movie_id");
+ });
+
+ modelBuilder.Entity("link_collection_show", b =>
+ {
+ b.HasOne("Kyoo.Abstractions.Models.Collection", null)
+ .WithMany()
+ .HasForeignKey("collection_id")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_link_collection_show_collections_collection_id");
+
+ b.HasOne("Kyoo.Abstractions.Models.Show", null)
+ .WithMany()
+ .HasForeignKey("show_id")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired()
+ .HasConstraintName("fk_link_collection_show_shows_show_id");
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Episode", b =>
+ {
+ b.Navigation("Watched");
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Movie", b =>
+ {
+ b.Navigation("Watched");
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Season", b =>
+ {
+ b.Navigation("Episodes");
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Show", b =>
+ {
+ b.Navigation("Episodes");
+
+ b.Navigation("Seasons");
+
+ b.Navigation("Watched");
+ });
+
+ modelBuilder.Entity("Kyoo.Abstractions.Models.Studio", b =>
+ {
+ b.Navigation("Movies");
+
+ b.Navigation("Shows");
+ });
+#pragma warning restore 612, 618
+ }
+ }
+}
diff --git a/back/src/Kyoo.Postgresql/Migrations/20240324174638_UseDateOnly.cs b/back/src/Kyoo.Postgresql/Migrations/20240324174638_UseDateOnly.cs
new file mode 100644
index 00000000..725268a0
--- /dev/null
+++ b/back/src/Kyoo.Postgresql/Migrations/20240324174638_UseDateOnly.cs
@@ -0,0 +1,181 @@
+using System;
+using Microsoft.EntityFrameworkCore.Migrations;
+
+#nullable disable
+
+namespace Kyoo.Postgresql.Migrations
+{
+ ///
+ public partial class UseDateOnly : Migration
+ {
+ ///
+ protected override void Up(MigrationBuilder migrationBuilder)
+ {
+ migrationBuilder
+ .AlterDatabase()
+ .Annotation(
+ "Npgsql:Enum:genre",
+ "action,adventure,animation,comedy,crime,documentary,drama,family,fantasy,history,horror,music,mystery,romance,science_fiction,thriller,war,western"
+ )
+ .Annotation("Npgsql:Enum:status", "unknown,finished,airing,planned")
+ .Annotation("Npgsql:Enum:watch_status", "completed,watching,droped,planned,deleted")
+ .OldAnnotation(
+ "Npgsql:Enum:genre",
+ "action,adventure,animation,comedy,crime,documentary,drama,family,fantasy,history,horror,music,mystery,romance,science_fiction,thriller,war,western"
+ )
+ .OldAnnotation("Npgsql:Enum:status", "unknown,finished,airing,planned")
+ .OldAnnotation("Npgsql:Enum:watch_status", "completed,watching,droped,planned");
+
+ migrationBuilder.AlterColumn(
+ name: "start_air",
+ table: "shows",
+ type: "date",
+ nullable: true,
+ oldClrType: typeof(DateTime),
+ oldType: "timestamp with time zone",
+ oldNullable: true
+ );
+
+ migrationBuilder.AlterColumn(
+ name: "end_air",
+ table: "shows",
+ type: "date",
+ nullable: true,
+ oldClrType: typeof(DateTime),
+ oldType: "timestamp with time zone",
+ oldNullable: true
+ );
+
+ migrationBuilder.AlterColumn(
+ name: "start_date",
+ table: "seasons",
+ type: "date",
+ nullable: true,
+ oldClrType: typeof(DateTime),
+ oldType: "timestamp with time zone",
+ oldNullable: true
+ );
+
+ migrationBuilder.AlterColumn(
+ name: "end_date",
+ table: "seasons",
+ type: "date",
+ nullable: true,
+ oldClrType: typeof(DateTime),
+ oldType: "timestamp with time zone",
+ oldNullable: true
+ );
+
+ migrationBuilder.AlterColumn(
+ name: "air_date",
+ table: "movies",
+ type: "date",
+ nullable: true,
+ oldClrType: typeof(DateTime),
+ oldType: "timestamp with time zone",
+ oldNullable: true
+ );
+
+ migrationBuilder.AlterColumn(
+ name: "release_date",
+ table: "episodes",
+ type: "date",
+ nullable: true,
+ oldClrType: typeof(DateTime),
+ oldType: "timestamp with time zone",
+ oldNullable: true
+ );
+
+ migrationBuilder.CreateIndex(
+ name: "ix_users_username",
+ table: "users",
+ column: "username",
+ unique: true
+ );
+ }
+
+ ///
+ protected override void Down(MigrationBuilder migrationBuilder)
+ {
+ migrationBuilder.DropIndex(name: "ix_users_username", table: "users");
+
+ migrationBuilder
+ .AlterDatabase()
+ .Annotation(
+ "Npgsql:Enum:genre",
+ "action,adventure,animation,comedy,crime,documentary,drama,family,fantasy,history,horror,music,mystery,romance,science_fiction,thriller,war,western"
+ )
+ .Annotation("Npgsql:Enum:status", "unknown,finished,airing,planned")
+ .Annotation("Npgsql:Enum:watch_status", "completed,watching,droped,planned")
+ .OldAnnotation(
+ "Npgsql:Enum:genre",
+ "action,adventure,animation,comedy,crime,documentary,drama,family,fantasy,history,horror,music,mystery,romance,science_fiction,thriller,war,western"
+ )
+ .OldAnnotation("Npgsql:Enum:status", "unknown,finished,airing,planned")
+ .OldAnnotation(
+ "Npgsql:Enum:watch_status",
+ "completed,watching,droped,planned,deleted"
+ );
+
+ migrationBuilder.AlterColumn(
+ name: "start_air",
+ table: "shows",
+ type: "timestamp with time zone",
+ nullable: true,
+ oldClrType: typeof(DateOnly),
+ oldType: "date",
+ oldNullable: true
+ );
+
+ migrationBuilder.AlterColumn(
+ name: "end_air",
+ table: "shows",
+ type: "timestamp with time zone",
+ nullable: true,
+ oldClrType: typeof(DateOnly),
+ oldType: "date",
+ oldNullable: true
+ );
+
+ migrationBuilder.AlterColumn(
+ name: "start_date",
+ table: "seasons",
+ type: "timestamp with time zone",
+ nullable: true,
+ oldClrType: typeof(DateOnly),
+ oldType: "date",
+ oldNullable: true
+ );
+
+ migrationBuilder.AlterColumn(
+ name: "end_date",
+ table: "seasons",
+ type: "timestamp with time zone",
+ nullable: true,
+ oldClrType: typeof(DateOnly),
+ oldType: "date",
+ oldNullable: true
+ );
+
+ migrationBuilder.AlterColumn(
+ name: "air_date",
+ table: "movies",
+ type: "timestamp with time zone",
+ nullable: true,
+ oldClrType: typeof(DateOnly),
+ oldType: "date",
+ oldNullable: true
+ );
+
+ migrationBuilder.AlterColumn(
+ name: "release_date",
+ table: "episodes",
+ type: "timestamp with time zone",
+ nullable: true,
+ oldClrType: typeof(DateOnly),
+ oldType: "date",
+ oldNullable: true
+ );
+ }
+ }
+}
diff --git a/back/src/Kyoo.Postgresql/Migrations/PostgresContextModelSnapshot.cs b/back/src/Kyoo.Postgresql/Migrations/PostgresContextModelSnapshot.cs
index 68327e96..0a1e4337 100644
--- a/back/src/Kyoo.Postgresql/Migrations/PostgresContextModelSnapshot.cs
+++ b/back/src/Kyoo.Postgresql/Migrations/PostgresContextModelSnapshot.cs
@@ -19,12 +19,12 @@ namespace Kyoo.Postgresql.Migrations
{
#pragma warning disable 612, 618
modelBuilder
- .HasAnnotation("ProductVersion", "7.0.12")
+ .HasAnnotation("ProductVersion", "8.0.3")
.HasAnnotation("Relational:MaxIdentifierLength", 63);
NpgsqlModelBuilderExtensions.HasPostgresEnum(modelBuilder, "genre", new[] { "action", "adventure", "animation", "comedy", "crime", "documentary", "drama", "family", "fantasy", "history", "horror", "music", "mystery", "romance", "science_fiction", "thriller", "war", "western" });
NpgsqlModelBuilderExtensions.HasPostgresEnum(modelBuilder, "status", new[] { "unknown", "finished", "airing", "planned" });
- NpgsqlModelBuilderExtensions.HasPostgresEnum(modelBuilder, "watch_status", new[] { "completed", "watching", "droped", "planned" });
+ NpgsqlModelBuilderExtensions.HasPostgresEnum(modelBuilder, "watch_status", new[] { "completed", "watching", "droped", "planned", "deleted" });
NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder);
modelBuilder.Entity("Kyoo.Abstractions.Models.Collection", b =>
@@ -109,8 +109,8 @@ namespace Kyoo.Postgresql.Migrations
.HasColumnType("text")
.HasColumnName("path");
- b.Property("ReleaseDate")
- .HasColumnType("timestamp with time zone")
+ b.Property("ReleaseDate")
+ .HasColumnType("date")
.HasColumnName("release_date");
b.Property("Runtime")
@@ -238,8 +238,8 @@ namespace Kyoo.Postgresql.Migrations
.HasColumnName("added_date")
.HasDefaultValueSql("now() at time zone 'utc'");
- b.Property("AirDate")
- .HasColumnType("timestamp with time zone")
+ b.Property("AirDate")
+ .HasColumnType("date")
.HasColumnName("air_date");
b.Property("Aliases")
@@ -373,8 +373,8 @@ namespace Kyoo.Postgresql.Migrations
.HasColumnName("added_date")
.HasDefaultValueSql("now() at time zone 'utc'");
- b.Property("EndDate")
- .HasColumnType("timestamp with time zone")
+ b.Property("EndDate")
+ .HasColumnType("date")
.HasColumnName("end_date");
b.Property("ExternalId")
@@ -404,8 +404,8 @@ namespace Kyoo.Postgresql.Migrations
.HasColumnType("character varying(256)")
.HasColumnName("slug");
- b.Property("StartDate")
- .HasColumnType("timestamp with time zone")
+ b.Property("StartDate")
+ .HasColumnType("date")
.HasColumnName("start_date");
b.HasKey("Id")
@@ -440,8 +440,8 @@ namespace Kyoo.Postgresql.Migrations
.HasColumnType("text[]")
.HasColumnName("aliases");
- b.Property("EndAir")
- .HasColumnType("timestamp with time zone")
+ b.Property("EndAir")
+ .HasColumnType("date")
.HasColumnName("end_air");
b.Property("ExternalId")
@@ -473,8 +473,8 @@ namespace Kyoo.Postgresql.Migrations
.HasColumnType("character varying(256)")
.HasColumnName("slug");
- b.Property("StartAir")
- .HasColumnType("timestamp with time zone")
+ b.Property("StartAir")
+ .HasColumnType("date")
.HasColumnName("start_air");
b.Property("Status")
@@ -651,6 +651,10 @@ namespace Kyoo.Postgresql.Migrations
.IsUnique()
.HasDatabaseName("ix_users_slug");
+ b.HasIndex("Username")
+ .IsUnique()
+ .HasDatabaseName("ix_users_username");
+
b.ToTable("users", (string)null);
});