JellyfinDbContext.cs 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274
  1. using System;
  2. using System.Linq;
  3. using Jellyfin.Data.Entities;
  4. using Jellyfin.Data.Entities.Security;
  5. using Jellyfin.Data.Interfaces;
  6. using Microsoft.EntityFrameworkCore;
  7. using Microsoft.Extensions.Logging;
  8. namespace Jellyfin.Server.Implementations;
  9. /// <inheritdoc/>
  10. /// <summary>
  11. /// Initializes a new instance of the <see cref="JellyfinDbContext"/> class.
  12. /// </summary>
  13. /// <param name="options">The database context options.</param>
  14. /// <param name="logger">Logger.</param>
  15. public class JellyfinDbContext(DbContextOptions<JellyfinDbContext> options, ILogger<JellyfinDbContext> logger) : DbContext(options)
  16. {
  17. /// <summary>
  18. /// Gets the <see cref="DbSet{TEntity}"/> containing the access schedules.
  19. /// </summary>
  20. public DbSet<AccessSchedule> AccessSchedules => Set<AccessSchedule>();
  21. /// <summary>
  22. /// Gets the <see cref="DbSet{TEntity}"/> containing the activity logs.
  23. /// </summary>
  24. public DbSet<ActivityLog> ActivityLogs => Set<ActivityLog>();
  25. /// <summary>
  26. /// Gets the <see cref="DbSet{TEntity}"/> containing the API keys.
  27. /// </summary>
  28. public DbSet<ApiKey> ApiKeys => Set<ApiKey>();
  29. /// <summary>
  30. /// Gets the <see cref="DbSet{TEntity}"/> containing the devices.
  31. /// </summary>
  32. public DbSet<Device> Devices => Set<Device>();
  33. /// <summary>
  34. /// Gets the <see cref="DbSet{TEntity}"/> containing the device options.
  35. /// </summary>
  36. public DbSet<DeviceOptions> DeviceOptions => Set<DeviceOptions>();
  37. /// <summary>
  38. /// Gets the <see cref="DbSet{TEntity}"/> containing the display preferences.
  39. /// </summary>
  40. public DbSet<DisplayPreferences> DisplayPreferences => Set<DisplayPreferences>();
  41. /// <summary>
  42. /// Gets the <see cref="DbSet{TEntity}"/> containing the image infos.
  43. /// </summary>
  44. public DbSet<ImageInfo> ImageInfos => Set<ImageInfo>();
  45. /// <summary>
  46. /// Gets the <see cref="DbSet{TEntity}"/> containing the item display preferences.
  47. /// </summary>
  48. public DbSet<ItemDisplayPreferences> ItemDisplayPreferences => Set<ItemDisplayPreferences>();
  49. /// <summary>
  50. /// Gets the <see cref="DbSet{TEntity}"/> containing the custom item display preferences.
  51. /// </summary>
  52. public DbSet<CustomItemDisplayPreferences> CustomItemDisplayPreferences => Set<CustomItemDisplayPreferences>();
  53. /// <summary>
  54. /// Gets the <see cref="DbSet{TEntity}"/> containing the permissions.
  55. /// </summary>
  56. public DbSet<Permission> Permissions => Set<Permission>();
  57. /// <summary>
  58. /// Gets the <see cref="DbSet{TEntity}"/> containing the preferences.
  59. /// </summary>
  60. public DbSet<Preference> Preferences => Set<Preference>();
  61. /// <summary>
  62. /// Gets the <see cref="DbSet{TEntity}"/> containing the users.
  63. /// </summary>
  64. public DbSet<User> Users => Set<User>();
  65. /// <summary>
  66. /// Gets the <see cref="DbSet{TEntity}"/> containing the trickplay metadata.
  67. /// </summary>
  68. public DbSet<TrickplayInfo> TrickplayInfos => Set<TrickplayInfo>();
  69. /// <summary>
  70. /// Gets the <see cref="DbSet{TEntity}"/> containing the media segments.
  71. /// </summary>
  72. public DbSet<MediaSegment> MediaSegments => Set<MediaSegment>();
  73. /// <summary>
  74. /// Gets the <see cref="DbSet{TEntity}"/> containing the user data.
  75. /// </summary>
  76. public DbSet<UserData> UserData => Set<UserData>();
  77. /// <summary>
  78. /// Gets the <see cref="DbSet{TEntity}"/> containing the user data.
  79. /// </summary>
  80. public DbSet<AncestorId> AncestorIds => Set<AncestorId>();
  81. /// <summary>
  82. /// Gets the <see cref="DbSet{TEntity}"/> containing the user data.
  83. /// </summary>
  84. public DbSet<AttachmentStreamInfo> AttachmentStreamInfos => Set<AttachmentStreamInfo>();
  85. /// <summary>
  86. /// Gets the <see cref="DbSet{TEntity}"/> containing the user data.
  87. /// </summary>
  88. public DbSet<BaseItemEntity> BaseItems => Set<BaseItemEntity>();
  89. /// <summary>
  90. /// Gets the <see cref="DbSet{TEntity}"/> containing the user data.
  91. /// </summary>
  92. public DbSet<Chapter> Chapters => Set<Chapter>();
  93. /// <summary>
  94. /// Gets the <see cref="DbSet{TEntity}"/>.
  95. /// </summary>
  96. public DbSet<ItemValue> ItemValues => Set<ItemValue>();
  97. /// <summary>
  98. /// Gets the <see cref="DbSet{TEntity}"/>.
  99. /// </summary>
  100. public DbSet<ItemValueMap> ItemValuesMap => Set<ItemValueMap>();
  101. /// <summary>
  102. /// Gets the <see cref="DbSet{TEntity}"/>.
  103. /// </summary>
  104. public DbSet<MediaStreamInfo> MediaStreamInfos => Set<MediaStreamInfo>();
  105. /// <summary>
  106. /// Gets the <see cref="DbSet{TEntity}"/>.
  107. /// </summary>
  108. public DbSet<People> Peoples => Set<People>();
  109. /// <summary>
  110. /// Gets the <see cref="DbSet{TEntity}"/>.
  111. /// </summary>
  112. public DbSet<PeopleBaseItemMap> PeopleBaseItemMap => Set<PeopleBaseItemMap>();
  113. /// <summary>
  114. /// Gets the <see cref="DbSet{TEntity}"/> containing the referenced Providers with ids.
  115. /// </summary>
  116. public DbSet<BaseItemProvider> BaseItemProviders => Set<BaseItemProvider>();
  117. /// <summary>
  118. /// Gets the <see cref="DbSet{TEntity}"/>.
  119. /// </summary>
  120. public DbSet<BaseItemImageInfo> BaseItemImageInfos => Set<BaseItemImageInfo>();
  121. /// <summary>
  122. /// Gets the <see cref="DbSet{TEntity}"/>.
  123. /// </summary>
  124. public DbSet<BaseItemMetadataField> BaseItemMetadataFields => Set<BaseItemMetadataField>();
  125. /// <summary>
  126. /// Gets the <see cref="DbSet{TEntity}"/>.
  127. /// </summary>
  128. public DbSet<BaseItemTrailerType> BaseItemTrailerTypes => Set<BaseItemTrailerType>();
  129. /*public DbSet<Artwork> Artwork => Set<Artwork>();
  130. public DbSet<Book> Books => Set<Book>();
  131. public DbSet<BookMetadata> BookMetadata => Set<BookMetadata>();
  132. public DbSet<Chapter> Chapters => Set<Chapter>();
  133. public DbSet<Collection> Collections => Set<Collection>();
  134. public DbSet<CollectionItem> CollectionItems => Set<CollectionItem>();
  135. public DbSet<Company> Companies => Set<Company>();
  136. public DbSet<CompanyMetadata> CompanyMetadata => Set<CompanyMetadata>();
  137. public DbSet<CustomItem> CustomItems => Set<CustomItem>();
  138. public DbSet<CustomItemMetadata> CustomItemMetadata => Set<CustomItemMetadata>();
  139. public DbSet<Episode> Episodes => Set<Episode>();
  140. public DbSet<EpisodeMetadata> EpisodeMetadata => Set<EpisodeMetadata>();
  141. public DbSet<Genre> Genres => Set<Genre>();
  142. public DbSet<Group> Groups => Set<Groups>();
  143. public DbSet<Library> Libraries => Set<Library>();
  144. public DbSet<LibraryItem> LibraryItems => Set<LibraryItems>();
  145. public DbSet<LibraryRoot> LibraryRoot => Set<LibraryRoot>();
  146. public DbSet<MediaFile> MediaFiles => Set<MediaFiles>();
  147. public DbSet<MediaFileStream> MediaFileStream => Set<MediaFileStream>();
  148. public DbSet<Metadata> Metadata => Set<Metadata>();
  149. public DbSet<MetadataProvider> MetadataProviders => Set<MetadataProvider>();
  150. public DbSet<MetadataProviderId> MetadataProviderIds => Set<MetadataProviderId>();
  151. public DbSet<Movie> Movies => Set<Movie>();
  152. public DbSet<MovieMetadata> MovieMetadata => Set<MovieMetadata>();
  153. public DbSet<MusicAlbum> MusicAlbums => Set<MusicAlbum>();
  154. public DbSet<MusicAlbumMetadata> MusicAlbumMetadata => Set<MusicAlbumMetadata>();
  155. public DbSet<Person> People => Set<Person>();
  156. public DbSet<PersonRole> PersonRoles => Set<PersonRole>();
  157. public DbSet<Photo> Photo => Set<Photo>();
  158. public DbSet<PhotoMetadata> PhotoMetadata => Set<PhotoMetadata>();
  159. public DbSet<ProviderMapping> ProviderMappings => Set<ProviderMapping>();
  160. public DbSet<Rating> Ratings => Set<Rating>();
  161. /// <summary>
  162. /// Repository for global::Jellyfin.Data.Entities.RatingSource - This is the entity to
  163. /// store review ratings, not age ratings.
  164. /// </summary>
  165. public DbSet<RatingSource> RatingSources => Set<RatingSource>();
  166. public DbSet<Release> Releases => Set<Release>();
  167. public DbSet<Season> Seasons => Set<Season>();
  168. public DbSet<SeasonMetadata> SeasonMetadata => Set<SeasonMetadata>();
  169. public DbSet<Series> Series => Set<Series>();
  170. public DbSet<SeriesMetadata> SeriesMetadata => Set<SeriesMetadata();
  171. public DbSet<Track> Tracks => Set<Track>();
  172. public DbSet<TrackMetadata> TrackMetadata => Set<TrackMetadata>();*/
  173. /// <inheritdoc/>
  174. public override int SaveChanges()
  175. {
  176. foreach (var saveEntity in ChangeTracker.Entries()
  177. .Where(e => e.State == EntityState.Modified)
  178. .Select(entry => entry.Entity)
  179. .OfType<IHasConcurrencyToken>())
  180. {
  181. saveEntity.OnSavingChanges();
  182. }
  183. try
  184. {
  185. return base.SaveChanges();
  186. }
  187. catch (Exception e)
  188. {
  189. logger.LogError(e, "Error trying to save changes.");
  190. throw;
  191. }
  192. }
  193. /// <inheritdoc />
  194. protected override void OnModelCreating(ModelBuilder modelBuilder)
  195. {
  196. modelBuilder.SetDefaultDateTimeKind(DateTimeKind.Utc);
  197. base.OnModelCreating(modelBuilder);
  198. // Configuration for each entity is in its own class inside 'ModelConfiguration'.
  199. modelBuilder.ApplyConfigurationsFromAssembly(typeof(JellyfinDbContext).Assembly);
  200. }
  201. }