WebSocketMiddleware.cs 1.2 KB

123456789101112131415161718192021222324252627282930313233343536
  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. _webSocketManager.AddSocket(webSocketContext);
  25. }
  26. else
  27. {
  28. await _next.Invoke(httpContext);
  29. }
  30. }
  31. }
  32. }