es.pode.gestorFlujo.presentacion.objetosPendientes.ObjetosPendientesControllerImpl.java Source code

Java tutorial

Introduction

Here is the source code for es.pode.gestorFlujo.presentacion.objetosPendientes.ObjetosPendientesControllerImpl.java

Source

/* Agrega es una federacin de repositorios de objetos digitales educativos formada por todas las Comunidades Autnomas propiedad de Red.es. Este cdigo ha sido desarrollado por la Entidad Pblica Empresarial red.es adscrita al Ministerio de Industria,Turismo y Comercio a travs de la Secretara de Estado de Telecomunicaciones y para la Sociedad de la Informacin, dentro del Programa Internet en el Aula, que se encuadra dentro de las actuaciones previstas en el Plan Avanza (Plan 2006-2010 para el desarrollo de la Sociedad de la Informacin y de Convergencia con Europa y entre Comunidades Autnomas y Ciudades Autnomas) y ha sido cofinanciado con fondos FEDER del Programa Operativo FEDER 2000-2006 Sociedad de la Informacin
    
This program is free software: you can redistribute it and/or modify it under the terms of the European Union Public Licence (EUPL v.1.0).  This program 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 European Union Public Licence (EUPL v.1.0). You should have received a copy of the EUPL licence along with this program.  If not, see http://ec.europa.eu/idabc/en/document/7330.
*/
// license-header java merge-point
package es.pode.gestorFlujo.presentacion.objetosPendientes;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.acegisecurity.GrantedAuthority;
import org.apache.commons.validator.ValidatorException;
import org.apache.log4j.Logger;
import org.apache.struts.action.ActionMapping;

import es.pode.adminusuarios.negocio.servicios.SrvAdminUsuariosService;
import es.pode.publicacion.negocio.servicios.SrvPublicacionService;
import es.pode.publicacion.negocio.servicios.TransicionVO;
import es.pode.soporte.seguridad.ldap.LdapUserDetailsUtils;

/**
 * @see es.pode.gestorFlujo.presentacion.objetosPendientes.ObjetosPendientesController
 */
public class ObjetosPendientesControllerImpl extends ObjetosPendientesController {

    private Logger logger = Logger.getLogger(ObjetosPendientesController.class);

    /**
    * @see es.pode.gestorFlujo.presentacion.objetosPendientes.ObjetosPendientesController#cargarODESPendientes(org.apache.struts.action.ActionMapping,
    *      es.pode.gestorFlujo.presentacion.objetosPendientes.CargarODESPendientesForm,
    *      javax.servlet.http.HttpServletRequest,
    *      javax.servlet.http.HttpServletResponse)
    */
    public final void cargarODESPendientes(ActionMapping mapping,
            es.pode.gestorFlujo.presentacion.objetosPendientes.CargarODESPendientesForm form,
            HttpServletRequest request, HttpServletResponse response) throws Exception {
        //      if(logger.isDebugEnabled())
        //      logger.debug("Cargando objetos Pendientes");
        //      SrvPublicacionService publi = this.getSrvPublicacionService();
        //      try {
        //         form.setListaODESAsArray(publi.obtenODEsPropuestos());
        //      } catch (Exception ex) {
        //         logger.error("Imposible obtener los odes pendientes", ex);
        //         throw new ValidatorException("{gestorFlujo.error.inesperado}");
        //      }
        //      form.setIdUsuario(LdapUserDetailsUtils.getUsuario());
        //
        //      // Como estamos en administracin damos por sentado que esta autenticado
        //      form.setTipoUsuario(tipo_usuario(LdapUserDetailsUtils.getRoles()));
        //
        //      form.setEsDespublicado(new Boolean(false));
        //      logger.debug("cargarODESPendientes-El objeto es despublicado?"+form.getEsDespublicado().booleanValue());
        //      logger.info("Objetos Pendientes cargados correctamente");

        if (logger.isDebugEnabled())
            logger.debug("Cargando objetos Pendientes de Publicacion");
        SrvPublicacionService publi = this.getSrvPublicacionService();
        SrvAdminUsuariosService admin = this.getSrvAdminUsuariosService();
        try {
            TransicionVO[] odes = null;
            String[] todosUsuariosGrupos = admin
                    .obtenerListaUsuariosGrupoTrabajo(LdapUserDetailsUtils.getUsuario());
            //            
            //            String[] todosUsuariosGrupos=new String[] {LdapUserDetailsUtils.getUsuario()};
            if (todosUsuariosGrupos != null && todosUsuariosGrupos.length > 0) {
                logger.info("Obtenidos lista de usuarios de los grupos pertenecientes de usuario:["
                        + LdapUserDetailsUtils.getUsuario() + "Numero de usuarios:[" + todosUsuariosGrupos.length);
                odes = publi.obtenODEsPropuestosPorUsuarios(todosUsuariosGrupos);
                logger.info("Obtenidos odes de esos usuarios, numero de odes pendientes de publicacion ["
                        + odes.length);
            } else {
                logger.info("Obtenidos lista de todos los ODES, pues el usuario:["
                        + LdapUserDetailsUtils.getUsuario() + " es parte de todos los grupos");
                odes = publi.obtenODEsPropuestos();
                logger.info("Obtenidos odes de todos los usuarios, numero de odes pendientes de publicacion["
                        + odes.length);
            }
            form.setListaODESAsArray(odes);
        } catch (Exception ex) {
            logger.error("Imposible obtener los odes pendientes de publicacion", ex);
            throw new ValidatorException("{gestorFlujo.error.inesperado}");
        }
        form.setIdUsuario(LdapUserDetailsUtils.getUsuario());
        // Como estamos en administracin damos por sentado que esta autenticado
        form.setTipoUsuario(tipo_usuario(LdapUserDetailsUtils.getRoles()));

        form.setEsDespublicado(new Boolean(false));
        logger.debug("cargarODESPendientes-El objeto es despublicado?" + form.getEsDespublicado().booleanValue());
        logger.info("Objetos Pendientes de Publicacion cargados correctamente");

    }

    /**
    * Devuelve los permisos que tiene el usuario en forma de cdigo numrico,
    * aunque para manejarlo mejor le damos el tipo String: 0 - ninguno 1 -
    * catalogador 2 - publicador 3 - ambos
    */
    private String tipo_usuario(GrantedAuthority[] tipoUsuarios) {
        int resultado = 0;
        String role_publi = "ROLE_PUBLICADOR";
        for (int i = 0; i < tipoUsuarios.length; i++) {
            if (logger.isDebugEnabled())
                logger.debug("tipo user = " + tipoUsuarios[i].getAuthority());
            if (tipoUsuarios[i].getAuthority().equalsIgnoreCase("ROLE_CATALOGADOR")) {
                if (resultado == 0) {
                    resultado = 1;
                }
                // si no es 0 es que ya somos publicador
                else {
                    resultado = 3;
                }
            }
            if (tipoUsuarios[i].getAuthority().equalsIgnoreCase(role_publi)) {
                if (resultado == 0) {
                    resultado = 2;
                }
                // si no es 0 es que ya somos catalogador
                else {
                    resultado = 3;
                }
            }
        }
        if (logger.isDebugEnabled())
            logger.debug("tipo usuario = " + resultado);
        return String.valueOf(resultado);

    }

}