dotnet-digital-ops/DigitalOps.Authority/Validators/HasAccessToClientValidator.cs

42 lines
1.5 KiB
C#

using DigitalOps.Authority.Services;
using DigitalOps.Dal;
using DigitalOps.Dal.DbEntity;
using DigitalOps.Dal.Validators;
using FluentValidation;
using Microsoft.EntityFrameworkCore;
namespace DigitalOps.Authority.Validators;
public class HasAccessToClientValidator : AbstractValidator<long>
{
private readonly OrganizationRole _role;
private readonly MainDbContext _dbContext;
private readonly UserIdentityService _userIdentityService;
public HasAccessToClientValidator(OrganizationRole role, MainDbContext dbContext, UserIdentityService userIdentityService)
{
_role = role;
_userIdentityService = userIdentityService;
_dbContext = dbContext;
RuleFor(clientId => clientId)
.Cascade(CascadeMode.Stop)
.SetValidator(new DbEntityExistValidator<Client, long>(dbContext))
.CustomAsync(async (clientId, validationContext, cancellationToken) =>
{
var organizationClient = await _dbContext.OrganizationClients
.AsNoTracking()
.FirstOrDefaultAsync(organizationClient => organizationClient.ClientId == clientId, cancellationToken);
if (organizationClient is null)
return;
var validation = new HasAccessToOrganizationValidator(_role, _dbContext, _userIdentityService);
var validationResult = validation.Validate(organizationClient.OrganizationId);
if (!validationResult.IsValid)
foreach (var error in validationResult.Errors)
validationContext.AddFailure(error);
});
}
}