es.pode.visualizador.presentacion.modificarPerfil.ModificarPerfilControllerImpl.java Source code

Java tutorial

Introduction

Here is the source code for es.pode.visualizador.presentacion.modificarPerfil.ModificarPerfilControllerImpl.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.visualizador.presentacion.modificarPerfil;

import java.io.IOException;
import java.io.InputStream;
import java.util.Arrays;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.apache.commons.validator.ValidatorException;
import org.apache.log4j.Logger;
import org.apache.struts.action.ActionMapping;
import es.pode.adminusuarios.negocio.servicios.UsuarioVO;
import es.pode.soporte.i18n.I18n;
import es.pode.soporte.i18n.LocalizacionIdiomaVO;
import es.pode.soporte.seguridad.ldap.LdapUserDetailsUtils;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * @see es.pode.administracion.presentacion.adminusuarios.modificarPerfil.ModificarPerfilController
 */
public class ModificarPerfilControllerImpl extends ModificarPerfilController {

    private static Logger log = Logger.getLogger(ModificarPerfilControllerImpl.class);

    private java.util.Properties pSpringProperties = null;

    /**
     * @see es.pode.administracion.presentacion.adminusuarios.modificarPerfil.ModificarPerfilController#recuperarUsuario(org.apache.struts.action.ActionMapping,
     *      es.pode.administracion.presentacion.adminusuarios.modificarPerfil.RecuperarUsuarioForm,
     *      javax.servlet.http.HttpServletRequest,
     *      javax.servlet.http.HttpServletResponse)
     */
    public final void recuperarUsuario(ActionMapping mapping,
            es.pode.visualizador.presentacion.modificarPerfil.RecuperarUsuarioForm form, HttpServletRequest request,
            HttpServletResponse response) throws Exception {

        String idiomaBusquedaSelected = LdapUserDetailsUtils.getIdiomaBusqueda();
        String idiomaSelected = LdapUserDetailsUtils.getIdioma();
        I18n i18n = I18n.getInstance();
        LocalizacionIdiomaVO[] localizadorBusquedaIdioma = i18n.obtenerIdiomasBuscablesLocalizados(idiomaSelected);
        form.setIdiomaBusquedaBackingList(Arrays.asList(localizadorBusquedaIdioma), "idLocalizacion", "name");
        LocalizacionIdiomaVO[] localizadorNavegacionIdioma = i18n
                .obtenerIdiomasPlataformaLocalizados(idiomaSelected);
        form.setIdiomaBackingList(Arrays.asList(localizadorNavegacionIdioma), "idLocalizacion", "name");
        String usuarioModificar = LdapUserDetailsUtils.getUsuario();
        UsuarioVO usuario = this.getSrvAdminUsuariosService().obtenerDatosUsuario(usuarioModificar);
        form.setTipoEmpaquetador(usuario.getTipoEmpaquetador());
        form.setApellido1(usuario.getApellido1());
        form.setNombre(usuario.getNombre());
        form.setUsuario(usuario.getUsuario());
        form.setId(usuario.getId());
        form.setEmail(usuario.getEmail());
        form.setApellido2(usuario.getApellido2());
        form.setIdioma(usuario.getIdioma());
        form.setIdiomaBusqueda(usuario.getIdiomaBusqueda());
        form.setNIF(usuario.getNIF());
        form.setTipoCatalogador(usuario.getTipoCatalogador());
        form.setOpenIdUrl(usuario.getOpenIdUrl());
        //convertimos los bytes de cuota a mbytes para mostrarlos por pantalla
        long cuota = (long) (usuario.getCuota().intValue() / 1048576);
        form.setCuota(cuota);

        //recogemos los roles del usuario
        String[] roles = this.getSrvAdminUsuariosService().listarRolesUsuario(usuarioModificar);

        //Comprobamos si el rol del usuario es nicamente EMPAQUETADOR
        if ((roles.length == 1) && (roles[0].equalsIgnoreCase(getPropertyValue("rolEmpaquetador")))) {
            log("El usuario es empaquetador no puede modificar el tipo de empaquetador");
            form.setRolEmpaquetador("S");
        } else {
            form.setRolEmpaquetador("N");
        }

        //Comprobamos si el rol del usuario es nicamente CATALOGADOR
        if ((roles.length == 1) && (roles[0].equalsIgnoreCase(getPropertyValue("rolCatalogador")))) {
            log("El usuario es empaquetador no puede modificar el tipo de empaquetador");
            form.setRolCatalogador("S");
        } else {
            form.setRolCatalogador("N");
        }

        //Comprobamos si el usuario tiene rol de administrador
        String rolAdmin = new String("N");
        for (int i = 0; i < roles.length; i++) {
            if (roles[i].equalsIgnoreCase(getPropertyValue("rolAdministrador")))
                rolAdmin = "S";
        }

        form.setRolAdministrador(rolAdmin);

        log("despues de cargar los datos en el formulario");
    }

    /**
     * @see es.pode.administracion.presentacion.adminusuarios.modificarPerfil.ModificarPerfilController#modificarUsuarioMismo(org.apache.struts.action.ActionMapping,
     *      es.pode.administracion.presentacion.adminusuarios.modificarPerfil.ModificarUsuarioMismoForm,
     *      javax.servlet.http.HttpServletRequest,
     *      javax.servlet.http.HttpServletResponse)
     */
    public final void modificarUsuarioMismo(ActionMapping mapping,
            es.pode.visualizador.presentacion.modificarPerfil.ModificarUsuarioMismoForm form,
            HttpServletRequest request, HttpServletResponse response) throws Exception {

        String resultado = null;
        try {
            //String idiomaSelected = LdapUserDetailsUtils.getIdioma();
            String nombre = request.getParameter("nombre");
            String apellido1 = request.getParameter("apellido1");
            Long id = Long.valueOf(request.getParameter("id"));
            String apellido2 = request.getParameter("apellido2");
            String email = request.getParameter("email");
            String idioma = request.getParameter("idioma");
            String idiomaBusqueda = request.getParameter("idiomaBusqueda");
            String tipoEmpaquetador = request.getParameter("tipoEmpaquetador");
            String clave = request.getParameter("clave");
            String openIdUrl = request.getParameter("openIdUrl");
            String repitaClave = request.getParameter("repitaClave");
            String tipoCatalogador = request.getParameter("tipoCatalogador");
            long cuota = 0;
            Matcher matcher = null;
            if (request.getParameter("cuota").length() > 0) {
                Pattern maskNum = Pattern.compile("[0-9]+");
                matcher = maskNum.matcher(request.getParameter("cuota"));
                if (!matcher.matches()) {
                    if (log.isDebugEnabled())
                        log.debug("cuota caracter ilegal");
                    throw new ValidatorException("{errors.modificarusuario.cuota}");
                }
                cuota = Long.valueOf(request.getParameter("cuota")).longValue();
                cuota = cuota * 1024 * 1024;
            }

            UsuarioVO usuarioVO = this.getSrvAdminUsuariosService().descripcionUsuario(id);
            // Validaciones de los campos que recogemos del formulario
            Pattern mask = Pattern.compile("[^\\\\?\\\\!\\>\\#\\&\\<\\@\\$\\/\\\'\\\"]+");
            // Validaciones para password
            Pattern maskPwd = Pattern.compile("[^\\\\?\\\\!\\>\\#\\&\\<\\@\\$\\/\\\'\\\"]+");

            if (nombre.length() <= 0) {
                log("nombre.length() <= 0");
                throw new ValidatorException("{errors.modificarusuario.nombre}");
            }
            matcher = mask.matcher(nombre);
            if (!matcher.matches()) {
                log("nombre caracter ilegal");

                throw new ValidatorException("{errors.modificarusuario.nombre.caracterIlegal}");
            }

            if (apellido1.length() <= 0) {
                log("apellido1.length() <= 0");

                throw new ValidatorException("{errors.modificarusuario.apellido1}");
            }
            matcher = mask.matcher(apellido1);
            if (!matcher.matches()) {
                log("apellido1 caracter ilegal");
                throw new ValidatorException("{errors.modificarusuario.apellido1.caracterIlegal}");
            }
            if (apellido2.length() > 0) {
                matcher = mask.matcher(apellido2);
                if (!matcher.matches()) {
                    log("apellido2 caracter ilegal");
                    throw new ValidatorException("{errors.modificarusuario.apellido2.caracterIlegal}");
                }
            }
            /*
             * if (apellido2.length() <= 0) { log("apellido2.length() <=
             * 0");
             * 
             * throw new
             * ValidatorException("{errors.modificarusuario.apellido2}"); }
             * matcher = mask.matcher(apellido2); if (!matcher.matches()) {
             * log("apellido2 caracter ilegal"); throw new
             * ValidatorException("{errors.altausuario.modificarusuario.caracterIlegal}"); }
             */
            if (email.length() <= 0) {
                log("email.length() <= 0");
                throw new ValidatorException("{errors.modificarusuario.email}");
            }
            if (!((email.indexOf("@") > 0) && (email.indexOf(".") > 0))) {
                throw new ValidatorException("{errors.modificarusuario.emailIncorrecto}");
            }

            if ((clave == null) || (clave.equalsIgnoreCase(""))) {
                log("No se modifica la clave");
            } else {
                if (clave.length() < 7) {
                    log("clave .length() <= 7");
                    throw new ValidatorException("{errors.modificarusuario.clave}");
                }

                matcher = maskPwd.matcher(clave);
                if (!matcher.matches()) {
                    log("contrasea caracter ilegal");
                    throw new ValidatorException("{errors.modificarusuario.clave.caracterIlegal}");
                }

                if (!(clave.equalsIgnoreCase(repitaClave))) {
                    throw new ValidatorException("{errors.modificarusuario.claveDistintas}");
                }
                usuarioVO.setClave(clave);
            }
            if (openIdUrl != null && openIdUrl.length() > 0) {
                UsuarioVO usuariovo = this.getSrvAdminUsuariosService().obtenerUsuarioConOpenId(openIdUrl);
                if (usuariovo != null && !usuariovo.getUsuario().equals(usuarioVO.getUsuario())) {
                    if (log.isDebugEnabled())
                        log.debug("Ese identificador de openId ya existe en la base de datos");
                    throw new ValidatorException("{errors.altausuario.existe.openId}");
                }

            }
            if (idiomaBusqueda == null) {
                throw new ValidatorException("{errors.modificarusuario.idiomaBusqueda}");
            }
            if (idiomaBusqueda.length() <= 0) {
                log("empaquetador .length() <= 0");
                throw new ValidatorException("{errors.modificarusuario.idiomaBusqueda}");
            }

            if (idioma == null) {
                throw new ValidatorException("{errors.modificarusuario.idioma}");
            }
            if (idioma.length() <= 0) {
                log("empaquetador .length() <= 0");
                throw new ValidatorException("{errors.modificarusuario.idioma}");
            }

            if (tipoEmpaquetador == null) {
                throw new ValidatorException("{errors.modificarusuario.tipoEmpaquetador}");
            }
            if (tipoEmpaquetador.length() <= 0) {
                log("empaquetador .length() <= 0");
                throw new ValidatorException("{errors.modificarusuario.tipoEmpaquetador}");
            }

            // /////Fin de validaciones de campo //////////

            usuarioVO.setNombre(nombre);
            usuarioVO.setApellido1(apellido1);
            usuarioVO.setApellido2(apellido2);
            usuarioVO.setEmail(email);
            usuarioVO.setTipoEmpaquetador(tipoEmpaquetador);
            usuarioVO.setIdioma(idioma);
            usuarioVO.setIdiomaBusqueda(idiomaBusqueda);
            usuarioVO.setTipoCatalogador(tipoCatalogador);
            usuarioVO.setCuota(new Long(cuota));
            usuarioVO.setOpenIdUrl(openIdUrl);

            usuarioVO.setId(id);
            resultado = this.getSrvAdminUsuariosService().modificarUsuario(usuarioVO);
            // Fijamos la cookie de modificarPerfil
            String cookiesPerfil = this.getPropertyValue("cookieModificarPerfil");
            Long tiempo = new Long(System.currentTimeMillis());
            Cookie cookie = new Cookie(cookiesPerfil, tiempo.toString());
            cookie.setPath("/");
            response.addCookie(cookie);
            log("se ha creado la cookie MODIFICAR_PERFIL " + tiempo);
        } catch (ValidatorException ve) {
            log.error("se ha producido una validatorException");
            resultado = "FALLO.MODIFICARUSUARIO";
            throw ve;
        } catch (Exception e) {
            log.error("Error: " + e);
            resultado = "FALLO.MODIFICARUSUARIO";
            throw new ValidatorException("{modificarUsuario.error}");

        } finally {

            // /Elimino de la sesion la descripcion del grupo

            form.setResultadoModificacion(resultado);
        }

    }

    private void log(Object obj) {

        if (log.isDebugEnabled())
            log.debug(obj);
    }

    private String getPropertyValue(String sKey) throws IOException {

        InputStream fIsSpringProperties = this.getClass()
                .getResourceAsStream("/spring_visualizadorcontenidos.properties");
        if (this.pSpringProperties == null) {
            pSpringProperties = new java.util.Properties();
            pSpringProperties.load(fIsSpringProperties);
        }

        // devolvemos la propiedad
        return pSpringProperties.getProperty(sKey);
    }

}