org.fabric3.jpa.runtime.proxy.StatefulEntityManagerProxy Maven / Gradle / Ivy
The newest version!
/*
* Fabric3
* Copyright (c) 2009-2015 Metaform Systems
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* Portions originally based on Apache Tuscany 2007
* licensed under the Apache 2.0 license.
*/
package org.fabric3.jpa.runtime.proxy;
import javax.persistence.EntityGraph;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.EntityTransaction;
import javax.persistence.FlushModeType;
import javax.persistence.LockModeType;
import javax.persistence.Query;
import javax.persistence.StoredProcedureQuery;
import javax.persistence.TypedQuery;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaDelete;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.CriteriaUpdate;
import javax.persistence.metamodel.Metamodel;
import javax.transaction.SystemException;
import javax.transaction.Transaction;
import javax.transaction.TransactionManager;
import java.util.List;
import java.util.Map;
import org.fabric3.api.host.Fabric3Exception;
import org.oasisopen.sca.ServiceRuntimeException;
/**
* An EntityManager proxy that delegates to a cached instance. This proxy is injected on stateless-scoped components. This proxy is not safe to
* inject on composite-scoped implementations.
*
* If the persistence context is transaction-scoped (as defined by JPA), the proxy will attempt to retrieve the EntityManager instance associated with the
* current transaction context from the EntityManagerService. The proxy will cache the EntityManager instance until the transaction completes.
*/
public class StatefulEntityManagerProxy implements HibernateProxy, EntityManager {
private String unitName;
private EntityManager em;
private EntityManagerService emService;
private TransactionManager tm;
public StatefulEntityManagerProxy(String unitName, EntityManagerService emService, TransactionManager tm) {
this.unitName = unitName;
this.emService = emService;
this.tm = tm;
}
public void persist(Object entity) {
initEntityManager();
em.persist(entity);
}
public T merge(T entity) {
initEntityManager();
return em.merge(entity);
}
public void remove(Object entity) {
initEntityManager();
em.remove(entity);
}
public T find(Class entityClass, Object primaryKey) {
initEntityManager();
return em.find(entityClass, primaryKey);
}
public T find(Class tClass, Object o, Map stringObjectMap) {
initEntityManager();
return em.find(tClass, o, stringObjectMap);
}
public T find(Class tClass, Object o, LockModeType lockModeType) {
initEntityManager();
return em.find(tClass, o, lockModeType);
}
public T find(Class tClass, Object o, LockModeType lockModeType, Map stringObjectMap) {
initEntityManager();
return em.find(tClass, o, lockModeType, stringObjectMap);
}
public T getReference(Class entityClass, Object primaryKey) {
initEntityManager();
return em.getReference(entityClass, primaryKey);
}
public void flush() {
initEntityManager();
em.flush();
}
public void setFlushMode(FlushModeType flushMode) {
initEntityManager();
em.setFlushMode(flushMode);
}
public FlushModeType getFlushMode() {
initEntityManager();
return em.getFlushMode();
}
public void lock(Object entity, LockModeType lockMode) {
initEntityManager();
em.lock(entity, lockMode);
}
public void lock(Object o, LockModeType lockModeType, Map stringObjectMap) {
initEntityManager();
em.lock(o, lockModeType, stringObjectMap);
}
public void refresh(Object entity) {
initEntityManager();
em.remove(entity);
}
public void refresh(Object o, Map stringObjectMap) {
initEntityManager();
em.refresh(o, stringObjectMap);
}
public void refresh(Object o, LockModeType lockModeType) {
initEntityManager();
em.refresh(o, lockModeType);
}
public void refresh(Object o, LockModeType lockModeType, Map stringObjectMap) {
initEntityManager();
em.refresh(o, lockModeType, stringObjectMap);
}
public void clear() {
initEntityManager();
em.clear();
}
public void detach(Object o) {
initEntityManager();
em.detach(o);
}
public boolean contains(Object entity) {
initEntityManager();
return em.contains(entity);
}
public LockModeType getLockMode(Object o) {
initEntityManager();
return em.getLockMode(o);
}
public void setProperty(String s, Object o) {
initEntityManager();
em.setProperty(s, o);
}
public Map getProperties() {
initEntityManager();
return em.getProperties();
}
public Query createQuery(String qlString) {
initEntityManager();
return em.createQuery(qlString);
}
public TypedQuery createQuery(CriteriaQuery tCriteriaQuery) {
initEntityManager();
return em.createQuery(tCriteriaQuery);
}
public Query createQuery(CriteriaUpdate updateQuery) {
initEntityManager();
return em.createQuery(updateQuery);
}
public Query createQuery(CriteriaDelete deleteQuery) {
initEntityManager();
return em.createQuery(deleteQuery);
}
public TypedQuery createQuery(String s, Class tClass) {
initEntityManager();
return em.createQuery(s, tClass);
}
public Query createNamedQuery(String name) {
initEntityManager();
return em.createNamedQuery(name);
}
public TypedQuery createNamedQuery(String s, Class tClass) {
initEntityManager();
return em.createNamedQuery(s, tClass);
}
public Query createNativeQuery(String sqlString) {
initEntityManager();
return em.createNativeQuery(sqlString);
}
public Query createNativeQuery(String sqlString, Class resultClass) {
initEntityManager();
return em.createNativeQuery(sqlString, resultClass);
}
public Query createNativeQuery(String sqlString, String resultSetMapping) {
initEntityManager();
return em.createNativeQuery(sqlString, resultSetMapping);
}
public StoredProcedureQuery createNamedStoredProcedureQuery(String name) {
initEntityManager();
return em.createNamedStoredProcedureQuery(name);
}
public StoredProcedureQuery createStoredProcedureQuery(String procedureName) {
initEntityManager();
return em.createStoredProcedureQuery(procedureName);
}
public StoredProcedureQuery createStoredProcedureQuery(String procedureName, Class... resultClasses) {
initEntityManager();
return em.createStoredProcedureQuery(procedureName, resultClasses);
}
public StoredProcedureQuery createStoredProcedureQuery(String procedureName, String... resultSetMappings) {
initEntityManager();
return em.createStoredProcedureQuery(procedureName, resultSetMappings);
}
public void joinTransaction() {
initEntityManager();
em.joinTransaction();
}
public boolean isJoinedToTransaction() {
initEntityManager();
return em.isJoinedToTransaction();
}
public T unwrap(Class tClass) {
initEntityManager();
return em.unwrap(tClass);
}
public Object getDelegate() {
initEntityManager();
return em.getDelegate();
}
public void close() {
initEntityManager();
em.close();
}
public boolean isOpen() {
initEntityManager();
return em.isOpen();
}
public EntityTransaction getTransaction() {
initEntityManager();
return em.getTransaction();
}
public EntityManagerFactory getEntityManagerFactory() {
initEntityManager();
return em.getEntityManagerFactory();
}
public CriteriaBuilder getCriteriaBuilder() {
initEntityManager();
return em.getCriteriaBuilder();
}
public Metamodel getMetamodel() {
initEntityManager();
return em.getMetamodel();
}
public EntityGraph createEntityGraph(Class rootType) {
initEntityManager();
return em.createEntityGraph(rootType);
}
public EntityGraph> createEntityGraph(String graphName) {
initEntityManager();
return em.createEntityGraph(graphName);
}
public EntityGraph> getEntityGraph(String graphName) {
initEntityManager();
return em.getEntityGraph(graphName);
}
public List> getEntityGraphs(Class entityClass) {
initEntityManager();
return em.getEntityGraphs(entityClass);
}
public void clearEntityManager() {
em = null;
}
/**
* Initializes the delegated EntityManager. If the persistence context is transaction-scoped, the EntityManager associated with the current transaction will
* be used. Otherwise, if the persistence context is extended, the EntityManager associated with the current conversation will be used.
*/
private void initEntityManager() {
if (em != null) {
return;
}
// a transaction-scoped persistence context
try {
Transaction trx = tm.getTransaction();
if (trx == null) {
throw new IllegalStateException("A transaction is not active - ensure the component is executing in a managed transaction");
}
em = emService.getEntityManager(unitName, this, trx);
} catch (SystemException | Fabric3Exception e) {
throw new ServiceRuntimeException(e);
}
}
}