|
|
@ -14,15 +14,18 @@ namespace Emby.Server.Implementations.HttpServer
|
|
|
|
public class WebSocketManager : IWebSocketManager
|
|
|
|
public class WebSocketManager : IWebSocketManager
|
|
|
|
{
|
|
|
|
{
|
|
|
|
private readonly IWebSocketListener[] _webSocketListeners;
|
|
|
|
private readonly IWebSocketListener[] _webSocketListeners;
|
|
|
|
|
|
|
|
private readonly IAuthService _authService;
|
|
|
|
private readonly ILogger<WebSocketManager> _logger;
|
|
|
|
private readonly ILogger<WebSocketManager> _logger;
|
|
|
|
private readonly ILoggerFactory _loggerFactory;
|
|
|
|
private readonly ILoggerFactory _loggerFactory;
|
|
|
|
|
|
|
|
|
|
|
|
public WebSocketManager(
|
|
|
|
public WebSocketManager(
|
|
|
|
|
|
|
|
IAuthService authService,
|
|
|
|
IEnumerable<IWebSocketListener> webSocketListeners,
|
|
|
|
IEnumerable<IWebSocketListener> webSocketListeners,
|
|
|
|
ILogger<WebSocketManager> logger,
|
|
|
|
ILogger<WebSocketManager> logger,
|
|
|
|
ILoggerFactory loggerFactory)
|
|
|
|
ILoggerFactory loggerFactory)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_webSocketListeners = webSocketListeners.ToArray();
|
|
|
|
_webSocketListeners = webSocketListeners.ToArray();
|
|
|
|
|
|
|
|
_authService = authService;
|
|
|
|
_logger = logger;
|
|
|
|
_logger = logger;
|
|
|
|
_loggerFactory = loggerFactory;
|
|
|
|
_loggerFactory = loggerFactory;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -30,6 +33,7 @@ namespace Emby.Server.Implementations.HttpServer
|
|
|
|
/// <inheritdoc />
|
|
|
|
/// <inheritdoc />
|
|
|
|
public async Task WebSocketRequestHandler(HttpContext context)
|
|
|
|
public async Task WebSocketRequestHandler(HttpContext context)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
_ = _authService.Authenticate(context.Request);
|
|
|
|
try
|
|
|
|
try
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_logger.LogInformation("WS {IP} request", context.Connection.RemoteIpAddress);
|
|
|
|
_logger.LogInformation("WS {IP} request", context.Connection.RemoteIpAddress);
|
|
|
|