UserPermissionHandler.cs 1.8 KB

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