Focus mode

.Net Core

Modellerin Doğrulanması ve FluentValidation Kütüphanesi

Modellerin Doğrulanması ve FluentValidation Kütüphanesi


Uygulama geliştirirken en zor noktalardan birisi sistemi kararlı yapıda tutmaktır. Bunu yapmanın yolu da validasyonlardan geçiyor. Peki yazılım geliştirirken validasyon yapmak ne demek? Şöyle düşünün bir post endpoint'iniz var. Input olarak aldığı obje içerisinde de integer bir özellik var. Ve bu özelliğin mantıksal olarak 0 olmaması gerekiyor. Yada boş geçilmemesi gerekiyor. Eğer servisiniz bu özelliği kontrol etmeden db'ye yazarsa, database'in hata fırlatmasına ve uygulamanızın çalışma anında kırılmasına neden olur. Daha da kötüsü kırılmadan devam eder ve data bütünlüğünün bozulmasına neden olabilir.


Bir validasyon yapısı kurmak hem kuralların okunabilirliği hem de kuralların esnetilebilir olması açısından çok faydalıdır. Bu amaçla yaratılmış bir çok açık kaynaklı kütüphane bulunur. .Net uygulamaları için en çok kullanılan validation kütüphanesi ise FluentValidation dır.


FluentValidation'ı kullanabilmiz için öncelikle kütüphaneyi paket olarak uygulamamıza eklememiz gerekir.

dotnet add package FluentValidation


Şimdi gelin bir örnek üzerinden nasıl kullanıldığını keşfedelim. Aşağıdaki gibi bir Customer modelimizin olduğunu varsayalım.


public class Customer {
    public int Id { get; set; }
    public string Surname { get; set; }
    public string Forename { get; set; }
    public decimal Discount { get; set; }
    public string Address { get; set; }
}



Customer modelinin özelliklerini doğrulamak istersek aşağıdaki gibi bir validasyon sınıfı oluşturmamız gerekir:


using FluentValidation;
public class CustomerValidator: AbstractValidator<Customer> {
}


Şimdi Customer'ın özelliklerini bir takım kurallar ile kapsayalım :


using FluentValidation;

public class CustomerValidator : AbstractValidator<Customer> {
    public CustomerValidator() {
        RuleFor(customer => customer.Surname).NotNull();
        RuleFor(customer => customer.Discount).GreaterThan(0);
    }
}


Yukarıdaki 2 kuralı incelersek;


  • Surname null olamaz.


  • Discount 0'dan büyük olmak zorundadır.



Peki bu validasyonu nasıl çalıştıracağız?


Customer customer = new Customer();
CustomerValidator validator = new CustomerValidator();

ValidationResult results = validator.Validate(customer);

if(!results.IsValid) {
    foreach(var failure in results.Errors) {
        Console.WriteLine("Property " + failure.PropertyName + " failed validation. Error was: " + failure.ErrorMessage);
    }
}


Validasyon sınıfının bir nesnesi oluşturup Validate() metodunu çağırırsak geriye validasyon sonuçları döner. result objesi içerisinde IsValid özelliği validasyon sonucunda hata olup olmadığını geri döner. Ayrıca result objesi Errorsadında bir de hata mesajlarını barındıran bir dizi bulundurur. foreach döngüsü yardımıyla bu hata mesajlarını istediğimiz gibi kullanabiliriz. Yukarıdaki örnek içerisinden console'a yazdırdık. Burda bir log altyapısı varsa loglama yapılabilir yada son kullanıcıya geri döndürülebilir.


Peki eğer ben bir model validasyondan geçmezse hata fırlatmasını istersem ne yapmalıyım? Bunun için de FluentValidation Kütüphanesi ValidateAndThrow adında bir metot barındırır. Bu metot önce kontrolleri yapar, eğer hata varsa hata mesajlarını fırlatır.


Customer customer = new Customer();
CustomerValidator validator = new CustomerValidator();

validator.ValidateAndThrow(customer);


Throw edilen bu hata mesajlarını try catch blokları ile yakalayıp istediğimiz gibi yönetebiliriz. Istersek loga yazarız istersek son kullanıcıya hata mesajı olarak dönebiliriz.


Fluent Validation Kütüphanesi ile yapılabilecek hazır validasyonların tamamını burdan inceleyebilirsiniz.


Inceleme Önerisi: Fluent Validation Kütüphanesi ile ilgili daha detay bilgi için tıklayınız.

left-disk

Programs to Accelerate Your Progress in a Software Career

Join our 4-8 month intensive Patika+ bootcamps, start with the fundamentals and gain comprehensive knowledge to kickstart your software career!

right-cube

Comments

You need to enroll in the course to be able to comment!