From e0e7d0516766923014d7db16ef679fd1724f41bf Mon Sep 17 00:00:00 2001 From: Heng Sin Low Date: Sun, 1 Jul 2012 09:25:48 +0800 Subject: [PATCH] IDEMPIERE-324 Performance: Report render to pdf twice when auto archive is on --- .../src/org/compiere/print/ArchiveEngine.java | 72 +++++++++++++++++++ .../src/org/compiere/print/ReportEngine.java | 4 +- 2 files changed, 74 insertions(+), 2 deletions(-) diff --git a/org.adempiere.base/src/org/compiere/print/ArchiveEngine.java b/org.adempiere.base/src/org/compiere/print/ArchiveEngine.java index 49d97bc97c..6594b201f9 100644 --- a/org.adempiere.base/src/org/compiere/print/ArchiveEngine.java +++ b/org.adempiere.base/src/org/compiere/print/ArchiveEngine.java @@ -17,6 +17,13 @@ package org.compiere.print; import java.awt.print.Pageable; +import java.io.BufferedInputStream; +import java.io.ByteArrayOutputStream; +import java.io.File; +import java.io.FileInputStream; +import java.io.FileNotFoundException; +import java.io.IOException; +import java.util.logging.Level; import org.adempiere.pdf.Document; import org.compiere.model.MArchive; @@ -24,6 +31,8 @@ import org.compiere.model.MClient; import org.compiere.model.PrintInfo; import org.compiere.print.layout.LayoutEngine; import org.compiere.util.CLogger; +import org.compiere.util.Env; +import org.jfree.io.IOUtils; /** @@ -91,6 +100,69 @@ public class ArchiveEngine return data; } // archive + /** + * Create Archive. + * @param pdfFile + * @param info print info + */ + public void archive (File pdfFile, PrintInfo info) + { + // Do we need to Archive ? + MClient client = MClient.get(Env.getCtx()); + String aaClient = client.getAutoArchive(); + String aaRole = null; // role.getAutoArchive(); // TODO + String aa = aaClient; + if (aa == null) + aa = MClient.AUTOARCHIVE_None; + if (aaRole != null) + { + if (aaRole.equals(MClient.AUTOARCHIVE_AllReportsDocuments)) + aa = aaRole; + else if (aaRole.equals(MClient.AUTOARCHIVE_Documents) && !aaClient.equals(MClient.AUTOARCHIVE_AllReportsDocuments)) + aa = aaRole; + } + // Mothing to Archive + if (aa.equals(MClient.AUTOARCHIVE_None)) + return; + // Archive External only + if (aa.equals(MClient.AUTOARCHIVE_ExternalDocuments)) + { + if (info.isReport()) + return; + } + // Archive Documents only + if (aa.equals(MClient.AUTOARCHIVE_Documents)) + { + if (info.isReport()) + return; + } + + ByteArrayOutputStream bas = new ByteArrayOutputStream(); + FileInputStream fis = null; + try { + fis = new FileInputStream(pdfFile); + BufferedInputStream bis = new BufferedInputStream(fis); + IOUtils.getInstance().copyStreams(bis, bas); + } catch (FileNotFoundException e) { + log.log(Level.SEVERE, e.getLocalizedMessage(), e); + } catch (IOException e) { + log.log(Level.SEVERE, e.getLocalizedMessage(), e); + } finally { + if (fis != null) { + try { + fis.close(); + } catch (IOException e) {} + } + } + + byte[] data = bas.toByteArray(); + + // TODO to be done async + MArchive archive = new MArchive (Env.getCtx(),info, null); + archive.setBinaryData(data); + archive.saveEx(); + } // archive + /** * Can we archive the document? * @param layout layout diff --git a/org.adempiere.base/src/org/compiere/print/ReportEngine.java b/org.adempiere.base/src/org/compiere/print/ReportEngine.java index c982360e2f..9ff47e7715 100644 --- a/org.adempiere.base/src/org/compiere/print/ReportEngine.java +++ b/org.adempiere.base/src/org/compiere/print/ReportEngine.java @@ -985,9 +985,9 @@ queued-job-count = 0 (class javax.print.attribute.standard.QueuedJobCount) try { if (m_layout == null) - layout (); - ArchiveEngine.get().archive(m_layout, m_info); + layout (); Document.getPDFAsFile(fileName, m_layout.getPageable(false)); + ArchiveEngine.get().archive(new File(fileName), m_info); } catch (Exception e) {