PersonsService.cs 5.6 KB

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