Package br.gov.serpro.ouvidoria.controller.gerencial.administracao

Source Code of br.gov.serpro.ouvidoria.controller.gerencial.administracao.FuncionarioCtrl

/*
* 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.util.ArrayList;
import java.util.Collection;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
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.Acionamento;
import br.gov.serpro.ouvidoria.model.Assunto;
import br.gov.serpro.ouvidoria.model.EstadoAcionamento;
import br.gov.serpro.ouvidoria.model.Funcionalidade;
import br.gov.serpro.ouvidoria.model.Funcionario;
import br.gov.serpro.ouvidoria.model.Instituicao;
import br.gov.serpro.ouvidoria.model.LocalidadeOcorrencia;
import br.gov.serpro.ouvidoria.model.Orgao;
import br.gov.serpro.ouvidoria.model.Perfil;
import br.gov.serpro.ouvidoria.model.TipoMensagem;
import br.gov.serpro.ouvidoria.util.HibernateSessionFactory;
import br.gov.serpro.ouvidoria.util.Utilitario;
import org.hibernate.Query;

/**
* TipoFuncionarioCtrl
*
* Objetivo: Funcionalidades CRUD de Funcionário
*
* @author SERPRO
* @version $Revision: 1.1.2.3 $, $Date: 2011/10/18 17:55:14 $
* @version 0.1, Date: 2004/12/27
*/
public class FuncionarioCtrl {

  private DaoFactory daoFactory;

  private Dao defaultDao;

  private Dao perfilDao;

  private Dao acionamentoDao;

  /**
   * Construtor recebendo objeto Dao
   *
   * @param daoFactory
   */
  public FuncionarioCtrl(final DaoFactory daoFactory) {
    this.daoFactory = daoFactory;
    perfilDao = daoFactory.create(Perfil.class);
    defaultDao = daoFactory.create(Funcionario.class);
    acionamentoDao = daoFactory.create(Acionamento.class);
  }

  /**
   * Retorna um funcionário pelo seu ID.
   *
   * @param id
   *            id do funcionário.
   * @return funcionario (Funcionário) correspondente ao id.
   * @throws DaoException
   *             em caso de erro na comunicação com a base de dados.
   */
  public Funcionario get(final Long id) throws DaoException {
    if (id == null) {
      return null;
    }
    return (Funcionario) defaultDao.get(id);
  }

  /**
   * Retorna um funcionário pelo seu ID.
   *
   * @param id
   *            id do funcionário.
   * @return funcionario (Funcionário) correspondente ao id.
   * @throws DaoException
   *             em caso de erro na comunicação com a base de dados.
   */
  public Funcionario get(final String id) throws DaoException {
    return this.get(new Long(id));
  }

  public Funcionario getByLogin(final String login) throws DaoException {
    Funcionario funcionario = null;

    // montar consulta HQL
    String hql = "from Funcionario as f where f.login = :login";

    // construir e configurar a query do Hibernate
    Query query = HibernateSessionFactory.getFactory().getSession()
        .createQuery(hql);
    query.setString("login", login);

    List listaFunc = defaultDao.query(query);
    if (listaFunc != null && listaFunc.size() > 0) {
      funcionario = (Funcionario) listaFunc.get(0);
    }

    return funcionario;
  }

  /**
   * Armazena um funcionário na base de dados.
   *
   * @param object
   *            funcionário a ser armazenado.
   * @throws DaoException
   *             em caso de erro na comunicação com a base de dados.
   */
  private void save(final Funcionario object) throws DaoException {
    if (object == null) {
      throw new IllegalArgumentException(
          "Tentativa de salvar um funcionário nulo.");
    }

    defaultDao.save(object);
  }

  /**
   * Insere um funcionário na base do Sistema Ouvidoria.
   *
   * @param orgao
   *            órgão do funcionário.
   * @param nome
   *            nome completo.
   * @param login
   *            login (CPF).
   * @param senha
   *            senha de acesso.
   * @param situacao
   *            situação (Ativo, Inativo, Suspenso)
   * @param motivo
   *            motivo (observação) de cadastro.
   * @param perfil
   *            perfil de acesso. ************************************
   * @param consultor
   *            flag de informação se é especialista consultor.
   *            ************************************
   * @param funcionalidades
   *            lista de funcionalidades permitidas.
   * @param tipoAssunto
   *            lista de tipos de assuntos (de mensagens).
   * @param tipoMensagem
   *            lista de tipos de mensagens do funcionário.
   * @param subOrgao
   *            lista de sub-órgãos de atuação do funcionário.
   * @param localidades
   *            localidades associadas aos órgãos (e sub-órgãos).
   * @throws DaoException
   *             em caso de erro na comunicação com a base de dados.
   */
  public void insert(Orgao orgao, final String nome, final String login,
      final String senha, final String situacao, final String motivo,
      final Long perfil, final Long[] funcionalidades,
      final Long[] tipoAssunto, final Long[] tipoMensagem,
      final Long[] subOrgao, final Long[] localidades,
      final String nivelAcesso, final String consultor, final String email)
      throws DaoException {

    if (orgao == null) {
      throw new IllegalArgumentException(
          "Tentativa de cadastrar funcionário para órgão nulo.");
    }

    Funcionario object = new Funcionario();

    object.setNome(nome);
    object.setLogin(login);
    object.setSenha(senha);
    object.setSituacao(situacao);
    object.setMotivoNivelAtuacao(motivo);
    object.setPerfil((Perfil) perfilDao.get(perfil));
    object.setListaFuncionalidade(listas(funcionalidades,
        Funcionalidade.class));
    object.setListaAssunto(listas(tipoAssunto, Assunto.class));
    object.setListaTipoMensagem(listas(tipoMensagem, TipoMensagem.class));

    object.setConsultor(consultor);
   
    /* Inclusão do campo email para permitir que o funcionário receba notificações
     * sobre mensagens pendentes via email
     **/
    object.setEmail(email);

    object.setInstituicao(orgao);
    if (!Perfil.ADMINISTRADOR.equals(object.getPerfil())) {
      object.setInstituicao(orgao);

      if (object.getListaInstituicao() == null) {
        object.setListaInstituicao(new TreeSet());
      }
      object.getListaInstituicao().clear();

      if (object.getListaLocalidadeOcorrencia() == null) {
        object.setListaLocalidadeOcorrencia(new TreeSet());
      }
      object.getListaLocalidadeOcorrencia().clear();

      if (nivelAcesso.equals("O")) {
        object.getListaInstituicao().add(orgao);
      } else {
        object.setListaInstituicao(listas(subOrgao, Instituicao.class));
        object.setListaLocalidadeOcorrencia(listas(localidades,
            LocalidadeOcorrencia.class));
      }
    }

    save(object);
  }

  /**
   * Atualiza um Funcionário
   *
   * @param orgao
   * @param gestor
   * @param id
   * @param nome
   * @param login
   * @param senha
   * @param situacao
   * @param motivo
   * @param perfil
   * @param consultor
   * @param funcionalidades
   * @param tipoAssunto
   * @param tipoMensagem
   * @param subOrgao
   * @param localidades
   * @param nivelAcesso
   * @throws DaoException
   * @throws Exception
   */
  public void update(Orgao orgao, final Funcionario gestor, final Long id,
      final String nome, final String login, final String senha,
      final String situacao, final String motivo, final Long perfil,
      final Long[] funcionalidades, final Long[] tipoAssunto,
      final Long[] tipoMensagem, final Long[] subOrgao,
      final Long[] localidades, final String nivelAcesso,
      final String consultor, final String email) throws DaoException, Exception {

    if (orgao == null) {
      throw new NullPointerException();
    }

    if (gestor == null) {
      throw new NullPointerException();
    }

    if (id == null) {
      throw new NullPointerException();
    }

    Funcionario object = get(id);

    object.setNome(nome);
    object.setLogin(login);

    if (senha != null && senha.trim().length() > 0) {
      object.setSenha(senha);
    }
    object.setEmail(email);
   
    object.setSituacao(situacao);

    object.setPerfil((Perfil) perfilDao.get(perfil));
    object.setInstituicao(orgao);

    object.setListaFuncionalidade(listas(funcionalidades,
        Funcionalidade.class));

    object.setListaAssunto(listas(tipoAssunto, Assunto.class));

    object.setListaTipoMensagem(listas(tipoMensagem, TipoMensagem.class));

    object.setMotivoNivelAtuacao(motivo);
   
    object.setConsultor(consultor);

    if (!Perfil.ADMINISTRADOR.equals(object.getPerfil())) {

      /* Inicializo as collections, caso não existam */
      if (object.getListaInstituicao() == null) {
        object.setListaInstituicao(new TreeSet());
      }

      if (object.getListaLocalidadeOcorrencia() == null) {
        object.setListaLocalidadeOcorrencia(new TreeSet());
      }

      /* Limpo as collections dependendo do nível de acesso do gestor */
      if (gestor.getNivelAtuacao() == Funcionario.NA_ORGAO) {
        object.getListaInstituicao().clear();
        object.getListaLocalidadeOcorrencia().clear();
      } else {
        object.getListaInstituicao().removeAll(
            gestor.getListaInstituicao());

        object.getListaLocalidadeOcorrencia().removeAll(
            gestor.getListaLocalidadeOcorrencia());
      }

      /*
       * Preencho as collections dependendo do nível de acesso
       */
      if (nivelAcesso.equals("O")) {
        object.getListaInstituicao().add(orgao);
      } else {
        object.getListaInstituicao().addAll(
            listas(subOrgao, Instituicao.class));
        object.getListaLocalidadeOcorrencia().addAll(
            listas(localidades, LocalidadeOcorrencia.class));
      }

    }

    /* Redireciono meus acionamentos, caso eu me torne inativo */
    List acionamentos = new ArrayList();
    boolean erro = false;
    if (!object.getSituacao().equals(Funcionario.ATIVO)
        && object.getListaAcionamento() != null) {

      for (Iterator iter = object.getListaAcionamento().iterator(); iter
          .hasNext();) {
        Acionamento acionamento = (Acionamento) iter.next();
        if (!(acionamento.getEstadoAcionamento().equals(
            EstadoAcionamento.RESPONDIDO) || acionamento
            .getEstadoAcionamento().equals(
                EstadoAcionamento.ENVIADO))) {
          if (acionamento.redirecionarAcionamento(orgao, object)) {
            acionamentos.add(acionamento);
          } else {
            erro = true;
            break;
          }
        }
      }
    }

    if (erro) {
      throw new Exception();
    }

    for (Iterator iter = acionamentos.iterator(); iter.hasNext();) {
      acionamentoDao.save((Acionamento) iter.next());
    }

    save(object);
  }

  /**
   * Devolve a lista de funcionários de um órgão. Se o funcionário solicitante
   * for Administrador, os outros administradores também serão incluídos na
   * lista.
   *
   * @param orgao
   *            Órgão para o qual os funcionários serão listados.
   * @return lista (Collection) de usuários do órgão.
   * @throws DaoException
   *             em caso de erro no processo de consulta.
   */
  public Collection list(final Orgao orgao, final Funcionario funcionario,
      final String criterio) throws DaoException {

    // verificar que o Órgão não seja nulo
    if (orgao == null) {
      throw new NullPointerException();
    }

    // montar a consulta
    String crit = Utilitario.trataPlic(criterio);

    StringBuffer hql = new StringBuffer();
    hql.append("from Funcionario as f \n");
    hql.append("  inner join fetch f.perfil as p \n");
    hql.append("  left outer join fetch f.instituicao as i \n");
    hql.append("where ( f.instituicao.id = " + orgao.getId() + " \n");

    if (funcionario.getPerfil().equals(Perfil.ADMINISTRADOR)) {
      hql.append("  or f.perfil.id = " + Perfil.ADMINISTRADOR.getId()
          + " ) \n");
    } else {
      hql.append("  and f.perfil.id <> " + Perfil.ADMINISTRADOR.getId()
          + " ) \n");
    }

    if (criterio != null && criterio.trim().length() > 0) {
      hql.append("  and f.nome LIKE '%" + crit + "%' \n");
    }
    hql.append("order by f.nome asc \n");

    String sql = hql.toString();

    // executar a query
    List resultados = defaultDao.query(sql);

    // processar os resultados e montar a lista final de funcionários
    List listaFinal = null;
    if (!funcionario.getPerfil().equals(Perfil.ADMINISTRADOR)
        && funcionario.getListaSubOrgaosAtivos() != null
        && !funcionario.getListaSubOrgaosAtivos().isEmpty()) {
      listaFinal = new ArrayList();

      // manter apenas os usuários que são da localidade do funcionário
      // logado
      for (Iterator iter = resultados.iterator(); iter.hasNext();) {
        Funcionario func = (Funcionario) iter.next();

        for (Iterator iterLoc = funcionario
            .getListaLocalidadeOcorrencia().iterator(); iterLoc
            .hasNext();) {
          LocalidadeOcorrencia loc = (LocalidadeOcorrencia) iterLoc
              .next();
          if (func.getListaLocalidadeOcorrencia().contains(loc)) {
            listaFinal.add(func);
            break;
          }
        }
      }
    } else {
      listaFinal = resultados;
    }

    return listaFinal;
  }

  /**
   * Retorna uma lista especificada do Tipo do Parâmetro pClass
   *
   * @param ids
   * @param pClass
   * @return
   * @throws DaoException
   */
  public Collection listas(final Long[] ids, final Class pClass)
      throws DaoException {
    Dao dao = daoFactory.create(pClass);
    Collection lista = new HashSet();
    for (int i = 0; ids != null && i < ids.length; i++) {
      lista.add(dao.get(ids[i]));
    }
    return lista;
  }

  /**
   * Retorna uma lista de funcionários por Perfil
   *
   * @param orgao
   * @param funcionario
   * @param perfil
   * @return
   * @throws DaoException
   */
  public List listaFuncionarioPorPerfil(final Orgao orgao,
      final Funcionario funcionario, final String perfil)
      throws DaoException {

    if (orgao == null) {
      throw new NullPointerException();
    }

    if (funcionario == null) {
      throw new NullPointerException();
    }

    String lsFrom = " Select f from Funcionario as f ";
    String lsWhere = " Where  f.instituicao.id = " + orgao.getId();

    // Se foi informado um perfil, consulta-se os funcionários do mesmo
    if (perfil != null && !perfil.equals("0")) {
      lsWhere = lsWhere + " And f.perfil.id = " + perfil;
    }

    String lsOrder = " Order By f.nome ";

    String lsQuery = lsFrom + lsWhere + lsOrder;

    // Recupera todos os funcionários dentro do perfil selecionado
    return defaultDao.query(lsQuery);
  }

  /**
   * Retorna o funcionário por seu login
   *
   * @param orgao
   * @param login
   * @return Funcionario
   * @throws DaoException
   */
  public Funcionario getByLogin(final Orgao orgao, final String login)
      throws DaoException {

    String sql = " select f from Funcionario as f " + "  where f.login = '"
        + login.replaceAll("'", "") + "'" + "    and f.situacao = '"
        + Funcionario.ATIVO + "'" + "    and ( f.perfil.id = "
        + Perfil.ADMINISTRADOR.getId() + "     or f.instituicao.id = "
        + orgao.getId() + " )";

    List lstFunc = defaultDao.query(sql);

    if (lstFunc == null || lstFunc.isEmpty()) {
      return null;
    }

    return (Funcionario) lstFunc.get(0);
  }
}
TOP

Related Classes of br.gov.serpro.ouvidoria.controller.gerencial.administracao.FuncionarioCtrl

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.