org.hibernate.proxy.ProxyFactory Maven / Gradle / Ivy
/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
* See the lgpl.txt file in the root directory or .
*/
package org.hibernate.proxy;
import java.io.Serializable;
import java.lang.reflect.Method;
import java.util.Set;
import org.hibernate.HibernateException;
import org.hibernate.engine.spi.SharedSessionContractImplementor;
import org.hibernate.type.CompositeType;
/**
* Contract for run-time, proxy-based lazy initialization proxies.
*
* @author Gavin King
*/
public interface ProxyFactory {
/**
* Called immediately after instantiation of this factory.
*
* Essentially equivalent to constructor injection, but contracted
* here via interface.
*
* @param entityName The name of the entity for which this factory should
* generate proxies.
* @param persistentClass The entity class for which to generate proxies;
* not always the same as the entityName.
* @param interfaces The interfaces to expose in the generated proxy;
* {@link HibernateProxy} is already included in this collection.
* @param getIdentifierMethod Reference to the identifier getter method;
* invocation on this method should not force initialization
* @param setIdentifierMethod Reference to the identifier setter method;
* invocation on this method should not force initialization
* @param componentIdType For composite identifier types, a reference to
* the {@link org.hibernate.type.CompositeType type} of the identifier
* property; again accessing the id should generally not cause
* initialization - but need to bear in mind
* mappings.
* @throws HibernateException Indicates a problem completing post
* instantiation initialization.
*/
void postInstantiate(
String entityName,
Class persistentClass,
Set interfaces,
Method getIdentifierMethod,
Method setIdentifierMethod,
CompositeType componentIdType) throws HibernateException;
/**
* Create a new proxy instance
*
* @param id The id value for the proxy to be generated.
* @param session The session to which the generated proxy will be
* associated.
* @return The generated proxy.
* @throws HibernateException Indicates problems generating the requested
* proxy.
*/
HibernateProxy getProxy(Serializable id, SharedSessionContractImplementor session) throws HibernateException;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy