12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- using System.Threading.Tasks;
- using Jellyfin.Api.Extensions;
- using Jellyfin.Extensions;
- using MediaBrowser.Common.Extensions;
- using MediaBrowser.Controller.Library;
- using Microsoft.AspNetCore.Authorization;
- namespace Jellyfin.Api.Auth.UserPermissionPolicy
- {
- /// <summary>
- /// User permission authorization handler.
- /// </summary>
- public class UserPermissionHandler : AuthorizationHandler<UserPermissionRequirement>
- {
- private readonly IUserManager _userManager;
- /// <summary>
- /// Initializes a new instance of the <see cref="UserPermissionHandler"/> class.
- /// </summary>
- /// <param name="userManager">Instance of the <see cref="IUserManager"/> interface.</param>
- public UserPermissionHandler(IUserManager userManager)
- {
- _userManager = userManager;
- }
- /// <inheritdoc />
- protected override Task HandleRequirementAsync(AuthorizationHandlerContext context, UserPermissionRequirement requirement)
- {
- // Api keys have global permissions, so just succeed the requirement.
- if (context.User.GetIsApiKey())
- {
- context.Succeed(requirement);
- }
- else
- {
- var userId = context.User.GetUserId();
- if (!userId.IsEmpty())
- {
- var user = _userManager.GetUserById(context.User.GetUserId());
- if (user is null)
- {
- throw new ResourceNotFoundException();
- }
- if (user.HasPermission(requirement.RequiredPermission))
- {
- context.Succeed(requirement);
- }
- }
- }
- return Task.CompletedTask;
- }
- }
- }
|