PersonsService.cs 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. using MediaBrowser.Controller.Dto;
  2. using MediaBrowser.Controller.Entities;
  3. using MediaBrowser.Controller.Library;
  4. using MediaBrowser.Controller.Net;
  5. using MediaBrowser.Controller.Persistence;
  6. using MediaBrowser.Model.Dto;
  7. using ServiceStack;
  8. using System.Collections.Generic;
  9. using System.Linq;
  10. namespace MediaBrowser.Api.UserLibrary
  11. {
  12. /// <summary>
  13. /// Class GetPersons
  14. /// </summary>
  15. [Route("/Persons", "GET", Summary = "Gets all persons from a given item, folder, or the entire library")]
  16. public class GetPersons : GetItemsByName
  17. {
  18. /// <summary>
  19. /// Gets or sets the person types.
  20. /// </summary>
  21. /// <value>The person types.</value>
  22. [ApiMember(Name = "PersonTypes", Description = "Optional filter by person type. Accepts multiple, comma-delimited.", IsRequired = false, DataType = "string", ParameterType = "query", Verb = "GET", AllowMultiple = true)]
  23. public string PersonTypes { get; set; }
  24. }
  25. /// <summary>
  26. /// Class GetPerson
  27. /// </summary>
  28. [Route("/Persons/{Name}", "GET", Summary = "Gets a person, by name")]
  29. public class GetPerson : IReturn<BaseItemDto>
  30. {
  31. /// <summary>
  32. /// Gets or sets the name.
  33. /// </summary>
  34. /// <value>The name.</value>
  35. [ApiMember(Name = "Name", Description = "The person name", IsRequired = true, DataType = "string", ParameterType = "path", Verb = "GET")]
  36. public string Name { get; set; }
  37. /// <summary>
  38. /// Gets or sets the user id.
  39. /// </summary>
  40. /// <value>The user id.</value>
  41. [ApiMember(Name = "UserId", Description = "Optional. Filter by user id, and attach user data", IsRequired = false, DataType = "string", ParameterType = "query", Verb = "GET")]
  42. public string UserId { get; set; }
  43. }
  44. /// <summary>
  45. /// Class PersonsService
  46. /// </summary>
  47. [Authenticated]
  48. public class PersonsService : BaseItemsByNameService<Person>
  49. {
  50. /// <summary>
  51. /// Initializes a new instance of the <see cref="PersonsService" /> class.
  52. /// </summary>
  53. /// <param name="userManager">The user manager.</param>
  54. /// <param name="libraryManager">The library manager.</param>
  55. /// <param name="userDataRepository">The user data repository.</param>
  56. /// <param name="itemRepo">The item repo.</param>
  57. public PersonsService(IUserManager userManager, ILibraryManager libraryManager, IUserDataManager userDataRepository, IItemRepository itemRepo, IDtoService dtoService)
  58. : base(userManager, libraryManager, userDataRepository, itemRepo, dtoService)
  59. {
  60. }
  61. /// <summary>
  62. /// Gets the specified request.
  63. /// </summary>
  64. /// <param name="request">The request.</param>
  65. /// <returns>System.Object.</returns>
  66. public object Get(GetPerson request)
  67. {
  68. var result = GetItem(request);
  69. return ToOptimizedSerializedResultUsingCache(result);
  70. }
  71. /// <summary>
  72. /// Gets the item.
  73. /// </summary>
  74. /// <param name="request">The request.</param>
  75. /// <returns>Task{BaseItemDto}.</returns>
  76. private BaseItemDto GetItem(GetPerson request)
  77. {
  78. var item = GetPerson(request.Name, LibraryManager);
  79. var dtoOptions = GetDtoOptions(request);
  80. if (!string.IsNullOrWhiteSpace(request.UserId))
  81. {
  82. var user = UserManager.GetUserById(request.UserId);
  83. return DtoService.GetBaseItemDto(item, dtoOptions, user);
  84. }
  85. return DtoService.GetBaseItemDto(item, dtoOptions);
  86. }
  87. /// <summary>
  88. /// Gets the specified request.
  89. /// </summary>
  90. /// <param name="request">The request.</param>
  91. /// <returns>System.Object.</returns>
  92. public object Get(GetPersons request)
  93. {
  94. var result = GetResult(request);
  95. return ToOptimizedSerializedResultUsingCache(result);
  96. }
  97. /// <summary>
  98. /// Gets all items.
  99. /// </summary>
  100. /// <param name="request">The request.</param>
  101. /// <param name="items">The items.</param>
  102. /// <returns>IEnumerable{Tuple{System.StringFunc{System.Int32}}}.</returns>
  103. protected override IEnumerable<Person> GetAllItems(GetItemsByName request, IEnumerable<BaseItem> items)
  104. {
  105. var inputPersonTypes = ((GetPersons)request).PersonTypes;
  106. var personTypes = string.IsNullOrEmpty(inputPersonTypes) ? new string[] { } : inputPersonTypes.Split(',');
  107. var itemsList = items.ToList();
  108. // Either get all people, or all people filtered by a specific person type
  109. var allPeople = GetAllPeople(itemsList, personTypes);
  110. return allPeople
  111. .Select(i => i.Name)
  112. .DistinctNames()
  113. .Select(name =>
  114. {
  115. try
  116. {
  117. return LibraryManager.GetPerson(name);
  118. }
  119. catch
  120. {
  121. return null;
  122. // Already logged at lower levels
  123. }
  124. }
  125. ).Where(i => i != null);
  126. }
  127. /// <summary>
  128. /// Gets all people.
  129. /// </summary>
  130. /// <param name="itemsList">The items list.</param>
  131. /// <param name="personTypes">The person types.</param>
  132. /// <returns>IEnumerable{PersonInfo}.</returns>
  133. private IEnumerable<PersonInfo> GetAllPeople(IEnumerable<BaseItem> itemsList, IEnumerable<string> personTypes)
  134. {
  135. var allIds = itemsList.Select(i => i.Id).ToList();
  136. var allPeople = LibraryManager.GetPeople(new InternalPeopleQuery
  137. {
  138. PersonTypes = personTypes.ToList()
  139. });
  140. return allPeople.Where(i => allIds.Contains(i.ItemId)).OrderBy(p => p.SortOrder ?? int.MaxValue).ThenBy(p => p.Type);
  141. }
  142. }
  143. }