GamesService.cs 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  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 Guid? 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 Guid? 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)
  98. .OfType<GameSystem>()
  99. .ToList();
  100. var user = request.UserId == null ? null : _userManager.GetUserById(request.UserId.Value);
  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)
  110. .OfType<Game>()
  111. .ToList();
  112. var lookup = games
  113. .ToLookup(i => i.PlayersSupported ?? -1)
  114. .OrderBy(i => i.Key)
  115. .Select(i => new ItemIndex
  116. {
  117. ItemCount = i.Count(),
  118. Name = i.Key == -1 ? string.Empty : i.Key.ToString(UsCulture)
  119. })
  120. .ToList();
  121. return ToOptimizedSerializedResultUsingCache(lookup);
  122. }
  123. /// <summary>
  124. /// Gets the summary.
  125. /// </summary>
  126. /// <param name="system">The system.</param>
  127. /// <param name="user">The user.</param>
  128. /// <returns>GameSystemSummary.</returns>
  129. private GameSystemSummary GetSummary(GameSystem system, User user)
  130. {
  131. var summary = new GameSystemSummary
  132. {
  133. Name = system.GameSystemName,
  134. DisplayName = system.Name
  135. };
  136. var items = user == null ? system.RecursiveChildren : system.GetRecursiveChildren(user);
  137. var games = items.OfType<Game>().ToList();
  138. summary.ClientInstalledGameCount = games.Count(i => i.IsPlaceHolder);
  139. summary.GameCount = games.Count;
  140. summary.GameFileExtensions = games.Where(i => !i.IsPlaceHolder).Select(i => Path.GetExtension(i.Path))
  141. .Distinct(StringComparer.OrdinalIgnoreCase)
  142. .ToList();
  143. return summary;
  144. }
  145. /// <summary>
  146. /// Gets the specified request.
  147. /// </summary>
  148. /// <param name="request">The request.</param>
  149. /// <returns>System.Object.</returns>
  150. public object Get(GetSimilarGames request)
  151. {
  152. var result = SimilarItemsHelper.GetSimilarItemsResult(_userManager,
  153. _itemRepo,
  154. _libraryManager,
  155. _userDataRepository,
  156. _dtoService,
  157. Logger,
  158. request, item => item is Game,
  159. SimilarItemsHelper.GetSimiliarityScore);
  160. return ToOptimizedSerializedResultUsingCache(result);
  161. }
  162. }
  163. }