/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package mx.edu.um.mateo.colportor.web;
import java.io.BufferedOutputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.mail.MessagingException;
import javax.mail.internet.MimeMessage;
import javax.mail.util.ByteArrayDataSource;
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.ColportorDao;
import mx.edu.um.mateo.general.dao.RolDao;
import mx.edu.um.mateo.colportor.model.Colportor;
import mx.edu.um.mateo.general.model.Rol;
import mx.edu.um.mateo.general.model.Usuario;
import mx.edu.um.mateo.general.utils.LabelValueBean;
import mx.edu.um.mateo.general.web.BaseController;
import net.sf.jasperreports.engine.*;
import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;
import net.sf.jasperreports.engine.design.JasperDesign;
import net.sf.jasperreports.engine.export.JRCsvExporter;
import net.sf.jasperreports.engine.export.JRXlsExporter;
import net.sf.jasperreports.engine.export.JRXlsExporterParameter;
import net.sf.jasperreports.engine.xml.JRXmlLoader;
import org.apache.commons.lang.StringUtils;
import org.hibernate.exception.ConstraintViolationException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.mail.javamail.MimeMessageHelper;
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 osoto
*/
@Controller
@RequestMapping(Constantes.PATH_COLPORTOR)
public class ColportorController extends BaseController {
@Autowired
private ColportorDao colportorDao;
@Autowired
private RolDao rolDao;
/*
* DE AQUI @InitBinder public void initBinder(WebDataBinder binder) {
*
* binder.registerCustomEditor(TipoColportor.class, new
* EnumEditor(TipoColportor.class)); }
*/
@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 Colportor");
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("reporte", true);
params = colportorDao.lista(params);
try {
generaReporte(tipo, (List<Colportor>) params.get("colportores"), response);
return null;
} catch (JRException | IOException e) {
log.error("No se pudo generar el reporte", e);
}
}
if (StringUtils.isNotBlank(correo)) {
params.put("reporte", true);
params = colportorDao.lista(params);
params.remove("reporte");
try {
enviaCorreo(correo, (List<Colportor>) params.get("colportores"), request);
modelo.addAttribute("message", "lista.enviada.message");
modelo.addAttribute("messageAttrs", new String[]{messageSource.getMessage("colportor.lista.label", null, request.getLocale()), ambiente.obtieneUsuario().getUsername()});
} catch (JRException | MessagingException e) {
log.error("No se pudo enviar el reporte por correo", e);
}
}
params = colportorDao.lista(params);
modelo.addAttribute(Constantes.COLPORTOR_LIST, params.get(Constantes.COLPORTOR_LIST));
this.pagina(params, modelo, Constantes.COLPORTOR_LIST, pagina);
return Constantes.PATH_COLPORTOR_LISTA;
}
@RequestMapping(value="/get_colportor_list", method = RequestMethod.GET, headers="Accept=*/*", produces = "application/json")
public @ResponseBody
List <LabelValueBean> getColportorList(@RequestParam("term") String filtro, HttpServletResponse response){
log.debug("Buscando colportores por {}", filtro);
Map<String, Object> params = new HashMap<>();
params.put("empresa", ambiente.obtieneUsuario().getEmpresa().getId());
params.put("filtro", filtro);
colportorDao.lista(params);
List <LabelValueBean> rValues = new ArrayList<>();
List <Colportor> clps = (List <Colportor>) params.get(Constantes.COLPORTOR_LIST);
for(Colportor c : clps){
log.debug("Colportor {}", c.getClave());
StringBuilder sb = new StringBuilder();
sb.append(c.getClave());
sb.append(" | ");
sb.append(c.getNombreCompleto());
//Por alguna razon, el jQuery toma el valor del attr value por default.
//Asi que en el constructor invertimos los valores: como value va el string, y como nombre la clave
rValues.add(new LabelValueBean(c.getId(), sb.toString(), c.getClave()));
}
response.setContentType("application/json");
response.setStatus(HttpServletResponse.SC_OK);
return rValues;
}
@RequestMapping("/ver/{id}")
public String ver(@PathVariable Long id, Model modelo) {
log.debug("Mostrando colportor {}", id);
Colportor colportor = colportorDao.obtiene(id);
modelo.addAttribute(Constantes.ADDATTRIBUTE_COLPORTOR, colportor);
return Constantes.PATH_COLPORTOR_VER;
}
@RequestMapping("/nuevo")
public String nuevo(Model modelo) {
log.debug("Nuevo colportor");
Colportor colportores = new Colportor();
modelo.addAttribute(Constantes.ADDATTRIBUTE_COLPORTOR, colportores);
return Constantes.PATH_COLPORTOR_NUEVO;
}
/**
* TODO
*
* @param request
* @param response
* @param colportor
* @param bindingResult
* @param errors
* @param modelo
* @param redirectAttributes
* @return
* @throws ParseException
*/
@Transactional
@RequestMapping(value = "/crea", method = RequestMethod.POST)
public String crea(HttpServletRequest request, HttpServletResponse response, @Valid Colportor colportor, BindingResult bindingResult, Errors errors, Model modelo, RedirectAttributes redirectAttributes) throws ParseException {
log.debug("Entrando al metodo 'crea'");
for (String nombre : request.getParameterMap().keySet()) {
log.debug("Param: {} : {}", nombre, request.getParameterMap().get(nombre));
}
log.debug("bindingResult");
if (bindingResult.hasErrors()) {
log.debug("Hubo algun error en la forma ");
utils.despliegaBindingResultErrors(bindingResult);
return Constantes.PATH_COLPORTOR_NUEVO;
}
try {
Usuario usuario = ambiente.obtieneUsuario();
colportor = colportorDao.crea(colportor, usuario);
redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE, "colportor.creado.message");
redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{colportor.getNombre()});
return "redirect:" + Constantes.PATH_COLPORTOR_VER + "/" + colportor.getId();
} catch (Exception e) {
log.error("No se pudo crear el colportor", e);
return Constantes.PATH_COLPORTOR_NUEVO;
}
}
@RequestMapping("/edita/{id}")
public String edita(HttpServletRequest request, @PathVariable Long id, Model modelo) {
log.debug("Editar colportor {}", id);
Rol roles = rolDao.obtiene("ROLE_COL");
Colportor colportor = colportorDao.obtiene(id);
modelo.addAttribute(Constantes.ADDATTRIBUTE_COLPORTOR, colportor);
request.getSession().setAttribute(Constantes.COLPORTOR, colportor);
return Constantes.PATH_COLPORTOR_EDITA;
}
@Transactional
@RequestMapping(value = "/actualiza", method = RequestMethod.POST)
public String actualiza(HttpServletRequest request, @Valid Colportor colportor, BindingResult bindingResult,
Errors errors, Model modelo, RedirectAttributes redirectAttributes) {
if (bindingResult.hasErrors()) {
log.error("Hubo algun error en la forma, regresando");
utils.despliegaBindingResultErrors(bindingResult);
return Constantes.PATH_COLPORTOR_EDITA;
}
try {
log.debug("Colportor FechaDeNacimiento" + colportor.getFechaDeNacimiento());
Colportor clp = (Colportor)request.getSession().getAttribute(Constantes.COLPORTOR);
colportor.setEjercicio(clp.getEjercicio());
colportor.setEmpresa(clp.getEmpresa());
colportor.setAlmacen(clp.getAlmacen());
colportor.setCentrosDeCosto(clp.getCentrosDeCosto());
colportor.setEnabled(clp.getEnabled());
colportor.setPassword(clp.getPassword());
colportor = colportorDao.actualiza(colportor);
} catch (ConstraintViolationException e) {
log.error("No se pudo crear la colportor", e);
return Constantes.PATH_COLPORTOR_EDITA;
}finally{
request.getSession().removeAttribute(Constantes.COLPORTOR);
}
redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE, "colportor.actualizado.message");
redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{colportor.getNombre()});
return "redirect:" + Constantes.PATH_COLPORTOR_VER + "/" + colportor.getId();
}
@Transactional
@RequestMapping(value = "/elimina", method = RequestMethod.POST)
public String elimina(HttpServletRequest request, @RequestParam Long id, Model modelo, @ModelAttribute Colportor colportores, BindingResult bindingResult, RedirectAttributes redirectAttributes) {
log.debug("Elimina colportor");
try {
String nombre = colportorDao.elimina(id);
redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE, "colportor.eliminado.message");
redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{nombre});
} catch (Exception e) {
log.error("No se pudo eliminar el colportor " + id, e);
bindingResult.addError(new ObjectError(Constantes.ADDATTRIBUTE_COLPORTOR, new String[]{"colportor.no.eliminado.message"}, null, null));
return Constantes.PATH_COLPORTOR_VER;
}
return "redirect:" + Constantes.PATH_COLPORTOR;
}
private void generaReporte(String tipo, List<Colportor> colportores, HttpServletResponse response) throws JRException, IOException {
log.debug("Generando reporte {}", tipo);
byte[] archivo = null;
switch (tipo) {
case "PDF":
archivo = generaPdf(colportores);
response.setContentType("application/pdf");
response.addHeader("Content-Disposition", "attachment; filename=Colportores.pdf");
break;
case "CSV":
archivo = generaCsv(colportores);
response.setContentType("text/csv");
response.addHeader("Content-Disposition", "attachment; filename=Colportores.csv");
break;
case "XLS":
archivo = generaXls(colportores);
response.setContentType("application/vnd.ms-excel");
response.addHeader("Content-Disposition", "attachment; filename=Colportores.xls");
}
if (archivo != null) {
response.setContentLength(archivo.length);
try (BufferedOutputStream bos = new BufferedOutputStream(response.getOutputStream())) {
bos.write(archivo);
bos.flush();
}
}
}
private void enviaCorreo(String tipo, List<Colportor> colportores, HttpServletRequest request) throws JRException, MessagingException {
log.debug("Enviando correo {}", tipo);
byte[] archivo = null;
String tipoContenido = null;
switch (tipo) {
case "PDF":
archivo = generaPdf(colportores);
tipoContenido = "application/pdf";
break;
case "CSV":
archivo = generaCsv(colportores);
tipoContenido = "text/csv";
break;
case "XLS":
archivo = generaXls(colportores);
tipoContenido = "application/vnd.ms-excel";
}
MimeMessage message = mailSender.createMimeMessage();
MimeMessageHelper helper = new MimeMessageHelper(message, true);
helper.setTo(ambiente.obtieneUsuario().getUsername());
String titulo = messageSource.getMessage("colportor.lista.label", null, request.getLocale());
helper.setSubject(messageSource.getMessage("envia.correo.titulo.message", new String[]{titulo}, request.getLocale()));
helper.setText(messageSource.getMessage("envia.correo.contenido.message", new String[]{titulo}, request.getLocale()), true);
helper.addAttachment(titulo + "." + tipo, new ByteArrayDataSource(archivo, tipoContenido));
mailSender.send(message);
}
private byte[] generaPdf(List colportores) throws JRException {
Map<String, Object> params = new HashMap<>();
JasperDesign jd = JRXmlLoader.load(this.getClass().getResourceAsStream("/mx/edu/um/mateo/general/reportes/colportores.jrxml"));
JasperReport jasperReport = JasperCompileManager.compileReport(jd);
JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, params, new JRBeanCollectionDataSource(colportores));
byte[] archivo = JasperExportManager.exportReportToPdf(jasperPrint);
return archivo;
}
private byte[] generaCsv(List colportores) throws JRException {
Map<String, Object> params = new HashMap<>();
JRCsvExporter exporter = new JRCsvExporter();
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
JasperDesign jd = JRXmlLoader.load(this.getClass().getResourceAsStream("/mx/edu/um/mateo/general/reportes/colportores.jrxml"));
JasperReport jasperReport = JasperCompileManager.compileReport(jd);
JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, params, new JRBeanCollectionDataSource(colportores));
exporter.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
exporter.setParameter(JRExporterParameter.OUTPUT_STREAM, byteArrayOutputStream);
exporter.exportReport();
byte[] archivo = byteArrayOutputStream.toByteArray();
return archivo;
}
private byte[] generaXls(List colportores) throws JRException {
Map<String, Object> params = new HashMap<>();
JRXlsExporter exporter = new JRXlsExporter();
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
JasperDesign jd = JRXmlLoader.load(this.getClass().getResourceAsStream("/mx/edu/um/mateo/general/reportes/colportores.jrxml"));
JasperReport jasperReport = JasperCompileManager.compileReport(jd);
JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, params, new JRBeanCollectionDataSource(colportores));
exporter.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
exporter.setParameter(JRExporterParameter.OUTPUT_STREAM, byteArrayOutputStream);
exporter.setParameter(JRXlsExporterParameter.IS_WHITE_PAGE_BACKGROUND, Boolean.FALSE);
exporter.setParameter(JRXlsExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_ROWS, Boolean.TRUE);
exporter.setParameter(JRXlsExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_COLUMNS, Boolean.TRUE);
exporter.setParameter(JRXlsExporterParameter.IS_COLLAPSE_ROW_SPAN, Boolean.TRUE);
exporter.setParameter(JRXlsExporterParameter.IGNORE_PAGE_MARGINS, Boolean.TRUE);
exporter.setParameter(JRXlsExporterParameter.IS_ONE_PAGE_PER_SHEET, Boolean.FALSE);
exporter.exportReport();
byte[] archivo = byteArrayOutputStream.toByteArray();
return archivo;
}
}