kreta/Kreta.Core/CustomAttributes/PhoneExtendedAttribute.cs
2024-03-13 00:33:46 +01:00

55 lines
2 KiB
C#

using System;
using System.ComponentModel.DataAnnotations;
using System.Text.RegularExpressions;
namespace Kreta.Core.CustomAttributes
{
[AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter)]
public class PhoneExtendedAttribute : DataTypeAttribute
{
public bool IsNullValid { get; }
public bool IsEmptyValid { get; }
//NOTE: A beépített PhoneAttribute a null-t valid true-nak, az üres string-et valid false-nak veszi alapból, ezért ezek a default értékek itt is!
public PhoneExtendedAttribute(bool isNullValid = true, bool isEmptyValid = false) : base(DataType.PhoneNumber)
{
IsNullValid = isNullValid;
IsEmptyValid = isEmptyValid;
}
public override bool IsValid(object value)
{
//NOTE: Null esetében, az IsNullValid property értékétől függően térünk vissza, hogy valid-e vagy sem!
if (value == null)
{
return IsNullValid;
}
string valueAsString = value as string;
//NOTE: Ha nem sikerül string-é alakítani a nem null value-t, akkor rossz a value típusa, ezért nem lesz valid!
if (valueAsString == null)
{
return false;
}
//NOTE: Üres string esetében, az IsEmptyValid property értékétől függően térünk vissza, hogy valid-e vagy sem!
if (valueAsString == string.Empty)
{
return IsEmptyValid;
}
//NOTE: Levalidáljuk a Regex alapján! "+00000000000000000000"
Match match = new Regex(Constants.RegularExpressions.Telefon).Match(valueAsString);
if (!match.Success)
{
return false;
}
//NOTE: Végül levalidáljuk a beépített PhoneAttribute validációjával!
bool result = new PhoneAttribute().IsValid(valueAsString);
return result;
}
}
}