Проверка уникального имени FluentValidation с использованием базы данных
У меня есть модель категории, которая имеет поле Name, и каждое имя категории должно быть уникальным. Я сделал проверку, и она работает, когда я пытаюсь создать новую категорию, но у меня проблема при попытке ее редактировать. На данный момент он просто проверяет, существует ли это имя и, конечно же, оно делает, когда я пытаюсь редактировать ту же категорию.
Model
[Validator(typeof(CategoryValidator))]
public class Category
{
public int ID { get; set; }
public string Name { get; set; }
virtual public ICollection<Image> Images { get; set; }
}
public class CategoryValidator : AbstractValidator<Category>
{
public CategoryValidator()
{
RuleFor(x => x.Name).NotEmpty().WithMessage("Category name is required.").Must(UniqueName).WithMessage("This category name already exists.");
}
private bool UniqueName(string name)
{
ProjecteDataContext _db = new ProjecteDataContext();
var category = _db.Categories.Where(x => x.Name.ToLower() == name.ToLower()).SingleOrDefault();
if (category == null) return true;
return false;
}
}
Как вы можете видеть, у меня есть функция UniqueName(string name)
, но как я могу передать идентификатор или целую модель в нем, чтобы я мог проверить, совпадает ли он с тем же идентификатором, что и модель, которую я пытаюсь редактировать, а затем она проходит. Как я могу передать что-то вроде UniqueName(string name, int? id)
? Я обнаружил FluentValidation только сегодня, и я не могу понять.
Ответы
Ответ 1
Predicate Validator (aka Must) имеет перегрузку, которая принимает предикат с двумя параметрами (проверенный объект и значение свойства). В вашем случае предикат будет иметь тип Func<Category, string, bool>
. Поэтому просто добавьте параметр Category
к вашему уникальному методу проверки имени:
private bool UniqueName(Category category, string name)
{
ProjecteDataContext _db = new ProjecteDataContext();
var dbCategory = _db.Categories
.Where(x => x.Name.ToLower() == name.ToLower())
.SingleOrDefault();
if (dbCategory == null)
return true;
return dbCategory.ID == category.ID;
}