Package org.hibernate.proxy
Class AbstractLazyInitializer
- java.lang.Object
-
- org.hibernate.proxy.AbstractLazyInitializer
-
- All Implemented Interfaces:
LazyInitializer
- Direct Known Subclasses:
BasicLazyInitializer,MapLazyInitializer
public abstract class AbstractLazyInitializer extends java.lang.Object implements LazyInitializer
Convenience base class for lazy initialization handlers. Centralizes the basic plumbing of doing lazy initialization freeing subclasses to acts as essentially adapters to their intended entity mode and/or proxy generation strategy.
-
-
Constructor Summary
Constructors Modifier Constructor Description protectedAbstractLazyInitializer()Deprecated.This constructor was initially intended for serialization only, and is not useful anymore.protectedAbstractLazyInitializer(java.lang.String entityName, java.io.Serializable id, SharedSessionContractImplementor session)Main constructor.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description java.lang.StringgetEntityName()The entity-name of the entity our owning proxy represents.java.io.SerializablegetIdentifier()Retrieve the identifier value for the entity our owning proxy represents.java.lang.ObjectgetImplementation()Return the underlying persistent object, initializing if necessaryjava.lang.ObjectgetImplementation(SharedSessionContractImplementor s)Return the underlying persistent object in the given session, or null if not contained in this session's persistence context.java.io.SerializablegetInternalIdentifier()Retrieve the identifier value for the entity our owning proxy represents.SharedSessionContractImplementorgetSession()Get the session to which this proxy is associated, or null if it is not attached.protected java.lang.StringgetSessionFactoryUuid()Get the session factory UUID.protected java.lang.ObjectgetTarget()Getter for property 'target'.voidinitialize()Initialize the proxy, fetching the target entity if necessary.voidinitializeWithoutLoadIfPossible()Attempt to initialize the proxy without loading anything from the database.protected booleanisAllowLoadOutsideTransaction()Get whether the proxy can load data even if it's not attached to a session with an ongoing transaction.protected booleanisConnectedToSession()Getter for property 'connectedToSession'.booleanisReadOnly()Is the proxy read-only?.java.lang.BooleanisReadOnlyBeforeAttachedToSession()Get the read-only/modifiable setting that should be put in affect when it is attached to a session.booleanisReadOnlySettingAvailable()Is the proxy's read-only/modifiable setting available?booleanisUninitialized()Is the proxy uninitialzed?booleanisUnwrap()protected voidpermissiveInitialization()protected voidprepareForPossibleLoadingOutsideTransaction()Initialize internal state based on the currently attached session, in order to be ready to load data even after the proxy is detached from the session.voidsetIdentifier(java.io.Serializable id)Set the identifier value for the entity our owning proxy represents.voidsetImplementation(java.lang.Object target)Initialize the proxy manually by injecting its target.voidsetReadOnly(boolean readOnly)Set an associated modifiable proxy to read-only mode, or a read-only proxy to modifiable mode.voidsetSession(SharedSessionContractImplementor s)Associate the proxy with the given session.voidsetUnwrap(boolean unwrap)voidunsetSession()Unset this initializer's reference to session.-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.hibernate.proxy.LazyInitializer
getPersistentClass
-
-
-
-
Constructor Detail
-
AbstractLazyInitializer
@Deprecated protected AbstractLazyInitializer()
Deprecated.This constructor was initially intended for serialization only, and is not useful anymore. In any case it should not be relied on by user code. Subclasses should rather implement Serializable with anObject writeReplace()method returning a subclass ofAbstractSerializableProxy, which in turn implements Serializable and anObject readResolve()method instantiating theAbstractLazyInitializersubclass and callingAbstractSerializableProxy.afterDeserialization(AbstractLazyInitializer)on it. SeeByteBuddyInterceptorandSerializableProxyfor examples.
-
AbstractLazyInitializer
protected AbstractLazyInitializer(java.lang.String entityName, java.io.Serializable id, SharedSessionContractImplementor session)Main constructor.- Parameters:
entityName- The name of the entity being proxied.id- The identifier of the entity being proxied.session- The session owning the proxy.
-
-
Method Detail
-
getEntityName
public final java.lang.String getEntityName()
Description copied from interface:LazyInitializerThe entity-name of the entity our owning proxy represents.- Specified by:
getEntityNamein interfaceLazyInitializer- Returns:
- The entity-name.
-
getInternalIdentifier
public final java.io.Serializable getInternalIdentifier()
Description copied from interface:LazyInitializerRetrieve the identifier value for the entity our owning proxy represents.- Specified by:
getInternalIdentifierin interfaceLazyInitializer- Returns:
- The identifier value.
-
getIdentifier
public final java.io.Serializable getIdentifier()
Description copied from interface:LazyInitializerRetrieve the identifier value for the entity our owning proxy represents. When JPA proxy compliance is enabled the proxy is initialized.- Specified by:
getIdentifierin interfaceLazyInitializer- Returns:
- The identifier value.
-
setIdentifier
public final void setIdentifier(java.io.Serializable id)
Description copied from interface:LazyInitializerSet the identifier value for the entity our owning proxy represents.- Specified by:
setIdentifierin interfaceLazyInitializer- Parameters:
id- The identifier value.
-
isUninitialized
public final boolean isUninitialized()
Description copied from interface:LazyInitializerIs the proxy uninitialzed?- Specified by:
isUninitializedin interfaceLazyInitializer- Returns:
- True if uninitialized; false otherwise.
-
getSession
public final SharedSessionContractImplementor getSession()
Description copied from interface:LazyInitializerGet the session to which this proxy is associated, or null if it is not attached.- Specified by:
getSessionin interfaceLazyInitializer- Returns:
- The associated session.
-
setSession
public final void setSession(SharedSessionContractImplementor s) throws HibernateException
Description copied from interface:LazyInitializerAssociate the proxy with the given session. Care should be given to make certain that the proxy is added to the session's persistence context as well to maintain the symetry of the association. That must be done seperately as this method simply sets an internal reference. We do also check that if there is already an associated session that the proxy reference was removed from that previous session's persistence contet.- Specified by:
setSessionin interfaceLazyInitializer- Parameters:
s- The session- Throws:
HibernateException- Indicates that the proxy was still contained in the persistence context of the "previous session".
-
unsetSession
public final void unsetSession()
Description copied from interface:LazyInitializerUnset this initializer's reference to session. It is assumed that the caller is also taking care or cleaning up the owning proxy's reference in the persistence context. Generally speaking this is intended to be called only duringSession.evict(java.lang.Object)andSession.clear()processing; most other use-cases should callLazyInitializer.setSession(org.hibernate.engine.spi.SharedSessionContractImplementor)instead.- Specified by:
unsetSessionin interfaceLazyInitializer
-
initialize
public final void initialize() throws HibernateExceptionDescription copied from interface:LazyInitializerInitialize the proxy, fetching the target entity if necessary.- Specified by:
initializein interfaceLazyInitializer- Throws:
HibernateException- Indicates a problem initializing the proxy.
-
permissiveInitialization
protected void permissiveInitialization()
-
initializeWithoutLoadIfPossible
public final void initializeWithoutLoadIfPossible()
Attempt to initialize the proxy without loading anything from the database. This will only have any effect if the proxy is still attached to a session, and the entity being proxied has been loaded and added to the persistence context of that session since the proxy was created.
-
prepareForPossibleLoadingOutsideTransaction
protected void prepareForPossibleLoadingOutsideTransaction()
Initialize internal state based on the currently attached session, in order to be ready to load data even after the proxy is detached from the session. This method only has any effect ifSessionFactoryOptions.isInitializeLazyStateOutsideTransactionsEnabled()istrue.
-
isConnectedToSession
protected final boolean isConnectedToSession()
Getter for property 'connectedToSession'.- Returns:
- Value for property 'connectedToSession'.
-
getImplementation
public final java.lang.Object getImplementation()
Description copied from interface:LazyInitializerReturn the underlying persistent object, initializing if necessary- Specified by:
getImplementationin interfaceLazyInitializer- Returns:
- The underlying target entity.
-
setImplementation
public final void setImplementation(java.lang.Object target)
Description copied from interface:LazyInitializerInitialize the proxy manually by injecting its target.- Specified by:
setImplementationin interfaceLazyInitializer- Parameters:
target- The proxy target (the actual entity being proxied).
-
getImplementation
public final java.lang.Object getImplementation(SharedSessionContractImplementor s) throws HibernateException
Description copied from interface:LazyInitializerReturn the underlying persistent object in the given session, or null if not contained in this session's persistence context.- Specified by:
getImplementationin interfaceLazyInitializer- Parameters:
s- The session to check- Returns:
- The target, or null.
- Throws:
HibernateException- Indicates problem locating the target.
-
getTarget
protected final java.lang.Object getTarget()
Getter for property 'target'. Same asgetImplementation()except that this method will not force initialization.- Returns:
- Value for property 'target'.
-
isReadOnlySettingAvailable
public final boolean isReadOnlySettingAvailable()
Description copied from interface:LazyInitializerIs the proxy's read-only/modifiable setting available?- Specified by:
isReadOnlySettingAvailablein interfaceLazyInitializer- Returns:
- true, if the setting is available false, if the proxy is detached or its associated session is closed
-
isReadOnly
public final boolean isReadOnly()
Description copied from interface:LazyInitializerIs the proxy read-only?. The read-only/modifiable setting is not available when the proxy is detached or its associated session is closed. To check if the read-only/modifiable setting is available:- Specified by:
isReadOnlyin interfaceLazyInitializer- Returns:
- true, if this proxy is read-only; false, otherwise
- See Also:
LazyInitializer.isReadOnlySettingAvailable(),Session.isReadOnly(Object entityOrProxy)
-
setReadOnly
public final void setReadOnly(boolean readOnly)
Description copied from interface:LazyInitializerSet an associated modifiable proxy to read-only mode, or a read-only proxy to modifiable mode. If the proxy is currently initialized, its implementation will be set to the same mode; otherwise, when the proxy is initialized, its implementation will have the same read-only/ modifiable setting as the proxy. In read-only mode, no snapshot is maintained and the instance is never dirty checked. If the associated proxy already has the specified read-only/modifiable setting, then this method does nothing.- Specified by:
setReadOnlyin interfaceLazyInitializer- Parameters:
readOnly- if true, the associated proxy is made read-only; if false, the associated proxy is made modifiable.- See Also:
Session.setReadOnly(Object entityOrProxy, boolean readOnly)
-
isReadOnlyBeforeAttachedToSession
public final java.lang.Boolean isReadOnlyBeforeAttachedToSession()
Get the read-only/modifiable setting that should be put in affect when it is attached to a session. This method should only be called during serialization when read-only/modifiable setting is not available (i.e., isReadOnlySettingAvailable() == false)- Returns:
- null, if the default setting should be used; true, for read-only; false, for modifiable
- Throws:
java.lang.IllegalStateException- if isReadOnlySettingAvailable() == true
-
isAllowLoadOutsideTransaction
protected boolean isAllowLoadOutsideTransaction()
Get whether the proxy can load data even if it's not attached to a session with an ongoing transaction. This method should only be called during serialization, and only makes sense after a call toprepareForPossibleLoadingOutsideTransaction().- Returns:
trueif out-of-transaction loads are allowed,falseotherwise.
-
getSessionFactoryUuid
protected java.lang.String getSessionFactoryUuid()
Get the session factory UUID. This method should only be called during serialization, and only makes sense after a call toprepareForPossibleLoadingOutsideTransaction().- Returns:
- the session factory UUID.
-
isUnwrap
public boolean isUnwrap()
- Specified by:
isUnwrapin interfaceLazyInitializer
-
setUnwrap
public void setUnwrap(boolean unwrap)
- Specified by:
setUnwrapin interfaceLazyInitializer
-
-