@ -1,10 +1,6 @@
using System.Threading.Tasks ;
using Jellyfin.Api.Constants ;
using Jellyfin.Api.Extensions ;
using Jellyfin.Extensions ;
using MediaBrowser.Common.Configuration ;
using MediaBrowser.Common.Extensions ;
using MediaBrowser.Controller.Library ;
using Microsoft.AspNetCore.Authorization ;
namespace Jellyfin.Api.Auth.FirstTimeSetupPolicy
@ -15,19 +11,14 @@ namespace Jellyfin.Api.Auth.FirstTimeSetupPolicy
public class FirstTimeSetupHandler : AuthorizationHandler < FirstTimeSetupRequirement >
{
private readonly IConfigurationManager _configurationManager ;
private readonly IUserManager _userManager ;
/// <summary>
/// Initializes a new instance of the <see cref="FirstTimeSetupHandler" /> class.
/// </summary>
/// <param name="configurationManager">Instance of the <see cref="IConfigurationManager"/> interface.</param>
/// <param name="userManager">Instance of the <see cref="IUserManager"/> interface.</param>
public FirstTimeSetupHandler (
IConfigurationManager configurationManager ,
IUserManager userManager )
public FirstTimeSetupHandler ( IConfigurationManager configurationManager )
{
_configurationManager = configurationManager ;
_userManager = userManager ;
}
/// <inheritdoc />
@ -36,37 +27,14 @@ namespace Jellyfin.Api.Auth.FirstTimeSetupPolicy
if ( ! _configurationManager . CommonConfiguration . IsStartupWizardCompleted )
{
context . Succeed ( requirement ) ;
return Task . CompletedTask ;
}
var contextUser = context . User ;
if ( requirement . RequireAdmin & & ! contextUser . IsInRole ( UserRoles . Administrator ) )
else if ( requirement . RequireAdmin & & ! context . User . IsInRole ( UserRoles . Administrator ) )
{
context . Fail ( ) ;
return Task . CompletedTask ;
}
var userId = contextUser . GetUserId ( ) ;
if ( userId . IsEmpty ( ) )
{
context . Fail ( ) ;
return Task . CompletedTask ;
}
if ( ! requirement . ValidateParentalSchedule )
{
context . Succeed ( requirement ) ;
return Task . CompletedTask ;
}
var user = _userManager . GetUserById ( userId ) ;
if ( user is null )
{
throw new ResourceNotFoundException ( ) ;
}
if ( user . IsParentalScheduleAllowed ( ) )
else
{
// Any user-specific checks are handled in the DefaultAuthorizationHandler.
context . Succeed ( requirement ) ;
}