--- /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.HashSet;
+import java.util.List;
+import java.util.Set;
+
+import org.apache.commons.lang.StringEscapeUtils;
+
+import com.pentila.evalcomp.dao.IMessageDAO;
+import com.pentila.evalcomp.domain.Message;
+
+// TODO: Auto-generated Javadoc
+/**
+ * The Class MessageDAOImpl.
+ */
+public class MessageDAOImpl extends GenericDAOImpl<Message, Long> implements IMessageDAO {
+
+ /** The HQL last messages list. */
+ static String HQLLastMessagesList =
+
+ "select distinct(msg), mrs.readed "
+ + "from Message as msg inner join msg.messageRecipients as mrs inner join mrs.recipient as owner "
+ + "where not exists elements(msg.replies) "
+ + "and owner.uid=:login ";
+
+ /** The HQL last messages list2. */
+ static String HQLLastMessagesList2 =
+
+ "select distinct(msg) " + "from Message as msg "
+ + "where not exists elements(msg.replies) "
+ + "and msg.author.uid=:login ";
+
+
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see
+ * com.pentila.evalcomp.dao.IMessageDAO#getLastMessagesList(java.lang.String
+ * )
+ */
+ public Set<Message> getLastMessagesList(String login, String searchFilter) {
+
+ Set<Message> s = new HashSet<Message>();
+
+
+
+ String request = HQLLastMessagesList;
+ String request2 = HQLLastMessagesList2;
+
+ String add = "";
+
+ if(searchFilter != null && ! searchFilter.equals("")){
+ add += " and ( ";
+ add += "msg.body like '%" +StringEscapeUtils.escapeSql(searchFilter) + "%'";
+ add += "or msg.subject like '%" +StringEscapeUtils.escapeSql(searchFilter) + "%'";
+ add += " )";
+ }
+
+ request += add;
+ request2 += add;
+
+
+ List<Object[]> lm = getCachableHibernateTemplate().findByNamedParam(request, new String[] { "login" }, new Object[] { login });
+
+ if (lm != null && !lm.isEmpty()){
+
+
+
+ for (Object[] o : lm){
+ Message m = (Message)o[0];
+ Boolean b = (Boolean)o[1];
+ m.setComputedReaded(b);
+ s.add(m);
+ }
+
+ }
+ List<Message> lm2 = getCachableHibernateTemplate().findByNamedParam(request2, new String[] { "login" }, new Object[] { login });
+ for (Message m : lm2){
+ m.setComputedReaded(true);
+ }
+
+ if (lm2 != null) {
+ s.addAll(lm2);
+ }
+
+
+
+
+ return s;
+ }
+
+}