Auditoria de Envios Condicionais
Eu tenho um requisito onde eu quero registros de auditoria apenas na mudança do campo Status. Eu segui o tutorial do capítulo de documentação "15.8. Auditoria condicional".
Etapa 1: Desativar o registro automático de ouvintes de eventos do Envers. Eu tenho seguinte:
<prop key="hibernate.listeners.envers.autoRegister">false</prop>
Etapa 2: crie subclasses para os ouvintes de eventos apropriados.
public class DeleteEnversListener extends EnversPostDeleteEventListenerImpl {
private static final long serialVersionUID = 5906427978349712224L;
private static Log log = LogFactory.getLog(DeleteEnversListener.class);
public DeleteEnversListener(AuditConfiguration enversConfiguration) {
super(enversConfiguration);
}
@Override
public void onPostDelete(PostDeleteEvent event) {
log.info("!!! just logging entity !! "+ event.getEntity());
super.onPostDelete(event);
}
}
De maneira semelhante, eu tenho
InsertEnversListenerUpdateEnversListenerDeleteEnversListenerCollectionRecreateEnversListenerPreCollectionRemoveEnversListenerPreCollectionUpdateEnversListenerEtapa 3: crie sua própria implementação deorg.hibernate.integrator.spi.Integrator
public class CustomEnversIntegrator extends EnversIntegrator {
private static Log log = LogFactory.getLog(CustomEnversIntegrator.class);
@Override
public void integrate(Configuration configuration,
SessionFactoryImplementor sessionFactory,
SessionFactoryServiceRegistry serviceRegistry) {
super.integrate(configuration, sessionFactory, serviceRegistry);
final AuditConfiguration enversConfiguration = AuditConfiguration.getFor( configuration, serviceRegistry.getService( ClassLoaderService.class ) );
EventListenerRegistry listenerRegistry = serviceRegistry.getService( EventListenerRegistry.class );
System.out.println("Registering event listeners");
if (enversConfiguration.getEntCfg().hasAuditedEntities()) {
listenerRegistry.appendListeners(EventType.POST_INSERT, new InsertEnversListener(enversConfiguration));
listenerRegistry.appendListeners(EventType.POST_UPDATE, new UpdateEnversListener(enversConfiguration));
listenerRegistry.appendListeners(EventType.POST_DELETE, new DeleteEnversListener(enversConfiguration ) );
listenerRegistry.appendListeners(EventType.POST_COLLECTION_RECREATE, new CollectionRecreateEnversListener(enversConfiguration ) );
listenerRegistry.appendListeners(EventType.PRE_COLLECTION_REMOVE, new PreCollectionRemoveEnversListener(enversConfiguration ) );
listenerRegistry.appendListeners(EventType.PRE_COLLECTION_UPDATE, new PreCollectionUpdateEnversListener(enversConfiguration ) );
}
}
}
Passo 4: Para o integrador ser usado automaticamente quando o Hibernate for iniciado, você precisará adicionar umMETA-INF/services/org.hibernate.integrator.spi.Integrator
Arquivo. Aqui está o conteúdo deorg.hibernate.integrator.spi.Integrator
Arquivo
com.hib.sample.listener.CustomEnversIntegrator
Não tenho certeza se estou perdendo alguma coisa. Estou usando o JBOSS AS 7.0 com o Hibernate 4.1.8