using MediaBrowser.Controller.Dto; using MediaBrowser.Controller.Entities; using MediaBrowser.Controller.Entities.Audio; using MediaBrowser.Controller.Entities.Movies; using MediaBrowser.Controller.Entities.TV; using MediaBrowser.Controller.Library; using MediaBrowser.Controller.Persistence; using MediaBrowser.Model.Dto; using MediaBrowser.Model.Querying; using ServiceStack.ServiceHost; using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; namespace MediaBrowser.Api.UserLibrary { /// /// Class GetGenres /// [Route("/Genres", "GET")] [Api(Description = "Gets all genres from a given item, folder, or the entire library")] public class GetGenres : GetItemsByName { } [Route("/Genres/{Name}/Counts", "GET")] [Api(Description = "Gets item counts of library items that a genre appears in")] public class GetGenreItemCounts : IReturn { /// /// Gets or sets the user id. /// /// The user id. [ApiMember(Name = "UserId", Description = "User Id", IsRequired = false, DataType = "string", ParameterType = "query", Verb = "GET")] public Guid? UserId { get; set; } /// /// Gets or sets the name. /// /// The name. [ApiMember(Name = "Name", Description = "The genre name", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")] public string Name { get; set; } } /// /// Class GetGenre /// [Route("/Genres/{Name}", "GET")] [Api(Description = "Gets a genre, by name")] public class GetGenre : IReturn { /// /// Gets or sets the name. /// /// The name. [ApiMember(Name = "Name", Description = "The genre name", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")] public string Name { get; set; } /// /// Gets or sets the user id. /// /// The user id. [ApiMember(Name = "UserId", Description = "Optional. Filter by user id, and attach user data", IsRequired = false, DataType = "string", ParameterType = "query", Verb = "GET")] public Guid? UserId { get; set; } } /// /// Class GenresService /// public class GenresService : BaseItemsByNameService { public GenresService(IUserManager userManager, ILibraryManager libraryManager, IUserDataRepository userDataRepository) : base(userManager, libraryManager, userDataRepository) { } /// /// Gets the specified request. /// /// The request. /// System.Object. public object Get(GetGenre request) { var result = GetItem(request).Result; return ToOptimizedResult(result); } /// /// Gets the item. /// /// The request. /// Task{BaseItemDto}. private async Task GetItem(GetGenre request) { var item = await GetGenre(request.Name, LibraryManager).ConfigureAwait(false); // Get everything var fields = Enum.GetNames(typeof(ItemFields)).Select(i => (ItemFields)Enum.Parse(typeof(ItemFields), i, true)); var builder = new DtoBuilder(Logger, LibraryManager, UserDataRepository); if (request.UserId.HasValue) { var user = UserManager.GetUserById(request.UserId.Value); return await builder.GetBaseItemDto(item, fields.ToList(), user).ConfigureAwait(false); } return await builder.GetBaseItemDto(item, fields.ToList()).ConfigureAwait(false); } /// /// Gets the specified request. /// /// The request. /// System.Object. public object Get(GetGenres request) { var result = GetResult(request).Result; return ToOptimizedResult(result); } /// /// Gets all items. /// /// The request. /// The items. /// IEnumerable{Tuple{System.StringFunc{System.Int32}}}. protected override IEnumerable> GetAllItems(GetItemsByName request, IEnumerable items) { var itemsList = items.Where(i => i.Genres != null).ToList(); return itemsList .SelectMany(i => i.Genres) .Distinct(StringComparer.OrdinalIgnoreCase) .Select(name => new IbnStub(name, () => itemsList.Where(i => i.Genres.Contains(name, StringComparer.OrdinalIgnoreCase)), GetEntity)); } /// /// Gets the entity. /// /// The name. /// Task{Genre}. protected Task GetEntity(string name) { return LibraryManager.GetGenre(name); } /// /// Gets the specified request. /// /// The request. /// System.Object. public object Get(GetGenreItemCounts request) { var name = DeSlugGenreName(request.Name, LibraryManager); var items = GetItems(request.UserId).Where(i => i.Genres != null && i.Genres.Contains(name, StringComparer.OrdinalIgnoreCase)).ToList(); var counts = new ItemByNameCounts { TotalCount = items.Count, TrailerCount = items.OfType().Count(), MovieCount = items.OfType().Count(), SeriesCount = items.OfType().Count(), GameCount = items.OfType().Count(), SongCount = items.OfType