2
0

WebSocketMiddleware.cs 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. using System.Threading.Tasks;
  2. using Microsoft.AspNetCore.Http;
  3. using Microsoft.Extensions.Logging;
  4. using WebSocketManager = Emby.Server.Implementations.WebSockets.WebSocketManager;
  5. namespace Emby.Server.Implementations.Middleware
  6. {
  7. public class WebSocketMiddleware
  8. {
  9. private readonly RequestDelegate _next;
  10. private readonly ILogger<WebSocketMiddleware> _logger;
  11. private readonly WebSocketManager _webSocketManager;
  12. public WebSocketMiddleware(RequestDelegate next, ILogger<WebSocketMiddleware> logger, WebSocketManager webSocketManager)
  13. {
  14. _next = next;
  15. _logger = logger;
  16. _webSocketManager = webSocketManager;
  17. }
  18. public async Task Invoke(HttpContext httpContext)
  19. {
  20. _logger.LogInformation("Handling request: " + httpContext.Request.Path);
  21. if (httpContext.WebSockets.IsWebSocketRequest)
  22. {
  23. var webSocketContext = await httpContext.WebSockets.AcceptWebSocketAsync(null).ConfigureAwait(false);
  24. if (webSocketContext != null)
  25. {
  26. await _webSocketManager.OnWebSocketConnected(webSocketContext);
  27. }
  28. }
  29. else
  30. {
  31. await _next.Invoke(httpContext);
  32. }
  33. }
  34. }
  35. }