Package br.gov.serpro.ouvidoria.controller.acionamento

Source Code of br.gov.serpro.ouvidoria.controller.acionamento.ConsultarScriptCtrl

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

import java.sql.Timestamp;
import java.util.Iterator;
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.Assunto;
import br.gov.serpro.ouvidoria.model.Atendimento;
import br.gov.serpro.ouvidoria.model.Funcionario;
import br.gov.serpro.ouvidoria.model.Script;

/**
* Objetivo: Controlar as operações sobre os objetos relacionados à parte de
* recuperar scripts da funcionalidade Consultar Script.
*
* @author SERPRO
* @version $Revision: 1.1.2.4 $, $Date: 2011/10/18 17:55:14 $
* @version 0.1, Date: 2004/12/08
*/
public class ConsultarScriptCtrl {

    /** atributo para datasource do script */
    /* Requerido */
    private Dao scriptDao;

    /** atributo para datasource do atendimento */
    /* Requerido */
    private Dao atendimentoDao;

    /**
     * Construtor recebendo objeto Dao
     */
    public ConsultarScriptCtrl(final DaoFactory daoFactory) {
        scriptDao = daoFactory.create(Script.class);
        atendimentoDao = daoFactory.create(Atendimento.class);
    }

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

    /**
     * Método para consultar os scripts do BD de acordo com os parámetros
     * informados
     *
     * @param pTexto
     *            texto a ser buscado no titulo ou texto do script
     * @param pAssunto
     *            Assunto do script a ser consultado
     * * @param pEstado
     *            Estado do script a ser consultado
     * @param pFunc
     *            Funcionário logado
     * @param pBuscarNovamente
     *            Identificador de busca sobre os resultados de outra busca
     *            anterior
     * @param pHistoricoTextos
     *            Lista com o histórico dos textos consultado anteriormente
     * 
     */
    public List ListarScript(String pTexto, String pAssunto, Funcionario pFunc,
            String pBuscarNovamente, List pHistoricoTextos) throws DaoException {

        String lsFrom = "Select s from Script as s";
        String lsTexto = "";
        String lsOrdem = " order by s.titulo";
        String lsStringHistorico = "";
        String lsHistoricoTexto = "";
        String lsQuery = "";
        String lsAssunto = "";
        String lsEstadoScript = "";
        List listaScript = null;
        List listaAssunto = null;
        Assunto assunto;
        Iterator iter;

        // filtra pelo texto informado
        lsTexto = " Where (s.descricao LIKE '%" + pTexto + "%' OR"
                + " s.titulo LIKE '%" + pTexto + "%')";

        // Monta filtro com o histórico de busca se a opção "Buscar nestes
        // resultados" estiver marcada
        if ((pBuscarNovamente != null)
                && (pBuscarNovamente.equalsIgnoreCase("S"))) {

            if (pHistoricoTextos != null) {
                iter = pHistoricoTextos.iterator();
                while (iter.hasNext()) {
                    lsStringHistorico = (String) iter.next();
                    lsHistoricoTexto = lsHistoricoTexto
                            + " and (s.descricao LIKE '%" + lsStringHistorico
                            + "%' OR" + " s.titulo LIKE '%" + lsStringHistorico
                            + "%')";
                }

                lsTexto = lsTexto + lsHistoricoTexto;
            }
        }

        // Filtra por assuntos ativos para o funcionario logado
        listaAssunto = pFunc.getListaAssuntosComAtuacao("Ativo");

        // 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 os scripts cujo assunto esteja associado ao funcionario
        // através do relacionamento de atuação
        else {
            // Varre os assuntos pegando seus respectivos IDs
            if (listaAssunto != null) {
                lsAssunto = " and (";
                iter = listaAssunto.iterator();
                while (iter.hasNext()) {
                    assunto = (Assunto) iter.next();
                    lsAssunto = lsAssunto + " s.assunto.id = "
                            + assunto.getId() + " or";
                }
                // retirar último " or"
                lsAssunto = lsAssunto.substring(0, (lsAssunto.length() - 3));
                lsAssunto = lsAssunto + ")";

            } else {
                // se o funcionario não atua em nenhum assunto, filtra para não
                // trazer nada
                lsAssunto = lsAssunto + " and s.assunto.id IS NULL";
            }
        }

         // filtra apenas pelo estado de APROVADO
        lsEstadoScript = " and s.estado.descricao = 'APROVADO'";

        // monta a string com a query
        lsQuery = lsFrom + lsTexto + lsAssunto + lsEstadoScript + lsOrdem;

        // Recupera lista de script
        listaScript = scriptDao.query(lsQuery);
        return listaScript;
    }

    /**
     * Método para salvar um atendimento
     *
     * @param s
     *            script consultado
     * @param func
     *            funcionario logado
     */
    public void salvarAtendimento(Script s, Funcionario func)
            throws DaoException {

        Atendimento atendimento = new Atendimento();

        if (s == null)
            throw new NullPointerException("Script não pode ser nulo.");

        if (func == null)
            throw new NullPointerException("Funcionario não pode ser nulo.");

        atendimento.setScript(s);
        atendimento.setFuncionario(func);
        atendimento.setData(new Timestamp(System.currentTimeMillis()));
        atendimentoDao.save(atendimento);
    }
}
TOP

Related Classes of br.gov.serpro.ouvidoria.controller.acionamento.ConsultarScriptCtrl

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.