Files
jellyfin-jellyfin-1/Jellyfin.Api/Auth/FirstTimeSetupPolicy/FirstTimeSetupHandler.cs

57 lines
2.0 KiB
C#
Raw Normal View History

2020-08-06 08:17:45 -06:00
using System.Threading.Tasks;
2023-02-08 23:55:26 +01:00
using Jellyfin.Api.Constants;
using Jellyfin.Api.Extensions;
2020-08-06 08:17:45 -06:00
using MediaBrowser.Common.Configuration;
using Microsoft.AspNetCore.Authorization;
2023-02-08 23:55:26 +01:00
namespace Jellyfin.Api.Auth.FirstTimeSetupPolicy
2020-08-06 08:17:45 -06:00
{
/// <summary>
2020-08-06 17:59:48 -06:00
/// Authorization handler for requiring first time setup or default privileges.
2020-08-06 08:17:45 -06:00
/// </summary>
2023-02-08 23:55:26 +01:00
public class FirstTimeSetupHandler : AuthorizationHandler<FirstTimeSetupRequirement>
2020-08-06 08:17:45 -06:00
{
private readonly IConfigurationManager _configurationManager;
/// <summary>
2023-02-08 23:55:26 +01:00
/// Initializes a new instance of the <see cref="FirstTimeSetupHandler" /> class.
2020-08-06 08:17:45 -06:00
/// </summary>
/// <param name="configurationManager">Instance of the <see cref="IConfigurationManager"/> interface.</param>
public FirstTimeSetupHandler(IConfigurationManager configurationManager)
2020-08-06 08:17:45 -06:00
{
_configurationManager = configurationManager;
}
/// <inheritdoc />
2023-02-08 23:55:26 +01:00
protected override Task HandleRequirementAsync(AuthorizationHandlerContext context, FirstTimeSetupRequirement requirement)
2020-08-06 08:17:45 -06:00
{
// Succeed if the startup wizard / first time setup is not complete
2020-08-06 08:17:45 -06:00
if (!_configurationManager.CommonConfiguration.IsStartupWizardCompleted)
{
2021-02-14 15:11:46 +01:00
context.Succeed(requirement);
2020-08-06 08:17:45 -06:00
}
// Succeed if user is admin
else if (context.User.IsInRole(UserRoles.Administrator))
{
context.Succeed(requirement);
}
// Fail if admin is required and user is not admin
else if (requirement.RequireAdmin)
{
context.Fail();
}
// Succeed if admin is not required and user is not guest
else if (context.User.IsInRole(UserRoles.User))
2020-08-06 08:17:45 -06:00
{
2023-02-08 23:55:26 +01:00
context.Succeed(requirement);
2020-08-06 08:17:45 -06:00
}
// Any user-specific checks are handled in the DefaultAuthorizationHandler.
2020-08-06 08:17:45 -06:00
return Task.CompletedTask;
}
}
}