using System.Net; using System.Threading.Tasks; using MediaBrowser.Common.Extensions; using MediaBrowser.Common.Net; using MediaBrowser.Controller.Configuration; using Microsoft.AspNetCore.Http; namespace Jellyfin.Api.Middleware; /// /// Validates the LAN host IP based on application configuration. /// public class LanFilteringMiddleware { private readonly RequestDelegate _next; /// /// Initializes a new instance of the class. /// /// The next delegate in the pipeline. public LanFilteringMiddleware(RequestDelegate next) { _next = next; } /// /// Executes the middleware action. /// /// The current HTTP context. /// The network manager. /// The server configuration manager. /// The async task. public async Task Invoke(HttpContext httpContext, INetworkManager networkManager, IServerConfigurationManager serverConfigurationManager) { if (serverConfigurationManager.GetNetworkConfiguration().EnableRemoteAccess) { await _next(httpContext).ConfigureAwait(false); return; } var host = httpContext.GetNormalizedRemoteIP(); if (!networkManager.IsInLocalNetwork(host)) { // No access from network, respond with 503 instead of 200. httpContext.Response.StatusCode = StatusCodes.Status503ServiceUnavailable; return; } await _next(httpContext).ConfigureAwait(false); } }