SyncPlayAccessHandler.cs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. using System.Threading.Tasks;
  2. using Jellyfin.Api.Extensions;
  3. using Jellyfin.Api.Helpers;
  4. using Jellyfin.Data.Enums;
  5. using MediaBrowser.Common.Extensions;
  6. using MediaBrowser.Common.Net;
  7. using MediaBrowser.Controller.Library;
  8. using MediaBrowser.Controller.SyncPlay;
  9. using Microsoft.AspNetCore.Authorization;
  10. using Microsoft.AspNetCore.Http;
  11. namespace Jellyfin.Api.Auth.SyncPlayAccessPolicy
  12. {
  13. /// <summary>
  14. /// Default authorization handler.
  15. /// </summary>
  16. public class SyncPlayAccessHandler : BaseAuthorizationHandler<SyncPlayAccessRequirement>
  17. {
  18. private readonly ISyncPlayManager _syncPlayManager;
  19. private readonly IUserManager _userManager;
  20. /// <summary>
  21. /// Initializes a new instance of the <see cref="SyncPlayAccessHandler"/> class.
  22. /// </summary>
  23. /// <param name="syncPlayManager">Instance of the <see cref="ISyncPlayManager"/> interface.</param>
  24. /// <param name="userManager">Instance of the <see cref="IUserManager"/> interface.</param>
  25. /// <param name="networkManager">Instance of the <see cref="INetworkManager"/> interface.</param>
  26. /// <param name="httpContextAccessor">Instance of the <see cref="IHttpContextAccessor"/> interface.</param>
  27. public SyncPlayAccessHandler(
  28. ISyncPlayManager syncPlayManager,
  29. IUserManager userManager,
  30. INetworkManager networkManager,
  31. IHttpContextAccessor httpContextAccessor)
  32. : base(userManager, networkManager, httpContextAccessor)
  33. {
  34. _syncPlayManager = syncPlayManager;
  35. _userManager = userManager;
  36. }
  37. /// <inheritdoc />
  38. protected override Task HandleRequirementAsync(AuthorizationHandlerContext context, SyncPlayAccessRequirement requirement)
  39. {
  40. if (!ValidateClaims(context.User))
  41. {
  42. context.Fail();
  43. return Task.CompletedTask;
  44. }
  45. var userId = context.User.GetUserId();
  46. var user = _userManager.GetUserById(userId);
  47. if (user is null)
  48. {
  49. throw new ResourceNotFoundException();
  50. }
  51. if (requirement.RequiredAccess == SyncPlayAccessRequirementType.HasAccess)
  52. {
  53. if (user.SyncPlayAccess == SyncPlayUserAccessType.CreateAndJoinGroups
  54. || user.SyncPlayAccess == SyncPlayUserAccessType.JoinGroups
  55. || _syncPlayManager.IsUserActive(userId))
  56. {
  57. context.Succeed(requirement);
  58. }
  59. else
  60. {
  61. context.Fail();
  62. }
  63. }
  64. else if (requirement.RequiredAccess == SyncPlayAccessRequirementType.CreateGroup)
  65. {
  66. if (user.SyncPlayAccess == SyncPlayUserAccessType.CreateAndJoinGroups)
  67. {
  68. context.Succeed(requirement);
  69. }
  70. else
  71. {
  72. context.Fail();
  73. }
  74. }
  75. else if (requirement.RequiredAccess == SyncPlayAccessRequirementType.JoinGroup)
  76. {
  77. if (user.SyncPlayAccess == SyncPlayUserAccessType.CreateAndJoinGroups
  78. || user.SyncPlayAccess == SyncPlayUserAccessType.JoinGroups)
  79. {
  80. context.Succeed(requirement);
  81. }
  82. else
  83. {
  84. context.Fail();
  85. }
  86. }
  87. else if (requirement.RequiredAccess == SyncPlayAccessRequirementType.IsInGroup)
  88. {
  89. if (_syncPlayManager.IsUserActive(userId))
  90. {
  91. context.Succeed(requirement);
  92. }
  93. else
  94. {
  95. context.Fail();
  96. }
  97. }
  98. else
  99. {
  100. context.Fail();
  101. }
  102. return Task.CompletedTask;
  103. }
  104. }
  105. }