using System.Threading.Tasks; using Jellyfin.Api.Constants; using Jellyfin.Api.Extensions; using MediaBrowser.Common.Configuration; using Microsoft.AspNetCore.Authorization; namespace Jellyfin.Api.Auth.FirstTimeSetupPolicy { /// /// Authorization handler for requiring first time setup or default privileges. /// public class FirstTimeSetupHandler : AuthorizationHandler { private readonly IConfigurationManager _configurationManager; /// /// Initializes a new instance of the class. /// /// Instance of the interface. public FirstTimeSetupHandler(IConfigurationManager configurationManager) { _configurationManager = configurationManager; } /// protected override Task HandleRequirementAsync(AuthorizationHandlerContext context, FirstTimeSetupRequirement requirement) { // Succeed if the startup wizard / first time setup is not complete if (!_configurationManager.CommonConfiguration.IsStartupWizardCompleted) { context.Succeed(requirement); } // 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)) { context.Succeed(requirement); } // Any user-specific checks are handled in the DefaultAuthorizationHandler. return Task.CompletedTask; } } }