PersonsService.cs 6.3 KB

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