/** * Copyright (C) 2008-2010, Squale Project - http://www.squale.org * * This file is part of Squale. * * Squale 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 3 of the * License, or any later version. * * Squale 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 Lesser General Public License * along with Squale. If not, see <http://www.gnu.org/licenses/>. */ package org.squale.squalecommon.daolayer.message; import java.util.Calendar; import java.util.Collection; import java.util.Date; import org.squale.jraf.commons.exception.JrafDaoException; import org.squale.jraf.provider.persistence.hibernate.AbstractDAOImpl; import org.squale.jraf.spi.persistence.ISession; import org.squale.squalecommon.daolayer.DAOUtils; import org.squale.squalecommon.enterpriselayer.businessobject.message.MessageBO; import org.squale.squalecommon.enterpriselayer.businessobject.message.NewsBO; /** * Couche DAO pour les news */ public class NewsDAOImpl extends AbstractDAOImpl { /** * Instance singleton */ private static NewsDAOImpl instance = null; /** initialisation du singleton */ static { instance = new NewsDAOImpl(); } /** * Constructeur prive * * @throws JrafDaoException */ private NewsDAOImpl() { initialize( NewsBO.class ); } /** * Retourne un singleton du DAO * * @return singleton du DAO */ public static NewsDAOImpl getInstance() { return instance; } /** * @param pSession la session hibernate * @param pKind le type de news qu'on veut r�cup�rer * @return les news correspondantes * @throws JrafDaoException en cas d'�chec */ public Collection findWhereKind( ISession pSession, String pKind ) throws JrafDaoException { String whereClause = "where "; // Clause qu'on rajoute pour trier les d�peches de la plus r�cente � la plus ancienne String orderClause = " order by " + getAlias() + ".beginningDate desc"; Collection coll = null; // Dans ces cas on les r�cup�re toutes if ( pKind == null || ( !pKind.equals( "old" ) && !pKind.equals( "current" ) ) ) { coll = findWhere( pSession, orderClause ); } else { // s�lection en fonction de crit�res sur les dates Date now = Calendar.getInstance().getTime(); String todayDate = DAOUtils.makeQueryDate( now ); // On r�cup�re celles qui ne sont plus d'actualit� if ( pKind.equals( "old" ) ) { whereClause += getAlias() + ".endDate < " + todayDate; } else { // on r�cup�re celles qui sont actuellement visibles sur le portail if ( pKind.equals( "current" ) ) { whereClause += getAlias() + ".beginningDate < " + todayDate + "and " + getAlias() + ".endDate > " + todayDate; } } // et on les trie pour afficher la plus r�cente en premier whereClause += orderClause; coll = findWhere( pSession, whereClause ); } return coll; } /** * supprime une news * * @param pSession la session hibernate * @param pNewsBO la news que l'on veut supprimer * @param pMessBO le message de la news qu'on veut supprimer * @throws JrafDaoException en cas d'�chec */ public void removeNews( ISession pSession, NewsBO pNewsBO, MessageBO pMessBO ) throws JrafDaoException { MessageDAOImpl messDao = MessageDAOImpl.getInstance(); messDao.removeMessage( pSession, pMessBO ); long id = pNewsBO.getId(); String whereClause = "where " + getAlias() + ".id=" + id; removeWhere( pSession, whereClause ); } /** * ajoute une news * * @param pSession la session hibernate * @param pNewsBO la news � ajouter * @param pMessBO le message de la news � ajouter * @throws JrafDaoException en cas d'�chec */ public void addNews( ISession pSession, NewsBO pNewsBO, MessageBO pMessBO ) throws JrafDaoException { MessageDAOImpl messDao = MessageDAOImpl.getInstance(); messDao.create( pSession, pMessBO ); create( pSession, pNewsBO ); } /** * modifie une news * * @param pSession la session hibernate * @param pNewsBO la news � ajouter * @param pMessBO le message de la news � ajouter * @throws JrafDaoException en cas d'�chec */ public void modifyNews( ISession pSession, NewsBO pNewsBO, MessageBO pMessBO ) throws JrafDaoException { MessageDAOImpl messDao = MessageDAOImpl.getInstance(); // on fait un remove puis un create au lieu d'un save // car sinon avec l'id composite on ne prend pas en compte // les modifications mais on ajoute un nouveau message messDao.save( pSession, pMessBO ); // pas de probl�me dans le cas d'une news car il y a un id save( pSession, pNewsBO ); } /** * @param pSession la session * @param pKey la cl� * @return la collection des news contenant un telle cl� * @throws JrafDaoException en cas d'�chec */ public Collection findWhereNewsKeyIs( ISession pSession, String pKey ) throws JrafDaoException { String whereClause = "where "+getAlias()+".key like '" + pKey + "'"; return findWhere( pSession, whereClause ); } }