IServerManager.cs 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Threading;
  4. using System.Threading.Tasks;
  5. namespace MediaBrowser.Common.Net
  6. {
  7. /// <summary>
  8. /// Interface IServerManager
  9. /// </summary>
  10. public interface IServerManager : IDisposable
  11. {
  12. /// <summary>
  13. /// Starts this instance.
  14. /// </summary>
  15. /// <param name="urlPrefixes">The URL prefixes.</param>
  16. void Start(IEnumerable<string> urlPrefixes);
  17. /// <summary>
  18. /// Sends a message to all clients currently connected via a web socket
  19. /// </summary>
  20. /// <typeparam name="T"></typeparam>
  21. /// <param name="messageType">Type of the message.</param>
  22. /// <param name="data">The data.</param>
  23. /// <returns>Task.</returns>
  24. void SendWebSocketMessage<T>(string messageType, T data);
  25. /// <summary>
  26. /// Sends a message to all clients currently connected via a web socket
  27. /// </summary>
  28. /// <typeparam name="T"></typeparam>
  29. /// <param name="messageType">Type of the message.</param>
  30. /// <param name="dataFunction">The function that generates the data to send, if there are any connected clients</param>
  31. void SendWebSocketMessage<T>(string messageType, Func<T> dataFunction);
  32. /// <summary>
  33. /// Sends a message to all clients currently connected via a web socket
  34. /// </summary>
  35. /// <typeparam name="T"></typeparam>
  36. /// <param name="messageType">Type of the message.</param>
  37. /// <param name="dataFunction">The function that generates the data to send, if there are any connected clients</param>
  38. /// <param name="cancellationToken">The cancellation token.</param>
  39. /// <returns>Task.</returns>
  40. /// <exception cref="System.ArgumentNullException">messageType</exception>
  41. Task SendWebSocketMessageAsync<T>(string messageType, Func<T> dataFunction, CancellationToken cancellationToken);
  42. /// <summary>
  43. /// Adds the web socket listeners.
  44. /// </summary>
  45. /// <param name="listeners">The listeners.</param>
  46. void AddWebSocketListeners(IEnumerable<IWebSocketListener> listeners);
  47. /// <summary>
  48. /// Gets the web socket connections.
  49. /// </summary>
  50. /// <value>The web socket connections.</value>
  51. IEnumerable<IWebSocketConnection> WebSocketConnections { get; }
  52. }
  53. }