/** * GRANITE DATA SERVICES * Copyright (C) 2006-2015 GRANITE DATA SERVICES S.A.S. * * This file is part of the Granite Data Services Platform. * * Granite Data Services is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * Granite Data Services is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser * General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, * USA, or see <http://www.gnu.org/licenses/>. */ package org.granite.tide.hibernate; import java.io.Serializable; import org.granite.hibernate.HibernateOptimisticLockException; import org.granite.tide.data.TidePersistenceAdapter; import org.hibernate.Criteria; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.criterion.Restrictions; /** * Implementation of Tide persistence adapter with a Hibernate Session * @author William DRAI * */ public class HibernatePersistenceAdapter implements TidePersistenceAdapter { private Session session; public HibernatePersistenceAdapter(SessionFactory sessionFactory) { this.session = sessionFactory.getCurrentSession(); } public HibernatePersistenceAdapter(Session session) { this.session = session; } /** * Find an entity in the persistence context * @param entityClass class of the looked up entity * @param id entity identifier * @return the entity with the persistence context. */ public Object find(Class<?> entityClass, Serializable id) { // Use Criteria instead of Session.load() to avoid getting proxies Criteria criteria = session.createCriteria(entityClass); criteria.add(Restrictions.idEq(id)); return criteria.uniqueResult(); } /** * Throw an optimistic locking error * @param entity entity instance loaded from the database */ public void throwOptimisticLockException(Object entity) { throw new HibernateOptimisticLockException("Change detected on stale object", null, entity); } }