Example usage for org.hibernate.event.spi PostCollectionRecreateEvent getCollection

List of usage examples for org.hibernate.event.spi PostCollectionRecreateEvent getCollection

Introduction

In this page you can find the example usage for org.hibernate.event.spi PostCollectionRecreateEvent getCollection.

Prototype

public PersistentCollection getCollection() 

Source Link

Usage

From source file:com.googlecode.hibernate.audit.listener.AuditListener.java

License:Open Source License

public void onPostRecreateCollection(PostCollectionRecreateEvent event) {
    try {/*ww w .  ja  v a2  s.  c  o  m*/
        String entityName = event.getAffectedOwnerEntityName();

        if (auditConfiguration.getExtensionManager().getAuditableInformationProvider().isAuditable(entityName)
                && (recordEmptyCollectionsOnInsert || !event.getCollection().empty())) {
            AuditProcess auditProcess = auditConfiguration.getAuditProcessManager().get(event.getSession());
            AuditWorkUnit workUnit = new InsertCollectionAuditWorkUnit(entityName,
                    event.getAffectedOwnerIdOrNull(), event.getAffectedOwnerOrNull(), event.getCollection());
            auditProcess.addWorkUnit(workUnit);
        }
    } catch (RuntimeException e) {
        if (log.isErrorEnabled()) {
            log.error("RuntimeException occured during onPostRecreateCollection, will re-throw the exception",
                    e);
        }
        throw e;
    }
}