PersonsService.cs 6.1 KB

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