ISyncPlayManager.cs 2.6 KB

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