Class AbstractCollectionMapper<T>
java.lang.Object
org.hibernate.envers.internal.entities.mapper.AbstractMapper
org.hibernate.envers.internal.entities.mapper.AbstractPropertyMapper
org.hibernate.envers.internal.entities.mapper.relation.AbstractCollectionMapper<T>
- All Implemented Interfaces:
DynamicComponentMapperSupport,ModifiedFlagMapperSupport,PropertyMapper
- Direct Known Subclasses:
BasicCollectionMapper,ListCollectionMapper,MapCollectionMapper
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected final CommonCollectionMapperDataprotected final Configurationprotected final booleanprotected final boolean -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedAbstractCollectionMapper(Configuration configuration, CommonCollectionMapperData commonCollectionMapperData, Class<? extends T> collectionClass, Class<? extends T> proxyClass, boolean ordinalInId, boolean revisionTypeInId) -
Method Summary
Modifier and TypeMethodDescriptionprotected voidaddCollectionChanges(SessionImplementor session, List<PersistentCollectionChangeData> collectionChanges, Set<Object> changed, RevisionType revisionType, Object id) buildCollectionChangeSet(Object eventCollection, Collection collection) createIdMap(int ordinal) Creates map for storing identifier data.protected abstract Initializor<T>getInitializor(EnversService enversService, AuditReaderImplementor versionsReader, Object primaryKey, Number revision, boolean removed) protected abstract CollectiongetNewCollectionContent(PersistentCollection newCollection) protected abstract CollectiongetOldCollectionContent(Serializable oldCollection) booleanReturns whether the associatedPropertyMapperhas any properties that use thewitModifiedFlagfeature.protected booleanisSame(CollectionPersister collectionPersister, Object oldObject, Object newObject) Checks whether the old collection element and new collection element are the same.mapCollectionChanges(SessionImplementor session, String referencingPropertyName, PersistentCollection newColl, Serializable oldColl, Object id) Maps collection changes.protected abstract List<PersistentCollectionChangeData>mapCollectionChanges(SessionImplementor session, PersistentCollection newColl, Serializable oldColl, Object id) Map collection changes using hash identity.voidmapModifiedFlagsToMapForCollectionChange(String collectionPropertyName, Map<String, Object> data) voidmapModifiedFlagsToMapFromEntity(SessionImplementor session, Map<String, Object> data, Object newObj, Object oldObj) voidmapToEntityFromMap(EnversService enversService, Object obj, Map data, Object primaryKey, AuditReaderImplementor versionsReader, Number revision) Maps properties from the given map to the given object.mapToEntityFromMap(EnversService enversService, Map data, Object primaryKey, AuditReaderImplementor versionsReader, Number revision) booleanmapToMapFromEntity(SessionImplementor session, Map<String, Object> data, Object newObj, Object oldObj) Maps properties to the given map, basing on differences between properties of new and old objects.protected abstract voidmapToMapFromObject(SessionImplementor session, Map<String, Object> idData, Map<String, Object> data, Object changed) Maps the changed collection element to the given map.protected CollectionPersisterresolveCollectionPersister(SessionImplementor session, PersistentCollection collection) Methods inherited from class org.hibernate.envers.internal.entities.mapper.AbstractPropertyMapper
isDynamicComponentMap, markAsDynamicComponentMapMethods inherited from class org.hibernate.envers.internal.entities.mapper.AbstractMapper
getAndSetValue, getValueFromObject, getValueFromObject, newObjectInstance, setValueOnObject
-
Field Details
-
configuration
-
commonCollectionMapperData
-
collectionClass
-
ordinalInId
protected final boolean ordinalInId -
revisionTypeInId
protected final boolean revisionTypeInId
-
-
Constructor Details
-
AbstractCollectionMapper
protected AbstractCollectionMapper(Configuration configuration, CommonCollectionMapperData commonCollectionMapperData, Class<? extends T> collectionClass, Class<? extends T> proxyClass, boolean ordinalInId, boolean revisionTypeInId)
-
-
Method Details
-
getNewCollectionContent
-
getOldCollectionContent
-
buildCollectionChangeSet
protected abstract Set<Object> buildCollectionChangeSet(Object eventCollection, Collection collection) -
mapToMapFromObject
protected abstract void mapToMapFromObject(SessionImplementor session, Map<String, Object> idData, Map<String, Object> data, Object changed) Maps the changed collection element to the given map.- Parameters:
idData- Map to which composite-id data should be added.data- Where to map the data.changed- The changed collection element to map.
-
createIdMap
Creates map for storing identifier data. Ordinal parameter guarantees uniqueness of primary key. Composite primary key cannot contain embeddable properties since they might be nullable.- Parameters:
ordinal- Iteration ordinal.- Returns:
- Map for holding identifier data.
-
addCollectionChanges
protected void addCollectionChanges(SessionImplementor session, List<PersistentCollectionChangeData> collectionChanges, Set<Object> changed, RevisionType revisionType, Object id) -
mapCollectionChanges
public List<PersistentCollectionChangeData> mapCollectionChanges(SessionImplementor session, String referencingPropertyName, PersistentCollection newColl, Serializable oldColl, Object id) Description copied from interface:PropertyMapperMaps collection changes.- Parameters:
session- The current session.referencingPropertyName- Name of the field, which holds the collection in the entity.newColl- New collection, after updates.oldColl- Old collection, before updates.id- Id of the object owning the collection.- Returns:
- List of changes that need to be performed on the persistent store.
-
mapToMapFromEntity
public boolean mapToMapFromEntity(SessionImplementor session, Map<String, Object> data, Object newObj, Object oldObj) Description copied from interface:PropertyMapperMaps properties to the given map, basing on differences between properties of new and old objects.- Parameters:
session- The current session.data- Data to map to.newObj- New state of the entity.oldObj- Old state of the entity.- Returns:
- True if there are any differences between the states represented by newObj and oldObj.
-
mapModifiedFlagsToMapFromEntity
-
mapModifiedFlagsToMapForCollectionChange
-
getInitializor
protected abstract Initializor<T> getInitializor(EnversService enversService, AuditReaderImplementor versionsReader, Object primaryKey, Number revision, boolean removed) -
resolveCollectionPersister
protected CollectionPersister resolveCollectionPersister(SessionImplementor session, PersistentCollection collection) -
isSame
protected boolean isSame(CollectionPersister collectionPersister, Object oldObject, Object newObject) Checks whether the old collection element and new collection element are the same. By default, this delegates to the collection persister'sCollectionPersister.getElementType().- Parameters:
collectionPersister- The collection persister.oldObject- The collection element from the old persistent collection.newObject- The collection element from the new persistent collection.- Returns:
- true if the two objects are the same, false otherwise.
-
mapToEntityFromMap
public void mapToEntityFromMap(EnversService enversService, Object obj, Map data, Object primaryKey, AuditReaderImplementor versionsReader, Number revision) Description copied from interface:PropertyMapperMaps properties from the given map to the given object.- Parameters:
enversService- The EnversService.obj- Object to map to.data- Data to map from.primaryKey- Primary key of the object to which we map (for relations)versionsReader- VersionsReader for reading relationsrevision- Revision at which the object is read, for reading relations
-
mapToEntityFromMap
public Object mapToEntityFromMap(EnversService enversService, Map data, Object primaryKey, AuditReaderImplementor versionsReader, Number revision) -
mapCollectionChanges
protected abstract List<PersistentCollectionChangeData> mapCollectionChanges(SessionImplementor session, PersistentCollection newColl, Serializable oldColl, Object id) Map collection changes using hash identity.- Parameters:
session- The session.newColl- The new persistent collection.oldColl- The old collection.id- The owning entity identifier.- Returns:
- the persistent collection changes.
-
hasPropertiesWithModifiedFlag
public boolean hasPropertiesWithModifiedFlag()Description copied from interface:ModifiedFlagMapperSupportReturns whether the associatedPropertyMapperhas any properties that use thewitModifiedFlagfeature.- Returns:
trueif a property useswithModifiedFlag, otherwisefalse.
-