LocalAccessOrRequiresElevationHandler.cs 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. using System.Threading.Tasks;
  2. using Jellyfin.Api.Constants;
  3. using MediaBrowser.Common.Net;
  4. using MediaBrowser.Controller.Library;
  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 : BaseAuthorizationHandler<LocalAccessOrRequiresElevationRequirement>
  13. {
  14. /// <summary>
  15. /// Initializes a new instance of the <see cref="LocalAccessOrRequiresElevationHandler"/> class.
  16. /// </summary>
  17. /// <param name="userManager">Instance of the <see cref="IUserManager"/> interface.</param>
  18. /// <param name="networkManager">Instance of the <see cref="INetworkManager"/> interface.</param>
  19. /// <param name="httpContextAccessor">Instance of the <see cref="IHttpContextAccessor"/> interface.</param>
  20. public LocalAccessOrRequiresElevationHandler(
  21. IUserManager userManager,
  22. INetworkManager networkManager,
  23. IHttpContextAccessor httpContextAccessor)
  24. : base(userManager, networkManager, httpContextAccessor)
  25. {
  26. }
  27. /// <inheritdoc />
  28. protected override Task HandleRequirementAsync(AuthorizationHandlerContext context, LocalAccessOrRequiresElevationRequirement requirement)
  29. {
  30. var validated = ValidateClaims(context.User, localAccessOnly: true);
  31. if (validated || context.User.IsInRole(UserRoles.Administrator))
  32. {
  33. context.Succeed(requirement);
  34. }
  35. else
  36. {
  37. context.Fail();
  38. }
  39. return Task.CompletedTask;
  40. }
  41. }
  42. }