ISyncPlayManager.cs 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. #nullable disable
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Threading;
  5. using MediaBrowser.Controller.Session;
  6. using MediaBrowser.Controller.SyncPlay.Requests;
  7. using MediaBrowser.Model.SyncPlay;
  8. namespace MediaBrowser.Controller.SyncPlay
  9. {
  10. /// <summary>
  11. /// Interface ISyncPlayManager.
  12. /// </summary>
  13. public interface ISyncPlayManager
  14. {
  15. /// <summary>
  16. /// Creates a new group.
  17. /// </summary>
  18. /// <param name="session">The session that's creating the group.</param>
  19. /// <param name="request">The request.</param>
  20. /// <param name="cancellationToken">The cancellation token.</param>
  21. /// <returns>The newly created group.</returns>
  22. GroupInfoDto NewGroup(SessionInfo session, NewGroupRequest request, CancellationToken cancellationToken);
  23. /// <summary>
  24. /// Adds the session to a group.
  25. /// </summary>
  26. /// <param name="session">The session.</param>
  27. /// <param name="request">The request.</param>
  28. /// <param name="cancellationToken">The cancellation token.</param>
  29. void JoinGroup(SessionInfo session, JoinGroupRequest request, CancellationToken cancellationToken);
  30. /// <summary>
  31. /// Removes the session from a group.
  32. /// </summary>
  33. /// <param name="session">The session.</param>
  34. /// <param name="request">The request.</param>
  35. /// <param name="cancellationToken">The cancellation token.</param>
  36. void LeaveGroup(SessionInfo session, LeaveGroupRequest request, CancellationToken cancellationToken);
  37. /// <summary>
  38. /// Gets list of available groups for a session.
  39. /// </summary>
  40. /// <param name="session">The session.</param>
  41. /// <param name="request">The request.</param>
  42. /// <returns>The list of available groups.</returns>
  43. List<GroupInfoDto> ListGroups(SessionInfo session, ListGroupsRequest request);
  44. /// <summary>
  45. /// Gets available groups for a session by id.
  46. /// </summary>
  47. /// <param name="session">The session.</param>
  48. /// <param name="groupId">The group id.</param>
  49. /// <returns>The groups or null.</returns>
  50. GroupInfoDto GetGroup(SessionInfo session, Guid groupId);
  51. /// <summary>
  52. /// Handle a request by a session in a group.
  53. /// </summary>
  54. /// <param name="session">The session.</param>
  55. /// <param name="request">The request.</param>
  56. /// <param name="cancellationToken">The cancellation token.</param>
  57. void HandleRequest(SessionInfo session, IGroupPlaybackRequest request, CancellationToken cancellationToken);
  58. /// <summary>
  59. /// Checks whether a user has an active session using SyncPlay.
  60. /// </summary>
  61. /// <param name="userId">The user identifier to check.</param>
  62. /// <returns><c>true</c> if the user is using SyncPlay; <c>false</c> otherwise.</returns>
  63. bool IsUserActive(Guid userId);
  64. }
  65. }