UserPermissionHandler.cs 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. using System.Threading.Tasks;
  2. using Jellyfin.Api.Extensions;
  3. using Jellyfin.Extensions;
  4. using MediaBrowser.Common.Extensions;
  5. using MediaBrowser.Controller.Library;
  6. using Microsoft.AspNetCore.Authorization;
  7. namespace Jellyfin.Api.Auth.UserPermissionPolicy
  8. {
  9. /// <summary>
  10. /// User permission authorization handler.
  11. /// </summary>
  12. public class UserPermissionHandler : AuthorizationHandler<UserPermissionRequirement>
  13. {
  14. private readonly IUserManager _userManager;
  15. /// <summary>
  16. /// Initializes a new instance of the <see cref="UserPermissionHandler"/> class.
  17. /// </summary>
  18. /// <param name="userManager">Instance of the <see cref="IUserManager"/> interface.</param>
  19. public UserPermissionHandler(IUserManager userManager)
  20. {
  21. _userManager = userManager;
  22. }
  23. /// <inheritdoc />
  24. protected override Task HandleRequirementAsync(AuthorizationHandlerContext context, UserPermissionRequirement requirement)
  25. {
  26. // Api keys have global permissions, so just succeed the requirement.
  27. if (context.User.GetIsApiKey())
  28. {
  29. context.Succeed(requirement);
  30. }
  31. else
  32. {
  33. var userId = context.User.GetUserId();
  34. if (!userId.IsEmpty())
  35. {
  36. var user = _userManager.GetUserById(context.User.GetUserId());
  37. if (user is null)
  38. {
  39. throw new ResourceNotFoundException();
  40. }
  41. if (user.HasPermission(requirement.RequiredPermission))
  42. {
  43. context.Succeed(requirement);
  44. }
  45. }
  46. }
  47. return Task.CompletedTask;
  48. }
  49. }
  50. }