有没有办法为nhibernate会话/活动记录范围禁用Castle Active Record验证

时间:2011-01-16 20:17:45

标签: validation nhibernate castle-activerecord castle-validators

有没有办法为nhibernate会话/活动记录范围禁用Active Record验证?

我有一个场景,我们正在执行大量项目的删除 - 在某些情况下,客户的数据库中有数据不会通过验证(它是在引入新验证规则之前捕获的,或者是由于手册操纵数据库等。)

删除时,由于构建数据库的方式,会对现有实体进行一些验证检查,并且会因异常而失败 - 阻止删除这些实体。

对于删除方案,我们希望禁用与实体被删除的事务/会话/范围相关联的所有验证,这可能吗?

更新23/01/2011

实现了一个简单的验证活动记录基类,用于禁用验证:

public class DisabledValidationProvider : IValidationProvider
{
    public bool IsValid()
    {
        return true;
    }

    public bool IsValid(RunWhen runWhen)
    {
        return true;
    }

    public string[] ValidationErrorMessages
    {
        get { return null; }
    }

    public IDictionary PropertiesValidationErrorMessages
    {
        get { return null; }
    }
}

public class DisableValidationScope : IDisposable
{
    public DisableValidationScope()
    {
        Local.Data["DisableValidationScope"] = true;
    }

    public static bool IsValidationDisabled
    {
        get { return Local.Data["DisableValidationScope"] != null; }
    }

    public void Dispose()
    {
        Local.Data["DisableValidationScope"] = null;
    }
}

public abstract class ScopeAwareValidationBase : ActiveRecordHooksValidationBase
{
    static readonly IValidationProvider DisabledProvider = new DisabledValidationProvider();

    protected override IValidationProvider ActualValidator
    {
        get
        {
            if (DisableValidationScope.IsValidationDisabled)
            {
                return DisabledProvider;
            }
            return base.ActualValidator;
        }
    }
}

我的ActiveRecord模型继承自ScopeAwareValidationBase,然后我可以在我的事务代码周围使用一个using语句,然后处理。

using (new DisableValidationScope()) 
{
    // do transactional thing...
}

1 个答案:

答案 0 :(得分:2)

我会考虑覆盖ActualValidator属性,你可以:

  • 提供一个setter,让您的代码决定是否在每个实例的基础上应用验证,或者
  • (更好)查找与当前SessionScope关联的某些上下文,决定是否应用验证。

要禁用验证,您将返回一个虚拟IValidationProvider,它始终返回true给IsValid()等。