--- /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.util.ArrayList;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+import com.pentila.evalcomp.dao.ICompetenceInstanceDAO;
+import com.pentila.evalcomp.domain.definition.EvaluationDefinition;
+import com.pentila.evalcomp.domain.definition.Referentiel;
+import com.pentila.evalcomp.domain.instance.CompetenceInstance;
+
+// TODO: Auto-generated Javadoc
+/**
+ * The Class CompetenceInstanceDAOImpl.
+ */
+public class CompetenceInstanceDAOImpl extends
+GenericDAOImpl<CompetenceInstance, Long> implements
+ICompetenceInstanceDAO {
+
+ /** The HQL user competence / comptenceinstance. */
+ static String HQLUserCI = "select C.id, CI "
+ + "from CompetenceInstance as CI inner join CI.competence as C "
+ + "where CI.owner.uid=:login";
+
+ /** The HQL user e def by ref. */
+ static String HQLUserEDefByRef = "select ED, CI "
+ + "from CompetenceInstance as CI inner join CI.evaluationSubjectInstance as ESI inner join ESI.scenarioInstance as SI inner join SI.evaluationInstance as EI inner join EI.evaluationDefinition as ED "
+ + "where CI.competence.idRef=:idref " + "and CI.owner.uid=:login ";
+
+ /** The HQL user referentiels. */
+ static String HQLUserReferentiels = "select distinct(R) "
+ + "from Referentiel as R, CompetenceInstance as CI inner join CI.competence as C "
+ + "where CI.owner.uid=:login and R.id=C.idRef";
+
+ /** The HQLVC. */
+ static String HQLVC = "select CI "
+ + "from CompetenceInstance as CI inner join CI.level as L "
+ + "where CI.owner.uid=:login " + "and L.value >= ( "
+ + "select LL.value " + "from Level as LL "
+ + "where LL.threshold=true)";
+
+ /** The HQL users table. */
+ static String HQLUsersTable = "select CI from CompetenceInstance as CI inner join CI.evaluationSubjectInstance as ESI inner join ESI.scenarioInstance as SI inner join SI.evaluationInstance as EI inner join EI.evaluationDefinition as ED inner join ED.plan as P where CI.owner is not NULL and CI.competence.idRef=:idref and P.id=:idplan";
+
+ /** The HQL user table. */
+ static String HQLUserTable = "select CI from CompetenceInstance as CI inner join CI.evaluationSubjectInstance as ESI inner join ESI.scenarioInstance as SI inner join SI.evaluationInstance as EI inner join EI.evaluationDefinition as ED inner join ED.plan as P where CI.owner.uid=:login and CI.competence.idRef=:idRef and P.id=:idPlan";
+
+
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see
+ * com.pentila.evalcomp.dao.ICompetenceInstanceDAO#getUserCompetenceInstances
+ * (java.lang.String)
+ */
+ public Map<Long, Set<CompetenceInstance>> getUserCompetenceInstances(
+ String login) {
+
+ Map<Long, Set<CompetenceInstance>> mci = new HashMap<Long, Set<CompetenceInstance>>();
+
+ List<Object[]> led = getCachableHibernateTemplate().findByNamedParam(HQLUserCI,
+ new String[] { "login", }, new Object[] { login });
+
+ for (Object[] o : led) {
+ Long c = (Long) o[0];
+ CompetenceInstance CI = (CompetenceInstance) o[1];
+
+ if (!mci.containsKey(c)) {
+ mci.put(c, new HashSet<CompetenceInstance>());
+ }
+
+ mci.get(c).add(CI);
+
+ }
+
+ return mci;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @seecom.pentila.evalcomp.dao.ICompetenceInstanceDAO#
+ * getUserEDefinitionCompetenceInstanceByRef(java.lang.String,
+ * java.lang.Long)
+ */
+ public Map<EvaluationDefinition, Set<CompetenceInstance>> getUserEDefinitionCompetenceInstanceByRef(
+ String login, Long idRef) {
+ // TODO Auto-generated method stub
+
+ Map<EvaluationDefinition, Set<CompetenceInstance>> mci = new HashMap<EvaluationDefinition, Set<CompetenceInstance>>();
+
+ List<Object[]> led = getCachableHibernateTemplate().findByNamedParam(
+ HQLUserEDefByRef, new String[] { "login", "idref" },
+ new Object[] { login, idRef });
+
+ for (Object[] o : led) {
+ EvaluationDefinition c = (EvaluationDefinition) o[0];
+ CompetenceInstance CI = (CompetenceInstance) o[1];
+
+ if (!mci.containsKey(c)) {
+ mci.put(c, new HashSet<CompetenceInstance>());
+ }
+
+ mci.get(c).add(CI);
+
+ }
+
+ return mci;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see
+ * com.pentila.evalcomp.dao.ICompetenceInstanceDAO#getUserReferentiels(java
+ * .lang.String)
+ */
+ public Set<Referentiel> getUserReferentiels(String login) {
+ Set<Referentiel> sr = new HashSet<Referentiel>();
+ List<Referentiel> led = getCachableHibernateTemplate().findByNamedParam(
+ HQLUserReferentiels, new String[] { "login", },
+ new Object[] { login });
+
+ if (led != null) {
+ sr = new HashSet<Referentiel>(led);
+ }
+
+ return sr;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see
+ * com.pentila.evalcomp.dao.ICompetenceInstanceDAO#getValidableCompetences
+ * (java.lang.String)
+ */
+ public Set<CompetenceInstance> getValidableCompetences(String login) {
+ // TODO Auto-generated method stub
+
+ Set<CompetenceInstance> sci = new HashSet<CompetenceInstance>();
+
+ List<CompetenceInstance> led = getCachableHibernateTemplate().findByNamedParam(
+ HQLVC, new String[] { "login" }, new Object[] { login });
+
+ if (led != null) {
+ sci = new HashSet<CompetenceInstance>(led);
+ }
+ return sci;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see
+ * com.pentila.evalcomp.dao.ICompetenceInstanceDAO#getUsersTable(java.lang
+ * .Long, java.lang.Long)
+ */
+ public Set<CompetenceInstance> getUsersTable(Long idRef, Long idPlan) {
+ Set<CompetenceInstance> sci = new HashSet<CompetenceInstance>();
+ List<CompetenceInstance> led = getCachableHibernateTemplate().findByNamedParam(
+ HQLUsersTable, new String[] { "idref", "idplan" },
+ new Object[] { idRef, idPlan });
+
+ if (led != null) {
+ sci = new HashSet<CompetenceInstance>(led);
+ }
+ return sci;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see
+ * com.pentila.evalcomp.dao.ICompetenceInstanceDAO#getUserTable(java.lang
+ * .Long, java.lang.Long, java.lang.String)
+ */
+ public Set<CompetenceInstance> getUserTable(Long idRef, Long idPlan,
+ String login, Set<Long> EDIds, Set<Long> ESIIds) {
+
+ Set<CompetenceInstance> sci = new HashSet<CompetenceInstance>();
+
+ String searchString = HQLUserTable;
+
+
+ List<String> paramNames = new ArrayList<String>();
+
+ paramNames.add("idRef");
+ paramNames.add("idPlan");
+ paramNames.add("login");
+
+ List<Object> values = new ArrayList<Object>();
+
+ values.add(idRef);
+ values.add(idPlan);
+ values.add(login);
+
+ if (EDIds != null && !EDIds.isEmpty()){
+ searchString = searchString + " and ED.id in (:EDIds)";
+
+ paramNames.add("EDIds");
+
+ List<Long> ll = new ArrayList<Long>(EDIds);
+
+ Collections.sort(ll);
+
+ values.add(ll.toArray());
+
+ }
+
+ if (ESIIds != null && !ESIIds.isEmpty()){
+ searchString = searchString + " and CI.evaluationSubjectInstance.Id in (:ESIIds)";
+
+ paramNames.add("ESIIds");
+
+ List<Long> ll = new ArrayList<Long>(ESIIds);
+
+ Collections.sort(ll);
+ values.add(ll.toArray());
+ }
+
+
+ List<CompetenceInstance> led = getCachableHibernateTemplate().findByNamedParam(
+ searchString, paramNames.toArray(new String[paramNames.size()]),
+ values.toArray());
+
+ if (led != null) {
+ sci = new HashSet<CompetenceInstance>(led);
+ }
+ return sci;
+ }
+
+ public Set<CompetenceInstance> getCompetenceInstancesForUsers(Long ESIId,
+ Set<Long> usersIds) {
+ Set<CompetenceInstance> sci = new HashSet<CompetenceInstance>();
+
+ String query = "select CI from EvaluationSubjectInstance as ESI inner join ESI.competenceInstances as CI inner join CI.owner as OWNER where ESI.id=:ESIId and OWNER.id in (:usersIds)";
+
+ List<CompetenceInstance> lci = getCachableHibernateTemplate().findByNamedParam(query, new String[]{"ESIId", "usersIds"}, new Object[]{ESIId, usersIds.toArray()});
+
+ if (lci != null) {
+ sci = new HashSet<CompetenceInstance>(lci);
+ }
+ return sci;
+
+ }
+
+}