//
// Copyright (c) alveus.dev. All rights reserved. Licensed under the MIT License.
//
using Astral.Services.Dtos;
using Astral.Services.Interfaces;
using FluentValidation;
using Injectio.Attributes;
namespace Astral.Services.Validators;
///
/// Validation for .
///
[RegisterScoped]
public class CreateUserValidator : AbstractValidator
{
private const int MinimumUsernameLength = 4;
private const int MaximumUsernameLength = 16;
///
/// Initializes a new instance of the class.
///
/// Instance of .
public CreateUserValidator(IEmailDomainBlacklistService emailDomainBlacklistService)
{
RuleFor(dto => dto.Username).NotEmpty().WithMessage("Username must be provided")
.MinimumLength(MinimumUsernameLength)
.WithMessage("Username must be a minimum of " + MinimumUsernameLength + " characters")
.MaximumLength(MaximumUsernameLength)
.WithMessage("Username must be within " + MaximumUsernameLength + " characters")
.Matches(@"^[A-Za-z0-9._-]+$")
.WithMessage("Username can only contain letters, numbers, hyphens, dashes and periods.");
RuleFor(dto => dto.Email).NotEmpty().WithMessage("Email address must be provided")
.EmailAddress().WithMessage("Email address is not a valid email address");
RuleFor(dto => dto.Email).MustAsync(async (email, _) =>
await emailDomainBlacklistService.CheckBlacklist(email) == false)
.WithMessage("Email addresses from this domain cannot be used");
RuleFor(dto => dto.Password).NotEmpty().WithMessage("Password must be provided");
}
}