1003856 IDEMPIERE-1951 Run report as a background job. Fix bug discover during testing.
This commit is contained in:
parent
c73000c38b
commit
c232e04e04
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue