/* * To change this template, choose Tools | Templates * and open the template in the editor. */ package mx.edu.um.mateo.contabilidad.facturas.web; import java.io.BufferedOutputStream; import java.io.ByteArrayOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; 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.contabilidad.facturas.model.InformeEmpleado; import mx.edu.um.mateo.contabilidad.facturas.model.InformeEmpleadoDetalle; import mx.edu.um.mateo.contabilidad.facturas.service.InformeEmpleadoDetalleManager; import mx.edu.um.mateo.contabilidad.facturas.service.InformeEmpleadoManager; import mx.edu.um.mateo.general.model.Usuario; import mx.edu.um.mateo.general.utils.AutorizacionCCPlInvalidoException; import mx.edu.um.mateo.general.utils.Constantes; import mx.edu.um.mateo.general.web.BaseController; import mx.edu.um.mateo.inscripciones.model.FileUploadForm; import net.sf.jasperreports.engine.JRException; import net.sf.jasperreports.engine.JRExporterParameter; import net.sf.jasperreports.engine.JasperCompileManager; import net.sf.jasperreports.engine.JasperExportManager; import net.sf.jasperreports.engine.JasperFillManager; import net.sf.jasperreports.engine.JasperPrint; import net.sf.jasperreports.engine.JasperReport; 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.io.IOUtils; 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.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.ModelAttribute; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.multipart.MultipartFile; import org.springframework.web.servlet.ModelAndView; import org.springframework.web.servlet.mvc.support.RedirectAttributes; /** * * @author develop */ @Controller @RequestMapping(Constantes.PATH_INFORMEEMPLEADODETALLE) public class InformeEmpleadoDetalleController extends BaseController { @Autowired private InformeEmpleadoDetalleManager manager; @Autowired private InformeEmpleadoManager managerInforme; @RequestMapping({"", "/lista"}) 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 informes"); Map<String, Object> params = new HashMap<>(); Long empresaId = (Long) request.getSession().getAttribute("empresaId"); params.put("empresa", empresaId); InformeEmpleado informeId = (InformeEmpleado) request.getSession().getAttribute("informeEmpleadoId"); params.put("informeEmpleado", informeId.getId()); if (StringUtils.isNotBlank(filtro)) { params.put(Constantes.CONTAINSKEY_FILTRO, filtro); } if (pagina != null) { params.put(Constantes.CONTAINSKEY_PAGINA, pagina); modelo.addAttribute(Constantes.CONTAINSKEY_PAGINA, pagina); } else { pagina = 1L; modelo.addAttribute(Constantes.CONTAINSKEY_PAGINA, pagina); } 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 = manager.lista(params); try { generaReporte(tipo, (List<InformeEmpleadoDetalle>) params.get(Constantes.CONTAINSKEY_INFORMESDETALLES), response); return null; } catch (JRException | IOException 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 = manager.lista(params); params.remove(Constantes.CONTAINSKEY_REPORTE); try { enviaCorreo(correo, (List<InformeEmpleadoDetalle>) params.get(Constantes.CONTAINSKEY_INFORMESDETALLES), request); modelo.addAttribute(Constantes.CONTAINSKEY_MESSAGE, "lista.enviada.message"); modelo.addAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{messageSource.getMessage("detalle.lista.label", null, request.getLocale()), ambiente.obtieneUsuario().getUsername()}); } catch (JRException | MessagingException e) { log.error("No se pudo enviar el reporte por correo", e); } } params = manager.lista(params); log.debug("params{}", params.get(Constantes.CONTAINSKEY_INFORMESDETALLES)); modelo.addAttribute(Constantes.CONTAINSKEY_INFORMESDETALLES, params.get(Constantes.CONTAINSKEY_INFORMESDETALLES)); // inicia paginado Long cantidad = (Long) params.get(Constantes.CONTAINSKEY_CANTIDAD); Integer max = (Integer) params.get(Constantes.CONTAINSKEY_MAX); Long cantidadDePaginas = cantidad / max; List<Long> paginas = new ArrayList<>(); long i = 1; do { paginas.add(i); } while (i++ < cantidadDePaginas); List<InformeEmpleadoDetalle> detalles = (List<InformeEmpleadoDetalle>) params.get(Constantes.CONTAINSKEY_INFORMESDETALLES); Long primero = ((pagina - 1) * max) + 1; log.debug("primero {}", primero); log.debug("detalles {}", detalles.size()); Long ultimo = primero + (detalles.size() - 1); String[] paginacion = new String[]{primero.toString(), ultimo.toString(), cantidad.toString()}; modelo.addAttribute(Constantes.CONTAINSKEY_PAGINACION, paginacion); log.debug("Paginacion{}", paginacion); modelo.addAttribute(Constantes.CONTAINSKEY_PAGINAS, paginas); log.debug("paginas{}", paginas); modelo.addAttribute(Constantes.CONTAINSKEY_PAGINA, pagina); log.debug("Pagina{}", pagina); // termina paginado return Constantes.PATH_INFORMEEMPLEADODETALLE_LISTA; } @RequestMapping({"/contrarecibo"}) public String contrarecibo(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 informes"); Map<String, Object> params = new HashMap<>(); Long empresaId = (Long) request.getSession().getAttribute("empresaId"); params.put("empresa", empresaId); InformeEmpleado informeId = (InformeEmpleado) request.getSession().getAttribute("informeEmpleadoId"); params.put("informeEmpleado", informeId.getId()); if (StringUtils.isNotBlank(filtro)) { params.put(Constantes.CONTAINSKEY_FILTRO, filtro); } if (pagina != null) { params.put(Constantes.CONTAINSKEY_PAGINA, pagina); modelo.addAttribute(Constantes.CONTAINSKEY_PAGINA, pagina); } else { pagina = 1L; modelo.addAttribute(Constantes.CONTAINSKEY_PAGINA, pagina); } 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 = manager.lista(params); try { generaReporte(tipo, (List<InformeEmpleadoDetalle>) params.get(Constantes.CONTAINSKEY_INFORMESDETALLES), response); return null; } catch (JRException | IOException 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 = manager.lista(params); params.remove(Constantes.CONTAINSKEY_REPORTE); try { enviaCorreo(correo, (List<InformeEmpleadoDetalle>) params.get(Constantes.CONTAINSKEY_INFORMESDETALLES), request); modelo.addAttribute(Constantes.CONTAINSKEY_MESSAGE, "lista.enviada.message"); modelo.addAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{messageSource.getMessage("detalle.lista.label", null, request.getLocale()), ambiente.obtieneUsuario().getUsername()}); } catch (JRException | MessagingException e) { log.error("No se pudo enviar el reporte por correo", e); } } params = manager.lista(params); log.debug("params{}", params.get(Constantes.CONTAINSKEY_INFORMESDETALLES)); modelo.addAttribute(Constantes.CONTAINSKEY_INFORMESDETALLES, params.get(Constantes.CONTAINSKEY_INFORMESDETALLES)); // inicia paginado Long cantidad = (Long) params.get(Constantes.CONTAINSKEY_CANTIDAD); Integer max = (Integer) params.get(Constantes.CONTAINSKEY_MAX); Long cantidadDePaginas = cantidad / max; List<Long> paginas = new ArrayList<>(); long i = 1; do { paginas.add(i); } while (i++ < cantidadDePaginas); List<InformeEmpleadoDetalle> detalles = (List<InformeEmpleadoDetalle>) params.get(Constantes.CONTAINSKEY_INFORMESDETALLES); Long primero = ((pagina - 1) * max) + 1; log.debug("primero {}", primero); log.debug("detalles {}", detalles.size()); Long ultimo = primero + (detalles.size() - 1); String[] paginacion = new String[]{primero.toString(), ultimo.toString(), cantidad.toString()}; modelo.addAttribute(Constantes.CONTAINSKEY_PAGINACION, paginacion); log.debug("Paginacion{}", paginacion); modelo.addAttribute(Constantes.CONTAINSKEY_PAGINAS, paginas); log.debug("paginas{}", paginas); modelo.addAttribute(Constantes.CONTAINSKEY_PAGINA, pagina); log.debug("Pagina{}", pagina); // termina paginado return Constantes.PATH_INFORMEEMPLEADODETALLE_CONTRARECIBO; } @RequestMapping({"/revisar"}) public String detalles(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 informes"); Map<String, Object> params = new HashMap<>(); Long empresaId = (Long) request.getSession().getAttribute("empresaId"); params.put("empresa", empresaId); InformeEmpleado informeId = (InformeEmpleado) request.getSession().getAttribute("informeEmpleadoId"); params.put("informeEmpleado", informeId.getId()); if (StringUtils.isNotBlank(filtro)) { params.put(Constantes.CONTAINSKEY_FILTRO, filtro); } if (pagina != null) { params.put(Constantes.CONTAINSKEY_PAGINA, pagina); modelo.addAttribute(Constantes.CONTAINSKEY_PAGINA, pagina); } else { pagina = 1L; modelo.addAttribute(Constantes.CONTAINSKEY_PAGINA, pagina); } 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 = manager.lista(params); try { generaReporte(tipo, (List<InformeEmpleadoDetalle>) params.get(Constantes.CONTAINSKEY_INFORMESDETALLES), response); return null; } catch (JRException | IOException 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 = manager.lista(params); params.remove(Constantes.CONTAINSKEY_REPORTE); try { enviaCorreo(correo, (List<InformeEmpleadoDetalle>) params.get(Constantes.CONTAINSKEY_INFORMESDETALLES), request); modelo.addAttribute(Constantes.CONTAINSKEY_MESSAGE, "lista.enviada.message"); modelo.addAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{messageSource.getMessage("detalle.lista.label", null, request.getLocale()), ambiente.obtieneUsuario().getUsername()}); } catch (JRException | MessagingException e) { log.error("No se pudo enviar el reporte por correo", e); } } params = manager.lista(params); log.debug("params{}", params.get(Constantes.CONTAINSKEY_INFORMESDETALLES)); modelo.addAttribute(Constantes.CONTAINSKEY_INFORMESDETALLES, params.get(Constantes.CONTAINSKEY_INFORMESDETALLES)); // inicia paginado Long cantidad = (Long) params.get(Constantes.CONTAINSKEY_CANTIDAD); Integer max = (Integer) params.get(Constantes.CONTAINSKEY_MAX); Long cantidadDePaginas = cantidad / max; List<Long> paginas = new ArrayList<>(); long i = 1; do { paginas.add(i); } while (i++ < cantidadDePaginas); List<InformeEmpleadoDetalle> detalles = (List<InformeEmpleadoDetalle>) params.get(Constantes.CONTAINSKEY_INFORMESDETALLES); Long primero = ((pagina - 1) * max) + 1; log.debug("primero {}", primero); log.debug("detalles {}", detalles.size()); Long ultimo = primero + (detalles.size() - 1); String[] paginacion = new String[]{primero.toString(), ultimo.toString(), cantidad.toString()}; modelo.addAttribute(Constantes.CONTAINSKEY_PAGINACION, paginacion); log.debug("Paginacion{}", paginacion); modelo.addAttribute(Constantes.CONTAINSKEY_PAGINAS, paginas); log.debug("paginas{}", paginas); modelo.addAttribute(Constantes.CONTAINSKEY_PAGINA, pagina); log.debug("Pagina{}", pagina); // termina paginado return "/factura/revisa/detalles"; } @RequestMapping("/ver/{id}") public String ver(@PathVariable Long id, Model modelo) { log.debug("Mostrando paquete {}", id); InformeEmpleadoDetalle detalle = manager.obtiene(id); modelo.addAttribute(Constantes.ADDATTRIBUTE_INFORMEEMPLEADODETALLE, detalle); return Constantes.PATH_INFORMEEMPLEADODETALLE_VER; } @RequestMapping("/nuevo") public String nueva(HttpServletRequest request, Model modelo) { log.debug("Nuevo paquete"); Map<String, Object> params = new HashMap<>(); params = managerInforme.lista(params); List<InformeEmpleado> informes = (List) params.get(Constantes.CONTAINSKEY_INFORMESEMPLEADO); modelo.addAttribute(Constantes.CONTAINSKEY_INFORMESEMPLEADO, informes); InformeEmpleadoDetalle detalle = new InformeEmpleadoDetalle(); modelo.addAttribute(Constantes.ADDATTRIBUTE_INFORMEEMPLEADODETALLE, detalle); params.put("empresa", request.getSession() .getAttribute("empresaId")); params.put("reporte", true); modelo.addAttribute(Constantes.ADDATTRIBUTE_INFORMEEMPLEADODETALLE, detalle); return Constantes.PATH_INFORMEEMPLEADODETALLE_NUEVO; } @Transactional @RequestMapping(value = "/graba", method = RequestMethod.POST) public String graba(HttpServletRequest request, HttpServletResponse response, @Valid InformeEmpleadoDetalle detalle, BindingResult bindingResult, Errors errors, Model modelo, RedirectAttributes redirectAttributes, @ModelAttribute("uploadForm") FileUploadForm uploadForm) throws Exception { 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"); Map<String, Object> params = new HashMap<>(); params.put("empresa", request.getSession() .getAttribute("empresaId")); this.despliegaBindingResultErrors(bindingResult); return Constantes.PATH_INFORMEEMPLEADODETALLE_NUEVO; } Map<String, Object> params = new HashMap<>(); //Subir archivos List<MultipartFile> files = uploadForm.getFiles(); List<String> fileNames = new ArrayList<String>(); if (null != files && files.size() > 0) { for (MultipartFile multipartFile : files) { String fileName = multipartFile.getOriginalFilename(); fileNames.add(fileName); String uploadDir = "/home/facturas/" + request.getRemoteUser() + "/" + multipartFile.getOriginalFilename(); File dirPath = new File(uploadDir); if (!dirPath.exists()) { dirPath.mkdirs(); } multipartFile.transferTo(new File("/home/facturas/" + request.getRemoteUser() + "/" + multipartFile.getOriginalFilename())); if (multipartFile.getOriginalFilename().contains(".pdf")) { detalle.setPathPDF("/home/facturas/" + request.getRemoteUser() + "/" + multipartFile.getOriginalFilename()); detalle.setNombrePDF(multipartFile.getOriginalFilename()); } if (multipartFile.getOriginalFilename().contains(".xml")) { detalle.setPathXMl("/home/facturas/" + request.getRemoteUser() + "/" + multipartFile.getOriginalFilename()); detalle.setNombreXMl(multipartFile.getOriginalFilename()); } } } ////Subir archivos\\\ InformeEmpleado informe = (InformeEmpleado) request.getSession().getAttribute("informeEmpleadoId"); detalle.setInformeEmpleado(informe); Usuario usuario = ambiente.obtieneUsuario(); try { manager.graba(detalle, usuario); request.getSession().setAttribute("detalleId", detalle.getId()); } catch (AutorizacionCCPlInvalidoException e) { log.error("No se pudo crear el detalle", e); if (e != null) { log.debug("**Enviando mensajes....CCP no encontrado"); errors.rejectValue("ccp", "entrada.no.eligio.proveedor.message", null, null); redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE, "ccp.invalido.message"); redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{e.getMessage()}); } params = managerInforme.lista(params); List<InformeEmpleado> informes = (List) params.get(Constantes.CONTAINSKEY_INFORMESEMPLEADO); modelo.addAttribute(Constantes.CONTAINSKEY_INFORMESEMPLEADO, informes); params.put("empresa", request.getSession().getAttribute("empresaId")); modelo.addAttribute(Constantes.ADDATTRIBUTE_INFORMEEMPLEADODETALLE, detalle); return Constantes.PATH_INFORMEEMPLEADODETALLE_NUEVO; } redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE, "detalle.graba.message"); redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{detalle.getNombreProveedor()}); return "redirect:" + Constantes.PATH_INFORMEEMPLEADODETALLE_LISTA; } @Transactional @RequestMapping(value = "/actualiza", method = RequestMethod.POST) public String actualiza(HttpServletRequest request, HttpServletResponse response, @Valid InformeEmpleadoDetalle detalle, BindingResult bindingResult, Errors errors, Model modelo, RedirectAttributes redirectAttributes, @ModelAttribute("uploadForm") FileUploadForm uploadForm) throws Exception { for (String nombre : request.getParameterMap().keySet()) { log.debug("Param: {} : {}", nombre, request.getParameterMap().get(nombre)); } utils.despliegaBindingResultErrors(bindingResult); if (bindingResult.hasErrors()) { log.debug("Hubo algun error en la forma, regresando"); Map<String, Object> params = new HashMap<>(); params.put("empresa", request.getSession() .getAttribute("empresaId")); this.despliegaBindingResultErrors(bindingResult); return Constantes.PATH_INFORMEEMPLEADODETALLE_NUEVO; } try { InformeEmpleado informe = (InformeEmpleado) request.getSession().getAttribute("informeEmpleadoId"); detalle.setInformeEmpleado(informe); InformeEmpleadoDetalle detalleTmp = manager.obtiene(detalle.getId()); detalle.setNombrePDF(detalleTmp.getNombrePDF()); detalle.setNombreXMl(detalleTmp.getNombreXMl()); detalle.setPathPDF(detalleTmp.getPathPDF()); detalle.setPathXMl(detalleTmp.getPathXMl()); Usuario usuario = ambiente.obtieneUsuario(); log.debug("Paquete {}", detalle); manager.actualiza(detalle, usuario); } catch (ConstraintViolationException e) { log.error("No se pudo crear el detalle", e); return Constantes.PATH_INFORMEEMPLEADODETALLE_NUEVO; } redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE, "detalle.graba.message"); redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{detalle.getNombreProveedor()}); return "redirect:" + Constantes.PATH_INFORMEEMPLEADODETALLE_LISTA; } @RequestMapping("/edita/{id}") public String edita(@PathVariable Long id, Model modelo) { log.debug("Editar cuenta de detalles{}", id); Map<String, Object> params = new HashMap<>(); params = managerInforme.lista(params); List<InformeEmpleado> informes = (List) params.get(Constantes.CONTAINSKEY_INFORMESEMPLEADO); modelo.addAttribute(Constantes.CONTAINSKEY_INFORMESEMPLEADO, informes); InformeEmpleadoDetalle detalle = manager.obtiene(id); modelo.addAttribute(Constantes.ADDATTRIBUTE_INFORMEEMPLEADODETALLE, detalle); return Constantes.PATH_INFORMEEMPLEADODETALLE_EDITA; } @Transactional @RequestMapping(value = "/elimina", method = RequestMethod.POST) public String elimina(HttpServletRequest request, @RequestParam Long id, Model modelo, @ModelAttribute InformeEmpleadoDetalle detalle, BindingResult bindingResult, RedirectAttributes redirectAttributes) { log.debug("Elimina cuenta de detalles"); try { manager.elimina(id); redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE, "detalle.elimina.message"); redirectAttributes.addFlashAttribute(Constantes.CONTAINSKEY_MESSAGE_ATTRS, new String[]{detalle.getNombreProveedor()}); } catch (Exception e) { log.error("No se pudo eliminar el tipo de paquete " + id, e); bindingResult.addError(new ObjectError(Constantes.ADDATTRIBUTE_INFORMEEMPLEADODETALLE, new String[]{"detalle.no.elimina.message"}, null, null)); return Constantes.PATH_INFORMEEMPLEADODETALLE_VER; } return "redirect:" + Constantes.PATH_INFORMEEMPLEADODETALLE_LISTA; } @RequestMapping(value = "/descargarPdf/{id}", method = RequestMethod.GET) public ModelAndView handleRequestPDF(@PathVariable Long id, Model modelo, HttpServletRequest request, HttpServletResponse response) throws Exception { // Long detalleId = (Long) (request.getSession().getAttribute("detalleId")); // InformeEmpleadoDetalle detalle = manager.obtiene(detalleId); InformeEmpleadoDetalle detalle = manager.obtiene(id); try { // Suponemos que es un zip lo que se quiere descargar el usuario. // Aqui se hace a piñón fijo, pero podría obtenerse el fichero // pedido por el usuario a partir de algún parámetro del request // o de la URL con la que nos han llamado. String nombreFichero = detalle.getNombrePDF(); String unPath = detalle.getPathPDF(); response.setContentType("application/pdf"); response.setHeader("Content-Disposition", "attachment; filename=\"" + nombreFichero + "\""); InputStream is = new FileInputStream(unPath); IOUtils.copy(is, response.getOutputStream()); response.flushBuffer(); } catch (IOException ex) { // Sacar log de error. throw ex; } return null; } @RequestMapping(value = "/descargarXML/{id}", method = RequestMethod.GET) public ModelAndView handleRequestXML(@PathVariable Long id, Model modelo, HttpServletRequest request, HttpServletResponse response) throws Exception { InformeEmpleadoDetalle detalle = manager.obtiene(id); try { // Suponemos que es un zip lo que se quiere descargar el usuario. // Aqui se hace a piñón fijo, pero podría obtenerse el fichero // pedido por el usuario a partir de algún parámetro del request // o de la URL con la que nos han llamado. String nombreFichero = detalle.getNombreXMl(); String unPath = detalle.getPathXMl(); response.setContentType("application/xml"); response.setHeader("Content-Disposition", "attachment; filename=\"" + nombreFichero + "\""); InputStream is = new FileInputStream(unPath); IOUtils.copy(is, response.getOutputStream()); response.flushBuffer(); } catch (IOException ex) { // Sacar log de error. throw ex; } return null; } private void generaReporte(String tipo, List<InformeEmpleadoDetalle> detalle, HttpServletResponse response) throws JRException, IOException { log.debug("Generando reporte {}", tipo); byte[] archivo = null; switch (tipo) { case "PDF": archivo = generaPdf(detalle); response.setContentType("application/pdf"); response.addHeader("Content-Disposition", "attachment; filename=InformeDetalles.pdf"); break; case "CSV": archivo = generaCsv(detalle); response.setContentType("text/csv"); response.addHeader("Content-Disposition", "attachment; filename=InformeDetalles.csv"); break; case "XLS": archivo = generaXls(detalle); response.setContentType("application/vnd.ms-excel"); response.addHeader("Content-Disposition", "attachment; filename=InformeDetalles.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<InformeEmpleadoDetalle> detalle, HttpServletRequest request) throws JRException, MessagingException { log.debug("Enviando correo {}", tipo); byte[] archivo = null; String tipoContenido = null; switch (tipo) { case "PDF": archivo = generaPdf(detalle); tipoContenido = "application/pdf"; break; case "CSV": archivo = generaCsv(detalle); tipoContenido = "text/csv"; break; case "XLS": archivo = generaXls(detalle); tipoContenido = "application/vnd.ms-excel"; } MimeMessage message = mailSender.createMimeMessage(); MimeMessageHelper helper = new MimeMessageHelper(message, true); helper.setTo(ambiente.obtieneUsuario().getUsername()); String titulo = messageSource.getMessage("detalle.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 detalles) throws JRException { Map<String, Object> params = new HashMap<>(); JasperDesign jd = JRXmlLoader.load(this.getClass().getResourceAsStream("/mx/edu/um/mateo/general/reportes/detalles.jrxml")); JasperReport jasperReport = JasperCompileManager.compileReport(jd); JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, params, new JRBeanCollectionDataSource(detalles)); byte[] archivo = JasperExportManager.exportReportToPdf(jasperPrint); return archivo; } private byte[] generaCsv(List detalles) 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/detalles.jrxml")); JasperReport jasperReport = JasperCompileManager.compileReport(jd); JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, params, new JRBeanCollectionDataSource(detalles)); exporter.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint); exporter.setParameter(JRExporterParameter.OUTPUT_STREAM, byteArrayOutputStream); exporter.exportReport(); byte[] archivo = byteArrayOutputStream.toByteArray(); return archivo; } private byte[] generaXls(List detalles) 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/detalles.jrxml")); JasperReport jasperReport = JasperCompileManager.compileReport(jd); JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, params, new JRBeanCollectionDataSource(detalles)); 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; } }