using MediaBrowser.Controller.Dto; using MediaBrowser.Controller.Entities; using MediaBrowser.Controller.Library; using MediaBrowser.Controller.Net; using MediaBrowser.Controller.Persistence; using MediaBrowser.Model.Dto; using ServiceStack; using System.Collections.Generic; using System.Linq; namespace MediaBrowser.Api.UserLibrary { /// /// Class GetPersons /// [Route("/Persons", "GET", Summary = "Gets all persons from a given item, folder, or the entire library")] public class GetPersons : GetItemsByName { /// /// Gets or sets the person types. /// /// The person types. [ApiMember(Name = "PersonTypes", Description = "Optional filter by person type. Accepts multiple, comma-delimited.", IsRequired = false, DataType = "string", ParameterType = "query", Verb = "GET", AllowMultiple = true)] public string PersonTypes { get; set; } } /// /// Class GetPerson /// [Route("/Persons/{Name}", "GET", Summary = "Gets a person, by name")] public class GetPerson : IReturn { /// /// Gets or sets the name. /// /// The name. [ApiMember(Name = "Name", Description = "The person 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 string UserId { get; set; } } /// /// Class PersonsService /// [Authenticated] public class PersonsService : BaseItemsByNameService { /// /// Initializes a new instance of the class. /// /// The user manager. /// The library manager. /// The user data repository. /// The item repo. public PersonsService(IUserManager userManager, ILibraryManager libraryManager, IUserDataManager userDataRepository, IItemRepository itemRepo, IDtoService dtoService) : base(userManager, libraryManager, userDataRepository, itemRepo, dtoService) { } /// /// Gets the specified request. /// /// The request. /// System.Object. public object Get(GetPerson request) { var result = GetItem(request); return ToOptimizedSerializedResultUsingCache(result); } /// /// Gets the item. /// /// The request. /// Task{BaseItemDto}. private BaseItemDto GetItem(GetPerson request) { var item = GetPerson(request.Name, LibraryManager); var dtoOptions = GetDtoOptions(request); if (!string.IsNullOrWhiteSpace(request.UserId)) { var user = UserManager.GetUserById(request.UserId); return DtoService.GetBaseItemDto(item, dtoOptions, user); } return DtoService.GetBaseItemDto(item, dtoOptions); } /// /// Gets the specified request. /// /// The request. /// System.Object. public object Get(GetPersons request) { var result = GetResult(request); return ToOptimizedSerializedResultUsingCache(result); } /// /// Gets all items. /// /// The request. /// The items. /// IEnumerable{Tuple{System.StringFunc{System.Int32}}}. protected override IEnumerable GetAllItems(GetItemsByName request, IEnumerable items) { var inputPersonTypes = ((GetPersons)request).PersonTypes; var personTypes = string.IsNullOrEmpty(inputPersonTypes) ? new string[] { } : inputPersonTypes.Split(','); var itemsList = items.ToList(); // Either get all people, or all people filtered by a specific person type var allPeople = GetAllPeople(itemsList, personTypes); return allPeople .Select(i => i.Name) .DistinctNames() .Select(name => { try { return LibraryManager.GetPerson(name); } catch { return null; // Already logged at lower levels } } ).Where(i => i != null); } /// /// Gets all people. /// /// The items list. /// The person types. /// IEnumerable{PersonInfo}. private IEnumerable GetAllPeople(IEnumerable itemsList, IEnumerable personTypes) { var allIds = itemsList.Select(i => i.Id).ToList(); var allPeople = LibraryManager.GetPeople(new InternalPeopleQuery { PersonTypes = personTypes.ToList() }); return allPeople.Where(i => allIds.Contains(i.ItemId)).OrderBy(p => p.SortOrder ?? int.MaxValue).ThenBy(p => p.Type); } } }