jellyfin/Emby.Server.Implementations/Middleware/WebSocketMiddleware.cs

40 lines
1.4 KiB
C#
Raw Normal View History

using System.Threading.Tasks;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.Logging;
using WebSocketManager = Emby.Server.Implementations.WebSockets.WebSocketManager;
namespace Emby.Server.Implementations.Middleware
{
public class WebSocketMiddleware
{
private readonly RequestDelegate _next;
private readonly ILogger<WebSocketMiddleware> _logger;
private readonly WebSocketManager _webSocketManager;
public WebSocketMiddleware(RequestDelegate next, ILogger<WebSocketMiddleware> logger, WebSocketManager webSocketManager)
{
_next = next;
_logger = logger;
_webSocketManager = webSocketManager;
}
public async Task Invoke(HttpContext httpContext)
{
_logger.LogInformation("Handling request: " + httpContext.Request.Path);
if (httpContext.WebSockets.IsWebSocketRequest)
{
var webSocketContext = await httpContext.WebSockets.AcceptWebSocketAsync(null).ConfigureAwait(false);
2019-03-01 14:08:51 +01:00
if (webSocketContext != null)
{
2019-10-25 12:47:20 +02:00
await _webSocketManager.OnWebSocketConnected(webSocketContext).ConfigureAwait(false);
2019-03-01 14:08:51 +01:00
}
}
else
{
2019-10-25 12:47:20 +02:00
await _next.Invoke(httpContext).ConfigureAwait(false);
}
}
}
}