--- /dev/null
+/*****************************************************************************
+ * Copyright Igor Barma, Eric Brun, Alexandre Desoubeaux, Christian Martel,
+ * (2 décembre 2008)
+ *
+ * Ce logiciel est un programme informatique servant à l'évaluation des
+ * compétences.
+ *
+ * Ce logiciel est régi par la licence CeCILL soumise au droit français et
+ * respectant les principes de diffusion des logiciels libres. Vous pouvez
+ * utiliser, modifier et/ou redistribuer ce programme sous les conditions
+ * de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA
+ * sur le site "http://www.cecill.info".
+ *
+ * En contrepartie de l'accessibilité au code source et des droits de copie,
+ * de modification et de redistribution accordés par cette licence, il n'est
+ * offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons,
+ * seule une responsabilité restreinte pèse sur l'auteur du programme, le
+ * titulaire des droits patrimoniaux et les concédants successifs.
+ *
+ * A cet égard l'attention de l'utilisateur est attirée sur les risques
+ * associés au chargement, à l'utilisation, à la modification et/ou au
+ * développement et à la reproduction du logiciel par l'utilisateur étant
+ * donné sa spécificité de logiciel libre, qui peut le rendre complexe à
+ * manipuler et qui le réserve donc à des développeurs et des professionnels
+ * avertis possédant des connaissances informatiques approfondies. Les
+ * utilisateurs sont donc invités à charger et tester l'adéquation du
+ * logiciel à leurs besoins dans des conditions permettant d'assurer la
+ * sécurité de leurs systèmes et ou de leurs données et, plus généralement,
+ * à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.
+ *
+ * Le fait que vous puissiez accéder à cet en-tête signifie que vous avez
+ * pris connaissance de la licence CeCILL, et que vous en avez accepté les
+ * termes.
+ *******************************************************************************/
+package com.pentila.evalcomp.dao.impl;
+
+import java.io.Serializable;
+import java.lang.reflect.ParameterizedType;
+import java.util.Collection;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+
+import org.springframework.orm.hibernate3.HibernateTemplate;
+import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
+
+import com.pentila.evalcomp.dao.GenericDAO;
+
+
+/**
+ * The Class GenericDAOImpl.
+ *
+ * @param <T> the
+ * @param <ID> the
+ */
+public abstract class GenericDAOImpl<T, ID extends Serializable> extends
+HibernateDaoSupport implements GenericDAO<T, ID> {
+
+ /** The persistent class. */
+ private Class<T> persistentClass;
+
+ /**
+ * Instantiates a new generic dao impl.
+ */
+ public GenericDAOImpl() {
+ this.persistentClass = (Class<T>) ((ParameterizedType) getClass()
+ .getGenericSuperclass()).getActualTypeArguments()[0];
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see com.pentila.evalcomp.dao.GenericDAO#delete(java.lang.Object)
+ */
+ public void delete(T t) {
+ getCachableHibernateTemplate().delete(t);
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see com.pentila.evalcomp.dao.GenericDAO#evict(java.lang.Object)
+ */
+ public void evict(T t) {
+ getCachableHibernateTemplate().evict(t);
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see com.pentila.evalcomp.dao.GenericDAO#flush()
+ */
+ public void flush() {
+ getCachableHibernateTemplate().flush();
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see com.pentila.evalcomp.dao.GenericDAO#get(java.io.Serializable)
+ */
+ public T get(ID id) {
+ return getCachableHibernateTemplate().get(getPersistentClass(), id);
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see com.pentila.evalcomp.dao.GenericDAO#getAll()
+ */
+ public Set<T> getAll() {
+ List<T> l = getCachableHibernateTemplate().find(
+ "from " + this.getPersistentClass().getName());
+ if (l != null) {
+ return new HashSet<T>(l);
+ }
+ return null;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see com.pentila.evalcomp.dao.GenericDAO#getByExample(java.lang.Object)
+ */
+ public List<T> getByExample(T t) {
+ return getCachableHibernateTemplate().findByExample(t);
+ }
+
+ /**
+ * Gets the persistent class.
+ *
+ * @return the persistent class
+ */
+ public Class<T> getPersistentClass() {
+ return persistentClass;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see com.pentila.evalcomp.dao.GenericDAO#merge(java.lang.Object)
+ */
+ public T merge(T t) {
+ return getCachableHibernateTemplate().merge(t);
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see com.pentila.evalcomp.dao.GenericDAO#saveOrUpdate(java.lang.Object)
+ */
+ public T saveOrUpdate(T t) {
+ getCachableHibernateTemplate().saveOrUpdate(t);
+ return t;
+ }
+
+ public void deleteAll(Collection<T> entities){
+ getCachableHibernateTemplate().deleteAll(entities);
+
+
+ }
+
+
+ public void saveOrUpdateAll(Collection<T> entities){
+ getCachableHibernateTemplate().saveOrUpdateAll(entities);
+
+
+ }
+
+ public HibernateTemplate getCachableHibernateTemplate(){
+ getHibernateTemplate().setCacheQueries(true);
+ getHibernateTemplate().setQueryCacheRegion(this.persistentClass.getCanonicalName());
+
+ return getHibernateTemplate();
+ }
+
+}