AlchemyWebSocket.cs 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. using Alchemy.Classes;
  2. using MediaBrowser.Common.Net;
  3. using MediaBrowser.Model.Logging;
  4. using MediaBrowser.Model.Net;
  5. using System;
  6. using System.Threading;
  7. using System.Threading.Tasks;
  8. namespace MediaBrowser.Server.Implementations.WebSocket
  9. {
  10. /// <summary>
  11. /// Class AlchemyWebSocket
  12. /// </summary>
  13. public class AlchemyWebSocket : IWebSocket
  14. {
  15. /// <summary>
  16. /// The logger
  17. /// </summary>
  18. private readonly ILogger _logger;
  19. /// <summary>
  20. /// Gets or sets the web socket.
  21. /// </summary>
  22. /// <value>The web socket.</value>
  23. private UserContext UserContext { get; set; }
  24. /// <summary>
  25. /// Initializes a new instance of the <see cref="AlchemyWebSocket" /> class.
  26. /// </summary>
  27. /// <param name="context">The context.</param>
  28. /// <param name="logger">The logger.</param>
  29. /// <exception cref="System.ArgumentNullException">context</exception>
  30. public AlchemyWebSocket(UserContext context, ILogger logger)
  31. {
  32. if (context == null)
  33. {
  34. throw new ArgumentNullException("context");
  35. }
  36. _logger = logger;
  37. UserContext = context;
  38. context.SetOnDisconnect(OnDisconnected);
  39. context.SetOnReceive(OnReceiveContext);
  40. _logger.Info("Client connected from {0}", context.ClientAddress);
  41. }
  42. /// <summary>
  43. /// The _disconnected
  44. /// </summary>
  45. private bool _disconnected;
  46. /// <summary>
  47. /// Gets or sets the state.
  48. /// </summary>
  49. /// <value>The state.</value>
  50. public WebSocketState State
  51. {
  52. get { return _disconnected ? WebSocketState.Closed : WebSocketState.Open; }
  53. }
  54. /// <summary>
  55. /// Called when [disconnected].
  56. /// </summary>
  57. /// <param name="context">The context.</param>
  58. private void OnDisconnected(UserContext context)
  59. {
  60. _disconnected = true;
  61. }
  62. /// <summary>
  63. /// Called when [receive].
  64. /// </summary>
  65. /// <param name="context">The context.</param>
  66. private void OnReceiveContext(UserContext context)
  67. {
  68. if (OnReceive != null)
  69. {
  70. var json = context.DataFrame.ToString();
  71. OnReceive(json);
  72. }
  73. }
  74. /// <summary>
  75. /// Sends the async.
  76. /// </summary>
  77. /// <param name="bytes">The bytes.</param>
  78. /// <param name="type">The type.</param>
  79. /// <param name="endOfMessage">if set to <c>true</c> [end of message].</param>
  80. /// <param name="cancellationToken">The cancellation token.</param>
  81. /// <returns>Task.</returns>
  82. public Task SendAsync(byte[] bytes, WebSocketMessageType type, bool endOfMessage, CancellationToken cancellationToken)
  83. {
  84. UserContext.Send(bytes);
  85. return Task.FromResult(true);
  86. }
  87. /// <summary>
  88. /// Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.
  89. /// </summary>
  90. public void Dispose()
  91. {
  92. Dispose(true);
  93. }
  94. /// <summary>
  95. /// Releases unmanaged and - optionally - managed resources.
  96. /// </summary>
  97. /// <param name="dispose"><c>true</c> to release both managed and unmanaged resources; <c>false</c> to release only unmanaged resources.</param>
  98. protected virtual void Dispose(bool dispose)
  99. {
  100. }
  101. /// <summary>
  102. /// Gets or sets the receive action.
  103. /// </summary>
  104. /// <value>The receive action.</value>
  105. public Action<byte[]> OnReceiveBytes { get; set; }
  106. /// <summary>
  107. /// Gets or sets the on receive.
  108. /// </summary>
  109. /// <value>The on receive.</value>
  110. public Action<string> OnReceive { get; set; }
  111. }
  112. }