LocalAccessOrRequiresElevationHandler.cs 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. using System.Threading.Tasks;
  2. using Jellyfin.Api.Constants;
  3. using MediaBrowser.Common.Extensions;
  4. using MediaBrowser.Common.Net;
  5. using Microsoft.AspNetCore.Authorization;
  6. using Microsoft.AspNetCore.Http;
  7. namespace Jellyfin.Api.Auth.LocalAccessOrRequiresElevationPolicy
  8. {
  9. /// <summary>
  10. /// Local access or require elevated privileges handler.
  11. /// </summary>
  12. public class LocalAccessOrRequiresElevationHandler : AuthorizationHandler<LocalAccessOrRequiresElevationRequirement>
  13. {
  14. private readonly INetworkManager _networkManager;
  15. private readonly IHttpContextAccessor _httpContextAccessor;
  16. /// <summary>
  17. /// Initializes a new instance of the <see cref="LocalAccessOrRequiresElevationHandler"/> class.
  18. /// </summary>
  19. /// <param name="networkManager">Instance of the <see cref="INetworkManager"/> interface.</param>
  20. /// <param name="httpContextAccessor">Instance of the <see cref="IHttpContextAccessor"/> interface.</param>
  21. public LocalAccessOrRequiresElevationHandler(
  22. INetworkManager networkManager,
  23. IHttpContextAccessor httpContextAccessor)
  24. {
  25. _networkManager = networkManager;
  26. _httpContextAccessor = httpContextAccessor;
  27. }
  28. /// <inheritdoc />
  29. protected override Task HandleRequirementAsync(AuthorizationHandlerContext context, LocalAccessOrRequiresElevationRequirement requirement)
  30. {
  31. var ip = _httpContextAccessor.HttpContext?.GetNormalizedRemoteIP();
  32. // Loopback will be on LAN, so we can accept null.
  33. if (ip is null || _networkManager.IsInLocalNetwork(ip))
  34. {
  35. context.Succeed(requirement);
  36. return Task.CompletedTask;
  37. }
  38. if (context.User.IsInRole(UserRoles.Administrator))
  39. {
  40. context.Succeed(requirement);
  41. }
  42. else
  43. {
  44. context.Fail();
  45. }
  46. return Task.CompletedTask;
  47. }
  48. }
  49. }