/*
* Sistema de Ouvidoria: um canal através do qual os usuários
* podem encaminhar suas reclamações, elogios e sugestões.
*
* Copyright (C) 2011 SERPRO
*
* Este programa é software livre; você pode redistribuí-lo e/ou
* modificá-lo sob os termos da Licença Pública Geral GNU, conforme
* publicada pela Free Software Foundation; tanto a versão 2 da
* Licença como (a seu critério) qualquer versão mais nova.
*
* Este programa é distribuído na expectativa de ser útil, mas SEM
* QUALQUER GARANTIA; sem mesmo a garantia implícita de
* COMERCIALIZAÇÃO ou de ADEQUAÇÃO A QUALQUER PROPÓSITO EM
* PARTICULAR. Consulte a Licença Pública Geral GNU para obter mais
* detalhes.
*
* Você deve ter recebido uma cópia da Licença Pública Geral GNU,
* sob o título "LICENCA.txt", junto com esse programa. Se não,
* acesse o Portal do Software Público Brasileiro no endereço
* http://www.softwarepublico.gov.br/ ou escreva para a Fundação do
* Software Livre (FSF) Inc., 51 Franklin St, Fifth Floor, Boston,
* MA 02111-1301, USA.
*
* Contatos através do seguinte endereço internet:
* http://www.serpro.gov.br/sistemaouvidoria/
*/
package br.gov.serpro.ouvidoria.controller.gerencial.administracao;
import java.sql.Timestamp;
import java.util.Comparator;
import java.util.Iterator;
import java.util.SortedSet;
import java.util.TreeSet;
import br.gov.serpro.ouvidoria.dao.Dao;
import br.gov.serpro.ouvidoria.dao.DaoException;
import br.gov.serpro.ouvidoria.dao.DaoFactory;
import br.gov.serpro.ouvidoria.model.Orgao;
import br.gov.serpro.ouvidoria.model.TipoAvaliacaoResposta;
/**
* TipoAvaliacaoRespostaCtrl
*
* @author SERPRO
* @version $Revision: 1.1.2.3 $, $Date: 2011/10/19 18:18:09 $
* @version 0.1, Date: 2005/01/07
*/
public class TipoAvaliacaoRespostaCtrl {
private Dao defaultDao;
private Dao orgaoDao;
/**
* Construtor recebendo objeto Dao
*
* @param daoFactory
*/
public TipoAvaliacaoRespostaCtrl(final DaoFactory daoFactory) {
defaultDao = daoFactory.create(TipoAvaliacaoResposta.class);
orgaoDao = daoFactory.create(Orgao.class);
}
/**
* Obtém a entidade à partir do ID recebido como parâmetro
*
* @param id
* @return
* @throws DaoException
*/
public TipoAvaliacaoResposta get(final Long id) throws DaoException {
if (id == null) {
throw new DaoException("ID do Objeto não pode ser nulo.");
}
return (TipoAvaliacaoResposta) defaultDao.get(id);
}
/**
* Obtém uma lista de objetos da entidade à partir do parâmetro
*
* @param orgao
* @return
*/
public SortedSet list(final Orgao orgao) {
SortedSet query = new TreeSet(new Comparator() {
public int compare(Object obj1, Object obj2) {
return ((TipoAvaliacaoResposta) obj1).getId().compareTo(
((TipoAvaliacaoResposta) obj2).getId());
}
});
final Timestamp agora = new Timestamp(System.currentTimeMillis());
for (Iterator iter = orgao.getListaTipoAvaliacaoResposta().iterator(); iter
.hasNext();) {
TipoAvaliacaoResposta tipoAvaliacaoResposta = (TipoAvaliacaoResposta) iter
.next();
if (tipoAvaliacaoResposta.getDataVigencia() == null
|| tipoAvaliacaoResposta.getDataVigencia().after(agora)) {
query.add(tipoAvaliacaoResposta);
}
}
return query;
}
/**
* Salva a entidade recebida como parâmetro
*
* @param orgao
* @param object
* @throws DaoException
*/
public void save(Orgao orgao, final TipoAvaliacaoResposta object)
throws DaoException {
if (orgao == null) {
throw new DaoException("Orgao não pode ser nulo.");
}
if (object == null) {
throw new DaoException("TipoAvaliacaoResposta não pode ser nulo.");
}
defaultDao.save(object);
orgao.getListaTipoAvaliacaoResposta().remove(object);
orgao.getListaTipoAvaliacaoResposta().add(object);
orgaoDao.save(orgao);
}
/**
* Atualiza a entidade no banco utilizando as informações recebidas como
* parâmetro
*
* @param orgao
* @param id
* @param descricao
* @param vigencia
* @param tipoAvaliacao
* @throws DaoException
*/
public void update(Orgao orgao, final String id, final String descricao,
final Timestamp vigencia, final String tipoAvaliacao)
throws DaoException {
if (id == null) {
throw new DaoException("ID do Objeto não pode ser nulo.");
}
TipoAvaliacaoResposta object = get(new Long(id));
object.setDescricao(descricao);
object.setDataVigencia(vigencia);
object.setTipoAvaliacao(tipoAvaliacao);
save(orgao, object);
}
/**
* Insere a entidade no banco utilizando as informações recebidas como
* parâmetro
*
* @param orgao
* @param descricao
* @param vigencia
* @param tipoAvaliacao
* @throws DaoException
*/
public void insert(Orgao orgao, final String descricao,
final Timestamp vigencia, final String tipoAvaliacao)
throws DaoException {
TipoAvaliacaoResposta object = new TipoAvaliacaoResposta();
object.setDataCadastramento(new Timestamp(System.currentTimeMillis()));
object.setDescricao(descricao);
object.setDataVigencia(vigencia);
object.setTipoAvaliacao(tipoAvaliacao);
save(orgao, object);
}
/**
* Deleta a entidade do à partir das informações recebidas como parâmetro
*
* @param orgao
* @param id
* @param dataVigencia
* @throws DaoException
*/
public void delete(Orgao orgao, final String id,
final Timestamp dataVigencia) throws DaoException {
if (id == null) {
throw new DaoException("ID do Objeto não pode ser nulo.");
}
TipoAvaliacaoResposta object = get(new Long(id));
object.setDataVigencia(dataVigencia);
save(orgao, object);
}
}