2020-08-06 08:17:45 -06:00
|
|
|
using System.Threading.Tasks;
|
2023-02-08 23:55:26 +01:00
|
|
|
using Jellyfin.Api.Constants;
|
2024-05-30 12:08:52 -04:00
|
|
|
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>
|
2024-04-10 22:32:37 -06:00
|
|
|
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
|
|
|
{
|
2024-05-31 14:09:04 -04: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
|
|
|
}
|
2024-05-31 14:09:04 -04:00
|
|
|
|
2024-05-31 16:31:15 -04:00
|
|
|
// Succeed if user is admin
|
|
|
|
|
else if (context.User.IsInRole(UserRoles.Administrator))
|
2024-05-30 12:08:52 -04:00
|
|
|
{
|
|
|
|
|
context.Succeed(requirement);
|
|
|
|
|
}
|
2024-05-31 14:09:04 -04:00
|
|
|
|
|
|
|
|
// Fail if admin is required and user is not admin
|
2024-05-31 16:31:15 -04:00
|
|
|
else if (requirement.RequireAdmin)
|
2023-05-10 22:05:27 +02:00
|
|
|
{
|
|
|
|
|
context.Fail();
|
|
|
|
|
}
|
2020-08-06 08:17:45 -06:00
|
|
|
|
2024-05-31 14:09:04 -04:00
|
|
|
// Succeed if admin is not required and user is not guest
|
2024-05-31 16:31:15 -04:00
|
|
|
else if (context.User.IsInRole(UserRoles.User))
|
2024-05-31 14:09:04 -04:00
|
|
|
{
|
|
|
|
|
context.Succeed(requirement);
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-29 14:35:41 -04:00
|
|
|
// Any user-specific checks are handled in the DefaultAuthorizationHandler.
|
2020-08-06 08:17:45 -06:00
|
|
|
return Task.CompletedTask;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|