JellyfinDb.cs 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. #nullable disable
  2. #pragma warning disable CS1591
  3. using System;
  4. using System.Linq;
  5. using Jellyfin.Data.Entities;
  6. using Jellyfin.Data.Entities.Security;
  7. using Jellyfin.Data.Interfaces;
  8. using Microsoft.EntityFrameworkCore;
  9. namespace Jellyfin.Server.Implementations
  10. {
  11. /// <inheritdoc/>
  12. public class JellyfinDb : DbContext
  13. {
  14. /// <summary>
  15. /// Initializes a new instance of the <see cref="JellyfinDb"/> class.
  16. /// </summary>
  17. /// <param name="options">The database context options.</param>
  18. public JellyfinDb(DbContextOptions<JellyfinDb> options) : base(options)
  19. {
  20. }
  21. /// <summary>
  22. /// Gets or sets the default connection string.
  23. /// </summary>
  24. public static string ConnectionString { get; set; } = @"Data Source=jellyfin.db";
  25. public virtual DbSet<AccessSchedule> AccessSchedules { get; set; }
  26. public virtual DbSet<ActivityLog> ActivityLogs { get; set; }
  27. public virtual DbSet<ApiKey> ApiKeys { get; set; }
  28. public virtual DbSet<Device> Devices { get; set; }
  29. public virtual DbSet<DeviceOptions> DeviceOptions { get; set; }
  30. public virtual DbSet<DisplayPreferences> DisplayPreferences { get; set; }
  31. public virtual DbSet<ImageInfo> ImageInfos { get; set; }
  32. public virtual DbSet<ItemDisplayPreferences> ItemDisplayPreferences { get; set; }
  33. public virtual DbSet<CustomItemDisplayPreferences> CustomItemDisplayPreferences { get; set; }
  34. public virtual DbSet<Permission> Permissions { get; set; }
  35. public virtual DbSet<Preference> Preferences { get; set; }
  36. public virtual DbSet<User> Users { get; set; }
  37. /*public virtual DbSet<Artwork> Artwork { get; set; }
  38. public virtual DbSet<Book> Books { get; set; }
  39. public virtual DbSet<BookMetadata> BookMetadata { get; set; }
  40. public virtual DbSet<Chapter> Chapters { get; set; }
  41. public virtual DbSet<Collection> Collections { get; set; }
  42. public virtual DbSet<CollectionItem> CollectionItems { get; set; }
  43. public virtual DbSet<Company> Companies { get; set; }
  44. public virtual DbSet<CompanyMetadata> CompanyMetadata { get; set; }
  45. public virtual DbSet<CustomItem> CustomItems { get; set; }
  46. public virtual DbSet<CustomItemMetadata> CustomItemMetadata { get; set; }
  47. public virtual DbSet<Episode> Episodes { get; set; }
  48. public virtual DbSet<EpisodeMetadata> EpisodeMetadata { get; set; }
  49. public virtual DbSet<Genre> Genres { get; set; }
  50. public virtual DbSet<Group> Groups { get; set; }
  51. public virtual DbSet<Library> Libraries { get; set; }
  52. public virtual DbSet<LibraryItem> LibraryItems { get; set; }
  53. public virtual DbSet<LibraryRoot> LibraryRoot { get; set; }
  54. public virtual DbSet<MediaFile> MediaFiles { get; set; }
  55. public virtual DbSet<MediaFileStream> MediaFileStream { get; set; }
  56. public virtual DbSet<Metadata> Metadata { get; set; }
  57. public virtual DbSet<MetadataProvider> MetadataProviders { get; set; }
  58. public virtual DbSet<MetadataProviderId> MetadataProviderIds { get; set; }
  59. public virtual DbSet<Movie> Movies { get; set; }
  60. public virtual DbSet<MovieMetadata> MovieMetadata { get; set; }
  61. public virtual DbSet<MusicAlbum> MusicAlbums { get; set; }
  62. public virtual DbSet<MusicAlbumMetadata> MusicAlbumMetadata { get; set; }
  63. public virtual DbSet<Person> People { get; set; }
  64. public virtual DbSet<PersonRole> PersonRoles { get; set; }
  65. public virtual DbSet<Photo> Photo { get; set; }
  66. public virtual DbSet<PhotoMetadata> PhotoMetadata { get; set; }
  67. public virtual DbSet<ProviderMapping> ProviderMappings { get; set; }
  68. public virtual DbSet<Rating> Ratings { get; set; }
  69. /// <summary>
  70. /// Repository for global::Jellyfin.Data.Entities.RatingSource - This is the entity to
  71. /// store review ratings, not age ratings.
  72. /// </summary>
  73. public virtual DbSet<RatingSource> RatingSources { get; set; }
  74. public virtual DbSet<Release> Releases { get; set; }
  75. public virtual DbSet<Season> Seasons { get; set; }
  76. public virtual DbSet<SeasonMetadata> SeasonMetadata { get; set; }
  77. public virtual DbSet<Series> Series { get; set; }
  78. public virtual DbSet<SeriesMetadata> SeriesMetadata { get; set; }
  79. public virtual DbSet<Track> Tracks { get; set; }
  80. public virtual DbSet<TrackMetadata> TrackMetadata { get; set; }*/
  81. /// <inheritdoc/>
  82. public override int SaveChanges()
  83. {
  84. foreach (var saveEntity in ChangeTracker.Entries()
  85. .Where(e => e.State == EntityState.Modified)
  86. .Select(entry => entry.Entity)
  87. .OfType<IHasConcurrencyToken>())
  88. {
  89. saveEntity.OnSavingChanges();
  90. }
  91. return base.SaveChanges();
  92. }
  93. /// <inheritdoc />
  94. protected override void OnModelCreating(ModelBuilder modelBuilder)
  95. {
  96. modelBuilder.SetDefaultDateTimeKind(DateTimeKind.Utc);
  97. base.OnModelCreating(modelBuilder);
  98. modelBuilder.HasDefaultSchema("jellyfin");
  99. // Collations
  100. modelBuilder.Entity<User>()
  101. .Property(user => user.Username)
  102. .UseCollation("NOCASE");
  103. // Delete behavior
  104. modelBuilder.Entity<User>()
  105. .HasOne(u => u.ProfileImage)
  106. .WithOne()
  107. .OnDelete(DeleteBehavior.Cascade);
  108. modelBuilder.Entity<User>()
  109. .HasMany(u => u.Permissions)
  110. .WithOne()
  111. .HasForeignKey(p => p.UserId)
  112. .OnDelete(DeleteBehavior.Cascade);
  113. modelBuilder.Entity<User>()
  114. .HasMany(u => u.Preferences)
  115. .WithOne()
  116. .HasForeignKey(p => p.UserId)
  117. .OnDelete(DeleteBehavior.Cascade);
  118. modelBuilder.Entity<User>()
  119. .HasMany(u => u.AccessSchedules)
  120. .WithOne()
  121. .OnDelete(DeleteBehavior.Cascade);
  122. modelBuilder.Entity<User>()
  123. .HasMany(u => u.DisplayPreferences)
  124. .WithOne()
  125. .OnDelete(DeleteBehavior.Cascade);
  126. modelBuilder.Entity<User>()
  127. .HasMany(u => u.ItemDisplayPreferences)
  128. .WithOne()
  129. .OnDelete(DeleteBehavior.Cascade);
  130. modelBuilder.Entity<DisplayPreferences>()
  131. .HasMany(d => d.HomeSections)
  132. .WithOne()
  133. .OnDelete(DeleteBehavior.Cascade);
  134. // Indexes
  135. modelBuilder.Entity<ApiKey>()
  136. .HasIndex(entity => entity.AccessToken)
  137. .IsUnique();
  138. modelBuilder.Entity<User>()
  139. .HasIndex(entity => entity.Username)
  140. .IsUnique();
  141. modelBuilder.Entity<DisplayPreferences>()
  142. .HasIndex(entity => new { entity.UserId, entity.ItemId, entity.Client })
  143. .IsUnique();
  144. modelBuilder.Entity<CustomItemDisplayPreferences>()
  145. .HasIndex(entity => new { entity.UserId, entity.ItemId, entity.Client, entity.Key })
  146. .IsUnique();
  147. // Used to get a user's permissions or a specific permission for a user.
  148. // Also prevents multiple values being created for a user.
  149. // Filtered over non-null user ids for when other entities (groups, API keys) get permissions
  150. modelBuilder.Entity<Permission>()
  151. .HasIndex(p => new { p.UserId, p.Kind })
  152. .HasFilter("[UserId] IS NOT NULL")
  153. .IsUnique();
  154. modelBuilder.Entity<Preference>()
  155. .HasIndex(p => new { p.UserId, p.Kind })
  156. .HasFilter("[UserId] IS NOT NULL")
  157. .IsUnique();
  158. }
  159. }
  160. }