/**
* 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.component;
import java.util.Collection;
import java.util.Iterator;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
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.enterpriselayer.businessobject.component.parameters.ProjectParameterBO;
/**
* DAO d'acc�s au ProjectParameter
*/
public class ProjectParameterDAOImpl
extends AbstractDAOImpl
{
/**
* Instance singleton
*/
private static ProjectParameterDAOImpl instance = null;
/** log */
private static Log LOG;
/** initialisation du singleton */
static
{
instance = new ProjectParameterDAOImpl();
}
/**
* Constructeur prive
*
* @throws JrafDaoException
*/
private ProjectParameterDAOImpl()
{
initialize( ProjectParameterBO.class );
if ( null == LOG )
{
LOG = LogFactory.getLog( ProjectParameterDAOImpl.class );
}
}
/**
* Retourne un singleton du DAO
*
* @return singleton du DAO
*/
public static ProjectParameterDAOImpl getInstance()
{
return instance;
}
/**
* Persiste un ProjectParameterBO
*
* @param pSession une session hibernate
* @param pProjectParamBO le ProjectParameterBO � faire persister
* @throws JrafDaoException en cas d'erreur
*/
public void create( ISession pSession, ProjectParameterBO pProjectParamBO )
throws JrafDaoException
{
super.create( pSession, pProjectParamBO );
}
/**
* @param pSession une session hibernate
* @param pProjectParamBO le ProjectParameterBO � supprimer
* @throws JrafDaoException en cas d'erreur
*/
public void remove( ISession pSession, ProjectParameterBO pProjectParamBO )
throws JrafDaoException
{
super.remove( pSession, pProjectParamBO );
}
/**
* @param pSession une session hibernate
* @param pParamId l'id des param�tres du projet
* @return l'ensemble des ProjectParameters de ce projet
* @throws JrafDaoException en cas d'erreur
*/
public Collection findWhere( ISession pSession, Long pParamId )
throws JrafDaoException
{
String whereClause = "where ";
whereClause += getAlias() + ".id=" + pParamId;
Collection ret = findWhere( pSession, whereClause );
return ret;
}
/**
* Met � jour les param�tres d'un projet en supprimant ses anciens param�tres et en cr�ant les nouveaux.
*
* @param pSession une session hibernate
* @param pParamId l'id des param�tres du projet
* @param pParameters les param�res du projet
* @throws JrafDaoException en cas d'erreur
*/
public void removeAndCreateNew( ISession pSession, Long pParamId, ProjectParameterBO pParameters )
throws JrafDaoException
{
// On supprime ses anciens param�tres dans une autre session
this.removeParameters( pSession, pParamId );
// On cr�e les nouveaux:
this.create( pSession, pParameters );
}
/**
* Supprime tous les param�tres d'un projet
*
* @param pSession une session hibernate
* @param pProjectId l'id du projet poss�dant ces param�tres
* @throws JrafDaoException en cas d'erreur
*/
public void removeParameters( ISession pSession, Long pProjectId )
throws JrafDaoException
{
Collection parameters = this.findWhere( pSession, pProjectId );
Iterator it = parameters.iterator();
while ( it.hasNext() )
{
this.remove( pSession, (ProjectParameterBO) it.next() );
}
}
}