SyncPlayService.cs 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. using System.Threading;
  2. using System;
  3. using System.Collections.Generic;
  4. using MediaBrowser.Controller.Configuration;
  5. using MediaBrowser.Controller.Net;
  6. using MediaBrowser.Controller.Session;
  7. using MediaBrowser.Controller.SyncPlay;
  8. using MediaBrowser.Model.Services;
  9. using MediaBrowser.Model.SyncPlay;
  10. using Microsoft.Extensions.Logging;
  11. namespace MediaBrowser.Api.SyncPlay
  12. {
  13. [Route("/SyncPlay/New", "POST", Summary = "Create a new SyncPlay group")]
  14. [Authenticated]
  15. public class SyncPlayNew : IReturnVoid
  16. {
  17. }
  18. [Route("/SyncPlay/Join", "POST", Summary = "Join an existing SyncPlay group")]
  19. [Authenticated]
  20. public class SyncPlayJoin : IReturnVoid
  21. {
  22. /// <summary>
  23. /// Gets or sets the Group id.
  24. /// </summary>
  25. /// <value>The Group id to join.</value>
  26. [ApiMember(Name = "GroupId", Description = "Group Id", IsRequired = true, DataType = "string", ParameterType = "query", Verb = "POST")]
  27. public string GroupId { get; set; }
  28. }
  29. [Route("/SyncPlay/Leave", "POST", Summary = "Leave joined SyncPlay group")]
  30. [Authenticated]
  31. public class SyncPlayLeave : IReturnVoid
  32. {
  33. }
  34. [Route("/SyncPlay/List", "GET", Summary = "List SyncPlay groups")]
  35. [Authenticated]
  36. public class SyncPlayList : IReturnVoid
  37. {
  38. /// <summary>
  39. /// Gets or sets the filter item id.
  40. /// </summary>
  41. /// <value>The filter item id.</value>
  42. [ApiMember(Name = "FilterItemId", Description = "Filter by item id", IsRequired = false, DataType = "string", ParameterType = "query", Verb = "GET")]
  43. public string FilterItemId { get; set; }
  44. }
  45. [Route("/SyncPlay/Play", "POST", Summary = "Request play in SyncPlay group")]
  46. [Authenticated]
  47. public class SyncPlayPlay : IReturnVoid
  48. {
  49. }
  50. [Route("/SyncPlay/Pause", "POST", Summary = "Request pause in SyncPlay group")]
  51. [Authenticated]
  52. public class SyncPlayPause : IReturnVoid
  53. {
  54. }
  55. [Route("/SyncPlay/Seek", "POST", Summary = "Request seek in SyncPlay group")]
  56. [Authenticated]
  57. public class SyncPlaySeek : IReturnVoid
  58. {
  59. [ApiMember(Name = "PositionTicks", IsRequired = true, DataType = "long", ParameterType = "query", Verb = "POST")]
  60. public long PositionTicks { get; set; }
  61. }
  62. [Route("/SyncPlay/Buffering", "POST", Summary = "Request group wait in SyncPlay group while buffering")]
  63. [Authenticated]
  64. public class SyncPlayBuffering : IReturnVoid
  65. {
  66. /// <summary>
  67. /// Gets or sets the date used to pin PositionTicks in time.
  68. /// </summary>
  69. /// <value>The date related to PositionTicks.</value>
  70. [ApiMember(Name = "When", IsRequired = true, DataType = "string", ParameterType = "query", Verb = "POST")]
  71. public string When { get; set; }
  72. [ApiMember(Name = "PositionTicks", IsRequired = true, DataType = "long", ParameterType = "query", Verb = "POST")]
  73. public long PositionTicks { get; set; }
  74. /// <summary>
  75. /// Gets or sets whether this is a buffering or a ready request.
  76. /// </summary>
  77. /// <value><c>true</c> if buffering is complete; <c>false</c> otherwise.</value>
  78. [ApiMember(Name = "BufferingDone", IsRequired = true, DataType = "bool", ParameterType = "query", Verb = "POST")]
  79. public bool BufferingDone { get; set; }
  80. }
  81. [Route("/SyncPlay/Ping", "POST", Summary = "Update session ping")]
  82. [Authenticated]
  83. public class SyncPlayPing : IReturnVoid
  84. {
  85. [ApiMember(Name = "Ping", IsRequired = true, DataType = "double", ParameterType = "query", Verb = "POST")]
  86. public double Ping { get; set; }
  87. }
  88. /// <summary>
  89. /// Class SyncPlayService.
  90. /// </summary>
  91. public class SyncPlayService : BaseApiService
  92. {
  93. /// <summary>
  94. /// The session context.
  95. /// </summary>
  96. private readonly ISessionContext _sessionContext;
  97. /// <summary>
  98. /// The SyncPlay manager.
  99. /// </summary>
  100. private readonly ISyncPlayManager _syncPlayManager;
  101. public SyncPlayService(
  102. ILogger<SyncPlayService> logger,
  103. IServerConfigurationManager serverConfigurationManager,
  104. IHttpResultFactory httpResultFactory,
  105. ISessionContext sessionContext,
  106. ISyncPlayManager syncPlayManager)
  107. : base(logger, serverConfigurationManager, httpResultFactory)
  108. {
  109. _sessionContext = sessionContext;
  110. _syncPlayManager = syncPlayManager;
  111. }
  112. /// <summary>
  113. /// Handles the specified request.
  114. /// </summary>
  115. /// <param name="request">The request.</param>
  116. public void Post(SyncPlayNew request)
  117. {
  118. var currentSession = GetSession(_sessionContext);
  119. _syncPlayManager.NewGroup(currentSession, CancellationToken.None);
  120. }
  121. /// <summary>
  122. /// Handles the specified request.
  123. /// </summary>
  124. /// <param name="request">The request.</param>
  125. public void Post(SyncPlayJoin request)
  126. {
  127. var currentSession = GetSession(_sessionContext);
  128. Guid groupId;
  129. if (!Guid.TryParse(request.GroupId, out groupId))
  130. {
  131. Logger.LogError("JoinGroup: {0} is not a valid format for GroupId. Ignoring request.", request.GroupId);
  132. return;
  133. }
  134. var joinRequest = new JoinGroupRequest()
  135. {
  136. GroupId = groupId
  137. };
  138. _syncPlayManager.JoinGroup(currentSession, groupId, joinRequest, CancellationToken.None);
  139. }
  140. /// <summary>
  141. /// Handles the specified request.
  142. /// </summary>
  143. /// <param name="request">The request.</param>
  144. public void Post(SyncPlayLeave request)
  145. {
  146. var currentSession = GetSession(_sessionContext);
  147. _syncPlayManager.LeaveGroup(currentSession, CancellationToken.None);
  148. }
  149. /// <summary>
  150. /// Handles the specified request.
  151. /// </summary>
  152. /// <param name="request">The request.</param>
  153. /// <value>The requested list of groups.</value>
  154. public List<GroupInfoView> Get(SyncPlayList request)
  155. {
  156. var currentSession = GetSession(_sessionContext);
  157. var filterItemId = Guid.Empty;
  158. if (!string.IsNullOrEmpty(request.FilterItemId) && !Guid.TryParse(request.FilterItemId, out filterItemId))
  159. {
  160. Logger.LogWarning("ListGroups: {0} is not a valid format for FilterItemId. Ignoring filter.", request.FilterItemId);
  161. }
  162. return _syncPlayManager.ListGroups(currentSession, filterItemId);
  163. }
  164. /// <summary>
  165. /// Handles the specified request.
  166. /// </summary>
  167. /// <param name="request">The request.</param>
  168. public void Post(SyncPlayPlay request)
  169. {
  170. var currentSession = GetSession(_sessionContext);
  171. var syncPlayRequest = new PlaybackRequest()
  172. {
  173. Type = PlaybackRequestType.Play
  174. };
  175. _syncPlayManager.HandleRequest(currentSession, syncPlayRequest, CancellationToken.None);
  176. }
  177. /// <summary>
  178. /// Handles the specified request.
  179. /// </summary>
  180. /// <param name="request">The request.</param>
  181. public void Post(SyncPlayPause request)
  182. {
  183. var currentSession = GetSession(_sessionContext);
  184. var syncPlayRequest = new PlaybackRequest()
  185. {
  186. Type = PlaybackRequestType.Pause
  187. };
  188. _syncPlayManager.HandleRequest(currentSession, syncPlayRequest, CancellationToken.None);
  189. }
  190. /// <summary>
  191. /// Handles the specified request.
  192. /// </summary>
  193. /// <param name="request">The request.</param>
  194. public void Post(SyncPlaySeek request)
  195. {
  196. var currentSession = GetSession(_sessionContext);
  197. var syncPlayRequest = new PlaybackRequest()
  198. {
  199. Type = PlaybackRequestType.Seek,
  200. PositionTicks = request.PositionTicks
  201. };
  202. _syncPlayManager.HandleRequest(currentSession, syncPlayRequest, CancellationToken.None);
  203. }
  204. /// <summary>
  205. /// Handles the specified request.
  206. /// </summary>
  207. /// <param name="request">The request.</param>
  208. public void Post(SyncPlayBuffering request)
  209. {
  210. var currentSession = GetSession(_sessionContext);
  211. var syncPlayRequest = new PlaybackRequest()
  212. {
  213. Type = request.BufferingDone ? PlaybackRequestType.Ready : PlaybackRequestType.Buffer,
  214. When = DateTime.Parse(request.When),
  215. PositionTicks = request.PositionTicks
  216. };
  217. _syncPlayManager.HandleRequest(currentSession, syncPlayRequest, CancellationToken.None);
  218. }
  219. /// <summary>
  220. /// Handles the specified request.
  221. /// </summary>
  222. /// <param name="request">The request.</param>
  223. public void Post(SyncPlayPing request)
  224. {
  225. var currentSession = GetSession(_sessionContext);
  226. var syncPlayRequest = new PlaybackRequest()
  227. {
  228. Type = PlaybackRequestType.Ping,
  229. Ping = Convert.ToInt64(request.Ping)
  230. };
  231. _syncPlayManager.HandleRequest(currentSession, syncPlayRequest, CancellationToken.None);
  232. }
  233. }
  234. }