LiveTvAccessHandler.cs 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. using System.Threading.Tasks;
  2. using MediaBrowser.Common.Net;
  3. using MediaBrowser.Controller.Library;
  4. using Microsoft.AspNetCore.Authorization;
  5. using Microsoft.AspNetCore.Http;
  6. namespace Jellyfin.Api.Auth.LiveTvAccessPolicy;
  7. /// <summary>
  8. /// Authorization handler for LiveTV access.
  9. /// </summary>
  10. public class LiveTvAccessHandler : BaseAuthorizationHandler<LiveTvAccessRequirement>
  11. {
  12. /// <summary>
  13. /// Initializes a new instance of the <see cref="LiveTvAccessHandler"/> class.
  14. /// </summary>
  15. /// <param name="userManager">Instance of the <see cref="IUserManager"/> interface.</param>
  16. /// <param name="networkManager">Instance of the <see cref="INetworkManager"/> interface.</param>
  17. /// <param name="httpContextAccessor">Instance of the <see cref="IHttpContextAccessor"/> interface.</param>
  18. public LiveTvAccessHandler(
  19. IUserManager userManager,
  20. INetworkManager networkManager,
  21. IHttpContextAccessor httpContextAccessor)
  22. : base(userManager, networkManager, httpContextAccessor)
  23. {
  24. }
  25. /// <inheritdoc />
  26. protected override Task HandleRequirementAsync(AuthorizationHandlerContext context, LiveTvAccessRequirement requirement)
  27. {
  28. var validated = ValidateClaims(context.User, requireLiveTvAccessPermission: true);
  29. if (validated)
  30. {
  31. context.Succeed(requirement);
  32. }
  33. else
  34. {
  35. context.Fail();
  36. }
  37. return Task.CompletedTask;
  38. }
  39. }