using MediaBrowser.Controller.Dto; using MediaBrowser.Controller.Entities; using MediaBrowser.Controller.Entities.Audio; 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 { [Route("/MusicGenres", "GET")] [Api(Description = "Gets all music genres from a given item, folder, or the entire library")] public class GetMusicGenres : GetItemsByName { public GetMusicGenres() { IncludeItemTypes = typeof (Audio).Name; } } [Route("/MusicGenres/{Name}/Counts", "GET")] [Api(Description = "Gets item counts of library items that a genre appears in")] public class GetMusicGenreItemCounts : 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; } } [Route("/MusicGenres/{Name}", "GET")] [Api(Description = "Gets a music genre, by name")] public class GetMusicGenre : 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; } } public class MusicGenresService : BaseItemsByNameService { public MusicGenresService(IUserManager userManager, ILibraryManager libraryManager, IUserDataRepository userDataRepository, IItemRepository itemRepo) : base(userManager, libraryManager, userDataRepository, itemRepo) { } /// /// Gets the specified request. /// /// The request. /// System.Object. public object Get(GetMusicGenre request) { var result = GetItem(request).Result; return ToOptimizedResult(result); } /// /// Gets the item. /// /// The request. /// Task{BaseItemDto}. private async Task GetItem(GetMusicGenre request) { var item = await GetMusicGenre(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, ItemRepository); 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(GetMusicGenres 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.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.GetMusicGenre(name); } /// /// Gets the specified request. /// /// The request. /// System.Object. public object Get(GetMusicGenreItemCounts 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, SongCount = items.OfType