/* * To change this template, choose Tools | Templates * and open the template in the editor. */ package mx.edu.um.mateo.colportor.web; import java.util.HashMap; import java.util.List; import java.util.Map; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.validation.Valid; import mx.edu.um.mateo.general.utils.Constantes; import mx.edu.um.mateo.colportor.dao.AsociadoDao; import mx.edu.um.mateo.general.dao.RolDao; import mx.edu.um.mateo.general.dao.UsuarioDao; import mx.edu.um.mateo.colportor.model.Asociado; import mx.edu.um.mateo.general.model.Rol; import mx.edu.um.mateo.general.model.Usuario; import mx.edu.um.mateo.general.utils.ReporteException; import mx.edu.um.mateo.general.web.BaseController; import org.apache.commons.lang.StringUtils; import org.hibernate.exception.ConstraintViolationException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.security.crypto.keygen.KeyGenerators; import org.springframework.stereotype.Controller; import org.springframework.transaction.annotation.Transactional; import org.springframework.ui.Model; import org.springframework.validation.BindingResult; import org.springframework.validation.Errors; import org.springframework.validation.ObjectError; import org.springframework.web.bind.annotation.*; import org.springframework.web.servlet.mvc.support.RedirectAttributes; /** * * @author gibrandemetrioo * */ @Controller @RequestMapping(Constantes.PATH_ASOCIADO) public class AsociadoController extends BaseController { private static final Logger log = LoggerFactory.getLogger(AsociadoController.class); @Autowired private AsociadoDao asociadoDao; @Autowired private RolDao rolDao; @Autowired private UsuarioDao usuarioDao; @RequestMapping public String lista(HttpServletRequest request, HttpServletResponse response, @RequestParam(required = false) String filtro, @RequestParam(required = false) Long pagina, @RequestParam(required = false) String tipo, @RequestParam(required = false) String correo, @RequestParam(required = false) String order, @RequestParam(required = false) String sort, Usuario usuario, Errors errors, Model modelo) { log.debug("Mostrando lista de Asociado"); Map<String, Object> params = new HashMap<>(); params.put("empresa", ambiente.obtieneUsuario().getEmpresa().getId()); if (StringUtils.isNotBlank(filtro)) { params.put(Constantes.CONTAINSKEY_FILTRO, filtro); } if (StringUtils.isNotBlank(order)) { params.put(Constantes.CONTAINSKEY_ORDER, order); params.put(Constantes.CONTAINSKEY_SORT, sort); } if (StringUtils.isNotBlank(tipo)) { params.put(Constantes.CONTAINSKEY_REPORTE, true); params = asociadoDao.lista(params); try { generaReporte(tipo, (List<Asociado>) params.get(Constantes.ASOCIADO_LIST), response, Constantes.ASOCIADO_LIST, Constantes.ASO, null); return null; } catch (ReporteException e) { log.error("No se pudo generar el reporte", e); params.remove(Constantes.CONTAINSKEY_REPORTE); //errors.reject("error.generar.reporte"); } } if (StringUtils.isNotBlank(correo)) { params.put(Constantes.CONTAINSKEY_REPORTE, true); params = asociadoDao.lista(params); params.remove(Constantes.CONTAINSKEY_REPORTE); try { enviaCorreo(correo, (List<Asociado>) params.get(Constantes.ASOCIADO_LIST), request, Constantes.ASOCIADO_LIST, Constantes.ASO, null); modelo.addAttribute(Constantes.CONTAINSKEY_MESSAGE, "lista.enviada.message"); modelo.addAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{messageSource.getMessage("asociado.lista.label", null, request.getLocale()), ambiente.obtieneUsuario().getUsername()}); } catch (ReporteException e) { log.error("No se pudo enviar el reporte por correo", e); } } params = asociadoDao.lista(params); log.debug("Asociados" + ((List) params.get(Constantes.ASOCIADO_LIST)).size()); modelo.addAttribute(Constantes.ASOCIADO_LIST, params.get(Constantes.ASOCIADO_LIST)); this.pagina(params, modelo, Constantes.ASOCIADO_LIST, pagina); return Constantes.PATH_ASOCIADO_LISTA; } @RequestMapping("/nuevo") public String nuevo(Model modelo) { log.debug("Nuevo asociado"); Asociado asociado = new Asociado(); modelo.addAttribute(Constantes.ADDATTRIBUTE_ASOCIADO, asociado); return Constantes.PATH_ASOCIADO_NUEVO; } @Transactional @RequestMapping(value = "/crea", method = RequestMethod.POST) public String crea(HttpServletRequest request, HttpServletResponse response, @Valid Asociado asociado, @Valid Usuario usuario, BindingResult bindingResult, Errors errors, Model modelo, RedirectAttributes redirectAttributes) { for (String nombre : request.getParameterMap().keySet()) { log.debug("Param: {} : {}", nombre, request.getParameterMap().get(nombre)); } if (bindingResult.hasErrors()) { log.debug("Hubo algun error en la forma, regresando"); this.despliegaBindingResultErrors(bindingResult); return Constantes.PATH_ASOCIADO_NUEVO; } String password = null; password = KeyGenerators.string().generateKey(); log.debug("passwordAsociado" + password); try { asociado.setPassword(password); asociado = asociadoDao.crea(asociado, ambiente.obtieneUsuario()); } catch (ConstraintViolationException e) { log.error("No se pudo crear al asociado", e); return Constantes.PATH_ASOCIADO_NUEVO; } redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE, "asociado.creado.message"); redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{asociado.getNombre()}); return "redirect:" + Constantes.PATH_ASOCIADO_VER + "/" + asociado.getId(); } @RequestMapping("/ver/{id}") public String ver(@PathVariable Long id, Model modelo) { log.debug("Mostrando asociado {}", id); Asociado asociados = asociadoDao.obtiene(id); modelo.addAttribute(Constantes.ADDATTRIBUTE_ASOCIADO, asociados); return Constantes.PATH_ASOCIADO_VER; } @RequestMapping("/edita/{id}") public String edita(@PathVariable Long id, Model modelo) { log.debug("Edita Asociado {}", id); Rol roles = rolDao.obtiene("ROLE_ASOC"); Asociado asociados = asociadoDao.obtiene(id); modelo.addAttribute(Constantes.ADDATTRIBUTE_ASOCIADO, asociados); modelo.addAttribute("roles", roles); return Constantes.PATH_ASOCIADO_EDITA; } @Transactional @RequestMapping(value = "/actualiza", method = RequestMethod.POST) public String actualiza(HttpServletRequest request, @Valid Asociado asociados, BindingResult bindingResult, Errors errors, Model modelo, RedirectAttributes redirectAttributes) { if (bindingResult.hasErrors()) { log.error("Hubo algun error en la forma, regresando"); return Constantes.PATH_ASOCIADO_EDITA; } try { String[] roles = request.getParameterValues("roles"); log.debug("Asignando ROLE_ASOC por defecto"); roles = new String[]{"ROLE_ASOC"}; modelo.addAttribute("roles", roles); asociados = asociadoDao.actualiza(asociados, roles); } catch (ConstraintViolationException e) { log.error("No se pudo crear al Asociacion", e); return Constantes.PATH_ASOCIADO_NUEVO; } redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE, "asociado.actualizado.message"); redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{asociados.getNombre()}); return "redirect:" + Constantes.PATH_ASOCIADO_VER + "/" + asociados.getId(); } @Transactional @RequestMapping(value = "/elimina", method = RequestMethod.POST) public String elimina(HttpServletRequest request, @RequestParam Long id, Model modelo, @ModelAttribute Asociado asociados, BindingResult bindingResult, RedirectAttributes redirectAttributes) { log.debug("Elimina Asociacion"); try { String nombre = asociadoDao.elimina(id); redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE, "asociado.eliminado.message"); redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{nombre}); } catch (Exception e) { log.error("No se pudo eliminar el asociado " + id, e); bindingResult.addError(new ObjectError(Constantes.ASOCIADO_LIST, new String[]{"asociado.no.eliminado.message"}, null, null)); return Constantes.PATH_ASOCIADO_VER; } return "redirect:" + Constantes.PATH_ASOCIADO; } }