web-dev-qa-db-ja.com

データベースを使用したFluentValidationの一意の名前の検証

Category Nameフィールドを持つモデルがあり、すべてのカテゴリ名は一意である必要があります。検証を行い、新しいカテゴリを作成しようとすると機能しますが、編集しようとすると問題が発生します。今のところ、名前が存在するかどうかをチェックしているだけで、もちろん同じカテゴリを編集しようとするとチェックします。

モデル

_[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)関数がありますが、IDまたはモデル全体を渡して、編集しようとしているモデルと同じIDであるかどうかを確認してから渡すにはどうすればよいですか。 UniqueName(string name, int? id)のようなものを渡すにはどうすればよいですか? FluentValidationを発見したのは今日だけで、理解できません。

27
Stan

Predicate Validator(aka Must) オーバーロードがあり、2つのパラメーター(検証済みのオブジェクトとプロパティ値)を持つ述語を受け入れます。あなたの場合、述語はタイプ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;
}
29