LibraryService.cs 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. using MediaBrowser.Common;
  2. using MediaBrowser.Controller.Entities;
  3. using MediaBrowser.Controller.Library;
  4. using MediaBrowser.Model.Dto;
  5. using MediaBrowser.Server.Implementations.HttpServer;
  6. using ServiceStack.ServiceHost;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Linq;
  10. namespace MediaBrowser.Api.Library
  11. {
  12. /// <summary>
  13. /// Class GetPhyscialPaths
  14. /// </summary>
  15. [Route("/Library/PhysicalPaths", "GET")]
  16. public class GetPhyscialPaths : IReturn<List<string>>
  17. {
  18. }
  19. /// <summary>
  20. /// Class GetItemTypes
  21. /// </summary>
  22. [Route("/Library/ItemTypes", "GET")]
  23. public class GetItemTypes : IReturn<List<string>>
  24. {
  25. /// <summary>
  26. /// Gets or sets a value indicating whether this instance has internet provider.
  27. /// </summary>
  28. /// <value><c>true</c> if this instance has internet provider; otherwise, <c>false</c>.</value>
  29. public bool HasInternetProvider { get; set; }
  30. }
  31. /// <summary>
  32. /// Class GetPerson
  33. /// </summary>
  34. [Route("/Library/Persons/{Name}", "GET")]
  35. public class GetPerson : IReturn<BaseItemDto>
  36. {
  37. /// <summary>
  38. /// Gets or sets the name.
  39. /// </summary>
  40. /// <value>The name.</value>
  41. public string Name { get; set; }
  42. }
  43. /// <summary>
  44. /// Class GetStudio
  45. /// </summary>
  46. [Route("/Library/Studios/{Name}", "GET")]
  47. public class GetStudio : IReturn<BaseItemDto>
  48. {
  49. /// <summary>
  50. /// Gets or sets the name.
  51. /// </summary>
  52. /// <value>The name.</value>
  53. public string Name { get; set; }
  54. }
  55. /// <summary>
  56. /// Class GetGenre
  57. /// </summary>
  58. [Route("/Library/Genres/{Name}", "GET")]
  59. public class GetGenre : IReturn<BaseItemDto>
  60. {
  61. /// <summary>
  62. /// Gets or sets the name.
  63. /// </summary>
  64. /// <value>The name.</value>
  65. public string Name { get; set; }
  66. }
  67. /// <summary>
  68. /// Class GetYear
  69. /// </summary>
  70. [Route("/Library/Years/{Year}", "GET")]
  71. public class GetYear : IReturn<BaseItemDto>
  72. {
  73. /// <summary>
  74. /// Gets or sets the year.
  75. /// </summary>
  76. /// <value>The year.</value>
  77. public int Year { get; set; }
  78. }
  79. /// <summary>
  80. /// Class LibraryService
  81. /// </summary>
  82. public class LibraryService : BaseRestService
  83. {
  84. /// <summary>
  85. /// The _app host
  86. /// </summary>
  87. private readonly IApplicationHost _appHost;
  88. private readonly ILibraryManager _libraryManager;
  89. /// <summary>
  90. /// Initializes a new instance of the <see cref="LibraryService" /> class.
  91. /// </summary>
  92. /// <param name="appHost">The app host.</param>
  93. /// <exception cref="System.ArgumentNullException">appHost</exception>
  94. public LibraryService(IApplicationHost appHost, ILibraryManager libraryManager)
  95. {
  96. if (appHost == null)
  97. {
  98. throw new ArgumentNullException("appHost");
  99. }
  100. _appHost = appHost;
  101. _libraryManager = libraryManager;
  102. }
  103. /// <summary>
  104. /// Gets the specified request.
  105. /// </summary>
  106. /// <param name="request">The request.</param>
  107. /// <returns>System.Object.</returns>
  108. public object Get(GetPerson request)
  109. {
  110. var item = _libraryManager.GetPerson(request.Name).Result;
  111. // Get everything
  112. var fields = Enum.GetNames(typeof(ItemFields)).Select(i => (ItemFields)Enum.Parse(typeof(ItemFields), i, true));
  113. var result = new DtoBuilder(Logger).GetDtoBaseItem(item, fields.ToList(), _libraryManager).Result;
  114. return ToOptimizedResult(result);
  115. }
  116. /// <summary>
  117. /// Gets the specified request.
  118. /// </summary>
  119. /// <param name="request">The request.</param>
  120. /// <returns>System.Object.</returns>
  121. public object Get(GetGenre request)
  122. {
  123. var item = _libraryManager.GetGenre(request.Name).Result;
  124. // Get everything
  125. var fields = Enum.GetNames(typeof(ItemFields)).Select(i => (ItemFields)Enum.Parse(typeof(ItemFields), i, true));
  126. var result = new DtoBuilder(Logger).GetDtoBaseItem(item, fields.ToList(), _libraryManager).Result;
  127. return ToOptimizedResult(result);
  128. }
  129. /// <summary>
  130. /// Gets the specified request.
  131. /// </summary>
  132. /// <param name="request">The request.</param>
  133. /// <returns>System.Object.</returns>
  134. public object Get(GetStudio request)
  135. {
  136. var item = _libraryManager.GetStudio(request.Name).Result;
  137. // Get everything
  138. var fields = Enum.GetNames(typeof(ItemFields)).Select(i => (ItemFields)Enum.Parse(typeof(ItemFields), i, true));
  139. var result = new DtoBuilder(Logger).GetDtoBaseItem(item, fields.ToList(), _libraryManager).Result;
  140. return ToOptimizedResult(result);
  141. }
  142. /// <summary>
  143. /// Gets the specified request.
  144. /// </summary>
  145. /// <param name="request">The request.</param>
  146. /// <returns>System.Object.</returns>
  147. public object Get(GetYear request)
  148. {
  149. var item = _libraryManager.GetYear(request.Year).Result;
  150. // Get everything
  151. var fields = Enum.GetNames(typeof(ItemFields)).Select(i => (ItemFields)Enum.Parse(typeof(ItemFields), i, true));
  152. var result = new DtoBuilder(Logger).GetDtoBaseItem(item, fields.ToList(), _libraryManager).Result;
  153. return ToOptimizedResult(result);
  154. }
  155. /// <summary>
  156. /// Gets the specified request.
  157. /// </summary>
  158. /// <param name="request">The request.</param>
  159. /// <returns>System.Object.</returns>
  160. public object Get(GetPhyscialPaths request)
  161. {
  162. var result = _libraryManager.RootFolder.Children.SelectMany(c => c.ResolveArgs.PhysicalLocations).ToList();
  163. return ToOptimizedResult(result);
  164. }
  165. /// <summary>
  166. /// Gets the specified request.
  167. /// </summary>
  168. /// <param name="request">The request.</param>
  169. /// <returns>System.Object.</returns>
  170. public object Get(GetItemTypes request)
  171. {
  172. var allTypes = _appHost.AllConcreteTypes.Where(t => t.IsSubclassOf(typeof(BaseItem)));
  173. if (request.HasInternetProvider)
  174. {
  175. allTypes = allTypes.Where(t =>
  176. {
  177. if (t == typeof(UserRootFolder) || t == typeof(AggregateFolder) || t == typeof(Folder) || t == typeof(IndexFolder) || t == typeof(CollectionFolder) || t == typeof(Year))
  178. {
  179. return false;
  180. }
  181. if (t == typeof(User))
  182. {
  183. return false;
  184. }
  185. // For now it seems internet providers generally only deal with video subclasses
  186. if (t == typeof(Video))
  187. {
  188. return false;
  189. }
  190. if (t.IsSubclassOf(typeof(BasePluginFolder)))
  191. {
  192. return false;
  193. }
  194. return true;
  195. });
  196. }
  197. return allTypes.Select(t => t.Name).OrderBy(s => s).ToList();
  198. }
  199. }
  200. }