Package br.gov.serpro.ouvidoria.controller.andamento

Source Code of br.gov.serpro.ouvidoria.controller.andamento.SolucaoCtrl

/*
* 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.andamento;

import java.sql.Timestamp;
import java.util.List;

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.EstadoScript;
import br.gov.serpro.ouvidoria.model.EstadoSolucao;
import br.gov.serpro.ouvidoria.model.Funcionario;
import br.gov.serpro.ouvidoria.model.Orgao;
import br.gov.serpro.ouvidoria.model.Solucao;

/**
* Objetivo: Controlar as operações sobre os objetos Solução, inclusive
* persistindo os mesmos
*
* @author SERPRO
* @version $Revision: 1.1.2.3 $, $Date: 2011/10/18 17:55:13 $
* @version 0.1, Date: 2004/11/19
*/
public class SolucaoCtrl {

    /** campo para datasource */
    private Dao solucaoDao;

    /**
     * Construtor "default"
     */
    public SolucaoCtrl() {
        // DO NOTHING
    }

    /**
     * Construtor recebendo objeto Dao
     */
    public SolucaoCtrl(final DaoFactory daoFactory) {
        solucaoDao = daoFactory.create(Solucao.class);
    }

    /**
     * Método para recuperar a Solução a partir de um id
     *
     * @param id
     *            identificador da solução
     */
    public Solucao get(Long id) throws DaoException {
        if (id == null) {
            throw new DaoException("ID do Objeto não pode ser nulo.");
        }
        return (Solucao) solucaoDao.get(id);
    }

    /**
     * Método para persistir a Solução no BD
     *
     * @param id
     *            identificador da solução
     * @param assunto
     *            id do assunto
     * @param titulo
     *            descrição do título
     * @param texto
     *            texto da solução
     * 
     */
    public void save(final String id, final String assunto,
            final String titulo, final String texto) throws DaoException {

        Solucao solucao = new Solucao();
        if (id != null && id.trim().length() > 0) {
            solucao.setId(new Long(id));
        }

        AssuntoCtrl ctAssnto = new AssuntoCtrl();

        solucao.setAssunto(ctAssnto.get(new Long(assunto)));
        solucao.setTitulo(titulo);
        solucao.setTexto(texto);

        solucaoDao.save(solucao);
    }

    /**
     * Método para persistir a Solução no BD
     *
     * @param solucao
     *            solução a ser salva
     */
    public void save(Solucao solucao) throws DaoException {

        solucaoDao.save(solucao);
    }

    /**
     * Método para excluir a Solução do BD
     *
     * @param id
     *            identificador da solução
     */
    public void delete(Long id) throws DaoException {
        if (id == null) {
            throw new DaoException("ID do Objeto não pode ser nulo.");
        }
        solucaoDao.delete(id);
    }

    /**
     * Método para listar as soluções do BD
     */
    public List list() throws DaoException {
        return solucaoDao.list();
    }

    /**
     * Método para consultar as soluções do BD de acordo com os parâmetros
     * informados
     *
     * @param pTexto -
     *            texto da solução a ser consultado
     * @param pAssunto -
     *            Assunto da solução a ser consultado
     * @param pSituacao -
     *            Situação do assunto (A - ativo; I - inativo)
     * 
     */
    public List consultaSolucao(String pTexto, String pAssunto,
            String pSituacao, Funcionario pFuncionario, Orgao pOrgao)
            throws DaoException {

        String lsFrom = " Select s from Solucao as s ";
        String lsSituac = "";
        String lsAssunto = "";
        String lsTexto = "";
        String lsQuery = "";
        String lsSolAuto="";
        List solucaoList = null;

        Timestamp hoje = new Timestamp(System.currentTimeMillis());

        lsTexto = " Where ( s.texto  LIKE '%" + pTexto + "%'  OR "
                + "        s.titulo LIKE '%" + pTexto + "%' ) ";
       
        lsSolAuto =" and s.estado.id="+EstadoSolucao.APROVADO.getId();

        // Selecionar assuntos e soluções ativos (vigentes) ou não
        // de acordo com o parâmetro informado
        if (pSituacao.equalsIgnoreCase("Ativos")) {
            lsSituac = " and ( s.assunto.dataVigencia >= '" + hoje + "' "
                    + "    or s.assunto.dataVigencia = 00000000  "
                    + "    or s.assunto.dataVigencia is null ) ";
        } else if (pSituacao.equalsIgnoreCase("Inativos")) {
            lsSituac = " and ( s.assunto.dataVigencia <  '" + hoje + "' "
                    + "    and s.assunto.dataVigencia <> 00000000  "
                    + "    and not s.assunto.dataVigencia is null ) ";
        } else if (pSituacao.equalsIgnoreCase("Ambos")) {
            lsSituac = "";
        }

        // Traz apenas as soluções ativas
        lsSituac = lsSituac + "  and ( s.dataVigencia >= '" + hoje + "' "
                + "    or s.dataVigencia = 00000000  "
                + "    or s.dataVigencia is null ) ";

        // Verifica se foi selecionado um assunto
        if (!pAssunto.equalsIgnoreCase("0")) {
            lsAssunto = " and s.assunto.id = " + pAssunto;
        }
        // Caso não tenha sido selecionado um assunto, traz-se
        // apenas as soluções cujo assunto esteja associado ao órgão
        // do especialista ou aos sub-órgãos daquele
        else {

          // Usou-se o DISTINCT pelo fato de um mesmo assunto poder
            // estar associado a mais de um sub-órgão, o que faz com
            // que suas soluções venham duplicadas
           
          lsFrom = " Select DISTINCT s  " + " from   Solucao     as s, "
                    + " Funcionario as f, " + " Orgao       as o ";
            lsAssunto = " and ( ( s.assunto in elements(f.listaAssunto) "
                    + "         and f.id = " + pFuncionario.getId() + " ) "
                    + "     or  s.assunto.instituicao.id = " + pOrgao.getId()
                    + ") ";
                   
        }

        lsQuery = lsFrom + lsTexto + lsSolAuto + lsAssunto + lsSituac;

        // Recupera lista de soluções
        solucaoList = solucaoDao.query(lsQuery);

        return solucaoList;
    }

    /**
     * Método para listar as soluções a serem alteradas, de acordo com os
     * parâmetros informados
     *
     * @param pAssunto
     *            Assunto selecionado
     * @param pTexto
     *            Texto a ser consultado
     * @param pOrgao
     *            Órgão do gestor
     */
    public List listaSolucoesAtualizacao(String pAssunto, String pTexto, Integer codEstadoSolucao,
            Orgao pOrgao) throws DaoException {

        String lsFrom = "Select s from Solucao as s";
        String lsWhere = "";
        String lsOrdem = " order by s.id";

        String lsQuery = "";
        List listaSolucao = null;
        Timestamp hoje = new Timestamp(System.currentTimeMillis());

        // Verifica se foi selecionado um assunto
        if (!pAssunto.equalsIgnoreCase("0")) {
            lsWhere = " Where s.assunto.id = " + pAssunto;
        }
        // Caso não tenha sido selecionado um assunto, traz-se
        // apenas os scripts cujo assunto esteja associado ao órgão
        // do gestor
        else {
            lsFrom = "Select DISTINCT s from Solucao as s, " + " Orgao o, "
                    + " SubOrgao sub ";
            lsWhere = " Where ( s.assunto.id in elements(o.listaAssunto) "
                    + "   Or  ( s.assunto.id in elements(sub.listaAssunto) "
                    + "     and sub.id in elements(o.listaSubOrgao) ) )"
                    + " And  o.id = " + pOrgao.getId()
                    + " And ( s.assunto.dataVigencia >= '" + hoje + "' "
                    + "    or s.assunto.dataVigencia = 00000000  "
                    + "    or s.assunto.dataVigencia is null ) ";
        }

        //filtra pelo estadoSolucao informado
        int codigoEstado=codEstadoSolucao!=null?codEstadoSolucao.intValue():0;
       
        if (codigoEstado!=0) {
        lsWhere = lsWhere + " And (("+codEstadoSolucao+" is not null and s.estado.id = "+codEstadoSolucao+")"
                  + " Or "+codEstadoSolucao+" is null)";
        }
        // filtra pelo texto informado
        lsWhere = lsWhere + " And (s.texto  LIKE '%" + pTexto + "%' OR"
                + "      s.titulo LIKE '%" + pTexto + "%')";

        // monta a string com a query
        lsQuery = lsFrom + lsWhere + lsOrdem;

        // Recupera lista de script
        listaSolucao = solucaoDao.query(lsQuery);

        return listaSolucao;
    }
   
    /**
     * Método para listar as soluções de acordo com os parâmetros informados
     *
     * @param pEstadoScript
     *            Estado dos scripts a serem listados
     * @param pOrgao
     *            Órgão do gestor
     */
    public List listaSolucoesPorEstado(EstadoScript pEstadoScript, Orgao pOrgao)
    throws DaoException {
       
        String lsFrom = "Select s from Solucao as s";
        String lsWhere = "";
        String lsOrdem = " order by s.id";
       
        String lsQuery = "";
        List listaSolucao = null;
        Timestamp hoje = new Timestamp(System.currentTimeMillis());
       
        // Traz-se apenas os scripts cujo assunto esteja associado
        // ao órgão do gestor ou aos sub-órgãos daquele
        lsFrom = "Select DISTINCT s from Solucao as s, " + " Orgao o, "
                + " SubOrgao sub ";
        lsWhere = " Where ( s.assunto.id in elements(o.listaAssunto) "
                + "   Or  ( s.assunto.id in elements(sub.listaAssunto) "
                + "     and sub.id in elements(o.listaSubOrgao) ) )"
                + " And  o.id = " + pOrgao.getId() + " And  s.estado.id = "
                + pEstadoScript.getId() + " And ( s.dataVigencia >= '"
                + hoje + "' " + "    or s.dataVigencia = 00000000  "
                + "    or s.dataVigencia is null ) ";
       
        // monta a string com a query
        lsQuery = lsFrom + lsWhere + lsOrdem;
       
        // Recupera lista de script
        listaSolucao = solucaoDao.query(lsQuery);
       
        return listaSolucao;
    }
   
    /**
     * Método para listar todos estados possíveis para uma solução
     *
     * @return
     * @throws DaoException
     */
    public List listaTodosEstadoSolucao() throws DaoException {
       
        String lsQuery = "Select distinct es"
                + " from EstadoSolucao as es"
                + " order by es.descricao";
       
        // Recupera lista de script
        List listaEstadoSolucao = solucaoDao.query(lsQuery);
       
        return listaEstadoSolucao;
    }
   
    /**
     * Método que recupera a quantidade de utilizações de uma Solução
     *
     * @return
     * @throws DaoException
     */
    public List listaQtdUtilizacaoSolucao(String id) throws DaoException {

        String lsQuery = " select count(r.solucao.id) "
              + " from RespostaAcionamento as r"
              + " where r.solucao.id = " + id;
      
        List listaqtdUtilizacao = solucaoDao.query(lsQuery);
         
          return listaqtdUtilizacao;
    }
   
}
TOP

Related Classes of br.gov.serpro.ouvidoria.controller.andamento.SolucaoCtrl

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.