1003856 IDEMPIERE-1951 Run report as a background job. Fix bug discover during testing.

This commit is contained in:
Heng Sin Low 2014-04-24 22:44:16 +08:00
parent c73000c38b
commit c232e04e04
3 changed files with 94 additions and 78 deletions

View File

@ -13,6 +13,7 @@ import org.compiere.process.ProcessInfoParameter;
import org.compiere.process.ServerProcessCtl; import org.compiere.process.ServerProcessCtl;
import org.compiere.util.CLogger; import org.compiere.util.CLogger;
import org.compiere.util.Env; import org.compiere.util.Env;
import org.compiere.util.Trx;
@ -28,6 +29,19 @@ public class ServerReportCtl {
/** Static Logger */ /** Static Logger */
private static CLogger s_log = CLogger.getCLogger (ServerReportCtl.class); private static CLogger s_log = CLogger.getCLogger (ServerReportCtl.class);
/**
* Start Document Print for Type with specified printer.
* @param type
* @param customPrintFormat
* @param Record_ID
* @param printerName
* @return
*/
public static boolean startDocumentPrint (int type, MPrintFormat customPrintFormat, int Record_ID, String printerName)
{
return startDocumentPrint(type, customPrintFormat, Record_ID, printerName, null);
}
/** /**
* Start Document Print for Type with specified printer. * Start Document Print for Type with specified printer.
* @param type document type in ReportEngine * @param type document type in ReportEngine
@ -35,9 +49,10 @@ public class ServerReportCtl {
* @param parent The window which invoked the printing * @param parent The window which invoked the printing
* @param WindowNo The windows number which invoked the printing * @param WindowNo The windows number which invoked the printing
* @param printerName Specified printer name * @param printerName Specified printer name
* @param pi
* @return true if success * @return true if success
*/ */
public static boolean startDocumentPrint (int type, MPrintFormat customPrintFormat, int Record_ID, String printerName) public static boolean startDocumentPrint (int type, MPrintFormat customPrintFormat, int Record_ID, String printerName, ProcessInfo pi)
{ {
ReportEngine re = ReportEngine.get (Env.getCtx(), type, Record_ID); ReportEngine re = ReportEngine.get (Env.getCtx(), type, Record_ID);
if (re == null) if (re == null)
@ -59,21 +74,27 @@ public class ServerReportCtl {
// ============================== // ==============================
if(format.getJasperProcess_ID() > 0) if(format.getJasperProcess_ID() > 0)
{ {
boolean result = runJasperProcess(Record_ID, re, true, printerName); boolean result = runJasperProcess(Record_ID, re, true, printerName, pi);
return(result); return(result);
} }
else else
// Standard Print Format (Non-Jasper) // Standard Print Format (Non-Jasper)
// ================================== // ==================================
{
if (pi != null && pi.isBatch() && pi.isPrintPreview())
{
pi.setPDFReport(re.getPDF());
}
else
{ {
createOutput(re, printerName); createOutput(re, printerName);
}
ReportEngine.printConfirm (type, Record_ID); ReportEngine.printConfirm (type, Record_ID);
} }
} }
return true; return true;
} // StartDocumentPrint } // StartDocumentPrint
/** /**
* Runs a Jasper process that prints the record * Runs a Jasper process that prints the record
* *
@ -85,10 +106,29 @@ public class ServerReportCtl {
* @return * @return
*/ */
public static boolean runJasperProcess(int Record_ID, ReportEngine re, boolean IsDirectPrint, String printerName) { public static boolean runJasperProcess(int Record_ID, ReportEngine re, boolean IsDirectPrint, String printerName) {
return runJasperProcess(Record_ID, re, IsDirectPrint, printerName, null);
}
/**
* Runs a Jasper process that prints the record
*
* @param format
* @param Record_ID
* @param re
* @param IsDirectPrint
* @param printerName
* @return
*/
public static boolean runJasperProcess(int Record_ID, ReportEngine re, boolean IsDirectPrint, String printerName, ProcessInfo pi) {
MPrintFormat format = re.getPrintFormat(); MPrintFormat format = re.getPrintFormat();
ProcessInfo pi = new ProcessInfo ("", format.getJasperProcess_ID()); ProcessInfo jasperProcessInfo = new ProcessInfo ("", format.getJasperProcess_ID());
pi.setPrintPreview( !IsDirectPrint ); if (pi != null) {
pi.setRecord_ID ( Record_ID ); jasperProcessInfo.setPrintPreview(pi.isPrintPreview());
jasperProcessInfo.setIsBatch(pi.isBatch());
} else {
jasperProcessInfo.setPrintPreview( !IsDirectPrint );
}
jasperProcessInfo.setRecord_ID ( Record_ID );
ArrayList<ProcessInfoParameter> jasperPrintParams = new ArrayList<ProcessInfoParameter>(); ArrayList<ProcessInfoParameter> jasperPrintParams = new ArrayList<ProcessInfoParameter>();
ProcessInfoParameter pip; ProcessInfoParameter pip;
if (printerName!=null && printerName.trim().length()>0) { if (printerName!=null && printerName.trim().length()>0) {
@ -101,11 +141,15 @@ public class ServerReportCtl {
pip = new ProcessInfoParameter(PARAM_PRINT_INFO, re.getPrintInfo(), null, null, null); pip = new ProcessInfoParameter(PARAM_PRINT_INFO, re.getPrintInfo(), null, null, null);
jasperPrintParams.add(pip); jasperPrintParams.add(pip);
pi.setParameter(jasperPrintParams.toArray(new ProcessInfoParameter[]{})); jasperProcessInfo.setParameter(jasperPrintParams.toArray(new ProcessInfoParameter[]{}));
ServerProcessCtl.process(pi, null); ServerProcessCtl.process(jasperProcessInfo, pi != null ? Trx.get(pi.getTransactionName(),false) : null);
boolean result = true; boolean result = !jasperProcessInfo.isError();
if (result && pi != null && pi.isBatch())
{
pi.setPDFReport(jasperProcessInfo.getPDFReport());
}
return(result); return(result);
} }
@ -139,21 +183,21 @@ public class ServerReportCtl {
* Order Print * Order Print
*/ */
if (pi.getAD_Process_ID() == 110) // C_Order if (pi.getAD_Process_ID() == 110) // C_Order
return startDocumentPrint(ReportEngine.ORDER, null, pi.getRecord_ID(), null); return startDocumentPrint(ReportEngine.ORDER, null, pi.getRecord_ID(), null, pi);
if (pi.getAD_Process_ID() == MProcess.getProcess_ID("Rpt PP_Order", null)) // C_Order if (pi.getAD_Process_ID() == MProcess.getProcess_ID("Rpt PP_Order", null)) // C_Order
return startDocumentPrint(ReportEngine.MANUFACTURING_ORDER, null, pi.getRecord_ID(), null); return startDocumentPrint(ReportEngine.MANUFACTURING_ORDER, null, pi.getRecord_ID(), null, pi);
if (pi.getAD_Process_ID() == MProcess.getProcess_ID("Rpt DD_Order", null)) // C_Order if (pi.getAD_Process_ID() == MProcess.getProcess_ID("Rpt DD_Order", null)) // C_Order
return startDocumentPrint(ReportEngine.DISTRIBUTION_ORDER, null, pi.getRecord_ID(), null); return startDocumentPrint(ReportEngine.DISTRIBUTION_ORDER, null, pi.getRecord_ID(), null, pi);
else if (pi.getAD_Process_ID() == 116) // C_Invoice else if (pi.getAD_Process_ID() == 116) // C_Invoice
return startDocumentPrint(ReportEngine.INVOICE, null, pi.getRecord_ID(), null); return startDocumentPrint(ReportEngine.INVOICE, null, pi.getRecord_ID(), null, pi);
else if (pi.getAD_Process_ID() == 117) // M_InOut else if (pi.getAD_Process_ID() == 117) // M_InOut
return startDocumentPrint(ReportEngine.SHIPMENT, null, pi.getRecord_ID(), null); return startDocumentPrint(ReportEngine.SHIPMENT, null, pi.getRecord_ID(), null, pi);
else if (pi.getAD_Process_ID() == 217) // C_Project else if (pi.getAD_Process_ID() == 217) // C_Project
return startDocumentPrint(ReportEngine.PROJECT, null, pi.getRecord_ID(), null); return startDocumentPrint(ReportEngine.PROJECT, null, pi.getRecord_ID(), null, pi);
else if (pi.getAD_Process_ID() == 276) // C_RfQResponse else if (pi.getAD_Process_ID() == 276) // C_RfQResponse
return startDocumentPrint(ReportEngine.RFQ, null, pi.getRecord_ID(), null); return startDocumentPrint(ReportEngine.RFQ, null, pi.getRecord_ID(), null, pi);
else if (pi.getAD_Process_ID() == 159) // Dunning else if (pi.getAD_Process_ID() == 159) // Dunning
return startDocumentPrint(ReportEngine.DUNNING, null, pi.getRecord_ID(), null); return startDocumentPrint(ReportEngine.DUNNING, null, pi.getRecord_ID(), null, pi);
else if (pi.getAD_Process_ID() == 202 // Financial Report else if (pi.getAD_Process_ID() == 202 // Financial Report
|| pi.getAD_Process_ID() == 204) // Financial Statement || pi.getAD_Process_ID() == 204) // Financial Statement
return startFinReport (pi); return startFinReport (pi);
@ -203,7 +247,14 @@ public class ServerReportCtl {
MQuery query = MQuery.get (ctx, pi.getAD_PInstance_ID(), TableName); MQuery query = MQuery.get (ctx, pi.getAD_PInstance_ID(), TableName);
PrintInfo info = new PrintInfo(pi); PrintInfo info = new PrintInfo(pi);
re = new ReportEngine(ctx, format, query, info); re = new ReportEngine(ctx, format, query, info);
if (pi.isPrintPreview() && pi.isBatch())
{
pi.setPDFReport(re.getPDF());
}
else
{
createOutput(re, null); createOutput(re, null);
}
return true; return true;
} }
// //
@ -217,7 +268,14 @@ public class ServerReportCtl {
} }
} }
if (pi.isPrintPreview() && pi.isBatch())
{
pi.setPDFReport(re.getPDF());
}
else
{
createOutput(re, null); createOutput(re, null);
}
return true; return true;
} // startStandardReport } // startStandardReport
@ -247,7 +305,14 @@ public class ServerReportCtl {
PrintInfo info = new PrintInfo(pi); PrintInfo info = new PrintInfo(pi);
ReportEngine re = new ReportEngine(Env.getCtx(), format, query, info); ReportEngine re = new ReportEngine(Env.getCtx(), format, query, info);
if (pi.isPrintPreview() && pi.isBatch())
{
pi.setPDFReport(re.getPDF());
}
else
{
createOutput(re, null); createOutput(re, null);
}
return true; return true;
} // startFinReport } // startFinReport

View File

@ -41,7 +41,6 @@ import org.compiere.model.MScheduler;
import org.compiere.model.MSchedulerLog; import org.compiere.model.MSchedulerLog;
import org.compiere.model.MSchedulerPara; import org.compiere.model.MSchedulerPara;
import org.compiere.model.MUser; import org.compiere.model.MUser;
import org.compiere.print.ReportEngine;
import org.compiere.process.ProcessInfo; import org.compiere.process.ProcessInfo;
import org.compiere.process.ProcessInfoUtil; import org.compiere.process.ProcessInfoUtil;
import org.compiere.process.ServerProcessCtl; import org.compiere.process.ServerProcessCtl;
@ -173,6 +172,7 @@ public class Scheduler extends AdempiereServer
pi.setAD_Client_ID(m_model.getAD_Client_ID()); pi.setAD_Client_ID(m_model.getAD_Client_ID());
pi.setAD_PInstance_ID(pInstance.getAD_PInstance_ID()); pi.setAD_PInstance_ID(pInstance.getAD_PInstance_ID());
pi.setIsBatch(true); pi.setIsBatch(true);
pi.setPrintPreview(true);
MUser from = new MUser(getCtx(), pi.getAD_User_ID(), null); MUser from = new MUser(getCtx(), pi.getAD_User_ID(), null);
ServerProcessCtl.process(pi, m_trx); ServerProcessCtl.process(pi, m_trx);
@ -220,32 +220,8 @@ public class Scheduler extends AdempiereServer
ProcessInfoUtil.setLogFromDB(pi); ProcessInfoUtil.setLogFromDB(pi);
List<File> fileList = new ArrayList<File>(); List<File> fileList = new ArrayList<File>();
if (isReport) { if (isReport) {
// Report
ReportEngine re = ReportEngine.get(m_schedulerctx, pi);
if(re != null && re.getPrintFormat().getJasperProcess_ID() > 0)
{
// We have a Jasper Print Format
// ==============================
ProcessInfo jasperpi = new ProcessInfo ("", re.getPrintFormat().getJasperProcess_ID());
jasperpi.setIsBatch(true);
ServerProcessCtl.process(jasperpi, null);
fileList.add(jasperpi.getPDFReport());
}
else if (process.getJasperReport() != null)
{
fileList.add(pi.getPDFReport()); fileList.add(pi.getPDFReport());
} }
else
{
// Standard Print Format (Non-Jasper)
// ==================================
if (re == null)
return "Cannot create Report AD_Process_ID=" + process.getAD_Process_ID()
+ " - " + process.getName();
fileList.add(re.getPDF());
}
}
if (pi.isExport() && pi.getExportFile() != null) if (pi.isExport() && pi.getExportFile() != null)
{ {
fileList.add(pi.getExportFile()); fileList.add(pi.getExportFile());
@ -303,7 +279,7 @@ public class Scheduler extends AdempiereServer
if (fileList != null && !fileList.isEmpty()) { if (fileList != null && !fileList.isEmpty()) {
client.sendEMailAttachments(from, user, m_model.getName(), m_model.getDescription(), fileList); client.sendEMailAttachments(from, user, m_model.getName(), m_model.getDescription(), fileList);
} else { } else {
client.sendEMail(from, user, m_model.getName(), pi.getSummary() + " " + pi.getLogInfo(), null); client.sendEMail(from, user, m_model.getName(), pi.getSummary() + " " + pi.getLogInfo(true), null, true);
} }
} }

View File

@ -57,7 +57,6 @@ import org.compiere.model.MProcess;
import org.compiere.model.MSysConfig; import org.compiere.model.MSysConfig;
import org.compiere.model.MUser; import org.compiere.model.MUser;
import org.compiere.model.Query; import org.compiere.model.Query;
import org.compiere.print.ReportEngine;
import org.compiere.process.ProcessInfo; import org.compiere.process.ProcessInfo;
import org.compiere.process.ProcessInfoUtil; import org.compiere.process.ProcessInfoUtil;
import org.compiere.process.ServerProcessCtl; import org.compiere.process.ServerProcessCtl;
@ -667,6 +666,7 @@ public abstract class AbstractProcessDialog extends Window implements IProcessUI
{ {
ProcessInfo m_pi = getProcessInfo(); ProcessInfo m_pi = getProcessInfo();
m_pi.setIsBatch(true); m_pi.setIsBatch(true);
m_pi.setPrintPreview(true);
MPInstance instance = new MPInstance(m_ctx, m_pi.getAD_PInstance_ID(), null); MPInstance instance = new MPInstance(m_ctx, m_pi.getAD_PInstance_ID(), null);
String notificationType = instance.getNotificationType(); String notificationType = instance.getNotificationType();
@ -686,37 +686,12 @@ public abstract class AbstractProcessDialog extends Window implements IProcessUI
{ {
boolean isReport = (process.isReport() || process.getAD_ReportView_ID() > 0 || process.getJasperReport() != null || process.getAD_PrintFormat_ID() > 0); boolean isReport = (process.isReport() || process.getAD_ReportView_ID() > 0 || process.getJasperReport() != null || process.getAD_PrintFormat_ID() > 0);
if (isReport) if (isReport)
{
ReportEngine re = ReportEngine.get(m_ctx, m_pi);
if(re != null && re.getPrintFormat().getJasperProcess_ID() > 0)
{
ProcessInfo jasperpi = new ProcessInfo ("", re.getPrintFormat().getJasperProcess_ID());
jasperpi.setIsBatch(true);
ServerProcessCtl.process(jasperpi, null);
File report = jasperpi.getPDFReport();
if (report != null)
download(report);
}
else if (process.getJasperReport() != null)
{ {
download(m_pi.getPDFReport()); download(m_pi.getPDFReport());
} }
else
{
if (re == null)
log.log(Level.SEVERE, "Cannot create Report AD_Process_ID=" + process.getAD_Process_ID() + " - " + process.getName());
else
{
File report = re.getPDF();
if (report != null)
download(report);
}
}
}
File generatedFile = m_pi.isExport() ? m_pi.getExportFile() : m_pi.getPDFReport(); if (m_pi.isExport() && m_pi.getExportFile() != null)
if (generatedFile != null) download(m_pi.getExportFile());
download(generatedFile);
} }
if (sendEmail) if (sendEmail)