/**
* vlove - web based virtual machine management
* Copyright (C) 2010 Limone Fresco Limited
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
package vlove.dao.impl;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import javax.persistence.EntityManager;
import javax.persistence.NoResultException;
import javax.persistence.PersistenceContext;
import javax.persistence.Query;
import org.springframework.stereotype.Repository;
import org.springframework.transaction.annotation.Transactional;
import vlove.dao.GenericDao;
@Repository
@Transactional
public class GenericDaoImpl implements GenericDao {
@PersistenceContext
private EntityManager em;
private static void applyParameters(Query query, Map<String, Object> parameters) {
if (parameters != null) {
for (Entry<String, Object> e : parameters.entrySet()) {
query.setParameter(e.getKey(), e.getValue());
}
}
}
/**
* @see vlove.dao.GenericDao#find(Class, Object)
*/
@Override
public <T> T find(Class<T> entityClass, Object identifier) {
return em.find(entityClass, identifier);
}
/**
* @see vlove.dao.GenericDao#merge(Object)
*/
@Override
public <T> T merge(T entity) {
return em.merge(entity);
}
/**
* @see vlove.dao.GenericDao#persist(Object)
*/
@Override
public <T> T persist(T entity) {
em.persist(entity);
return entity;
}
/**
* @see vlove.dao.GenericDao#query(String, Map)
*/
@Override
public <T> List<T> query(String query, Map<String, Object> parameters) {
Query q = em.createQuery(query);
applyParameters(q, parameters);
return q.getResultList();
}
/**
* @see vlove.dao.GenericDao#query(String, Map, int, int)
*/
@Override
public <T> List<T> query(String query, Map<String, Object> parameters, int firstResult, int maxResults) {
Query q = em.createQuery(query).setFirstResult(firstResult).setMaxResults(maxResults);
applyParameters(q, parameters);
return q.getResultList();
}
/**
* @see vlove.dao.GenericDao#namedQuery(String, Map)
*/
@Override
public <T> List<T> namedQuery(String query, Map<String, Object> parameters) {
Query q = em.createNamedQuery(query);
applyParameters(q, parameters);
return q.getResultList();
}
/**
* @see vlove.dao.GenericDao#namedQuery(String, Map, int, int)
*/
@Override
public <T> List<T> namedQuery(String query, Map<String, Object> parameters, int firstResult, int maxResults) {
Query q = em.createNamedQuery(query).setFirstResult(firstResult).setMaxResults(maxResults);
applyParameters(q, parameters);
return q.getResultList();
}
/**
* @see vlove.dao.GenericDao#namedQuerySingle(String, Map)
*/
@Override
public <T> T namedQuerySingle(String query, Map<String, Object> parameters) {
Query q = em.createNamedQuery(query);
applyParameters(q, parameters);
try {
return (T) q.getSingleResult();
} catch (NoResultException nre) {
return null;
}
}
/**
* @see vlove.dao.GenericDao#querySingle(String, Map)
*/
@Override
public <T> T querySingle(String query, Map<String, Object> parameters) {
Query q = em.createQuery(query);
applyParameters(q, parameters);
return (T) q.getSingleResult();
}
/**
* @see vlove.dao.GenericDao#remove(Object)
*/
@Override
public void remove(Object entity) {
if (em.contains(entity)) {
em.remove(entity);
}
}
/**
* @see vlove.dao.GenericDao#refresh(Object)
*/
@Override
public void refresh(Object entity) {
em.refresh(entity);
}
/**
* @see vlove.dao.GenericDao#nativeQuery(String, Map, Integer)
*/
@Override
public <T> List<T> nativeQuery(String query, Map<String, Object> parameters, Integer maxResults) {
Query q = em.createNativeQuery(query);
if (maxResults != null) {
q.setMaxResults(maxResults);
}
applyParameters(q, parameters);
return q.getResultList();
}
}