LibraryService.cs 7.4 KB

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