GamesService.cs 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  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.Globalization;
  11. using System.IO;
  12. using System.Linq;
  13. namespace MediaBrowser.Api
  14. {
  15. /// <summary>
  16. /// Class GetSimilarGames
  17. /// </summary>
  18. [Route("/Games/{Id}/Similar", "GET", Summary = "Finds games similar to a given game.")]
  19. public class GetSimilarGames : BaseGetSimilarItemsFromItem
  20. {
  21. }
  22. /// <summary>
  23. /// Class GetGameSystemSummaries
  24. /// </summary>
  25. [Route("/Games/SystemSummaries", "GET", Summary = "Finds games similar to a given game.")]
  26. public class GetGameSystemSummaries : IReturn<List<GameSystemSummary>>
  27. {
  28. /// <summary>
  29. /// Gets or sets the user id.
  30. /// </summary>
  31. /// <value>The user id.</value>
  32. [ApiMember(Name = "UserId", Description = "Optional. Filter by user id", IsRequired = false, DataType = "string", ParameterType = "query", Verb = "GET")]
  33. public string UserId { get; set; }
  34. }
  35. /// <summary>
  36. /// Class GetGameSystemSummaries
  37. /// </summary>
  38. [Route("/Games/PlayerIndex", "GET", Summary = "Gets an index of players (1-x) and the number of games listed under each")]
  39. public class GetPlayerIndex : IReturn<List<ItemIndex>>
  40. {
  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", IsRequired = false, DataType = "string", ParameterType = "query", Verb = "GET")]
  46. public string UserId { get; set; }
  47. }
  48. /// <summary>
  49. /// Class GamesService
  50. /// </summary>
  51. [Authenticated]
  52. public class GamesService : BaseApiService
  53. {
  54. /// <summary>
  55. /// The _user manager
  56. /// </summary>
  57. private readonly IUserManager _userManager;
  58. /// <summary>
  59. /// The _user data repository
  60. /// </summary>
  61. private readonly IUserDataManager _userDataRepository;
  62. /// <summary>
  63. /// The _library manager
  64. /// </summary>
  65. private readonly ILibraryManager _libraryManager;
  66. /// <summary>
  67. /// The _item repo
  68. /// </summary>
  69. private readonly IItemRepository _itemRepo;
  70. /// <summary>
  71. /// The _dto service
  72. /// </summary>
  73. private readonly IDtoService _dtoService;
  74. /// <summary>
  75. /// Initializes a new instance of the <see cref="GamesService" /> class.
  76. /// </summary>
  77. /// <param name="userManager">The user manager.</param>
  78. /// <param name="userDataRepository">The user data repository.</param>
  79. /// <param name="libraryManager">The library manager.</param>
  80. /// <param name="itemRepo">The item repo.</param>
  81. /// <param name="dtoService">The dto service.</param>
  82. public GamesService(IUserManager userManager, IUserDataManager userDataRepository, ILibraryManager libraryManager, IItemRepository itemRepo, IDtoService dtoService)
  83. {
  84. _userManager = userManager;
  85. _userDataRepository = userDataRepository;
  86. _libraryManager = libraryManager;
  87. _itemRepo = itemRepo;
  88. _dtoService = dtoService;
  89. }
  90. /// <summary>
  91. /// Gets the specified request.
  92. /// </summary>
  93. /// <param name="request">The request.</param>
  94. /// <returns>System.Object.</returns>
  95. public object Get(GetGameSystemSummaries request)
  96. {
  97. var gameSystems = GetAllLibraryItems(request.UserId, _userManager, _libraryManager, null, i => i is GameSystem)
  98. .Cast<GameSystem>()
  99. .ToList();
  100. var user = request.UserId == null ? null : _userManager.GetUserById(request.UserId);
  101. var result = gameSystems
  102. .Select(i => GetSummary(i, user))
  103. .ToList();
  104. return ToOptimizedSerializedResultUsingCache(result);
  105. }
  106. private static readonly CultureInfo UsCulture = new CultureInfo("en-US");
  107. public object Get(GetPlayerIndex request)
  108. {
  109. var games = GetAllLibraryItems(request.UserId, _userManager, _libraryManager, null, i => i is Game)
  110. .Cast<Game>();
  111. var lookup = games
  112. .ToLookup(i => i.PlayersSupported ?? -1)
  113. .OrderBy(i => i.Key)
  114. .Select(i => new ItemIndex
  115. {
  116. ItemCount = i.Count(),
  117. Name = i.Key == -1 ? string.Empty : i.Key.ToString(UsCulture)
  118. })
  119. .ToList();
  120. return ToOptimizedSerializedResultUsingCache(lookup);
  121. }
  122. /// <summary>
  123. /// Gets the summary.
  124. /// </summary>
  125. /// <param name="system">The system.</param>
  126. /// <param name="user">The user.</param>
  127. /// <returns>GameSystemSummary.</returns>
  128. private GameSystemSummary GetSummary(GameSystem system, User user)
  129. {
  130. var summary = new GameSystemSummary
  131. {
  132. Name = system.GameSystemName,
  133. DisplayName = system.Name
  134. };
  135. var items = user == null ?
  136. system.GetRecursiveChildren(i => i is Game) :
  137. system.GetRecursiveChildren(user, i => i is Game);
  138. var games = items.Cast<Game>().ToList();
  139. summary.ClientInstalledGameCount = games.Count(i => i.IsPlaceHolder);
  140. summary.GameCount = games.Count;
  141. summary.GameFileExtensions = games.Where(i => !i.IsPlaceHolder).Select(i => Path.GetExtension(i.Path))
  142. .Distinct(StringComparer.OrdinalIgnoreCase)
  143. .ToList();
  144. return summary;
  145. }
  146. /// <summary>
  147. /// Gets the specified request.
  148. /// </summary>
  149. /// <param name="request">The request.</param>
  150. /// <returns>System.Object.</returns>
  151. public object Get(GetSimilarGames request)
  152. {
  153. var dtoOptions = GetDtoOptions(request);
  154. var result = SimilarItemsHelper.GetSimilarItemsResult(dtoOptions, _userManager,
  155. _itemRepo,
  156. _libraryManager,
  157. _userDataRepository,
  158. _dtoService,
  159. Logger,
  160. request, item => item is Game,
  161. SimilarItemsHelper.GetSimiliarityScore);
  162. return ToOptimizedSerializedResultUsingCache(result);
  163. }
  164. }
  165. }