< Summary - Jellyfin

Information
Class: Jellyfin.Api.Auth.AnonymousLanAccessPolicy.AnonymousLanAccessHandler
Assembly: Jellyfin.Api
File(s): /srv/git/jellyfin/Jellyfin.Api/Auth/AnonymousLanAccessPolicy/AnonymousLanAccessHandler.cs
Line coverage
54%
Covered lines: 6
Uncovered lines: 5
Coverable lines: 11
Total lines: 48
Line coverage: 54.5%
Branch coverage
0%
Covered branches: 0
Total branches: 6
Branch coverage: 0%
Method coverage

Feature is only available for sponsors

Upgrade to PRO version

Coverage history

Coverage history 0 25 50 75 100

Metrics

MethodBranch coverage Crap Score Cyclomatic complexity Line coverage
.ctor(...)100%11100%
HandleRequirementAsync(...)0%4260%

File(s)

/srv/git/jellyfin/Jellyfin.Api/Auth/AnonymousLanAccessPolicy/AnonymousLanAccessHandler.cs

#LineLine coverage
 1using System.Threading.Tasks;
 2using MediaBrowser.Common.Extensions;
 3using MediaBrowser.Common.Net;
 4using Microsoft.AspNetCore.Authorization;
 5using Microsoft.AspNetCore.Http;
 6
 7namespace Jellyfin.Api.Auth.AnonymousLanAccessPolicy
 8{
 9    /// <summary>
 10    /// LAN access handler. Allows anonymous users.
 11    /// </summary>
 12    public class AnonymousLanAccessHandler : AuthorizationHandler<AnonymousLanAccessRequirement>
 13    {
 14        private readonly INetworkManager _networkManager;
 15        private readonly IHttpContextAccessor _httpContextAccessor;
 16
 17        /// <summary>
 18        /// Initializes a new instance of the <see cref="AnonymousLanAccessHandler"/> class.
 19        /// </summary>
 20        /// <param name="networkManager">Instance of the <see cref="INetworkManager"/> interface.</param>
 21        /// <param name="httpContextAccessor">Instance of the <see cref="IHttpContextAccessor"/> interface.</param>
 1722        public AnonymousLanAccessHandler(
 1723            INetworkManager networkManager,
 1724            IHttpContextAccessor httpContextAccessor)
 25        {
 1726            _networkManager = networkManager;
 1727            _httpContextAccessor = httpContextAccessor;
 1728        }
 29
 30        /// <inheritdoc />
 31        protected override Task HandleRequirementAsync(AuthorizationHandlerContext context, AnonymousLanAccessRequiremen
 32        {
 033            var ip = _httpContextAccessor.HttpContext?.GetNormalizedRemoteIP();
 34
 35            // Loopback will be on LAN, so we can accept null.
 036            if (ip is null || _networkManager.IsInLocalNetwork(ip))
 37            {
 038                context.Succeed(requirement);
 39            }
 40            else
 41            {
 042                context.Fail();
 43            }
 44
 045            return Task.CompletedTask;
 46        }
 47    }
 48}