55 lines
2 KiB
C#
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;
|
|
}
|
|
}
|
|
}
|