All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.fabric3.jpa.runtime.proxy.StatefulEntityManagerProxy Maven / Gradle / Ivy

/*
 * 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.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 | EntityManagerCreationException e) { throw new ServiceRuntimeException(e); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy