Ton*_*onE 5 nhibernate audit interceptor
我正在使用NHibernate拦截器将有关更新/插入/删除的信息记录到我的各种实体.
记录的信息中包括实体类型和已修改实体的唯一ID.唯一ID <generator class="identity">在NHibernate映射文件中标记为a .
显而易见的问题是,当使用IInterceptor.OnSave()记录Insert操作时,尚未分配实体的Id.
如何在记录审计信息之前获取插入实体的Id?
(我已经研究过NHibernate Listeners PostSave事件,但是无法让他们使用正在使用的Spring.net配置,所以如果可能的话我想坚持使用拦截器)
码:
// object id parameter is null...
public override bool OnSave(object entity, object id, object[] state,
string[] propertyNames, IType[] types)
{
AddAuditItem(entity, INSERT);
return false;
}
Run Code Online (Sandbox Code Playgroud)
我通过在我的拦截器类中添加一个列表来解决这个问题,该类在OnSave实现过程中填充了对象.
在PostFlush实现中,迭代列表,并将每个元素作为插入进行审计.此列表中的对象已保留PostFlush(),因此生成了ID.
这似乎工作正常,但如果指出任何潜在的陷阱,我将不胜感激:-)
public class AuditInterceptor : EmptyInterceptor
{
// To hold inserted items to be audited after insert has been flushed
private IList<object> insertItems = new List<object>();
public override void PostFlush(System.Collections.ICollection entities)
{
foreach (var entity in insertItems)
{
AddAuditItem(entity, INSERT);
}
insertItems.Clear();
base.PostFlush(entities);
}
public override bool OnSave(object entity, object id, object[] state,
string[] propertyNames, IType[] types)
{
var auditable = entity as IAuditable;
if (auditable != null)
insertItems.Add(entity);
return false;
}
}
Run Code Online (Sandbox Code Playgroud)