https://sourceforge.net/tracker/?func=detail&atid=879332&aid=1729316&group_id=176962 [ Create dunning (partially) fails silently ]
- bpartner with no location exception is handle and log as process log - other exception doesn't trigger transaction rollback but log as process log so user knows that some invoice/payment is not process
This commit is contained in:
parent
6309936b81
commit
fc21ce058b
|
@ -22,6 +22,7 @@ import java.util.ArrayList;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
|
|
||||||
|
import org.adempiere.exceptions.BPartnerNoAddressException;
|
||||||
import org.compiere.util.CLogger;
|
import org.compiere.util.CLogger;
|
||||||
import org.compiere.util.DB;
|
import org.compiere.util.DB;
|
||||||
import org.compiere.util.Env;
|
import org.compiere.util.Env;
|
||||||
|
@ -40,6 +41,7 @@ public class MDunningRunEntry extends X_C_DunningRunEntry
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
private static final long serialVersionUID = 2028055451030209868L;
|
private static final long serialVersionUID = 2028055451030209868L;
|
||||||
|
|
||||||
/** Logger */
|
/** Logger */
|
||||||
private static CLogger s_log = CLogger.getCLogger (MPayment.class);
|
private static CLogger s_log = CLogger.getCLogger (MPayment.class);
|
||||||
|
|
||||||
|
@ -106,30 +108,58 @@ public class MDunningRunEntry extends X_C_DunningRunEntry
|
||||||
setC_BPartner_Location_ID (locations[0].getC_BPartner_Location_ID());
|
setC_BPartner_Location_ID (locations[0].getC_BPartner_Location_ID());
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
MBPartnerLocation firstActive = null;
|
||||||
|
MBPartnerLocation firstBillTo = null;
|
||||||
for (int i = 0; i < locations.length; i++)
|
for (int i = 0; i < locations.length; i++)
|
||||||
{
|
{
|
||||||
MBPartnerLocation location = locations[i];
|
MBPartnerLocation location = locations[i];
|
||||||
if (!location.isActive())
|
if (!location.isActive())
|
||||||
|
{
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
|
else if (firstActive == null)
|
||||||
|
{
|
||||||
|
firstActive = location;
|
||||||
|
}
|
||||||
if ((location.isPayFrom() && isSOTrx)
|
if ((location.isPayFrom() && isSOTrx)
|
||||||
|| (location.isRemitTo() && !isSOTrx))
|
|| (location.isRemitTo() && !isSOTrx))
|
||||||
{
|
{
|
||||||
setC_BPartner_Location_ID (location.getC_BPartner_Location_ID());
|
setC_BPartner_Location_ID (location.getC_BPartner_Location_ID());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
else if (firstBillTo == null && location.isBillTo())
|
||||||
|
{
|
||||||
|
firstBillTo = location;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// If IsPayFrom or isRemitTo is not found among the BP Locations, check IsBillTo
|
||||||
|
// if that isn't available, we should use any active location
|
||||||
|
if(getC_BPartner_Location_ID() == 0)
|
||||||
|
{
|
||||||
|
if (firstBillTo != null)
|
||||||
|
{
|
||||||
|
setC_BPartner_Location_ID (firstBillTo.getC_BPartner_Location_ID());
|
||||||
|
}
|
||||||
|
else if (firstActive != null)
|
||||||
|
{
|
||||||
|
String msg = "@C_BPartner_ID@ " + bp.getName();
|
||||||
|
if (isSOTrx)
|
||||||
|
msg += " @No@ @IsPayFrom@";
|
||||||
|
else
|
||||||
|
msg += " @No@ @IsRemitTo@";
|
||||||
|
msg += " & @IsBillTo@";
|
||||||
|
log.info(msg);
|
||||||
|
setC_BPartner_Location_ID (firstActive.getC_BPartner_Location_ID());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (getC_BPartner_Location_ID() == 0)
|
if (getC_BPartner_Location_ID() == 0)
|
||||||
{
|
{
|
||||||
String msg = "@C_BPartner_ID@ " + bp.getName();
|
throw new BPartnerNoAddressException(bp);
|
||||||
if (isSOTrx)
|
|
||||||
msg += " @No@ @IsPayFrom@";
|
|
||||||
else
|
|
||||||
msg += " @No@ @IsRemitTo@";
|
|
||||||
throw new IllegalArgumentException (msg);
|
|
||||||
}
|
}
|
||||||
// User with location
|
// User with location
|
||||||
MUser[] users = MUser.getOfBPartner(getCtx(), bp.getC_BPartner_ID());
|
MUser[] users = MUser.getOfBPartner(getCtx(), bp.getC_BPartner_ID(), null);
|
||||||
if (users.length == 1)
|
if (users.length == 1)
|
||||||
setAD_User_ID (users[0].getAD_User_ID());
|
setAD_User_ID (users[0].getAD_User_ID());
|
||||||
else
|
else
|
||||||
|
|
|
@ -21,11 +21,14 @@ import java.sql.PreparedStatement;
|
||||||
import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
|
|
||||||
|
import org.adempiere.exceptions.BPartnerNoAddressException;
|
||||||
|
import org.compiere.model.MBPartner;
|
||||||
import org.compiere.model.MDunningLevel;
|
import org.compiere.model.MDunningLevel;
|
||||||
import org.compiere.model.MDunningRun;
|
import org.compiere.model.MDunningRun;
|
||||||
import org.compiere.model.MDunningRunEntry;
|
import org.compiere.model.MDunningRunEntry;
|
||||||
import org.compiere.model.MDunningRunLine;
|
import org.compiere.model.MDunningRunLine;
|
||||||
import org.compiere.model.MInvoice;
|
import org.compiere.model.MInvoice;
|
||||||
|
import org.compiere.model.MPayment;
|
||||||
import org.compiere.util.DB;
|
import org.compiere.util.DB;
|
||||||
import org.compiere.util.Env;
|
import org.compiere.util.Env;
|
||||||
|
|
||||||
|
@ -252,16 +255,19 @@ public class DunningRunCreate extends SvrProcess
|
||||||
if (DaysBetweenDunning != 0 && DaysAfterLast < DaysBetweenDunning && !m_level.isShowAllDue () && !m_level.isShowNotDue ())
|
if (DaysBetweenDunning != 0 && DaysAfterLast < DaysBetweenDunning && !m_level.isShowAllDue () && !m_level.isShowNotDue ())
|
||||||
continue;
|
continue;
|
||||||
//
|
//
|
||||||
createInvoiceLine (C_Invoice_ID, C_InvoicePaySchedule_ID, C_Currency_ID, GrandTotal, Open,
|
if (createInvoiceLine (C_Invoice_ID, C_InvoicePaySchedule_ID, C_Currency_ID, GrandTotal, Open,
|
||||||
DaysDue, IsInDispute, C_BPartner_ID,
|
DaysDue, IsInDispute, C_BPartner_ID,
|
||||||
TimesDunned, DaysAfterLast);
|
TimesDunned, DaysAfterLast))
|
||||||
count++;
|
{
|
||||||
|
count++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
log.log(Level.SEVERE, "addInvoices", e);
|
log.log(Level.SEVERE, "addInvoices", e);
|
||||||
|
getProcessInfo().addLog(getProcessInfo().getAD_PInstance_ID(), null, null, e.getLocalizedMessage());
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
|
@ -283,15 +289,30 @@ public class DunningRunCreate extends SvrProcess
|
||||||
* @param TimesDunned
|
* @param TimesDunned
|
||||||
* @param DaysAfterLast
|
* @param DaysAfterLast
|
||||||
*/
|
*/
|
||||||
private void createInvoiceLine (int C_Invoice_ID, int C_InvoicePaySchedule_ID, int C_Currency_ID,
|
private boolean createInvoiceLine (int C_Invoice_ID, int C_InvoicePaySchedule_ID, int C_Currency_ID,
|
||||||
BigDecimal GrandTotal, BigDecimal Open,
|
BigDecimal GrandTotal, BigDecimal Open,
|
||||||
int DaysDue, boolean IsInDispute,
|
int DaysDue, boolean IsInDispute,
|
||||||
int C_BPartner_ID, int TimesDunned, int DaysAfterLast)
|
int C_BPartner_ID, int TimesDunned, int DaysAfterLast)
|
||||||
{
|
{
|
||||||
MDunningRunEntry entry = m_run.getEntry (C_BPartner_ID, p_C_Currency_ID, p_SalesRep_ID);
|
MDunningRunEntry entry = null;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
entry = m_run.getEntry (C_BPartner_ID, p_C_Currency_ID, p_SalesRep_ID);
|
||||||
|
}
|
||||||
|
catch (BPartnerNoAddressException e)
|
||||||
|
{
|
||||||
|
String msg = "@Skip@ @C_Invoice_ID@ " + MInvoice.get(getCtx(), C_Invoice_ID).getDocumentInfo()
|
||||||
|
+ ", @C_BPartner_ID@ " + MBPartner.get(getCtx(), C_BPartner_ID).getName()
|
||||||
|
+ " @No@ @IsActive@ @C_BPartner_Location_ID@";
|
||||||
|
getProcessInfo().addLog(getProcessInfo().getAD_PInstance_ID(), null, null, msg);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
if (entry.get_ID() == 0)
|
if (entry.get_ID() == 0)
|
||||||
|
{
|
||||||
if (!entry.save())
|
if (!entry.save())
|
||||||
throw new IllegalStateException("Cannot save MDunningRunEntry");
|
throw new IllegalStateException("Cannot save MDunningRunEntry");
|
||||||
|
}
|
||||||
//
|
//
|
||||||
MDunningRunLine line = new MDunningRunLine (entry);
|
MDunningRunLine line = new MDunningRunLine (entry);
|
||||||
line.setInvoice(C_Invoice_ID, C_Currency_ID, GrandTotal, Open,
|
line.setInvoice(C_Invoice_ID, C_Currency_ID, GrandTotal, Open,
|
||||||
|
@ -304,6 +325,8 @@ public class DunningRunCreate extends SvrProcess
|
||||||
invoice.setC_DunningLevel_ID(m_run.getC_DunningLevel_ID());
|
invoice.setC_DunningLevel_ID(m_run.getC_DunningLevel_ID());
|
||||||
if (!invoice.save())
|
if (!invoice.save())
|
||||||
throw new IllegalStateException("Cannot update dunning level information in invoice");
|
throw new IllegalStateException("Cannot update dunning level information in invoice");
|
||||||
|
|
||||||
|
return true;
|
||||||
} // createInvoiceLine
|
} // createInvoiceLine
|
||||||
|
|
||||||
|
|
||||||
|
@ -359,14 +382,17 @@ public class DunningRunCreate extends SvrProcess
|
||||||
if (Env.ZERO.compareTo(OpenAmt) == 0)
|
if (Env.ZERO.compareTo(OpenAmt) == 0)
|
||||||
continue;
|
continue;
|
||||||
//
|
//
|
||||||
createPaymentLine (C_Payment_ID, C_Currency_ID, PayAmt, OpenAmt,
|
if (createPaymentLine (C_Payment_ID, C_Currency_ID, PayAmt, OpenAmt,
|
||||||
C_BPartner_ID);
|
C_BPartner_ID))
|
||||||
count++;
|
{
|
||||||
|
count++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
log.log(Level.SEVERE, sql, e);
|
log.log(Level.SEVERE, sql, e);
|
||||||
|
getProcessInfo().addLog(getProcessInfo().getAD_PInstance_ID(), null, null, e.getLocalizedMessage());
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
|
@ -384,10 +410,20 @@ public class DunningRunCreate extends SvrProcess
|
||||||
* @param OpenAmt
|
* @param OpenAmt
|
||||||
* @param C_BPartner_ID
|
* @param C_BPartner_ID
|
||||||
*/
|
*/
|
||||||
private void createPaymentLine (int C_Payment_ID, int C_Currency_ID,
|
private boolean createPaymentLine (int C_Payment_ID, int C_Currency_ID,
|
||||||
BigDecimal PayAmt, BigDecimal OpenAmt, int C_BPartner_ID)
|
BigDecimal PayAmt, BigDecimal OpenAmt, int C_BPartner_ID)
|
||||||
{
|
{
|
||||||
MDunningRunEntry entry = m_run.getEntry (C_BPartner_ID, p_C_Currency_ID, p_SalesRep_ID);
|
MDunningRunEntry entry = null;
|
||||||
|
try {
|
||||||
|
entry = m_run.getEntry (C_BPartner_ID, p_C_Currency_ID, p_SalesRep_ID);
|
||||||
|
} catch (BPartnerNoAddressException e) {
|
||||||
|
MPayment payment = new MPayment(getCtx(), C_Payment_ID, null);
|
||||||
|
String msg = "@Skip@ @C_Payment_ID@ " + payment.getDocumentInfo()
|
||||||
|
+ ", @C_BPartner_ID@ " + MBPartner.get(getCtx(), C_BPartner_ID).getName()
|
||||||
|
+ " @No@ @IsActive@ @C_BPartner_Location_ID@";
|
||||||
|
getProcessInfo().addLog(getProcessInfo().getAD_PInstance_ID(), null, null, msg);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
if (entry.get_ID() == 0)
|
if (entry.get_ID() == 0)
|
||||||
if (!entry.save())
|
if (!entry.save())
|
||||||
throw new IllegalStateException("Cannot save MDunningRunEntry");
|
throw new IllegalStateException("Cannot save MDunningRunEntry");
|
||||||
|
@ -396,6 +432,7 @@ public class DunningRunCreate extends SvrProcess
|
||||||
line.setPayment(C_Payment_ID, C_Currency_ID, PayAmt, OpenAmt);
|
line.setPayment(C_Payment_ID, C_Currency_ID, PayAmt, OpenAmt);
|
||||||
if (!line.save())
|
if (!line.save())
|
||||||
throw new IllegalStateException("Cannot save MDunningRunLine");
|
throw new IllegalStateException("Cannot save MDunningRunLine");
|
||||||
|
return true;
|
||||||
} // createPaymentLine
|
} // createPaymentLine
|
||||||
|
|
||||||
private void addFees()
|
private void addFees()
|
||||||
|
|
Loading…
Reference in New Issue