< Summary - Jellyfin

Line coverage
99%
Covered lines: 1625
Uncovered lines: 8
Coverable lines: 1633
Total lines: 1732
Line coverage: 99.5%
Branch coverage
N/A
Covered branches: 0
Total branches: 0
Branch coverage: N/A
Method coverage

Feature is only available for sponsors

Upgrade to PRO version

Coverage history

Coverage history 0 25 50 75 100

Metrics

MethodBranch coverage Crap Score Cyclomatic complexity Line coverage
File 1: Up(...)100%11100%
File 1: Down(...)100%210%
File 2: BuildTargetModel(...)100%11100%

File(s)

/srv/git/jellyfin/src/Jellyfin.Database/Jellyfin.Database.Providers.Sqlite/Migrations/20250609115616_DetachUserDataInsteadOfDelete.cs

#LineLine coverage
 1using System;
 2using Microsoft.EntityFrameworkCore.Migrations;
 3
 4#nullable disable
 5
 6namespace Jellyfin.Server.Implementations.Migrations
 7{
 8    /// <inheritdoc />
 9    public partial class DetachUserDataInsteadOfDelete : Migration
 10    {
 11        /// <inheritdoc />
 12        protected override void Up(MigrationBuilder migrationBuilder)
 13        {
 2114            migrationBuilder.AddColumn<DateTimeOffset>(
 2115                name: "RetentionDate",
 2116                table: "UserData",
 2117                type: "TEXT",
 2118                nullable: true);
 19
 2120            migrationBuilder.InsertData(
 2121                table: "BaseItems",
 2122                columns: new[] { "Id", "Album", "AlbumArtists", "Artists", "Audio", "ChannelId", "CleanName", "Community
 2123                values: new object[] { new Guid("00000000-0000-0000-0000-000000000001"), null, null, null, null, null, n
 2124        }
 25
 26        /// <inheritdoc />
 27        protected override void Down(MigrationBuilder migrationBuilder)
 28        {
 029            migrationBuilder.DropColumn(
 030                name: "RetentionDate",
 031                table: "UserData");
 32
 033            migrationBuilder.DeleteData(
 034                table: "BaseItems",
 035                keyColumn: "Id",
 036                keyValue: new Guid("00000000-0000-0000-0000-000000000001"));
 037        }
 38    }
 39}

/srv/git/jellyfin/src/Jellyfin.Database/Jellyfin.Database.Providers.Sqlite/Migrations/20250609115616_DetachUserDataInsteadOfDelete.Designer.cs

#LineLine coverage
 1// <auto-generated />
 2using System;
 3using Jellyfin.Database.Implementations;
 4using Microsoft.EntityFrameworkCore;
 5using Microsoft.EntityFrameworkCore.Infrastructure;
 6using Microsoft.EntityFrameworkCore.Migrations;
 7using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
 8
 9#nullable disable
 10
 11namespace Jellyfin.Server.Implementations.Migrations
 12{
 13    [DbContext(typeof(JellyfinDbContext))]
 14    [Migration("20250609115616_DetachUserDataInsteadOfDelete")]
 15    partial class DetachUserDataInsteadOfDelete
 16    {
 17        /// <inheritdoc />
 18        protected override void BuildTargetModel(ModelBuilder modelBuilder)
 19        {
 20#pragma warning disable 612, 618
 2121            modelBuilder.HasAnnotation("ProductVersion", "9.0.5");
 22
 2123            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.AccessSchedule", b =>
 2124                {
 2125                    b.Property<int>("Id")
 2126                        .ValueGeneratedOnAdd()
 2127                        .HasColumnType("INTEGER");
 2128
 2129                    b.Property<int>("DayOfWeek")
 2130                        .HasColumnType("INTEGER");
 2131
 2132                    b.Property<double>("EndHour")
 2133                        .HasColumnType("REAL");
 2134
 2135                    b.Property<double>("StartHour")
 2136                        .HasColumnType("REAL");
 2137
 2138                    b.Property<Guid>("UserId")
 2139                        .HasColumnType("TEXT");
 2140
 2141                    b.HasKey("Id");
 2142
 2143                    b.HasIndex("UserId");
 2144
 2145                    b.ToTable("AccessSchedules");
 2146
 2147                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 2148                });
 49
 2150            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.ActivityLog", b =>
 2151                {
 2152                    b.Property<int>("Id")
 2153                        .ValueGeneratedOnAdd()
 2154                        .HasColumnType("INTEGER");
 2155
 2156                    b.Property<DateTime>("DateCreated")
 2157                        .HasColumnType("TEXT");
 2158
 2159                    b.Property<string>("ItemId")
 2160                        .HasMaxLength(256)
 2161                        .HasColumnType("TEXT");
 2162
 2163                    b.Property<int>("LogSeverity")
 2164                        .HasColumnType("INTEGER");
 2165
 2166                    b.Property<string>("Name")
 2167                        .IsRequired()
 2168                        .HasMaxLength(512)
 2169                        .HasColumnType("TEXT");
 2170
 2171                    b.Property<string>("Overview")
 2172                        .HasMaxLength(512)
 2173                        .HasColumnType("TEXT");
 2174
 2175                    b.Property<uint>("RowVersion")
 2176                        .IsConcurrencyToken()
 2177                        .HasColumnType("INTEGER");
 2178
 2179                    b.Property<string>("ShortOverview")
 2180                        .HasMaxLength(512)
 2181                        .HasColumnType("TEXT");
 2182
 2183                    b.Property<string>("Type")
 2184                        .IsRequired()
 2185                        .HasMaxLength(256)
 2186                        .HasColumnType("TEXT");
 2187
 2188                    b.Property<Guid>("UserId")
 2189                        .HasColumnType("TEXT");
 2190
 2191                    b.HasKey("Id");
 2192
 2193                    b.HasIndex("DateCreated");
 2194
 2195                    b.ToTable("ActivityLogs");
 2196
 2197                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 2198                });
 99
 21100            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.AncestorId", b =>
 21101                {
 21102                    b.Property<Guid>("ItemId")
 21103                        .HasColumnType("TEXT");
 21104
 21105                    b.Property<Guid>("ParentItemId")
 21106                        .HasColumnType("TEXT");
 21107
 21108                    b.HasKey("ItemId", "ParentItemId");
 21109
 21110                    b.HasIndex("ParentItemId");
 21111
 21112                    b.ToTable("AncestorIds");
 21113
 21114                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21115                });
 116
 21117            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.AttachmentStreamInfo", b =>
 21118                {
 21119                    b.Property<Guid>("ItemId")
 21120                        .HasColumnType("TEXT");
 21121
 21122                    b.Property<int>("Index")
 21123                        .HasColumnType("INTEGER");
 21124
 21125                    b.Property<string>("Codec")
 21126                        .HasColumnType("TEXT");
 21127
 21128                    b.Property<string>("CodecTag")
 21129                        .HasColumnType("TEXT");
 21130
 21131                    b.Property<string>("Comment")
 21132                        .HasColumnType("TEXT");
 21133
 21134                    b.Property<string>("Filename")
 21135                        .HasColumnType("TEXT");
 21136
 21137                    b.Property<string>("MimeType")
 21138                        .HasColumnType("TEXT");
 21139
 21140                    b.HasKey("ItemId", "Index");
 21141
 21142                    b.ToTable("AttachmentStreamInfos");
 21143
 21144                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21145                });
 146
 21147            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.BaseItemEntity", b =>
 21148                {
 21149                    b.Property<Guid>("Id")
 21150                        .ValueGeneratedOnAdd()
 21151                        .HasColumnType("TEXT");
 21152
 21153                    b.Property<string>("Album")
 21154                        .HasColumnType("TEXT");
 21155
 21156                    b.Property<string>("AlbumArtists")
 21157                        .HasColumnType("TEXT");
 21158
 21159                    b.Property<string>("Artists")
 21160                        .HasColumnType("TEXT");
 21161
 21162                    b.Property<int?>("Audio")
 21163                        .HasColumnType("INTEGER");
 21164
 21165                    b.Property<Guid?>("ChannelId")
 21166                        .HasColumnType("TEXT");
 21167
 21168                    b.Property<string>("CleanName")
 21169                        .HasColumnType("TEXT");
 21170
 21171                    b.Property<float?>("CommunityRating")
 21172                        .HasColumnType("REAL");
 21173
 21174                    b.Property<float?>("CriticRating")
 21175                        .HasColumnType("REAL");
 21176
 21177                    b.Property<string>("CustomRating")
 21178                        .HasColumnType("TEXT");
 21179
 21180                    b.Property<string>("Data")
 21181                        .HasColumnType("TEXT");
 21182
 21183                    b.Property<DateTime?>("DateCreated")
 21184                        .HasColumnType("TEXT");
 21185
 21186                    b.Property<DateTime?>("DateLastMediaAdded")
 21187                        .HasColumnType("TEXT");
 21188
 21189                    b.Property<DateTime?>("DateLastRefreshed")
 21190                        .HasColumnType("TEXT");
 21191
 21192                    b.Property<DateTime?>("DateLastSaved")
 21193                        .HasColumnType("TEXT");
 21194
 21195                    b.Property<DateTime?>("DateModified")
 21196                        .HasColumnType("TEXT");
 21197
 21198                    b.Property<DateTime?>("EndDate")
 21199                        .HasColumnType("TEXT");
 21200
 21201                    b.Property<string>("EpisodeTitle")
 21202                        .HasColumnType("TEXT");
 21203
 21204                    b.Property<string>("ExternalId")
 21205                        .HasColumnType("TEXT");
 21206
 21207                    b.Property<string>("ExternalSeriesId")
 21208                        .HasColumnType("TEXT");
 21209
 21210                    b.Property<string>("ExternalServiceId")
 21211                        .HasColumnType("TEXT");
 21212
 21213                    b.Property<string>("ExtraIds")
 21214                        .HasColumnType("TEXT");
 21215
 21216                    b.Property<int?>("ExtraType")
 21217                        .HasColumnType("INTEGER");
 21218
 21219                    b.Property<string>("ForcedSortName")
 21220                        .HasColumnType("TEXT");
 21221
 21222                    b.Property<string>("Genres")
 21223                        .HasColumnType("TEXT");
 21224
 21225                    b.Property<int?>("Height")
 21226                        .HasColumnType("INTEGER");
 21227
 21228                    b.Property<int?>("IndexNumber")
 21229                        .HasColumnType("INTEGER");
 21230
 21231                    b.Property<int?>("InheritedParentalRatingSubValue")
 21232                        .HasColumnType("INTEGER");
 21233
 21234                    b.Property<int?>("InheritedParentalRatingValue")
 21235                        .HasColumnType("INTEGER");
 21236
 21237                    b.Property<bool>("IsFolder")
 21238                        .HasColumnType("INTEGER");
 21239
 21240                    b.Property<bool>("IsInMixedFolder")
 21241                        .HasColumnType("INTEGER");
 21242
 21243                    b.Property<bool>("IsLocked")
 21244                        .HasColumnType("INTEGER");
 21245
 21246                    b.Property<bool>("IsMovie")
 21247                        .HasColumnType("INTEGER");
 21248
 21249                    b.Property<bool>("IsRepeat")
 21250                        .HasColumnType("INTEGER");
 21251
 21252                    b.Property<bool>("IsSeries")
 21253                        .HasColumnType("INTEGER");
 21254
 21255                    b.Property<bool>("IsVirtualItem")
 21256                        .HasColumnType("INTEGER");
 21257
 21258                    b.Property<float?>("LUFS")
 21259                        .HasColumnType("REAL");
 21260
 21261                    b.Property<string>("MediaType")
 21262                        .HasColumnType("TEXT");
 21263
 21264                    b.Property<string>("Name")
 21265                        .HasColumnType("TEXT");
 21266
 21267                    b.Property<float?>("NormalizationGain")
 21268                        .HasColumnType("REAL");
 21269
 21270                    b.Property<string>("OfficialRating")
 21271                        .HasColumnType("TEXT");
 21272
 21273                    b.Property<string>("OriginalTitle")
 21274                        .HasColumnType("TEXT");
 21275
 21276                    b.Property<string>("Overview")
 21277                        .HasColumnType("TEXT");
 21278
 21279                    b.Property<string>("OwnerId")
 21280                        .HasColumnType("TEXT");
 21281
 21282                    b.Property<Guid?>("ParentId")
 21283                        .HasColumnType("TEXT");
 21284
 21285                    b.Property<int?>("ParentIndexNumber")
 21286                        .HasColumnType("INTEGER");
 21287
 21288                    b.Property<string>("Path")
 21289                        .HasColumnType("TEXT");
 21290
 21291                    b.Property<string>("PreferredMetadataCountryCode")
 21292                        .HasColumnType("TEXT");
 21293
 21294                    b.Property<string>("PreferredMetadataLanguage")
 21295                        .HasColumnType("TEXT");
 21296
 21297                    b.Property<DateTime?>("PremiereDate")
 21298                        .HasColumnType("TEXT");
 21299
 21300                    b.Property<string>("PresentationUniqueKey")
 21301                        .HasColumnType("TEXT");
 21302
 21303                    b.Property<string>("PrimaryVersionId")
 21304                        .HasColumnType("TEXT");
 21305
 21306                    b.Property<string>("ProductionLocations")
 21307                        .HasColumnType("TEXT");
 21308
 21309                    b.Property<int?>("ProductionYear")
 21310                        .HasColumnType("INTEGER");
 21311
 21312                    b.Property<long?>("RunTimeTicks")
 21313                        .HasColumnType("INTEGER");
 21314
 21315                    b.Property<Guid?>("SeasonId")
 21316                        .HasColumnType("TEXT");
 21317
 21318                    b.Property<string>("SeasonName")
 21319                        .HasColumnType("TEXT");
 21320
 21321                    b.Property<Guid?>("SeriesId")
 21322                        .HasColumnType("TEXT");
 21323
 21324                    b.Property<string>("SeriesName")
 21325                        .HasColumnType("TEXT");
 21326
 21327                    b.Property<string>("SeriesPresentationUniqueKey")
 21328                        .HasColumnType("TEXT");
 21329
 21330                    b.Property<string>("ShowId")
 21331                        .HasColumnType("TEXT");
 21332
 21333                    b.Property<long?>("Size")
 21334                        .HasColumnType("INTEGER");
 21335
 21336                    b.Property<string>("SortName")
 21337                        .HasColumnType("TEXT");
 21338
 21339                    b.Property<DateTime?>("StartDate")
 21340                        .HasColumnType("TEXT");
 21341
 21342                    b.Property<string>("Studios")
 21343                        .HasColumnType("TEXT");
 21344
 21345                    b.Property<string>("Tagline")
 21346                        .HasColumnType("TEXT");
 21347
 21348                    b.Property<string>("Tags")
 21349                        .HasColumnType("TEXT");
 21350
 21351                    b.Property<Guid?>("TopParentId")
 21352                        .HasColumnType("TEXT");
 21353
 21354                    b.Property<int?>("TotalBitrate")
 21355                        .HasColumnType("INTEGER");
 21356
 21357                    b.Property<string>("Type")
 21358                        .IsRequired()
 21359                        .HasColumnType("TEXT");
 21360
 21361                    b.Property<string>("UnratedType")
 21362                        .HasColumnType("TEXT");
 21363
 21364                    b.Property<int?>("Width")
 21365                        .HasColumnType("INTEGER");
 21366
 21367                    b.HasKey("Id");
 21368
 21369                    b.HasIndex("ParentId");
 21370
 21371                    b.HasIndex("Path");
 21372
 21373                    b.HasIndex("PresentationUniqueKey");
 21374
 21375                    b.HasIndex("TopParentId", "Id");
 21376
 21377                    b.HasIndex("Type", "TopParentId", "Id");
 21378
 21379                    b.HasIndex("Type", "TopParentId", "PresentationUniqueKey");
 21380
 21381                    b.HasIndex("Type", "TopParentId", "StartDate");
 21382
 21383                    b.HasIndex("Id", "Type", "IsFolder", "IsVirtualItem");
 21384
 21385                    b.HasIndex("MediaType", "TopParentId", "IsVirtualItem", "PresentationUniqueKey");
 21386
 21387                    b.HasIndex("Type", "SeriesPresentationUniqueKey", "IsFolder", "IsVirtualItem");
 21388
 21389                    b.HasIndex("Type", "SeriesPresentationUniqueKey", "PresentationUniqueKey", "SortName");
 21390
 21391                    b.HasIndex("IsFolder", "TopParentId", "IsVirtualItem", "PresentationUniqueKey", "DateCreated");
 21392
 21393                    b.HasIndex("Type", "TopParentId", "IsVirtualItem", "PresentationUniqueKey", "DateCreated");
 21394
 21395                    b.ToTable("BaseItems");
 21396
 21397                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21398                });
 399
 21400            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.BaseItemImageInfo", b =>
 21401                {
 21402                    b.Property<Guid>("Id")
 21403                        .ValueGeneratedOnAdd()
 21404                        .HasColumnType("TEXT");
 21405
 21406                    b.Property<byte[]>("Blurhash")
 21407                        .HasColumnType("BLOB");
 21408
 21409                    b.Property<DateTime>("DateModified")
 21410                        .HasColumnType("TEXT");
 21411
 21412                    b.Property<int>("Height")
 21413                        .HasColumnType("INTEGER");
 21414
 21415                    b.Property<int>("ImageType")
 21416                        .HasColumnType("INTEGER");
 21417
 21418                    b.Property<Guid>("ItemId")
 21419                        .HasColumnType("TEXT");
 21420
 21421                    b.Property<string>("Path")
 21422                        .IsRequired()
 21423                        .HasColumnType("TEXT");
 21424
 21425                    b.Property<int>("Width")
 21426                        .HasColumnType("INTEGER");
 21427
 21428                    b.HasKey("Id");
 21429
 21430                    b.HasIndex("ItemId");
 21431
 21432                    b.ToTable("BaseItemImageInfos");
 21433
 21434                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21435                });
 436
 21437            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.BaseItemMetadataField", b =>
 21438                {
 21439                    b.Property<int>("Id")
 21440                        .HasColumnType("INTEGER");
 21441
 21442                    b.Property<Guid>("ItemId")
 21443                        .HasColumnType("TEXT");
 21444
 21445                    b.HasKey("Id", "ItemId");
 21446
 21447                    b.HasIndex("ItemId");
 21448
 21449                    b.ToTable("BaseItemMetadataFields");
 21450
 21451                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21452                });
 453
 21454            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.BaseItemProvider", b =>
 21455                {
 21456                    b.Property<Guid>("ItemId")
 21457                        .HasColumnType("TEXT");
 21458
 21459                    b.Property<string>("ProviderId")
 21460                        .HasColumnType("TEXT");
 21461
 21462                    b.Property<string>("ProviderValue")
 21463                        .IsRequired()
 21464                        .HasColumnType("TEXT");
 21465
 21466                    b.HasKey("ItemId", "ProviderId");
 21467
 21468                    b.HasIndex("ProviderId", "ProviderValue", "ItemId");
 21469
 21470                    b.ToTable("BaseItemProviders");
 21471
 21472                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21473                });
 474
 21475            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.BaseItemTrailerType", b =>
 21476                {
 21477                    b.Property<int>("Id")
 21478                        .HasColumnType("INTEGER");
 21479
 21480                    b.Property<Guid>("ItemId")
 21481                        .HasColumnType("TEXT");
 21482
 21483                    b.HasKey("Id", "ItemId");
 21484
 21485                    b.HasIndex("ItemId");
 21486
 21487                    b.ToTable("BaseItemTrailerTypes");
 21488
 21489                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21490                });
 491
 21492            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.Chapter", b =>
 21493                {
 21494                    b.Property<Guid>("ItemId")
 21495                        .HasColumnType("TEXT");
 21496
 21497                    b.Property<int>("ChapterIndex")
 21498                        .HasColumnType("INTEGER");
 21499
 21500                    b.Property<DateTime?>("ImageDateModified")
 21501                        .HasColumnType("TEXT");
 21502
 21503                    b.Property<string>("ImagePath")
 21504                        .HasColumnType("TEXT");
 21505
 21506                    b.Property<string>("Name")
 21507                        .HasColumnType("TEXT");
 21508
 21509                    b.Property<long>("StartPositionTicks")
 21510                        .HasColumnType("INTEGER");
 21511
 21512                    b.HasKey("ItemId", "ChapterIndex");
 21513
 21514                    b.ToTable("Chapters");
 21515
 21516                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21517                });
 518
 21519            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.CustomItemDisplayPreferences", b =>
 21520                {
 21521                    b.Property<int>("Id")
 21522                        .ValueGeneratedOnAdd()
 21523                        .HasColumnType("INTEGER");
 21524
 21525                    b.Property<string>("Client")
 21526                        .IsRequired()
 21527                        .HasMaxLength(32)
 21528                        .HasColumnType("TEXT");
 21529
 21530                    b.Property<Guid>("ItemId")
 21531                        .HasColumnType("TEXT");
 21532
 21533                    b.Property<string>("Key")
 21534                        .IsRequired()
 21535                        .HasColumnType("TEXT");
 21536
 21537                    b.Property<Guid>("UserId")
 21538                        .HasColumnType("TEXT");
 21539
 21540                    b.Property<string>("Value")
 21541                        .HasColumnType("TEXT");
 21542
 21543                    b.HasKey("Id");
 21544
 21545                    b.HasIndex("UserId", "ItemId", "Client", "Key")
 21546                        .IsUnique();
 21547
 21548                    b.ToTable("CustomItemDisplayPreferences");
 21549
 21550                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21551                });
 552
 21553            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.DisplayPreferences", b =>
 21554                {
 21555                    b.Property<int>("Id")
 21556                        .ValueGeneratedOnAdd()
 21557                        .HasColumnType("INTEGER");
 21558
 21559                    b.Property<int>("ChromecastVersion")
 21560                        .HasColumnType("INTEGER");
 21561
 21562                    b.Property<string>("Client")
 21563                        .IsRequired()
 21564                        .HasMaxLength(32)
 21565                        .HasColumnType("TEXT");
 21566
 21567                    b.Property<string>("DashboardTheme")
 21568                        .HasMaxLength(32)
 21569                        .HasColumnType("TEXT");
 21570
 21571                    b.Property<bool>("EnableNextVideoInfoOverlay")
 21572                        .HasColumnType("INTEGER");
 21573
 21574                    b.Property<int?>("IndexBy")
 21575                        .HasColumnType("INTEGER");
 21576
 21577                    b.Property<Guid>("ItemId")
 21578                        .HasColumnType("TEXT");
 21579
 21580                    b.Property<int>("ScrollDirection")
 21581                        .HasColumnType("INTEGER");
 21582
 21583                    b.Property<bool>("ShowBackdrop")
 21584                        .HasColumnType("INTEGER");
 21585
 21586                    b.Property<bool>("ShowSidebar")
 21587                        .HasColumnType("INTEGER");
 21588
 21589                    b.Property<int>("SkipBackwardLength")
 21590                        .HasColumnType("INTEGER");
 21591
 21592                    b.Property<int>("SkipForwardLength")
 21593                        .HasColumnType("INTEGER");
 21594
 21595                    b.Property<string>("TvHome")
 21596                        .HasMaxLength(32)
 21597                        .HasColumnType("TEXT");
 21598
 21599                    b.Property<Guid>("UserId")
 21600                        .HasColumnType("TEXT");
 21601
 21602                    b.HasKey("Id");
 21603
 21604                    b.HasIndex("UserId", "ItemId", "Client")
 21605                        .IsUnique();
 21606
 21607                    b.ToTable("DisplayPreferences");
 21608
 21609                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21610                });
 611
 21612            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.HomeSection", b =>
 21613                {
 21614                    b.Property<int>("Id")
 21615                        .ValueGeneratedOnAdd()
 21616                        .HasColumnType("INTEGER");
 21617
 21618                    b.Property<int>("DisplayPreferencesId")
 21619                        .HasColumnType("INTEGER");
 21620
 21621                    b.Property<int>("Order")
 21622                        .HasColumnType("INTEGER");
 21623
 21624                    b.Property<int>("Type")
 21625                        .HasColumnType("INTEGER");
 21626
 21627                    b.HasKey("Id");
 21628
 21629                    b.HasIndex("DisplayPreferencesId");
 21630
 21631                    b.ToTable("HomeSection");
 21632
 21633                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21634                });
 635
 21636            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.ImageInfo", b =>
 21637                {
 21638                    b.Property<int>("Id")
 21639                        .ValueGeneratedOnAdd()
 21640                        .HasColumnType("INTEGER");
 21641
 21642                    b.Property<DateTime>("LastModified")
 21643                        .HasColumnType("TEXT");
 21644
 21645                    b.Property<string>("Path")
 21646                        .IsRequired()
 21647                        .HasMaxLength(512)
 21648                        .HasColumnType("TEXT");
 21649
 21650                    b.Property<Guid?>("UserId")
 21651                        .HasColumnType("TEXT");
 21652
 21653                    b.HasKey("Id");
 21654
 21655                    b.HasIndex("UserId")
 21656                        .IsUnique();
 21657
 21658                    b.ToTable("ImageInfos");
 21659
 21660                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21661                });
 662
 21663            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.ItemDisplayPreferences", b =>
 21664                {
 21665                    b.Property<int>("Id")
 21666                        .ValueGeneratedOnAdd()
 21667                        .HasColumnType("INTEGER");
 21668
 21669                    b.Property<string>("Client")
 21670                        .IsRequired()
 21671                        .HasMaxLength(32)
 21672                        .HasColumnType("TEXT");
 21673
 21674                    b.Property<int?>("IndexBy")
 21675                        .HasColumnType("INTEGER");
 21676
 21677                    b.Property<Guid>("ItemId")
 21678                        .HasColumnType("TEXT");
 21679
 21680                    b.Property<bool>("RememberIndexing")
 21681                        .HasColumnType("INTEGER");
 21682
 21683                    b.Property<bool>("RememberSorting")
 21684                        .HasColumnType("INTEGER");
 21685
 21686                    b.Property<string>("SortBy")
 21687                        .IsRequired()
 21688                        .HasMaxLength(64)
 21689                        .HasColumnType("TEXT");
 21690
 21691                    b.Property<int>("SortOrder")
 21692                        .HasColumnType("INTEGER");
 21693
 21694                    b.Property<Guid>("UserId")
 21695                        .HasColumnType("TEXT");
 21696
 21697                    b.Property<int>("ViewType")
 21698                        .HasColumnType("INTEGER");
 21699
 21700                    b.HasKey("Id");
 21701
 21702                    b.HasIndex("UserId");
 21703
 21704                    b.ToTable("ItemDisplayPreferences");
 21705
 21706                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21707                });
 708
 21709            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.ItemValue", b =>
 21710                {
 21711                    b.Property<Guid>("ItemValueId")
 21712                        .ValueGeneratedOnAdd()
 21713                        .HasColumnType("TEXT");
 21714
 21715                    b.Property<string>("CleanValue")
 21716                        .IsRequired()
 21717                        .HasColumnType("TEXT");
 21718
 21719                    b.Property<int>("Type")
 21720                        .HasColumnType("INTEGER");
 21721
 21722                    b.Property<string>("Value")
 21723                        .IsRequired()
 21724                        .HasColumnType("TEXT");
 21725
 21726                    b.HasKey("ItemValueId");
 21727
 21728                    b.HasIndex("Type", "CleanValue");
 21729
 21730                    b.HasIndex("Type", "Value")
 21731                        .IsUnique();
 21732
 21733                    b.ToTable("ItemValues");
 21734
 21735                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21736                });
 737
 21738            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.ItemValueMap", b =>
 21739                {
 21740                    b.Property<Guid>("ItemValueId")
 21741                        .HasColumnType("TEXT");
 21742
 21743                    b.Property<Guid>("ItemId")
 21744                        .HasColumnType("TEXT");
 21745
 21746                    b.HasKey("ItemValueId", "ItemId");
 21747
 21748                    b.HasIndex("ItemId");
 21749
 21750                    b.ToTable("ItemValuesMap");
 21751
 21752                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21753                });
 754
 21755            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.KeyframeData", b =>
 21756                {
 21757                    b.Property<Guid>("ItemId")
 21758                        .HasColumnType("TEXT");
 21759
 21760                    b.PrimitiveCollection<string>("KeyframeTicks")
 21761                        .HasColumnType("TEXT");
 21762
 21763                    b.Property<long>("TotalDuration")
 21764                        .HasColumnType("INTEGER");
 21765
 21766                    b.HasKey("ItemId");
 21767
 21768                    b.ToTable("KeyframeData");
 21769
 21770                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21771                });
 772
 21773            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.MediaSegment", b =>
 21774                {
 21775                    b.Property<Guid>("Id")
 21776                        .ValueGeneratedOnAdd()
 21777                        .HasColumnType("TEXT");
 21778
 21779                    b.Property<long>("EndTicks")
 21780                        .HasColumnType("INTEGER");
 21781
 21782                    b.Property<Guid>("ItemId")
 21783                        .HasColumnType("TEXT");
 21784
 21785                    b.Property<string>("SegmentProviderId")
 21786                        .IsRequired()
 21787                        .HasColumnType("TEXT");
 21788
 21789                    b.Property<long>("StartTicks")
 21790                        .HasColumnType("INTEGER");
 21791
 21792                    b.Property<int>("Type")
 21793                        .HasColumnType("INTEGER");
 21794
 21795                    b.HasKey("Id");
 21796
 21797                    b.ToTable("MediaSegments");
 21798
 21799                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21800                });
 801
 21802            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.MediaStreamInfo", b =>
 21803                {
 21804                    b.Property<Guid>("ItemId")
 21805                        .HasColumnType("TEXT");
 21806
 21807                    b.Property<int>("StreamIndex")
 21808                        .HasColumnType("INTEGER");
 21809
 21810                    b.Property<string>("AspectRatio")
 21811                        .HasColumnType("TEXT");
 21812
 21813                    b.Property<float?>("AverageFrameRate")
 21814                        .HasColumnType("REAL");
 21815
 21816                    b.Property<int?>("BitDepth")
 21817                        .HasColumnType("INTEGER");
 21818
 21819                    b.Property<int?>("BitRate")
 21820                        .HasColumnType("INTEGER");
 21821
 21822                    b.Property<int?>("BlPresentFlag")
 21823                        .HasColumnType("INTEGER");
 21824
 21825                    b.Property<string>("ChannelLayout")
 21826                        .HasColumnType("TEXT");
 21827
 21828                    b.Property<int?>("Channels")
 21829                        .HasColumnType("INTEGER");
 21830
 21831                    b.Property<string>("Codec")
 21832                        .HasColumnType("TEXT");
 21833
 21834                    b.Property<string>("CodecTag")
 21835                        .HasColumnType("TEXT");
 21836
 21837                    b.Property<string>("CodecTimeBase")
 21838                        .HasColumnType("TEXT");
 21839
 21840                    b.Property<string>("ColorPrimaries")
 21841                        .HasColumnType("TEXT");
 21842
 21843                    b.Property<string>("ColorSpace")
 21844                        .HasColumnType("TEXT");
 21845
 21846                    b.Property<string>("ColorTransfer")
 21847                        .HasColumnType("TEXT");
 21848
 21849                    b.Property<string>("Comment")
 21850                        .HasColumnType("TEXT");
 21851
 21852                    b.Property<int?>("DvBlSignalCompatibilityId")
 21853                        .HasColumnType("INTEGER");
 21854
 21855                    b.Property<int?>("DvLevel")
 21856                        .HasColumnType("INTEGER");
 21857
 21858                    b.Property<int?>("DvProfile")
 21859                        .HasColumnType("INTEGER");
 21860
 21861                    b.Property<int?>("DvVersionMajor")
 21862                        .HasColumnType("INTEGER");
 21863
 21864                    b.Property<int?>("DvVersionMinor")
 21865                        .HasColumnType("INTEGER");
 21866
 21867                    b.Property<int?>("ElPresentFlag")
 21868                        .HasColumnType("INTEGER");
 21869
 21870                    b.Property<bool?>("Hdr10PlusPresentFlag")
 21871                        .HasColumnType("INTEGER");
 21872
 21873                    b.Property<int?>("Height")
 21874                        .HasColumnType("INTEGER");
 21875
 21876                    b.Property<bool?>("IsAnamorphic")
 21877                        .HasColumnType("INTEGER");
 21878
 21879                    b.Property<bool?>("IsAvc")
 21880                        .HasColumnType("INTEGER");
 21881
 21882                    b.Property<bool>("IsDefault")
 21883                        .HasColumnType("INTEGER");
 21884
 21885                    b.Property<bool>("IsExternal")
 21886                        .HasColumnType("INTEGER");
 21887
 21888                    b.Property<bool>("IsForced")
 21889                        .HasColumnType("INTEGER");
 21890
 21891                    b.Property<bool?>("IsHearingImpaired")
 21892                        .HasColumnType("INTEGER");
 21893
 21894                    b.Property<bool?>("IsInterlaced")
 21895                        .HasColumnType("INTEGER");
 21896
 21897                    b.Property<string>("KeyFrames")
 21898                        .HasColumnType("TEXT");
 21899
 21900                    b.Property<string>("Language")
 21901                        .HasColumnType("TEXT");
 21902
 21903                    b.Property<float?>("Level")
 21904                        .HasColumnType("REAL");
 21905
 21906                    b.Property<string>("NalLengthSize")
 21907                        .HasColumnType("TEXT");
 21908
 21909                    b.Property<string>("Path")
 21910                        .HasColumnType("TEXT");
 21911
 21912                    b.Property<string>("PixelFormat")
 21913                        .HasColumnType("TEXT");
 21914
 21915                    b.Property<string>("Profile")
 21916                        .HasColumnType("TEXT");
 21917
 21918                    b.Property<float?>("RealFrameRate")
 21919                        .HasColumnType("REAL");
 21920
 21921                    b.Property<int?>("RefFrames")
 21922                        .HasColumnType("INTEGER");
 21923
 21924                    b.Property<int?>("Rotation")
 21925                        .HasColumnType("INTEGER");
 21926
 21927                    b.Property<int?>("RpuPresentFlag")
 21928                        .HasColumnType("INTEGER");
 21929
 21930                    b.Property<int?>("SampleRate")
 21931                        .HasColumnType("INTEGER");
 21932
 21933                    b.Property<int>("StreamType")
 21934                        .HasColumnType("INTEGER");
 21935
 21936                    b.Property<string>("TimeBase")
 21937                        .HasColumnType("TEXT");
 21938
 21939                    b.Property<string>("Title")
 21940                        .HasColumnType("TEXT");
 21941
 21942                    b.Property<int?>("Width")
 21943                        .HasColumnType("INTEGER");
 21944
 21945                    b.HasKey("ItemId", "StreamIndex");
 21946
 21947                    b.HasIndex("StreamIndex");
 21948
 21949                    b.HasIndex("StreamType");
 21950
 21951                    b.HasIndex("StreamIndex", "StreamType");
 21952
 21953                    b.HasIndex("StreamIndex", "StreamType", "Language");
 21954
 21955                    b.ToTable("MediaStreamInfos");
 21956
 21957                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21958                });
 959
 21960            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.People", b =>
 21961                {
 21962                    b.Property<Guid>("Id")
 21963                        .ValueGeneratedOnAdd()
 21964                        .HasColumnType("TEXT");
 21965
 21966                    b.Property<string>("Name")
 21967                        .IsRequired()
 21968                        .HasColumnType("TEXT");
 21969
 21970                    b.Property<string>("PersonType")
 21971                        .HasColumnType("TEXT");
 21972
 21973                    b.HasKey("Id");
 21974
 21975                    b.HasIndex("Name");
 21976
 21977                    b.ToTable("Peoples");
 21978
 21979                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 21980                });
 981
 21982            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.PeopleBaseItemMap", b =>
 21983                {
 21984                    b.Property<Guid>("ItemId")
 21985                        .HasColumnType("TEXT");
 21986
 21987                    b.Property<Guid>("PeopleId")
 21988                        .HasColumnType("TEXT");
 21989
 21990                    b.Property<int?>("ListOrder")
 21991                        .HasColumnType("INTEGER");
 21992
 21993                    b.Property<string>("Role")
 21994                        .HasColumnType("TEXT");
 21995
 21996                    b.Property<int?>("SortOrder")
 21997                        .HasColumnType("INTEGER");
 21998
 21999                    b.HasKey("ItemId", "PeopleId");
 211000
 211001                    b.HasIndex("PeopleId");
 211002
 211003                    b.HasIndex("ItemId", "ListOrder");
 211004
 211005                    b.HasIndex("ItemId", "SortOrder");
 211006
 211007                    b.ToTable("PeopleBaseItemMap");
 211008
 211009                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 211010                });
 1011
 211012            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.Permission", b =>
 211013                {
 211014                    b.Property<int>("Id")
 211015                        .ValueGeneratedOnAdd()
 211016                        .HasColumnType("INTEGER");
 211017
 211018                    b.Property<int>("Kind")
 211019                        .HasColumnType("INTEGER");
 211020
 211021                    b.Property<Guid?>("Permission_Permissions_Guid")
 211022                        .HasColumnType("TEXT");
 211023
 211024                    b.Property<uint>("RowVersion")
 211025                        .IsConcurrencyToken()
 211026                        .HasColumnType("INTEGER");
 211027
 211028                    b.Property<Guid?>("UserId")
 211029                        .HasColumnType("TEXT");
 211030
 211031                    b.Property<bool>("Value")
 211032                        .HasColumnType("INTEGER");
 211033
 211034                    b.HasKey("Id");
 211035
 211036                    b.HasIndex("UserId", "Kind")
 211037                        .IsUnique()
 211038                        .HasFilter("[UserId] IS NOT NULL");
 211039
 211040                    b.ToTable("Permissions");
 211041
 211042                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 211043                });
 1044
 211045            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.Preference", b =>
 211046                {
 211047                    b.Property<int>("Id")
 211048                        .ValueGeneratedOnAdd()
 211049                        .HasColumnType("INTEGER");
 211050
 211051                    b.Property<int>("Kind")
 211052                        .HasColumnType("INTEGER");
 211053
 211054                    b.Property<Guid?>("Preference_Preferences_Guid")
 211055                        .HasColumnType("TEXT");
 211056
 211057                    b.Property<uint>("RowVersion")
 211058                        .IsConcurrencyToken()
 211059                        .HasColumnType("INTEGER");
 211060
 211061                    b.Property<Guid?>("UserId")
 211062                        .HasColumnType("TEXT");
 211063
 211064                    b.Property<string>("Value")
 211065                        .IsRequired()
 211066                        .HasMaxLength(65535)
 211067                        .HasColumnType("TEXT");
 211068
 211069                    b.HasKey("Id");
 211070
 211071                    b.HasIndex("UserId", "Kind")
 211072                        .IsUnique()
 211073                        .HasFilter("[UserId] IS NOT NULL");
 211074
 211075                    b.ToTable("Preferences");
 211076
 211077                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 211078                });
 1079
 211080            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.Security.ApiKey", b =>
 211081                {
 211082                    b.Property<int>("Id")
 211083                        .ValueGeneratedOnAdd()
 211084                        .HasColumnType("INTEGER");
 211085
 211086                    b.Property<string>("AccessToken")
 211087                        .IsRequired()
 211088                        .HasColumnType("TEXT");
 211089
 211090                    b.Property<DateTime>("DateCreated")
 211091                        .HasColumnType("TEXT");
 211092
 211093                    b.Property<DateTime>("DateLastActivity")
 211094                        .HasColumnType("TEXT");
 211095
 211096                    b.Property<string>("Name")
 211097                        .IsRequired()
 211098                        .HasMaxLength(64)
 211099                        .HasColumnType("TEXT");
 211100
 211101                    b.HasKey("Id");
 211102
 211103                    b.HasIndex("AccessToken")
 211104                        .IsUnique();
 211105
 211106                    b.ToTable("ApiKeys");
 211107
 211108                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 211109                });
 1110
 211111            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.Security.Device", b =>
 211112                {
 211113                    b.Property<int>("Id")
 211114                        .ValueGeneratedOnAdd()
 211115                        .HasColumnType("INTEGER");
 211116
 211117                    b.Property<string>("AccessToken")
 211118                        .IsRequired()
 211119                        .HasColumnType("TEXT");
 211120
 211121                    b.Property<string>("AppName")
 211122                        .IsRequired()
 211123                        .HasMaxLength(64)
 211124                        .HasColumnType("TEXT");
 211125
 211126                    b.Property<string>("AppVersion")
 211127                        .IsRequired()
 211128                        .HasMaxLength(32)
 211129                        .HasColumnType("TEXT");
 211130
 211131                    b.Property<DateTime>("DateCreated")
 211132                        .HasColumnType("TEXT");
 211133
 211134                    b.Property<DateTime>("DateLastActivity")
 211135                        .HasColumnType("TEXT");
 211136
 211137                    b.Property<DateTime>("DateModified")
 211138                        .HasColumnType("TEXT");
 211139
 211140                    b.Property<string>("DeviceId")
 211141                        .IsRequired()
 211142                        .HasMaxLength(256)
 211143                        .HasColumnType("TEXT");
 211144
 211145                    b.Property<string>("DeviceName")
 211146                        .IsRequired()
 211147                        .HasMaxLength(64)
 211148                        .HasColumnType("TEXT");
 211149
 211150                    b.Property<bool>("IsActive")
 211151                        .HasColumnType("INTEGER");
 211152
 211153                    b.Property<Guid>("UserId")
 211154                        .HasColumnType("TEXT");
 211155
 211156                    b.HasKey("Id");
 211157
 211158                    b.HasIndex("DeviceId");
 211159
 211160                    b.HasIndex("AccessToken", "DateLastActivity");
 211161
 211162                    b.HasIndex("DeviceId", "DateLastActivity");
 211163
 211164                    b.HasIndex("UserId", "DeviceId");
 211165
 211166                    b.ToTable("Devices");
 211167
 211168                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 211169                });
 1170
 211171            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.Security.DeviceOptions", b =>
 211172                {
 211173                    b.Property<int>("Id")
 211174                        .ValueGeneratedOnAdd()
 211175                        .HasColumnType("INTEGER");
 211176
 211177                    b.Property<string>("CustomName")
 211178                        .HasColumnType("TEXT");
 211179
 211180                    b.Property<string>("DeviceId")
 211181                        .IsRequired()
 211182                        .HasColumnType("TEXT");
 211183
 211184                    b.HasKey("Id");
 211185
 211186                    b.HasIndex("DeviceId")
 211187                        .IsUnique();
 211188
 211189                    b.ToTable("DeviceOptions");
 211190
 211191                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 211192                });
 1193
 211194            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.TrickplayInfo", b =>
 211195                {
 211196                    b.Property<Guid>("ItemId")
 211197                        .HasColumnType("TEXT");
 211198
 211199                    b.Property<int>("Width")
 211200                        .HasColumnType("INTEGER");
 211201
 211202                    b.Property<int>("Bandwidth")
 211203                        .HasColumnType("INTEGER");
 211204
 211205                    b.Property<int>("Height")
 211206                        .HasColumnType("INTEGER");
 211207
 211208                    b.Property<int>("Interval")
 211209                        .HasColumnType("INTEGER");
 211210
 211211                    b.Property<int>("ThumbnailCount")
 211212                        .HasColumnType("INTEGER");
 211213
 211214                    b.Property<int>("TileHeight")
 211215                        .HasColumnType("INTEGER");
 211216
 211217                    b.Property<int>("TileWidth")
 211218                        .HasColumnType("INTEGER");
 211219
 211220                    b.HasKey("ItemId", "Width");
 211221
 211222                    b.ToTable("TrickplayInfos");
 211223
 211224                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 211225                });
 1226
 211227            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.User", b =>
 211228                {
 211229                    b.Property<Guid>("Id")
 211230                        .ValueGeneratedOnAdd()
 211231                        .HasColumnType("TEXT");
 211232
 211233                    b.Property<string>("AudioLanguagePreference")
 211234                        .HasMaxLength(255)
 211235                        .HasColumnType("TEXT");
 211236
 211237                    b.Property<string>("AuthenticationProviderId")
 211238                        .IsRequired()
 211239                        .HasMaxLength(255)
 211240                        .HasColumnType("TEXT");
 211241
 211242                    b.Property<string>("CastReceiverId")
 211243                        .HasMaxLength(32)
 211244                        .HasColumnType("TEXT");
 211245
 211246                    b.Property<bool>("DisplayCollectionsView")
 211247                        .HasColumnType("INTEGER");
 211248
 211249                    b.Property<bool>("DisplayMissingEpisodes")
 211250                        .HasColumnType("INTEGER");
 211251
 211252                    b.Property<bool>("EnableAutoLogin")
 211253                        .HasColumnType("INTEGER");
 211254
 211255                    b.Property<bool>("EnableLocalPassword")
 211256                        .HasColumnType("INTEGER");
 211257
 211258                    b.Property<bool>("EnableNextEpisodeAutoPlay")
 211259                        .HasColumnType("INTEGER");
 211260
 211261                    b.Property<bool>("EnableUserPreferenceAccess")
 211262                        .HasColumnType("INTEGER");
 211263
 211264                    b.Property<bool>("HidePlayedInLatest")
 211265                        .HasColumnType("INTEGER");
 211266
 211267                    b.Property<long>("InternalId")
 211268                        .HasColumnType("INTEGER");
 211269
 211270                    b.Property<int>("InvalidLoginAttemptCount")
 211271                        .HasColumnType("INTEGER");
 211272
 211273                    b.Property<DateTime?>("LastActivityDate")
 211274                        .HasColumnType("TEXT");
 211275
 211276                    b.Property<DateTime?>("LastLoginDate")
 211277                        .HasColumnType("TEXT");
 211278
 211279                    b.Property<int?>("LoginAttemptsBeforeLockout")
 211280                        .HasColumnType("INTEGER");
 211281
 211282                    b.Property<int>("MaxActiveSessions")
 211283                        .HasColumnType("INTEGER");
 211284
 211285                    b.Property<int?>("MaxParentalRatingScore")
 211286                        .HasColumnType("INTEGER");
 211287
 211288                    b.Property<int?>("MaxParentalRatingSubScore")
 211289                        .HasColumnType("INTEGER");
 211290
 211291                    b.Property<bool>("MustUpdatePassword")
 211292                        .HasColumnType("INTEGER");
 211293
 211294                    b.Property<string>("Password")
 211295                        .HasMaxLength(65535)
 211296                        .HasColumnType("TEXT");
 211297
 211298                    b.Property<string>("PasswordResetProviderId")
 211299                        .IsRequired()
 211300                        .HasMaxLength(255)
 211301                        .HasColumnType("TEXT");
 211302
 211303                    b.Property<bool>("PlayDefaultAudioTrack")
 211304                        .HasColumnType("INTEGER");
 211305
 211306                    b.Property<bool>("RememberAudioSelections")
 211307                        .HasColumnType("INTEGER");
 211308
 211309                    b.Property<bool>("RememberSubtitleSelections")
 211310                        .HasColumnType("INTEGER");
 211311
 211312                    b.Property<int?>("RemoteClientBitrateLimit")
 211313                        .HasColumnType("INTEGER");
 211314
 211315                    b.Property<uint>("RowVersion")
 211316                        .IsConcurrencyToken()
 211317                        .HasColumnType("INTEGER");
 211318
 211319                    b.Property<string>("SubtitleLanguagePreference")
 211320                        .HasMaxLength(255)
 211321                        .HasColumnType("TEXT");
 211322
 211323                    b.Property<int>("SubtitleMode")
 211324                        .HasColumnType("INTEGER");
 211325
 211326                    b.Property<int>("SyncPlayAccess")
 211327                        .HasColumnType("INTEGER");
 211328
 211329                    b.Property<string>("Username")
 211330                        .IsRequired()
 211331                        .HasMaxLength(255)
 211332                        .HasColumnType("TEXT");
 211333
 211334                    b.HasKey("Id");
 211335
 211336                    b.HasIndex("Username")
 211337                        .IsUnique();
 211338
 211339                    b.ToTable("Users");
 211340
 211341                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 211342                });
 1343
 211344            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.UserData", b =>
 211345                {
 211346                    b.Property<Guid>("ItemId")
 211347                        .HasColumnType("TEXT");
 211348
 211349                    b.Property<Guid>("UserId")
 211350                        .HasColumnType("TEXT");
 211351
 211352                    b.Property<string>("CustomDataKey")
 211353                        .HasColumnType("TEXT");
 211354
 211355                    b.Property<int?>("AudioStreamIndex")
 211356                        .HasColumnType("INTEGER");
 211357
 211358                    b.Property<bool>("IsFavorite")
 211359                        .HasColumnType("INTEGER");
 211360
 211361                    b.Property<DateTime?>("LastPlayedDate")
 211362                        .HasColumnType("TEXT");
 211363
 211364                    b.Property<bool?>("Likes")
 211365                        .HasColumnType("INTEGER");
 211366
 211367                    b.Property<int>("PlayCount")
 211368                        .HasColumnType("INTEGER");
 211369
 211370                    b.Property<long>("PlaybackPositionTicks")
 211371                        .HasColumnType("INTEGER");
 211372
 211373                    b.Property<bool>("Played")
 211374                        .HasColumnType("INTEGER");
 211375
 211376                    b.Property<double?>("Rating")
 211377                        .HasColumnType("REAL");
 211378
 211379                    b.Property<DateTimeOffset?>("RetentionDate")
 211380                        .HasColumnType("TEXT");
 211381
 211382                    b.Property<int?>("SubtitleStreamIndex")
 211383                        .HasColumnType("INTEGER");
 211384
 211385                    b.HasKey("ItemId", "UserId", "CustomDataKey");
 211386
 211387                    b.HasIndex("UserId");
 211388
 211389                    b.HasIndex("ItemId", "UserId", "IsFavorite");
 211390
 211391                    b.HasIndex("ItemId", "UserId", "LastPlayedDate");
 211392
 211393                    b.HasIndex("ItemId", "UserId", "PlaybackPositionTicks");
 211394
 211395                    b.HasIndex("ItemId", "UserId", "Played");
 211396
 211397                    b.ToTable("UserData");
 211398
 211399                    b.HasAnnotation("Sqlite:UseSqlReturningClause", false);
 211400                });
 1401
 211402            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.AccessSchedule", b =>
 211403                {
 211404                    b.HasOne("Jellyfin.Database.Implementations.Entities.User", null)
 211405                        .WithMany("AccessSchedules")
 211406                        .HasForeignKey("UserId")
 211407                        .OnDelete(DeleteBehavior.Cascade)
 211408                        .IsRequired();
 211409                });
 1410
 211411            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.AncestorId", b =>
 211412                {
 211413                    b.HasOne("Jellyfin.Database.Implementations.Entities.BaseItemEntity", "Item")
 211414                        .WithMany("Parents")
 211415                        .HasForeignKey("ItemId")
 211416                        .OnDelete(DeleteBehavior.Cascade)
 211417                        .IsRequired();
 211418
 211419                    b.HasOne("Jellyfin.Database.Implementations.Entities.BaseItemEntity", "ParentItem")
 211420                        .WithMany("Children")
 211421                        .HasForeignKey("ParentItemId")
 211422                        .OnDelete(DeleteBehavior.Cascade)
 211423                        .IsRequired();
 211424
 211425                    b.Navigation("Item");
 211426
 211427                    b.Navigation("ParentItem");
 211428                });
 1429
 211430            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.AttachmentStreamInfo", b =>
 211431                {
 211432                    b.HasOne("Jellyfin.Database.Implementations.Entities.BaseItemEntity", "Item")
 211433                        .WithMany()
 211434                        .HasForeignKey("ItemId")
 211435                        .OnDelete(DeleteBehavior.Cascade)
 211436                        .IsRequired();
 211437
 211438                    b.Navigation("Item");
 211439                });
 1440
 211441            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.BaseItemImageInfo", b =>
 211442                {
 211443                    b.HasOne("Jellyfin.Database.Implementations.Entities.BaseItemEntity", "Item")
 211444                        .WithMany("Images")
 211445                        .HasForeignKey("ItemId")
 211446                        .OnDelete(DeleteBehavior.Cascade)
 211447                        .IsRequired();
 211448
 211449                    b.Navigation("Item");
 211450                });
 1451
 211452            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.BaseItemMetadataField", b =>
 211453                {
 211454                    b.HasOne("Jellyfin.Database.Implementations.Entities.BaseItemEntity", "Item")
 211455                        .WithMany("LockedFields")
 211456                        .HasForeignKey("ItemId")
 211457                        .OnDelete(DeleteBehavior.Cascade)
 211458                        .IsRequired();
 211459
 211460                    b.Navigation("Item");
 211461                });
 1462
 211463            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.BaseItemProvider", b =>
 211464                {
 211465                    b.HasOne("Jellyfin.Database.Implementations.Entities.BaseItemEntity", "Item")
 211466                        .WithMany("Provider")
 211467                        .HasForeignKey("ItemId")
 211468                        .OnDelete(DeleteBehavior.Cascade)
 211469                        .IsRequired();
 211470
 211471                    b.Navigation("Item");
 211472                });
 1473
 211474            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.BaseItemTrailerType", b =>
 211475                {
 211476                    b.HasOne("Jellyfin.Database.Implementations.Entities.BaseItemEntity", "Item")
 211477                        .WithMany("TrailerTypes")
 211478                        .HasForeignKey("ItemId")
 211479                        .OnDelete(DeleteBehavior.Cascade)
 211480                        .IsRequired();
 211481
 211482                    b.Navigation("Item");
 211483                });
 1484
 211485            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.Chapter", b =>
 211486                {
 211487                    b.HasOne("Jellyfin.Database.Implementations.Entities.BaseItemEntity", "Item")
 211488                        .WithMany("Chapters")
 211489                        .HasForeignKey("ItemId")
 211490                        .OnDelete(DeleteBehavior.Cascade)
 211491                        .IsRequired();
 211492
 211493                    b.Navigation("Item");
 211494                });
 1495
 211496            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.DisplayPreferences", b =>
 211497                {
 211498                    b.HasOne("Jellyfin.Database.Implementations.Entities.User", null)
 211499                        .WithMany("DisplayPreferences")
 211500                        .HasForeignKey("UserId")
 211501                        .OnDelete(DeleteBehavior.Cascade)
 211502                        .IsRequired();
 211503                });
 1504
 211505            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.HomeSection", b =>
 211506                {
 211507                    b.HasOne("Jellyfin.Database.Implementations.Entities.DisplayPreferences", null)
 211508                        .WithMany("HomeSections")
 211509                        .HasForeignKey("DisplayPreferencesId")
 211510                        .OnDelete(DeleteBehavior.Cascade)
 211511                        .IsRequired();
 211512                });
 1513
 211514            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.ImageInfo", b =>
 211515                {
 211516                    b.HasOne("Jellyfin.Database.Implementations.Entities.User", null)
 211517                        .WithOne("ProfileImage")
 211518                        .HasForeignKey("Jellyfin.Database.Implementations.Entities.ImageInfo", "UserId")
 211519                        .OnDelete(DeleteBehavior.Cascade);
 211520                });
 1521
 211522            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.ItemDisplayPreferences", b =>
 211523                {
 211524                    b.HasOne("Jellyfin.Database.Implementations.Entities.User", null)
 211525                        .WithMany("ItemDisplayPreferences")
 211526                        .HasForeignKey("UserId")
 211527                        .OnDelete(DeleteBehavior.Cascade)
 211528                        .IsRequired();
 211529                });
 1530
 211531            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.ItemValueMap", b =>
 211532                {
 211533                    b.HasOne("Jellyfin.Database.Implementations.Entities.BaseItemEntity", "Item")
 211534                        .WithMany("ItemValues")
 211535                        .HasForeignKey("ItemId")
 211536                        .OnDelete(DeleteBehavior.Cascade)
 211537                        .IsRequired();
 211538
 211539                    b.HasOne("Jellyfin.Database.Implementations.Entities.ItemValue", "ItemValue")
 211540                        .WithMany("BaseItemsMap")
 211541                        .HasForeignKey("ItemValueId")
 211542                        .OnDelete(DeleteBehavior.Cascade)
 211543                        .IsRequired();
 211544
 211545                    b.Navigation("Item");
 211546
 211547                    b.Navigation("ItemValue");
 211548                });
 1549
 211550            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.KeyframeData", b =>
 211551                {
 211552                    b.HasOne("Jellyfin.Database.Implementations.Entities.BaseItemEntity", "Item")
 211553                        .WithMany()
 211554                        .HasForeignKey("ItemId")
 211555                        .OnDelete(DeleteBehavior.Cascade)
 211556                        .IsRequired();
 211557
 211558                    b.Navigation("Item");
 211559                });
 1560
 211561            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.MediaStreamInfo", b =>
 211562                {
 211563                    b.HasOne("Jellyfin.Database.Implementations.Entities.BaseItemEntity", "Item")
 211564                        .WithMany("MediaStreams")
 211565                        .HasForeignKey("ItemId")
 211566                        .OnDelete(DeleteBehavior.Cascade)
 211567                        .IsRequired();
 211568
 211569                    b.Navigation("Item");
 211570                });
 1571
 211572            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.PeopleBaseItemMap", b =>
 211573                {
 211574                    b.HasOne("Jellyfin.Database.Implementations.Entities.BaseItemEntity", "Item")
 211575                        .WithMany("Peoples")
 211576                        .HasForeignKey("ItemId")
 211577                        .OnDelete(DeleteBehavior.Cascade)
 211578                        .IsRequired();
 211579
 211580                    b.HasOne("Jellyfin.Database.Implementations.Entities.People", "People")
 211581                        .WithMany("BaseItems")
 211582                        .HasForeignKey("PeopleId")
 211583                        .OnDelete(DeleteBehavior.Cascade)
 211584                        .IsRequired();
 211585
 211586                    b.Navigation("Item");
 211587
 211588                    b.Navigation("People");
 211589                });
 1590
 211591            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.Permission", b =>
 211592                {
 211593                    b.HasOne("Jellyfin.Database.Implementations.Entities.User", null)
 211594                        .WithMany("Permissions")
 211595                        .HasForeignKey("UserId")
 211596                        .OnDelete(DeleteBehavior.Cascade);
 211597                });
 1598
 211599            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.Preference", b =>
 211600                {
 211601                    b.HasOne("Jellyfin.Database.Implementations.Entities.User", null)
 211602                        .WithMany("Preferences")
 211603                        .HasForeignKey("UserId")
 211604                        .OnDelete(DeleteBehavior.Cascade);
 211605                });
 1606
 211607            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.Security.Device", b =>
 211608                {
 211609                    b.HasOne("Jellyfin.Database.Implementations.Entities.User", "User")
 211610                        .WithMany()
 211611                        .HasForeignKey("UserId")
 211612                        .OnDelete(DeleteBehavior.Cascade)
 211613                        .IsRequired();
 211614
 211615                    b.Navigation("User");
 211616                });
 1617
 211618            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.UserData", b =>
 211619                {
 211620                    b.HasOne("Jellyfin.Database.Implementations.Entities.BaseItemEntity", "Item")
 211621                        .WithMany("UserData")
 211622                        .HasForeignKey("ItemId")
 211623                        .OnDelete(DeleteBehavior.SetNull);
 211624
 211625                    b.HasOne("Jellyfin.Database.Implementations.Entities.User", "User")
 211626                        .WithMany()
 211627                        .HasForeignKey("UserId")
 211628                        .OnDelete(DeleteBehavior.Cascade)
 211629                        .IsRequired();
 211630
 211631                    b.Navigation("Item");
 211632
 211633                    b.Navigation("User");
 211634                });
 1635
 211636            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.BaseItemEntity", b =>
 211637                {
 211638                    b.Navigation("Chapters");
 211639
 211640                    b.Navigation("Children");
 211641
 211642                    b.Navigation("Images");
 211643
 211644                    b.Navigation("ItemValues");
 211645
 211646                    b.Navigation("LockedFields");
 211647
 211648                    b.Navigation("MediaStreams");
 211649
 211650                    b.Navigation("Parents");
 211651
 211652                    b.Navigation("Peoples");
 211653
 211654                    b.Navigation("Provider");
 211655
 211656                    b.Navigation("TrailerTypes");
 211657
 211658                    b.Navigation("UserData");
 211659                });
 1660
 211661            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.DisplayPreferences", b =>
 211662                {
 211663                    b.Navigation("HomeSections");
 211664                });
 1665
 211666            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.ItemValue", b =>
 211667                {
 211668                    b.Navigation("BaseItemsMap");
 211669                });
 1670
 211671            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.People", b =>
 211672                {
 211673                    b.Navigation("BaseItems");
 211674                });
 1675
 211676            modelBuilder.Entity("Jellyfin.Database.Implementations.Entities.User", b =>
 211677                {
 211678                    b.Navigation("AccessSchedules");
 211679
 211680                    b.Navigation("DisplayPreferences");
 211681
 211682                    b.Navigation("ItemDisplayPreferences");
 211683
 211684                    b.Navigation("Permissions");
 211685
 211686                    b.Navigation("Preferences");
 211687
 211688                    b.Navigation("ProfileImage");
 211689                });
 1690#pragma warning restore 612, 618
 211691        }
 1692    }
 1693}