mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-10-25 15:52:43 -04:00 
			
		
		
		
	Applied review comments
This commit is contained in:
		
							parent
							
								
									9c5599f81b
								
							
						
					
					
						commit
						ae641b7f3a
					
				| @ -1,6 +1,8 @@ | |||||||
| using System; | using System; | ||||||
| using System.Collections.Frozen; | using System.Collections.Frozen; | ||||||
| using System.Collections.Generic; | using System.Collections.Generic; | ||||||
|  | using System.Collections.Immutable; | ||||||
|  | using System.Linq; | ||||||
| using System.Threading.Channels; | using System.Threading.Channels; | ||||||
| using Emby.Server.Implementations.Playlists; | using Emby.Server.Implementations.Playlists; | ||||||
| using Jellyfin.Data.Enums; | using Jellyfin.Data.Enums; | ||||||
| @ -82,40 +84,43 @@ public class ItemTypeLookup : IItemTypeLookup | |||||||
|     ]; |     ]; | ||||||
| 
 | 
 | ||||||
|     /// <inheritdoc /> |     /// <inheritdoc /> | ||||||
|     public IDictionary<BaseItemKind, string?> BaseItemKindNames { get; } = new Dictionary<BaseItemKind, string?>() |     public IReadOnlyList<string> MusicGenreTypes => BaseItemKindNames.Where(e => e.Key is BaseItemKind.Audio or BaseItemKind.MusicVideo or BaseItemKind.MusicAlbum or BaseItemKind.MusicArtist).Select(e => e.Value).ToImmutableArray(); | ||||||
|  | 
 | ||||||
|  |     /// <inheritdoc /> | ||||||
|  |     public IDictionary<BaseItemKind, string> BaseItemKindNames { get; } = new Dictionary<BaseItemKind, string>() | ||||||
|     { |     { | ||||||
|         { BaseItemKind.AggregateFolder, typeof(AggregateFolder).FullName }, |         { BaseItemKind.AggregateFolder, typeof(AggregateFolder).FullName! }, | ||||||
|         { BaseItemKind.Audio, typeof(Audio).FullName }, |         { BaseItemKind.Audio, typeof(Audio).FullName! }, | ||||||
|         { BaseItemKind.AudioBook, typeof(AudioBook).FullName }, |         { BaseItemKind.AudioBook, typeof(AudioBook).FullName! }, | ||||||
|         { BaseItemKind.BasePluginFolder, typeof(BasePluginFolder).FullName }, |         { BaseItemKind.BasePluginFolder, typeof(BasePluginFolder).FullName! }, | ||||||
|         { BaseItemKind.Book, typeof(Book).FullName }, |         { BaseItemKind.Book, typeof(Book).FullName! }, | ||||||
|         { BaseItemKind.BoxSet, typeof(BoxSet).FullName }, |         { BaseItemKind.BoxSet, typeof(BoxSet).FullName! }, | ||||||
|         { BaseItemKind.Channel, typeof(Channel).FullName }, |         { BaseItemKind.Channel, typeof(Channel).FullName! }, | ||||||
|         { BaseItemKind.CollectionFolder, typeof(CollectionFolder).FullName }, |         { BaseItemKind.CollectionFolder, typeof(CollectionFolder).FullName! }, | ||||||
|         { BaseItemKind.Episode, typeof(Episode).FullName }, |         { BaseItemKind.Episode, typeof(Episode).FullName! }, | ||||||
|         { BaseItemKind.Folder, typeof(Folder).FullName }, |         { BaseItemKind.Folder, typeof(Folder).FullName! }, | ||||||
|         { BaseItemKind.Genre, typeof(Genre).FullName }, |         { BaseItemKind.Genre, typeof(Genre).FullName! }, | ||||||
|         { BaseItemKind.Movie, typeof(Movie).FullName }, |         { BaseItemKind.Movie, typeof(Movie).FullName! }, | ||||||
|         { BaseItemKind.LiveTvChannel, typeof(LiveTvChannel).FullName }, |         { BaseItemKind.LiveTvChannel, typeof(LiveTvChannel).FullName! }, | ||||||
|         { BaseItemKind.LiveTvProgram, typeof(LiveTvProgram).FullName }, |         { BaseItemKind.LiveTvProgram, typeof(LiveTvProgram).FullName! }, | ||||||
|         { BaseItemKind.MusicAlbum, typeof(MusicAlbum).FullName }, |         { BaseItemKind.MusicAlbum, typeof(MusicAlbum).FullName! }, | ||||||
|         { BaseItemKind.MusicArtist, typeof(MusicArtist).FullName }, |         { BaseItemKind.MusicArtist, typeof(MusicArtist).FullName! }, | ||||||
|         { BaseItemKind.MusicGenre, typeof(MusicGenre).FullName }, |         { BaseItemKind.MusicGenre, typeof(MusicGenre).FullName! }, | ||||||
|         { BaseItemKind.MusicVideo, typeof(MusicVideo).FullName }, |         { BaseItemKind.MusicVideo, typeof(MusicVideo).FullName! }, | ||||||
|         { BaseItemKind.Person, typeof(Person).FullName }, |         { BaseItemKind.Person, typeof(Person).FullName! }, | ||||||
|         { BaseItemKind.Photo, typeof(Photo).FullName }, |         { BaseItemKind.Photo, typeof(Photo).FullName! }, | ||||||
|         { BaseItemKind.PhotoAlbum, typeof(PhotoAlbum).FullName }, |         { BaseItemKind.PhotoAlbum, typeof(PhotoAlbum).FullName! }, | ||||||
|         { BaseItemKind.Playlist, typeof(Playlist).FullName }, |         { BaseItemKind.Playlist, typeof(Playlist).FullName! }, | ||||||
|         { BaseItemKind.PlaylistsFolder, typeof(PlaylistsFolder).FullName }, |         { BaseItemKind.PlaylistsFolder, typeof(PlaylistsFolder).FullName! }, | ||||||
|         { BaseItemKind.Season, typeof(Season).FullName }, |         { BaseItemKind.Season, typeof(Season).FullName! }, | ||||||
|         { BaseItemKind.Series, typeof(Series).FullName }, |         { BaseItemKind.Series, typeof(Series).FullName! }, | ||||||
|         { BaseItemKind.Studio, typeof(Studio).FullName }, |         { BaseItemKind.Studio, typeof(Studio).FullName! }, | ||||||
|         { BaseItemKind.Trailer, typeof(Trailer).FullName }, |         { BaseItemKind.Trailer, typeof(Trailer).FullName! }, | ||||||
|         { BaseItemKind.TvChannel, typeof(LiveTvChannel).FullName }, |         { BaseItemKind.TvChannel, typeof(LiveTvChannel).FullName! }, | ||||||
|         { BaseItemKind.TvProgram, typeof(LiveTvProgram).FullName }, |         { BaseItemKind.TvProgram, typeof(LiveTvProgram).FullName! }, | ||||||
|         { BaseItemKind.UserRootFolder, typeof(UserRootFolder).FullName }, |         { BaseItemKind.UserRootFolder, typeof(UserRootFolder).FullName! }, | ||||||
|         { BaseItemKind.UserView, typeof(UserView).FullName }, |         { BaseItemKind.UserView, typeof(UserView).FullName! }, | ||||||
|         { BaseItemKind.Video, typeof(Video).FullName }, |         { BaseItemKind.Video, typeof(Video).FullName! }, | ||||||
|         { BaseItemKind.Year, typeof(Year).FullName } |         { BaseItemKind.Year, typeof(Year).FullName! } | ||||||
|     }.ToFrozenDictionary(); |     }.ToFrozenDictionary(); | ||||||
| } | } | ||||||
|  | |||||||
| @ -23,6 +23,7 @@ using MediaBrowser.Controller.Entities.Audio; | |||||||
| using MediaBrowser.Controller.Entities.TV; | using MediaBrowser.Controller.Entities.TV; | ||||||
| using MediaBrowser.Controller.LiveTv; | using MediaBrowser.Controller.LiveTv; | ||||||
| using MediaBrowser.Controller.Persistence; | using MediaBrowser.Controller.Persistence; | ||||||
|  | using MediaBrowser.Controller.Providers; | ||||||
| using MediaBrowser.Model.Dto; | using MediaBrowser.Model.Dto; | ||||||
| using MediaBrowser.Model.Entities; | using MediaBrowser.Model.Entities; | ||||||
| using MediaBrowser.Model.LiveTv; | using MediaBrowser.Model.LiveTv; | ||||||
| @ -139,63 +140,57 @@ public sealed class BaseItemRepository( | |||||||
|     /// <inheritdoc /> |     /// <inheritdoc /> | ||||||
|     public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAllArtists(InternalItemsQuery filter) |     public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAllArtists(InternalItemsQuery filter) | ||||||
|     { |     { | ||||||
|         return GetItemValues(filter, [0, 1], typeof(MusicArtist).FullName!); |         return GetItemValues(filter, [ItemValueType.Artist, ItemValueType.AlbumArtist], itemTypeLookup.BaseItemKindNames[BaseItemKind.MusicArtist]!); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// <inheritdoc /> |     /// <inheritdoc /> | ||||||
|     public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetArtists(InternalItemsQuery filter) |     public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetArtists(InternalItemsQuery filter) | ||||||
|     { |     { | ||||||
|         return GetItemValues(filter, [0], typeof(MusicArtist).FullName!); |         return GetItemValues(filter, [ItemValueType.Artist], itemTypeLookup.BaseItemKindNames[BaseItemKind.MusicArtist]!); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// <inheritdoc /> |     /// <inheritdoc /> | ||||||
|     public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAlbumArtists(InternalItemsQuery filter) |     public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAlbumArtists(InternalItemsQuery filter) | ||||||
|     { |     { | ||||||
|         return GetItemValues(filter, [1], typeof(MusicArtist).FullName!); |         return GetItemValues(filter, [ItemValueType.AlbumArtist], itemTypeLookup.BaseItemKindNames[BaseItemKind.MusicArtist]!); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// <inheritdoc /> |     /// <inheritdoc /> | ||||||
|     public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetStudios(InternalItemsQuery filter) |     public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetStudios(InternalItemsQuery filter) | ||||||
|     { |     { | ||||||
|         return GetItemValues(filter, [3], typeof(Studio).FullName!); |         return GetItemValues(filter, [ItemValueType.Studios], itemTypeLookup.BaseItemKindNames[BaseItemKind.Studio]!); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// <inheritdoc /> |     /// <inheritdoc /> | ||||||
|     public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetGenres(InternalItemsQuery filter) |     public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetGenres(InternalItemsQuery filter) | ||||||
|     { |     { | ||||||
|         return GetItemValues(filter, [2], typeof(Genre).FullName!); |         return GetItemValues(filter, [ItemValueType.Genre], itemTypeLookup.BaseItemKindNames[BaseItemKind.Genre]!); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// <inheritdoc /> |     /// <inheritdoc /> | ||||||
|     public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetMusicGenres(InternalItemsQuery filter) |     public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetMusicGenres(InternalItemsQuery filter) | ||||||
|     { |     { | ||||||
|         return GetItemValues(filter, [2], typeof(MusicGenre).FullName!); |         return GetItemValues(filter, [ItemValueType.Genre], itemTypeLookup.BaseItemKindNames[BaseItemKind.MusicGenre]!); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// <inheritdoc /> |     /// <inheritdoc /> | ||||||
|     public IReadOnlyList<string> GetStudioNames() |     public IReadOnlyList<string> GetStudioNames() | ||||||
|     { |     { | ||||||
|         return GetItemValueNames([3], Array.Empty<string>(), Array.Empty<string>()); |         return GetItemValueNames([ItemValueType.Studios], Array.Empty<string>(), Array.Empty<string>()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// <inheritdoc /> |     /// <inheritdoc /> | ||||||
|     public IReadOnlyList<string> GetAllArtistNames() |     public IReadOnlyList<string> GetAllArtistNames() | ||||||
|     { |     { | ||||||
|         return GetItemValueNames([0, 1], Array.Empty<string>(), Array.Empty<string>()); |         return GetItemValueNames([ItemValueType.Artist, ItemValueType.AlbumArtist], Array.Empty<string>(), Array.Empty<string>()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// <inheritdoc /> |     /// <inheritdoc /> | ||||||
|     public IReadOnlyList<string> GetMusicGenreNames() |     public IReadOnlyList<string> GetMusicGenreNames() | ||||||
|     { |     { | ||||||
|         return GetItemValueNames( |         return GetItemValueNames( | ||||||
|             [2], |             [ItemValueType.Genre], | ||||||
|             new string[] |             itemTypeLookup.MusicGenreTypes, | ||||||
|             { |  | ||||||
|                     typeof(Audio).FullName!, |  | ||||||
|                     typeof(MusicVideo).FullName!, |  | ||||||
|                     typeof(MusicAlbum).FullName!, |  | ||||||
|                     typeof(MusicArtist).FullName! |  | ||||||
|             }, |  | ||||||
|             Array.Empty<string>()); |             Array.Empty<string>()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -203,15 +198,9 @@ public sealed class BaseItemRepository( | |||||||
|     public IReadOnlyList<string> GetGenreNames() |     public IReadOnlyList<string> GetGenreNames() | ||||||
|     { |     { | ||||||
|         return GetItemValueNames( |         return GetItemValueNames( | ||||||
|             [2], |             [ItemValueType.Genre], | ||||||
|             Array.Empty<string>(), |             Array.Empty<string>(), | ||||||
|             new string[] |             itemTypeLookup.MusicGenreTypes); | ||||||
|             { |  | ||||||
|                     typeof(Audio).FullName!, |  | ||||||
|                     typeof(MusicVideo).FullName!, |  | ||||||
|                     typeof(MusicAlbum).FullName!, |  | ||||||
|                     typeof(MusicArtist).FullName! |  | ||||||
|             }); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// <inheritdoc cref="IItemRepository"/> |     /// <inheritdoc cref="IItemRepository"/> | ||||||
| @ -1084,7 +1073,7 @@ public sealed class BaseItemRepository( | |||||||
|             if (includeTypes.Length == 1 && includeTypes.FirstOrDefault() is BaseItemKind.Episode) |             if (includeTypes.Length == 1 && includeTypes.FirstOrDefault() is BaseItemKind.Episode) | ||||||
|             { |             { | ||||||
|                 baseQuery = baseQuery |                 baseQuery = baseQuery | ||||||
|                     .Where(e => e.ItemValues!.Where(e => e.ItemValue.Type == ItemValueType.InheritedTags) |                     .Where(e => e.ItemValues!.Where(f => f.ItemValue.Type == ItemValueType.InheritedTags) | ||||||
|                         .Any(f => filter.IncludeInheritedTags.Contains(f.ItemValue.CleanValue)) |                         .Any(f => filter.IncludeInheritedTags.Contains(f.ItemValue.CleanValue)) | ||||||
|                         || |                         || | ||||||
|                         (e.ParentId.HasValue && context.ItemValuesMap.Where(w => w.ItemId == e.ParentId.Value)!.Where(w => w.ItemValue.Type == ItemValueType.InheritedTags) |                         (e.ParentId.HasValue && context.ItemValuesMap.Where(w => w.ItemId == e.ParentId.Value)!.Where(w => w.ItemValue.Type == ItemValueType.InheritedTags) | ||||||
| @ -1246,84 +1235,76 @@ public sealed class BaseItemRepository( | |||||||
|             tuples[i] = (item, ancestorIds, topParent, userdataKey, inheritedTags); |             tuples[i] = (item, ancestorIds, topParent, userdataKey, inheritedTags); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         try |         using var context = dbProvider.CreateDbContext(); | ||||||
|  |         using var transaction = context.Database.BeginTransaction(); | ||||||
|  |         foreach (var item in tuples) | ||||||
|         { |         { | ||||||
|             using var context = dbProvider.CreateDbContext(); |             var entity = Map(item.Item); | ||||||
|             using var transaction = context.Database.BeginTransaction(); |             if (!context.BaseItems.Any(e => e.Id == entity.Id)) | ||||||
|             foreach (var item in tuples) |  | ||||||
|             { |             { | ||||||
|                 var entity = Map(item.Item); |                 context.BaseItems.Add(entity); | ||||||
|                 if (!context.BaseItems.Any(e => e.Id == entity.Id)) |             } | ||||||
|                 { |             else | ||||||
|                     context.BaseItems.Add(entity); |             { | ||||||
|                 } |                 context.BaseItems.Attach(entity).State = EntityState.Modified; | ||||||
|                 else |             } | ||||||
|                 { |  | ||||||
|                     context.BaseItems.Attach(entity).State = EntityState.Modified; |  | ||||||
|                 } |  | ||||||
| 
 | 
 | ||||||
|                 context.AncestorIds.Where(e => e.ItemId == entity.Id).ExecuteDelete(); |             context.AncestorIds.Where(e => e.ItemId == entity.Id).ExecuteDelete(); | ||||||
|                 if (item.Item.SupportsAncestors && item.AncestorIds != null) |             if (item.Item.SupportsAncestors && item.AncestorIds != null) | ||||||
|  |             { | ||||||
|  |                 entity.AncestorIds = new List<AncestorId>(); | ||||||
|  |                 foreach (var ancestorId in item.AncestorIds) | ||||||
|                 { |                 { | ||||||
|                     entity.AncestorIds = new List<AncestorId>(); |                     entity.AncestorIds.Add(new AncestorId() | ||||||
|                     foreach (var ancestorId in item.AncestorIds) |  | ||||||
|                     { |                     { | ||||||
|                         entity.AncestorIds.Add(new AncestorId() |                         ParentItemId = ancestorId, | ||||||
|                         { |                         ItemId = entity.Id, | ||||||
|                             ParentItemId = ancestorId, |                         Item = null!, | ||||||
|                             ItemId = entity.Id, |                         ParentItem = null! | ||||||
|                             Item = null!, |                     }); | ||||||
|                             ParentItem = null! |  | ||||||
|                         }); |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 var itemValuesToSave = GetItemValuesToSave(item.Item, item.InheritedTags); |  | ||||||
|                 var itemValues = itemValuesToSave.Select(e => e.Value).ToArray(); |  | ||||||
|                 context.ItemValuesMap.Where(e => e.ItemId == entity.Id).ExecuteDelete(); |  | ||||||
|                 entity.ItemValues = new List<ItemValueMap>(); |  | ||||||
|                 var referenceValues = context.ItemValues.Where(e => itemValues.Any(f => f == e.CleanValue)).ToArray(); |  | ||||||
| 
 |  | ||||||
|                 foreach (var itemValue in itemValuesToSave) |  | ||||||
|                 { |  | ||||||
|                     var refValue = referenceValues.FirstOrDefault(f => f.CleanValue == itemValue.Value && (int)f.Type == itemValue.MagicNumber); |  | ||||||
|                     if (refValue is not null) |  | ||||||
|                     { |  | ||||||
|                         entity.ItemValues.Add(new ItemValueMap() |  | ||||||
|                         { |  | ||||||
|                             Item = entity, |  | ||||||
|                             ItemId = entity.Id, |  | ||||||
|                             ItemValue = null!, |  | ||||||
|                             ItemValueId = refValue.ItemValueId |  | ||||||
|                         }); |  | ||||||
|                     } |  | ||||||
|                     else |  | ||||||
|                     { |  | ||||||
|                         entity.ItemValues.Add(new ItemValueMap() |  | ||||||
|                         { |  | ||||||
|                             Item = entity, |  | ||||||
|                             ItemId = entity.Id, |  | ||||||
|                             ItemValue = new ItemValue() |  | ||||||
|                             { |  | ||||||
|                                 CleanValue = GetCleanValue(itemValue.Value), |  | ||||||
|                                 Type = (ItemValueType)itemValue.MagicNumber, |  | ||||||
|                                 ItemValueId = Guid.NewGuid(), |  | ||||||
|                                 Value = itemValue.Value |  | ||||||
|                             }, |  | ||||||
|                             ItemValueId = Guid.Empty |  | ||||||
|                         }); |  | ||||||
|                     } |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             context.SaveChanges(); |             var itemValuesToSave = GetItemValuesToSave(item.Item, item.InheritedTags); | ||||||
|             transaction.Commit(); |             var itemValues = itemValuesToSave.Select(e => e.Value).ToArray(); | ||||||
|         } |             context.ItemValuesMap.Where(e => e.ItemId == entity.Id).ExecuteDelete(); | ||||||
|         catch (System.Exception) |             entity.ItemValues = new List<ItemValueMap>(); | ||||||
|         { |             var referenceValues = context.ItemValues.Where(e => itemValues.Any(f => f == e.CleanValue)).ToArray(); | ||||||
|             System.Console.WriteLine(); | 
 | ||||||
|             throw; |             foreach (var itemValue in itemValuesToSave) | ||||||
|  |             { | ||||||
|  |                 var refValue = referenceValues.FirstOrDefault(f => f.CleanValue == itemValue.Value && (int)f.Type == itemValue.MagicNumber); | ||||||
|  |                 if (refValue is not null) | ||||||
|  |                 { | ||||||
|  |                     entity.ItemValues.Add(new ItemValueMap() | ||||||
|  |                     { | ||||||
|  |                         Item = entity, | ||||||
|  |                         ItemId = entity.Id, | ||||||
|  |                         ItemValue = null!, | ||||||
|  |                         ItemValueId = refValue.ItemValueId | ||||||
|  |                     }); | ||||||
|  |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     entity.ItemValues.Add(new ItemValueMap() | ||||||
|  |                     { | ||||||
|  |                         Item = entity, | ||||||
|  |                         ItemId = entity.Id, | ||||||
|  |                         ItemValue = new ItemValue() | ||||||
|  |                         { | ||||||
|  |                             CleanValue = GetCleanValue(itemValue.Value), | ||||||
|  |                             Type = (ItemValueType)itemValue.MagicNumber, | ||||||
|  |                             ItemValueId = Guid.NewGuid(), | ||||||
|  |                             Value = itemValue.Value | ||||||
|  |                         }, | ||||||
|  |                         ItemValueId = Guid.Empty | ||||||
|  |                     }); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |         context.SaveChanges(); | ||||||
|  |         transaction.Commit(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// <inheritdoc cref="IItemRepository" /> |     /// <inheritdoc cref="IItemRepository" /> | ||||||
| @ -1665,7 +1646,7 @@ public sealed class BaseItemRepository( | |||||||
|         return entity; |         return entity; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private IReadOnlyList<string> GetItemValueNames(int[] itemValueTypes, IReadOnlyList<string> withItemTypes, IReadOnlyList<string> excludeItemTypes) |     private IReadOnlyList<string> GetItemValueNames(ItemValueType[] itemValueTypes, IReadOnlyList<string> withItemTypes, IReadOnlyList<string> excludeItemTypes) | ||||||
|     { |     { | ||||||
|         using var context = dbProvider.CreateDbContext(); |         using var context = dbProvider.CreateDbContext(); | ||||||
| 
 | 
 | ||||||
| @ -1725,7 +1706,7 @@ public sealed class BaseItemRepository( | |||||||
|         return Map(baseItemEntity, dto); |         return Map(baseItemEntity, dto); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private QueryResult<(BaseItemDto Item, ItemCounts ItemCounts)> GetItemValues(InternalItemsQuery filter, int[] itemValueTypes, string returnType) |     private QueryResult<(BaseItemDto Item, ItemCounts ItemCounts)> GetItemValues(InternalItemsQuery filter, ItemValueType[] itemValueTypes, string returnType) | ||||||
|     { |     { | ||||||
|         ArgumentNullException.ThrowIfNull(filter); |         ArgumentNullException.ThrowIfNull(filter); | ||||||
| 
 | 
 | ||||||
| @ -1787,19 +1768,27 @@ public sealed class BaseItemRepository( | |||||||
|             result.TotalRecordCount = query.DistinctBy(e => e.PresentationUniqueKey).Count(); |             result.TotalRecordCount = query.DistinctBy(e => e.PresentationUniqueKey).Count(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         var seriesTypeName = itemTypeLookup.BaseItemKindNames[BaseItemKind.Series]; | ||||||
|  |         var movieTypeName = itemTypeLookup.BaseItemKindNames[BaseItemKind.Movie]; | ||||||
|  |         var episodeTypeName = itemTypeLookup.BaseItemKindNames[BaseItemKind.Episode]; | ||||||
|  |         var musicAlbumTypeName = itemTypeLookup.BaseItemKindNames[BaseItemKind.MusicAlbum]; | ||||||
|  |         var musicArtistTypeName = itemTypeLookup.BaseItemKindNames[BaseItemKind.MusicArtist]; | ||||||
|  |         var audioTypeName = itemTypeLookup.BaseItemKindNames[BaseItemKind.Audio]; | ||||||
|  |         var trailerTypeName = itemTypeLookup.BaseItemKindNames[BaseItemKind.Trailer]; | ||||||
|  | 
 | ||||||
|         var resultQuery = query.Select(e => new |         var resultQuery = query.Select(e => new | ||||||
|         { |         { | ||||||
|             item = e, |             item = e, | ||||||
|             // TODO: This is bad refactor! |             // TODO: This is bad refactor! | ||||||
|             itemCount = new ItemCounts() |             itemCount = new ItemCounts() | ||||||
|             { |             { | ||||||
|                 SeriesCount = e.ItemValues!.Count(f => f.Item.Type == typeof(Series).FullName), |                 SeriesCount = e.ItemValues!.Count(f => f.Item.Type == seriesTypeName), | ||||||
|                 EpisodeCount = e.ItemValues!.Count(f => f.Item.Type == typeof(Data.Entities.Libraries.Movie).FullName), |                 EpisodeCount = e.ItemValues!.Count(f => f.Item.Type == episodeTypeName), | ||||||
|                 MovieCount = e.ItemValues!.Count(f => f.Item.Type == typeof(Series).FullName), |                 MovieCount = e.ItemValues!.Count(f => f.Item.Type == movieTypeName), | ||||||
|                 AlbumCount = e.ItemValues!.Count(f => f.Item.Type == typeof(MusicAlbum).FullName), |                 AlbumCount = e.ItemValues!.Count(f => f.Item.Type == musicAlbumTypeName), | ||||||
|                 ArtistCount = e.ItemValues!.Count(f => f.Item.Type == typeof(MusicArtist).FullName), |                 ArtistCount = e.ItemValues!.Count(f => f.Item.Type == musicArtistTypeName), | ||||||
|                 SongCount = e.ItemValues!.Count(f => f.Item.Type == typeof(Audio).FullName), |                 SongCount = e.ItemValues!.Count(f => f.Item.Type == audioTypeName), | ||||||
|                 TrailerCount = e.ItemValues!.Count(f => f.Item.Type == typeof(Trailer).FullName), |                 TrailerCount = e.ItemValues!.Count(f => f.Item.Type == trailerTypeName), | ||||||
|             } |             } | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
| @ -1958,27 +1947,27 @@ public sealed class BaseItemRepository( | |||||||
| 
 | 
 | ||||||
|         if (IsTypeInQuery(BaseItemKind.Person, query)) |         if (IsTypeInQuery(BaseItemKind.Person, query)) | ||||||
|         { |         { | ||||||
|             list.Add(typeof(Person).FullName!); |             list.Add(itemTypeLookup.BaseItemKindNames[BaseItemKind.Person]!); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (IsTypeInQuery(BaseItemKind.Genre, query)) |         if (IsTypeInQuery(BaseItemKind.Genre, query)) | ||||||
|         { |         { | ||||||
|             list.Add(typeof(Genre).FullName!); |             list.Add(itemTypeLookup.BaseItemKindNames[BaseItemKind.Genre]!); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (IsTypeInQuery(BaseItemKind.MusicGenre, query)) |         if (IsTypeInQuery(BaseItemKind.MusicGenre, query)) | ||||||
|         { |         { | ||||||
|             list.Add(typeof(MusicGenre).FullName!); |             list.Add(itemTypeLookup.BaseItemKindNames[BaseItemKind.MusicGenre]!); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (IsTypeInQuery(BaseItemKind.MusicArtist, query)) |         if (IsTypeInQuery(BaseItemKind.MusicArtist, query)) | ||||||
|         { |         { | ||||||
|             list.Add(typeof(MusicArtist).FullName!); |             list.Add(itemTypeLookup.BaseItemKindNames[BaseItemKind.MusicArtist]!); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (IsTypeInQuery(BaseItemKind.Studio, query)) |         if (IsTypeInQuery(BaseItemKind.Studio, query)) | ||||||
|         { |         { | ||||||
|             list.Add(typeof(Studio).FullName!); |             list.Add(itemTypeLookup.BaseItemKindNames[BaseItemKind.Studio]!); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return list; |         return list; | ||||||
|  | |||||||
| @ -50,8 +50,13 @@ public interface IItemTypeLookup | |||||||
|     /// </summary> |     /// </summary> | ||||||
|     public IReadOnlyList<BaseItemKind> ArtistsTypes { get; } |     public IReadOnlyList<BaseItemKind> ArtistsTypes { get; } | ||||||
| 
 | 
 | ||||||
|  |     /// <summary> | ||||||
|  |     /// Gets all serialisation target types for music related kinds. | ||||||
|  |     /// </summary> | ||||||
|  |     IReadOnlyList<string> MusicGenreTypes { get; } | ||||||
|  | 
 | ||||||
|     /// <summary> |     /// <summary> | ||||||
|     /// Gets mapping for all BaseItemKinds and their expected serialization target. |     /// Gets mapping for all BaseItemKinds and their expected serialization target. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public IDictionary<BaseItemKind, string?> BaseItemKindNames { get; } |     public IDictionary<BaseItemKind, string> BaseItemKindNames { get; } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user