Merge release-7.1 into master
This commit is contained in:
commit
680bb2090c
|
@ -241,6 +241,7 @@ public class GridTabCSVImporter implements IGridTabImporter
|
||||||
manageMasterTrx(gridTab, null);
|
manageMasterTrx(gridTab, null);
|
||||||
createTrx(gridTab);
|
createTrx(gridTab);
|
||||||
}
|
}
|
||||||
|
if (trx != null)
|
||||||
trx.setDisplayName(GridTabCSVImporter.class.getName()+"_fileImport_" + gridTab.getTableName());
|
trx.setDisplayName(GridTabCSVImporter.class.getName()+"_fileImport_" + gridTab.getTableName());
|
||||||
|
|
||||||
String recordResult = processRecord(importMode, gridTab, indxDetail, isDetail, idx, rowResult, childs);
|
String recordResult = processRecord(importMode, gridTab, indxDetail, isDetail, idx, rowResult, childs);
|
||||||
|
|
|
@ -82,6 +82,8 @@ public class MDocTypeCounter extends X_C_DocTypeCounter
|
||||||
return Counter_C_DocType_ID;
|
return Counter_C_DocType_ID;
|
||||||
} // getCounterDocType_ID
|
} // getCounterDocType_ID
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get (first) valid Counter document for document type
|
* Get (first) valid Counter document for document type
|
||||||
* @param ctx context
|
* @param ctx context
|
||||||
|
@ -97,7 +99,7 @@ public class MDocTypeCounter extends X_C_DocTypeCounter
|
||||||
|
|
||||||
// Direct Relationship
|
// Direct Relationship
|
||||||
MDocTypeCounter temp = null;
|
MDocTypeCounter temp = null;
|
||||||
String sql = "SELECT * FROM C_DocTypeCounter WHERE C_DocType_ID=?";
|
String sql = "SELECT * FROM C_DocTypeCounter WHERE IsActive = 'Y' and C_DocType_ID=?";
|
||||||
PreparedStatement pstmt = null;
|
PreparedStatement pstmt = null;
|
||||||
ResultSet rs = null;
|
ResultSet rs = null;
|
||||||
try
|
try
|
||||||
|
|
|
@ -1,21 +0,0 @@
|
||||||
/**
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
package org.idempiere.fa.exceptions;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author Teo Sarca, SC ARHIPAC SERVICE SRL
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public class AssetInvoiceWithMixedLines_LRO extends AssetException {
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
private static final long serialVersionUID = 7477049497754422353L;
|
|
||||||
|
|
||||||
public AssetInvoiceWithMixedLines_LRO() {
|
|
||||||
super("@AssetInvoiceWithMixedLines@");
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -22,7 +22,6 @@ import org.compiere.model.SetGetModel;
|
||||||
import org.compiere.model.SetGetUtil;
|
import org.compiere.model.SetGetUtil;
|
||||||
import org.compiere.util.CLogger;
|
import org.compiere.util.CLogger;
|
||||||
import org.compiere.util.DB;
|
import org.compiere.util.DB;
|
||||||
import org.idempiere.fa.exceptions.AssetInvoiceWithMixedLines_LRO;
|
|
||||||
import org.idempiere.fa.exceptions.AssetProductStockedException;
|
import org.idempiere.fa.exceptions.AssetProductStockedException;
|
||||||
|
|
||||||
|
|
||||||
|
@ -57,7 +56,6 @@ implements org.compiere.model.ModelValidator, org.compiere.model.FactsValidator
|
||||||
engine.addDocValidate(MInvoice.Table_Name, this);
|
engine.addDocValidate(MInvoice.Table_Name, this);
|
||||||
engine.addModelChange(MMatchInv.Table_Name, this);
|
engine.addModelChange(MMatchInv.Table_Name, this);
|
||||||
//
|
//
|
||||||
// engine.addFactsValidate(MDepreciationEntry.Table_Name, this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String login(int AD_Org_ID, int AD_Role_ID, int AD_User_ID)
|
public String login(int AD_Org_ID, int AD_Role_ID, int AD_User_ID)
|
||||||
|
@ -105,12 +103,6 @@ implements org.compiere.model.ModelValidator, org.compiere.model.FactsValidator
|
||||||
// TABLE C_Invoice
|
// TABLE C_Invoice
|
||||||
String tableName = po.get_TableName();
|
String tableName = po.get_TableName();
|
||||||
if(tableName.equals(MInvoice.Table_Name)){
|
if(tableName.equals(MInvoice.Table_Name)){
|
||||||
// Invoice - Validate Fixed Assets Invoice (LRO)
|
|
||||||
if (timing==TIMING_AFTER_PREPARE)
|
|
||||||
{
|
|
||||||
MInvoice invoice = (MInvoice)po;
|
|
||||||
validateFixedAssetsInvoice_LRO(invoice);
|
|
||||||
}
|
|
||||||
|
|
||||||
if(timing==TIMING_AFTER_COMPLETE){
|
if(timing==TIMING_AFTER_COMPLETE){
|
||||||
MInvoice mi = (MInvoice)po;
|
MInvoice mi = (MInvoice)po;
|
||||||
|
@ -134,7 +126,7 @@ implements org.compiere.model.ModelValidator, org.compiere.model.FactsValidator
|
||||||
* @param m model
|
* @param m model
|
||||||
* @param changeType set when called from model validator (See TYPE_*); else -1, when called from callout
|
* @param changeType set when called from model validator (See TYPE_*); else -1, when called from callout
|
||||||
*/
|
*/
|
||||||
public static void modelChange_InvoiceLine(SetGetModel m, int changeType) {
|
public void modelChange_InvoiceLine(SetGetModel m, int changeType) {
|
||||||
//
|
//
|
||||||
// Set Asset Related Fields:
|
// Set Asset Related Fields:
|
||||||
if (-1 == changeType || TYPE_BEFORE_NEW == changeType || TYPE_BEFORE_CHANGE == changeType) {
|
if (-1 == changeType || TYPE_BEFORE_NEW == changeType || TYPE_BEFORE_CHANGE == changeType) {
|
||||||
|
@ -201,7 +193,7 @@ implements org.compiere.model.ModelValidator, org.compiere.model.FactsValidator
|
||||||
//
|
//
|
||||||
// Check Product - fixed assets products shouldn't be stocked (but inventory objects are allowed)
|
// Check Product - fixed assets products shouldn't be stocked (but inventory objects are allowed)
|
||||||
MProduct product = line.getProduct();
|
MProduct product = line.getProduct();
|
||||||
if (product.isStocked() && line.get_ValueAsBoolean("IsFixedAssetInvoice")) {
|
if (product.isStocked() && line.isFixedAssetInvoice()) {
|
||||||
throw new AssetProductStockedException(product);
|
throw new AssetProductStockedException(product);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -223,47 +215,7 @@ implements org.compiere.model.ModelValidator, org.compiere.model.FactsValidator
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if is a valid fixed asset related invoice (LRO)
|
|
||||||
* @param invoice
|
|
||||||
*/
|
|
||||||
private void validateFixedAssetsInvoice_LRO(MInvoice invoice)
|
|
||||||
{
|
|
||||||
if (invoice.get_ValueAsBoolean("IsFixedAssetInvoice"))
|
|
||||||
{
|
|
||||||
boolean hasFixedAssetLines = false;
|
|
||||||
boolean hasNormalLines = false;
|
|
||||||
for (MInvoiceLine line : invoice.getLines())
|
|
||||||
{
|
|
||||||
if (line.get_ValueAsBoolean("IsFixedAssetInvoice"))
|
|
||||||
{
|
|
||||||
hasFixedAssetLines = true;
|
|
||||||
}
|
|
||||||
else if (line.getM_Product_ID() > 0)
|
|
||||||
{
|
|
||||||
MProduct product = MProduct.get(line.getCtx(), line.getM_Product_ID());
|
|
||||||
if (product.isItem())
|
|
||||||
{
|
|
||||||
// Only items are forbiden for FA invoices because in Romania these should use
|
|
||||||
// V_Liability vendor account and not V_Liability_FixedAssets vendor account
|
|
||||||
hasNormalLines = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//
|
|
||||||
// No mixed lines are allowed
|
|
||||||
if (hasFixedAssetLines && hasNormalLines)
|
|
||||||
{
|
|
||||||
throw new AssetInvoiceWithMixedLines_LRO();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public String factsValidate(MAcctSchema schema, List<Fact> facts, PO po) {
|
public String factsValidate(MAcctSchema schema, List<Fact> facts, PO po) {
|
||||||
// TODO: implement it
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -182,22 +182,25 @@ public class CompiereService {
|
||||||
// Get Login Info
|
// Get Login Info
|
||||||
String loginInfo = null;
|
String loginInfo = null;
|
||||||
// Verify existence of User/Client/Org/Role and User's acces to Client & Org
|
// Verify existence of User/Client/Org/Role and User's acces to Client & Org
|
||||||
String sql = "SELECT u.Name || '@' || c.Name || '.' || o.Name AS Text "
|
|
||||||
+ "FROM AD_User u, AD_Client c, AD_Org o, AD_User_Roles ur, AD_Role r "
|
StringBuilder sql = new StringBuilder("SELECT u.Name || '@' || c.Name || '.' || o.Name AS Text")
|
||||||
+ "WHERE u.AD_User_ID=?" // #1
|
.append(" FROM AD_User u, AD_Client c, AD_Org o, AD_Role r")
|
||||||
+ " AND c.AD_Client_ID=?" // #2
|
.append(" WHERE u.AD_User_ID = ?") // #1
|
||||||
+ " AND o.AD_Org_ID=?" // #3
|
.append(" AND c.AD_Client_ID = ?") // #2
|
||||||
+ " AND ur.AD_Role_ID=?" // #4
|
.append(" AND o.AD_Org_ID = ?") // #3
|
||||||
+ " AND ur.AD_User_ID=u.AD_User_ID"
|
.append(" AND r.AD_Role_ID = ?") // #4
|
||||||
+ " AND ur.AD_Role_ID=r.AD_Role_ID"
|
.append(" AND (o.AD_Client_ID = 0 OR o.AD_Client_ID=c.AD_Client_ID)")
|
||||||
+ " AND (o.AD_Client_ID = 0 OR o.AD_Client_ID=c.AD_Client_ID)"
|
.append(" AND ( ")
|
||||||
+ " AND (r.IsAccessAllOrgs='Y' OR (c.AD_Client_ID IN (SELECT AD_Client_ID FROM AD_Role_OrgAccess ca WHERE ca.AD_Role_ID=ur.AD_Role_ID)"
|
.append(" r.IsAccessAllOrgs='Y'")
|
||||||
+ " AND o.AD_Org_ID IN (SELECT AD_Org_ID FROM AD_Role_OrgAccess ca WHERE ca.AD_Role_ID=ur.AD_Role_ID)))";
|
.append(" OR (r.IsUseUserOrgAccess='N' AND o.AD_Org_ID IN (SELECT AD_Org_ID FROM AD_Role_OrgAccess ra WHERE ra.AD_Role_ID=r.AD_Role_ID AND ra.IsActive='Y'))")
|
||||||
|
.append(" OR (r.IsUseUserOrgAccess='Y' AND o.AD_Org_ID IN (SELECT AD_Org_ID FROM AD_User_OrgAccess ua WHERE ua.AD_User_ID=u.AD_User_ID AND ua.IsActive='Y'))")
|
||||||
|
.append(")");
|
||||||
|
|
||||||
PreparedStatement pstmt = null;
|
PreparedStatement pstmt = null;
|
||||||
ResultSet rs = null;
|
ResultSet rs = null;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
pstmt = DB.prepareStatement(sql, null);
|
pstmt = DB.prepareStatement(sql.toString(), null);
|
||||||
pstmt.setInt(1, AD_User_ID);
|
pstmt.setInt(1, AD_User_ID);
|
||||||
pstmt.setInt(2, AD_Client_ID);
|
pstmt.setInt(2, AD_Client_ID);
|
||||||
pstmt.setInt(3, AD_Org_ID);
|
pstmt.setInt(3, AD_Org_ID);
|
||||||
|
|
Loading…
Reference in New Issue