Search in sources :

Example 1 with MAccount

use of org.compiere.model.MAccount in project adempiere by adempiere.

the class Doc_Requisition method createFacts.

// getBalance
/***************************************************************************
	 * Create Facts (the accounting logic) for POR.
	 * <pre>
	 * Reservation
	 * 	Expense		CR
	 * 	Offset			DR
	 * </pre>
	 * @param as accounting schema
	 * @return Fact
	 */
public ArrayList<Fact> createFacts(MAcctSchema as) {
    ArrayList<Fact> facts = new ArrayList<Fact>();
    Fact fact = new Fact(this, as, Fact.POST_Reservation);
    setC_Currency_ID(as.getC_Currency_ID());
    //
    BigDecimal grossAmt = getAmount(Doc.AMTTYPE_Gross);
    // Commitment
    if (as.isCreateReservation()) {
        BigDecimal total = Env.ZERO;
        for (int i = 0; i < p_lines.length; i++) {
            DocLine line = p_lines[i];
            BigDecimal cost = line.getAmtSource();
            total = total.add(cost);
            // Account
            MAccount expense = line.getAccount(ProductCost.ACCTTYPE_P_Expense, as);
            //
            fact.createLine(line, expense, as.getC_Currency_ID(), cost, null);
        }
        // Offset
        MAccount offset = getAccount(ACCTTYPE_CommitmentOffset, as);
        if (offset == null) {
            p_Error = "@NotFound@ @CommitmentOffset_Acct@";
            log.log(Level.SEVERE, p_Error);
            return null;
        }
        fact.createLine(null, offset, getC_Currency_ID(), null, total);
        facts.add(fact);
    }
    return facts;
}
Also used : MAccount(org.compiere.model.MAccount) ArrayList(java.util.ArrayList) BigDecimal(java.math.BigDecimal)

Example 2 with MAccount

use of org.compiere.model.MAccount in project adempiere by adempiere.

the class WAccountDialog method action_Save.

//	action_Find
/**
	 *	Create/Save Account
	 */
private void action_Save() {
    log.info("");
    /**
		 *	Check completeness (mandatory fields) ... and for duplicates
		 */
    StringBuffer sb = new StringBuffer();
    StringBuffer sql = new StringBuffer("SELECT C_ValidCombination_ID, Alias FROM C_ValidCombination WHERE ");
    Object value = null;
    if (s_AcctSchema.isHasAlias()) {
        value = f_Alias.getValue().toString();
        if (isEmpty(value) && f_Alias.isMandatory())
            sb.append(Msg.translate(Env.getCtx(), "Alias")).append(", ");
    }
    MAcctSchemaElement[] elements = s_AcctSchema.getAcctSchemaElements();
    for (int i = 0; i < elements.length; i++) {
        MAcctSchemaElement ase = elements[i];
        String type = ase.getElementType();
        //
        if (type.equals(MAcctSchemaElement.ELEMENTTYPE_Organization)) {
            value = f_AD_Org_ID.getValue();
            sql.append("AD_Org_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_Account)) {
            value = f_Account_ID.getValue();
            sql.append("Account_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_SubAccount)) {
            value = f_SubAcct_ID.getValue();
            sql.append("C_SubAcct_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_Product)) {
            value = f_M_Product_ID.getValue();
            sql.append("M_Product_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_BPartner)) {
            value = f_C_BPartner_ID.getValue();
            sql.append("C_BPartner_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_Campaign)) {
            value = f_C_Campaign_ID.getValue();
            sql.append("C_Campaign_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_LocationFrom)) {
            value = f_C_LocFrom_ID.getValue();
            sql.append("C_LocFrom_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_LocationTo)) {
            value = f_C_LocTo_ID.getValue();
            sql.append("C_LocTo_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_Project)) {
            value = f_C_Project_ID.getValue();
            sql.append("C_Project_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_SalesRegion)) {
            value = f_C_SalesRegion_ID.getValue();
            sql.append("C_SalesRegion_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_OrgTrx)) {
            value = f_AD_OrgTrx_ID.getValue();
            sql.append("AD_OrgTrx_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_Activity)) {
            value = f_C_Activity_ID.getValue();
            sql.append("C_Activity_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_UserList1)) {
            value = f_User1_ID.getValue();
            sql.append("User1_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_UserList2)) {
            value = f_User2_ID.getValue();
            sql.append("User2_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_UserList3)) {
            value = f_User3_ID.getValue();
            sql.append("User3_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        } else if (type.equals(MAcctSchemaElement.ELEMENTTYPE_UserList4)) {
            value = f_User4_ID.getValue();
            sql.append("User4_ID");
            if (isEmpty(value))
                sql.append(" IS NULL AND ");
            else
                sql.append("=").append(value).append(" AND ");
        }
        //
        if (ase.isMandatory() && isEmpty(value))
            sb.append(ase.getName()).append(", ");
    }
    if (sb.length() != 0) {
        FDialog.error(m_WindowNo, this, "FillMandatory", sb.substring(0, sb.length() - 2));
        return;
    }
    if (f_AD_Org_ID == null || f_AD_Org_ID.getValue() == null) {
        FDialog.error(m_WindowNo, this, "FillMandatory", Msg.getElement(Env.getCtx(), "AD_Org_ID"));
        return;
    }
    if (f_Account_ID == null || f_Account_ID.getValue() == null) {
        FDialog.error(m_WindowNo, this, "FillMandatory", Msg.getElement(Env.getCtx(), "Account_ID"));
        return;
    }
    /**
		 *	Check if already exists
		 */
    sql.append("AD_Client_ID=? AND C_AcctSchema_ID=?");
    log.fine("Check = " + sql.toString());
    int IDvalue = 0;
    String Alias = null;
    try {
        PreparedStatement pstmt = DB.prepareStatement(sql.toString(), null);
        pstmt.setInt(1, m_AD_Client_ID);
        pstmt.setInt(2, s_AcctSchema.getC_AcctSchema_ID());
        ResultSet rs = pstmt.executeQuery();
        if (rs.next()) {
            IDvalue = rs.getInt(1);
            Alias = rs.getString(2);
        }
        rs.close();
        pstmt.close();
    } catch (SQLException e) {
        log.log(Level.SEVERE, sql.toString(), e);
        IDvalue = 0;
    }
    log.fine("ID=" + IDvalue + ", Alias=" + Alias);
    if (Alias == null)
        Alias = "";
    //	We have an account like this already - check alias
    if (IDvalue != 0 && s_AcctSchema.isHasAlias() && !f_Alias.getValue().toString().equals(Alias)) {
        sql = new StringBuffer("UPDATE C_ValidCombination SET Alias=");
        if (f_Alias.getValue().toString().length() == 0)
            sql.append("NULL");
        else
            sql.append("'").append(f_Alias.getValue()).append("'");
        sql.append(" WHERE C_ValidCombination_ID=").append(IDvalue);
        int i = 0;
        try {
            java.sql.PreparedStatement stmt = DB.prepareStatement(sql.toString(), ResultSet.TYPE_FORWARD_ONLY, ResultSet.CONCUR_UPDATABLE, null);
            i = stmt.executeUpdate();
            stmt.close();
        } catch (SQLException e) {
            log.log(Level.SEVERE, sql.toString(), e);
        }
        if (i == 0)
            FDialog.error(m_WindowNo, this, "AccountNotUpdated");
    }
    //	load and display
    if (IDvalue != 0) {
        loadInfo(IDvalue, s_AcctSchema.getC_AcctSchema_ID());
        action_Find(false);
        return;
    }
    log.config("New");
    Alias = null;
    if (f_Alias != null)
        Alias = f_Alias.getValue().toString();
    int C_SubAcct_ID = 0;
    if (f_SubAcct_ID != null && !isEmpty(f_SubAcct_ID.getValue()))
        C_SubAcct_ID = ((Integer) f_SubAcct_ID.getValue()).intValue();
    int M_Product_ID = 0;
    if (f_M_Product_ID != null && !isEmpty(f_M_Product_ID.getValue()))
        M_Product_ID = ((Integer) f_M_Product_ID.getValue()).intValue();
    int C_BPartner_ID = 0;
    if (f_C_BPartner_ID != null && !isEmpty(f_C_BPartner_ID.getValue()))
        C_BPartner_ID = ((Integer) f_C_BPartner_ID.getValue()).intValue();
    int AD_OrgTrx_ID = 0;
    if (f_AD_OrgTrx_ID != null && !isEmpty(f_AD_OrgTrx_ID.getValue()))
        AD_OrgTrx_ID = ((Integer) f_AD_OrgTrx_ID.getValue()).intValue();
    int C_LocFrom_ID = 0;
    if (f_C_LocFrom_ID != null && !isEmpty(f_C_LocFrom_ID.getValue()))
        C_LocFrom_ID = ((Integer) f_C_LocFrom_ID.getValue()).intValue();
    int C_LocTo_ID = 0;
    if (f_C_LocTo_ID != null && !isEmpty(f_C_LocTo_ID.getValue()))
        C_LocTo_ID = ((Integer) f_C_LocTo_ID.getValue()).intValue();
    int C_SRegion_ID = 0;
    if (f_C_SalesRegion_ID != null && !isEmpty(f_C_SalesRegion_ID.getValue()))
        C_SRegion_ID = ((Integer) f_C_SalesRegion_ID.getValue()).intValue();
    int C_Project_ID = 0;
    if (f_C_Project_ID != null && !isEmpty(f_C_Project_ID.getValue()))
        C_Project_ID = ((Integer) f_C_Project_ID.getValue()).intValue();
    int C_Campaign_ID = 0;
    if (f_C_Campaign_ID != null && !isEmpty(f_C_Campaign_ID.getValue()))
        C_Campaign_ID = ((Integer) f_C_Campaign_ID.getValue()).intValue();
    int C_Activity_ID = 0;
    if (f_C_Activity_ID != null && !isEmpty(f_C_Activity_ID.getValue()))
        C_Activity_ID = ((Integer) f_C_Activity_ID.getValue()).intValue();
    int User1_ID = 0;
    if (f_User1_ID != null && !isEmpty(f_User1_ID.getValue()))
        User1_ID = ((Integer) f_User1_ID.getValue()).intValue();
    int User2_ID = 0;
    if (f_User2_ID != null && !isEmpty(f_User2_ID.getValue()))
        User2_ID = ((Integer) f_User2_ID.getValue()).intValue();
    int User3_ID = 0;
    if (f_User3_ID != null && !isEmpty(f_User3_ID.getValue()))
        User3_ID = ((Integer) f_User3_ID.getValue()).intValue();
    int User4_ID = 0;
    if (f_User4_ID != null && !isEmpty(f_User4_ID.getValue()))
        User4_ID = ((Integer) f_User4_ID.getValue()).intValue();
    MAccount acct = MAccount.get(Env.getCtx(), m_AD_Client_ID, ((Integer) f_AD_Org_ID.getValue()).intValue(), s_AcctSchema.getC_AcctSchema_ID(), ((Integer) f_Account_ID.getValue()).intValue(), C_SubAcct_ID, M_Product_ID, C_BPartner_ID, AD_OrgTrx_ID, C_LocFrom_ID, C_LocTo_ID, C_SRegion_ID, C_Project_ID, C_Campaign_ID, C_Activity_ID, User1_ID, User2_ID, User3_ID, User4_ID, 0, 0, null);
    if (acct != null && acct.get_ID() == 0)
        acct.saveEx();
    //  Show Info
    if (acct == null || acct.get_ID() == 0)
        loadInfo(0, 0);
    else {
        //	Update Account with optional Alias
        if (Alias != null && Alias.length() > 0) {
            acct.setAlias(Alias);
            acct.saveEx();
        }
        loadInfo(acct.get_ID(), s_AcctSchema.getC_AcctSchema_ID());
    }
    action_Find(false);
}
Also used : SQLException(java.sql.SQLException) MAccount(org.compiere.model.MAccount) PreparedStatement(java.sql.PreparedStatement) PreparedStatement(java.sql.PreparedStatement) ResultSet(java.sql.ResultSet) MAcctSchemaElement(org.compiere.model.MAcctSchemaElement)

Example 3 with MAccount

use of org.compiere.model.MAccount in project adempiere by adempiere.

the class ImportGLJournal method doIt.

//	prepare
/**
	 *  Perform process.
	 *  @return Message
	 *  @throws Exception
	 */
protected String doIt() throws java.lang.Exception {
    log.info("IsValidateOnly=" + m_IsValidateOnly + ", IsImportOnlyNoErrors=" + m_IsImportOnlyNoErrors);
    StringBuffer sql = null;
    int no = 0;
    String clientCheck = " AND AD_Client_ID=" + m_AD_Client_ID;
    //	Delete Old Imported
    if (m_DeleteOldImported) {
        sql = new StringBuffer("DELETE I_GLJournal " + "WHERE I_IsImported='Y'").append(clientCheck);
        no = DB.executeUpdate(sql.toString(), get_TrxName());
        log.fine("Delete Old Impored =" + no);
    }
    //	Set IsActive, Created/Updated
    sql = new StringBuffer("UPDATE I_GLJournal " + "SET IsActive = COALESCE (IsActive, 'Y')," + " Created = COALESCE (Created, SysDate)," + " CreatedBy = COALESCE (CreatedBy, 0)," + " Updated = COALESCE (Updated, SysDate)," + " UpdatedBy = COALESCE (UpdatedBy, 0)," + " I_ErrorMsg = ' '," + " I_IsImported = 'N' " + "WHERE I_IsImported<>'Y' OR I_IsImported IS NULL");
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.info("Reset=" + no);
    //	Set Client from Name
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET AD_Client_ID=(SELECT c.AD_Client_ID FROM AD_Client c WHERE c.Value=i.ClientValue) " + "WHERE (AD_Client_ID IS NULL OR AD_Client_ID=0) AND ClientValue IS NOT NULL" + " AND I_IsImported<>'Y'");
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set Client from Value=" + no);
    //	Set Default Client, Doc Org, AcctSchema, DatAcct
    sql = new StringBuffer("UPDATE I_GLJournal " + "SET AD_Client_ID = COALESCE (AD_Client_ID,").append(m_AD_Client_ID).append(")," + " AD_OrgDoc_ID = COALESCE (AD_OrgDoc_ID,").append(m_AD_Org_ID).append("),");
    if (m_C_AcctSchema_ID != 0)
        sql.append(" C_AcctSchema_ID = COALESCE (C_AcctSchema_ID,").append(m_C_AcctSchema_ID).append("),");
    if (m_DateAcct != null)
        sql.append(" DateAcct = COALESCE (DateAcct,").append(DB.TO_DATE(m_DateAcct)).append("),");
    sql.append(" Updated = COALESCE (Updated, SysDate) " + "WHERE I_IsImported<>'Y' OR I_IsImported IS NULL");
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Client/DocOrg/Default=" + no);
    //	Error Doc Org
    sql = new StringBuffer("UPDATE I_GLJournal o " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid Doc Org, '" + "WHERE (AD_OrgDoc_ID IS NULL OR AD_OrgDoc_ID=0" + " OR EXISTS (SELECT * FROM AD_Org oo WHERE o.AD_OrgDoc_ID=oo.AD_Org_ID AND (oo.IsSummary='Y' OR oo.IsActive='N')))" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid Doc Org=" + no);
    //	Set AcctSchema
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET C_AcctSchema_ID=(SELECT a.C_AcctSchema_ID FROM C_AcctSchema a" + " WHERE i.AcctSchemaName=a.Name AND i.AD_Client_ID=a.AD_Client_ID) " + "WHERE C_AcctSchema_ID IS NULL AND AcctSchemaName IS NOT NULL" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set AcctSchema from Name=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET C_AcctSchema_ID=(SELECT c.C_AcctSchema1_ID FROM AD_ClientInfo c WHERE c.AD_Client_ID=i.AD_Client_ID) " + "WHERE C_AcctSchema_ID IS NULL AND AcctSchemaName IS NULL" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set AcctSchema from Client=" + no);
    //	Error AcctSchema
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid AcctSchema, '" + "WHERE (C_AcctSchema_ID IS NULL OR C_AcctSchema_ID=0" + " OR NOT EXISTS (SELECT * FROM C_AcctSchema a WHERE i.AD_Client_ID=a.AD_Client_ID))" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid AcctSchema=" + no);
    //	Set DateAcct (mandatory)
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET DateAcct=SysDate " + "WHERE DateAcct IS NULL" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set DateAcct=" + no);
    //	Document Type
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET C_DocType_ID=(SELECT d.C_DocType_ID FROM C_DocType d" + " WHERE d.Name=i.DocTypeName AND d.DocBaseType='GLJ' AND i.AD_Client_ID=d.AD_Client_ID) " + "WHERE C_DocType_ID IS NULL AND DocTypeName IS NOT NULL" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set DocType=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid DocType, '" + "WHERE (C_DocType_ID IS NULL OR C_DocType_ID=0" + " OR NOT EXISTS (SELECT * FROM C_DocType d WHERE i.AD_Client_ID=d.AD_Client_ID AND d.DocBaseType='GLJ'))" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid DocType=" + no);
    //	GL Category
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET GL_Category_ID=(SELECT c.GL_Category_ID FROM GL_Category c" + " WHERE c.Name=i.CategoryName AND i.AD_Client_ID=c.AD_Client_ID) " + "WHERE GL_Category_ID IS NULL AND CategoryName IS NOT NULL" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set DocType=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid Category, '" + "WHERE (GL_Category_ID IS NULL OR GL_Category_ID=0)" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid GLCategory=" + no);
    //	Set Currency
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET C_Currency_ID=(SELECT c.C_Currency_ID FROM C_Currency c" + " WHERE c.ISO_Code=i.ISO_Code AND c.AD_Client_ID IN (0,i.AD_Client_ID)) " + "WHERE C_Currency_ID IS NULL AND ISO_Code IS NOT NULL" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set Currency from ISO=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET C_Currency_ID=(SELECT a.C_Currency_ID FROM C_AcctSchema a" + " WHERE a.C_AcctSchema_ID=i.C_AcctSchema_ID AND a.AD_Client_ID=i.AD_Client_ID)" + "WHERE C_Currency_ID IS NULL AND ISO_Code IS NULL" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set Default Currency=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid Currency, '" + "WHERE (C_Currency_ID IS NULL OR C_Currency_ID=0)" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid Currency=" + no);
    //	Set Conversion Type
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET ConversionTypeValue='S' " + "WHERE C_ConversionType_ID IS NULL AND ConversionTypeValue IS NULL" + " AND I_IsImported='N'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set CurrencyType Value to Spot =" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET C_ConversionType_ID=(SELECT c.C_ConversionType_ID FROM C_ConversionType c" + " WHERE c.Value=i.ConversionTypeValue AND c.AD_Client_ID IN (0,i.AD_Client_ID)) " + "WHERE C_ConversionType_ID IS NULL AND ConversionTypeValue IS NOT NULL" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set CurrencyType from Value=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid CurrencyType, '" + "WHERE (C_ConversionType_ID IS NULL OR C_ConversionType_ID=0) AND ConversionTypeValue IS NOT NULL" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid CurrencyTypeValue=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=No ConversionType, '" + "WHERE (C_ConversionType_ID IS NULL OR C_ConversionType_ID=0)" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("No CourrencyType=" + no);
    //	Set/Overwrite Home Currency Rate
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET CurrencyRate=1" + "WHERE EXISTS (SELECT * FROM C_AcctSchema a" + " WHERE a.C_AcctSchema_ID=i.C_AcctSchema_ID AND a.C_Currency_ID=i.C_Currency_ID)" + " AND C_Currency_ID IS NOT NULL AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set Home CurrencyRate=" + no);
    //	Set Currency Rate
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET CurrencyRate=(SELECT MAX(r.MultiplyRate) FROM C_Conversion_Rate r, C_AcctSchema s" + " WHERE s.C_AcctSchema_ID=i.C_AcctSchema_ID AND s.AD_Client_ID=i.AD_Client_ID" + " AND r.C_Currency_ID=i.C_Currency_ID AND r.C_Currency_ID_TO=s.C_Currency_ID" + " AND r.AD_Client_ID=i.AD_Client_ID AND r.AD_Org_ID=i.AD_OrgDoc_ID" + " AND r.C_ConversionType_ID=i.C_ConversionType_ID" + " AND i.DateAcct BETWEEN r.ValidFrom AND r.ValidTo " + //	ORDER BY ValidFrom DESC
    ") WHERE CurrencyRate IS NULL OR CurrencyRate=0 AND C_Currency_ID>0" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set Org Rate=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET CurrencyRate=(SELECT MAX(r.MultiplyRate) FROM C_Conversion_Rate r, C_AcctSchema s" + " WHERE s.C_AcctSchema_ID=i.C_AcctSchema_ID AND s.AD_Client_ID=i.AD_Client_ID" + " AND r.C_Currency_ID=i.C_Currency_ID AND r.C_Currency_ID_TO=s.C_Currency_ID" + " AND r.AD_Client_ID=i.AD_Client_ID" + " AND r.C_ConversionType_ID=i.C_ConversionType_ID" + " AND i.DateAcct BETWEEN r.ValidFrom AND r.ValidTo " + //	ORDER BY ValidFrom DESC
    ") WHERE CurrencyRate IS NULL OR CurrencyRate=0 AND C_Currency_ID>0" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set Client Rate=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=No Rate, '" + "WHERE CurrencyRate IS NULL OR CurrencyRate=0" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("No Rate=" + no);
    //	Set Period
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET C_Period_ID=(SELECT MAX(p.C_Period_ID) FROM C_Period p" + " INNER JOIN C_Year y ON (y.C_Year_ID=p.C_Year_ID)" + " INNER JOIN AD_ClientInfo c ON (c.C_Calendar_ID=y.C_Calendar_ID)" + " WHERE c.AD_Client_ID=i.AD_Client_ID" + // globalqss - cruiz - Bug [ 1577712 ] Financial Period Bug
    " AND i.DateAcct BETWEEN p.StartDate AND p.EndDate AND p.IsActive='Y' AND p.PeriodType='S') " + "WHERE C_Period_ID IS NULL" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set Period=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid Period, '" + "WHERE C_Period_ID IS NULL OR C_Period_ID NOT IN" + "(SELECT C_Period_ID FROM C_Period p" + " INNER JOIN C_Year y ON (y.C_Year_ID=p.C_Year_ID)" + " INNER JOIN AD_ClientInfo c ON (c.C_Calendar_ID=y.C_Calendar_ID) " + " WHERE c.AD_Client_ID=i.AD_Client_ID" + // globalqss - cruiz - Bug [ 1577712 ] Financial Period Bug
    " AND i.DateAcct BETWEEN p.StartDate AND p.EndDate AND p.IsActive='Y' AND p.PeriodType='S')" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid Period=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_ErrorMsg=I_ErrorMsg||'WARN=Period Closed, ' " + "WHERE C_Period_ID IS NOT NULL AND NOT EXISTS" + " (SELECT * FROM C_PeriodControl pc WHERE pc.C_Period_ID=i.C_Period_ID AND DocBaseType='GLJ' AND PeriodStatus='O') " + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Period Closed=" + no);
    //	Posting Type
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET PostingType='A' " + "WHERE PostingType IS NULL AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set Actual PostingType=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid PostingType, ' " + "WHERE PostingType IS NULL OR NOT EXISTS" + " (SELECT * FROM AD_Ref_List r WHERE r.AD_Reference_ID=125 AND i.PostingType=r.Value)" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid PostingTypee=" + no);
    //	** Account Elements (optional) **
    //	(C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0)
    //	Set Org from Name (* is overwritten and default)
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET AD_Org_ID=COALESCE((SELECT o.AD_Org_ID FROM AD_Org o" + " WHERE o.Value=i.OrgValue AND o.IsSummary='N' AND i.AD_Client_ID=o.AD_Client_ID),AD_Org_ID) " + "WHERE (AD_Org_ID IS NULL OR AD_Org_ID=0) AND OrgValue IS NOT NULL" + " AND (C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0) AND I_IsImported<>'Y'");
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set Org from Value=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET AD_Org_ID=AD_OrgDoc_ID " + "WHERE (AD_Org_ID IS NULL OR AD_Org_ID=0) AND OrgValue IS NULL AND AD_OrgDoc_ID IS NOT NULL AND AD_OrgDoc_ID<>0" + " AND (C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0) AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set Org from Doc Org=" + no);
    //	Error Org
    sql = new StringBuffer("UPDATE I_GLJournal o " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid Org, '" + "WHERE (AD_Org_ID IS NULL OR AD_Org_ID=0" + " OR EXISTS (SELECT * FROM AD_Org oo WHERE o.AD_Org_ID=oo.AD_Org_ID AND (oo.IsSummary='Y' OR oo.IsActive='N')))" + " AND (C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0) AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid Org=" + no);
    //	Set Account
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET Account_ID=(SELECT MAX(ev.C_ElementValue_ID) FROM C_ElementValue ev" + " INNER JOIN C_Element e ON (e.C_Element_ID=ev.C_Element_ID)" + " INNER JOIN C_AcctSchema_Element ase ON (e.C_Element_ID=ase.C_Element_ID AND ase.ElementType='AC')" + " WHERE ev.Value=i.AccountValue AND ev.IsSummary='N'" + " AND i.C_AcctSchema_ID=ase.C_AcctSchema_ID AND i.AD_Client_ID=ev.AD_Client_ID) " + "WHERE Account_ID IS NULL AND AccountValue IS NOT NULL" + " AND (C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0) AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set Account from Value=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid Account, '" + "WHERE (Account_ID IS NULL OR Account_ID=0)" + " AND (C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0) AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid Account=" + no);
    //	Set BPartner
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET C_BPartner_ID=(SELECT bp.C_BPartner_ID FROM C_BPartner bp" + " WHERE bp.Value=i.BPartnerValue AND bp.IsSummary='N' AND i.AD_Client_ID=bp.AD_Client_ID) " + "WHERE C_BPartner_ID IS NULL AND BPartnerValue IS NOT NULL" + " AND (C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0) AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set BPartner from Value=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid BPartner, '" + "WHERE C_BPartner_ID IS NULL AND BPartnerValue IS NOT NULL" + " AND (C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0) AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid BPartner=" + no);
    //	Set Product
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET M_Product_ID=(SELECT MAX(p.M_Product_ID) FROM M_Product p" + " WHERE (p.Value=i.ProductValue OR p.UPC=i.UPC OR p.SKU=i.SKU)" + " AND p.IsSummary='N' AND i.AD_Client_ID=p.AD_Client_ID) " + "WHERE M_Product_ID IS NULL AND (ProductValue IS NOT NULL OR UPC IS NOT NULL OR SKU IS NOT NULL)" + " AND (C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0) AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set Product from Value=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid Product, '" + "WHERE M_Product_ID IS NULL AND (ProductValue IS NOT NULL OR UPC IS NOT NULL OR SKU IS NOT NULL)" + " AND (C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0) AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid Product=" + no);
    //	Set Project
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET C_Project_ID=(SELECT p.C_Project_ID FROM C_Project p" + " WHERE p.Value=i.ProjectValue AND p.IsSummary='N' AND i.AD_Client_ID=p.AD_Client_ID) " + "WHERE C_Project_ID IS NULL AND ProjectValue IS NOT NULL" + " AND (C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0) AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set Project from Value=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid Project, '" + "WHERE C_Project_ID IS NULL AND ProjectValue IS NOT NULL" + " AND (C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0) AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid Project=" + no);
    //	Set TrxOrg
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET AD_OrgTrx_ID=(SELECT o.AD_Org_ID FROM AD_Org o" + " WHERE o.Value=i.OrgTrxValue AND o.IsSummary='N' AND i.AD_Client_ID=o.AD_Client_ID) " + "WHERE AD_OrgTrx_ID IS NULL AND OrgTrxValue IS NOT NULL" + " AND (C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0) AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set OrgTrx from Value=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_IsImported='E', I_ErrorMsg=I_ErrorMsg||'ERR=Invalid OrgTrx, '" + "WHERE AD_OrgTrx_ID IS NULL AND OrgTrxValue IS NOT NULL" + " AND (C_ValidCombination_ID IS NULL OR C_ValidCombination_ID=0) AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Invalid OrgTrx=" + no);
    //	Source Amounts
    sql = new StringBuffer("UPDATE I_GLJournal " + "SET AmtSourceDr = 0 " + "WHERE AmtSourceDr IS NULL" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set 0 Source Dr=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal " + "SET AmtSourceCr = 0 " + "WHERE AmtSourceCr IS NULL" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Set 0 Source Cr=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_ErrorMsg=I_ErrorMsg||'WARN=Zero Source Balance, ' " + "WHERE (AmtSourceDr-AmtSourceCr)=0" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Zero Source Balance=" + no);
    //	Accounted Amounts (Only if No Error)
    sql = new StringBuffer("UPDATE I_GLJournal " + //	HARDCODED rounding
    "SET AmtAcctDr = ROUND(AmtSourceDr * CurrencyRate, 2) " + "WHERE AmtAcctDr IS NULL OR AmtAcctDr=0" + " AND I_IsImported='N'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Calculate Acct Dr=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal " + "SET AmtAcctCr = ROUND(AmtSourceCr * CurrencyRate, 2) " + "WHERE AmtAcctCr IS NULL OR AmtAcctCr=0" + " AND I_IsImported='N'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    log.fine("Calculate Acct Cr=" + no);
    sql = new StringBuffer("UPDATE I_GLJournal i " + "SET I_ErrorMsg=I_ErrorMsg||'WARN=Zero Acct Balance, ' " + "WHERE (AmtSourceDr-AmtSourceCr)<>0 AND (AmtAcctDr-AmtAcctCr)=0" + " AND I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    if (no != 0)
        log.warning("Zero Acct Balance=" + no);
    //AZ Goodwill
    //BF: 2391401 Remove account balance limitation in Import GL Journal 
    /*
		sql = new StringBuffer ("UPDATE I_GLJournal i "
			+ "SET I_ErrorMsg=I_ErrorMsg||'WARN=Check Acct Balance, ' "
			+ "WHERE ABS(AmtAcctDr-AmtAcctCr)>100000000"	//	100 mio
			+ " AND I_IsImported<>'Y'").append (clientCheck);
		no = DB.executeUpdate(sql.toString(), get_TrxName());
		if (no != 0)
			log.warning ("Check Acct Balance=" + no);
		*/
    /*********************************************************************/
    //	Get Balance
    sql = new StringBuffer("SELECT SUM(AmtSourceDr)-SUM(AmtSourceCr), SUM(AmtAcctDr)-SUM(AmtAcctCr) " + "FROM I_GLJournal " + "WHERE I_IsImported='N'").append(clientCheck);
    PreparedStatement pstmt = null;
    try {
        pstmt = DB.prepareStatement(sql.toString(), get_TrxName());
        ResultSet rs = pstmt.executeQuery();
        if (rs.next()) {
            BigDecimal source = rs.getBigDecimal(1);
            BigDecimal acct = rs.getBigDecimal(2);
            if (source != null && source.signum() == 0 && acct != null && acct.signum() == 0)
                log.info("Import Balance = 0");
            else
                log.warning("Balance Source=" + source + ", Acct=" + acct);
            if (source != null)
                addLog(0, null, source, "@AmtSourceDr@ - @AmtSourceCr@");
            if (acct != null)
                addLog(0, null, acct, "@AmtAcctDr@ - @AmtAcctCr@");
        }
        rs.close();
        pstmt.close();
        pstmt = null;
    } catch (SQLException ex) {
        log.log(Level.SEVERE, sql.toString(), ex);
    }
    try {
        if (pstmt != null)
            pstmt.close();
    } catch (SQLException ex1) {
    }
    pstmt = null;
    // globalqss (moved the commit here to save the error messages)
    commitEx();
    //	Count Errors
    int errors = DB.getSQLValue(get_TrxName(), "SELECT COUNT(*) FROM I_GLJournal WHERE I_IsImported NOT IN ('Y','N')" + clientCheck);
    if (errors != 0) {
        if (m_IsValidateOnly || m_IsImportOnlyNoErrors)
            throw new Exception("@Errors@=" + errors);
    } else if (m_IsValidateOnly)
        return "@Errors@=" + errors;
    log.info("Validation Errors=" + errors);
    // moved commit above to save error messages
    // commit();
    /*********************************************************************/
    int noInsert = 0;
    int noInsertJournal = 0;
    int noInsertLine = 0;
    //	Change Batch per Batch DocumentNo
    MJournalBatch batch = null;
    String BatchDocumentNo = "";
    MJournal journal = null;
    String JournalDocumentNo = "";
    Timestamp DateAcct = null;
    //	Go through Journal Records
    sql = new StringBuffer("SELECT * FROM I_GLJournal " + "WHERE I_IsImported='N'").append(clientCheck).append(" ORDER BY COALESCE(BatchDocumentNo, TO_NCHAR(I_GLJournal_ID)||' '), COALESCE(JournalDocumentNo, " + "TO_NCHAR(I_GLJournal_ID)||' '), C_AcctSchema_ID, PostingType, C_DocType_ID, GL_Category_ID, " + "C_Currency_ID, TRUNC(DateAcct, 'DD'), Line, I_GLJournal_ID");
    try {
        pstmt = DB.prepareStatement(sql.toString(), get_TrxName());
        ResultSet rs = pstmt.executeQuery();
        //
        while (rs.next()) {
            X_I_GLJournal imp = new X_I_GLJournal(getCtx(), rs, get_TrxName());
            //	New Batch if Batch Document No changes
            String impBatchDocumentNo = imp.getBatchDocumentNo();
            if (impBatchDocumentNo == null)
                impBatchDocumentNo = "";
            if (batch == null || imp.isCreateNewBatch() || journal.getC_AcctSchema_ID() != imp.getC_AcctSchema_ID() || !BatchDocumentNo.equals(impBatchDocumentNo)) {
                //	cannot compare real DocumentNo
                BatchDocumentNo = impBatchDocumentNo;
                batch = new MJournalBatch(getCtx(), 0, get_TrxName());
                batch.setClientOrg(imp.getAD_Client_ID(), imp.getAD_OrgDoc_ID());
                if (imp.getBatchDocumentNo() != null && imp.getBatchDocumentNo().length() > 0)
                    batch.setDocumentNo(imp.getBatchDocumentNo());
                batch.setC_DocType_ID(imp.getC_DocType_ID());
                batch.setPostingType(imp.getPostingType());
                String description = imp.getBatchDescription();
                if (description == null || description.length() == 0)
                    description = "*Import-";
                else
                    description += " *Import-";
                description += new Timestamp(System.currentTimeMillis());
                batch.setDescription(description);
                if (!batch.save()) {
                    log.log(Level.SEVERE, "Batch not saved");
                    Exception ex = CLogger.retrieveException();
                    if (ex != null) {
                        addLog(0, null, null, ex.getLocalizedMessage());
                        throw ex;
                    }
                    break;
                }
                noInsert++;
                journal = null;
            }
            //	Journal
            String impJournalDocumentNo = imp.getJournalDocumentNo();
            if (impJournalDocumentNo == null)
                impJournalDocumentNo = "";
            Timestamp impDateAcct = TimeUtil.getDay(imp.getDateAcct());
            if (journal == null || imp.isCreateNewJournal() || !JournalDocumentNo.equals(impJournalDocumentNo) || journal.getC_DocType_ID() != imp.getC_DocType_ID() || journal.getGL_Category_ID() != imp.getGL_Category_ID() || !journal.getPostingType().equals(imp.getPostingType()) || journal.getC_Currency_ID() != imp.getC_Currency_ID() || !impDateAcct.equals(DateAcct)) {
                //	cannot compare real DocumentNo
                JournalDocumentNo = impJournalDocumentNo;
                DateAcct = impDateAcct;
                journal = new MJournal(getCtx(), 0, get_TrxName());
                journal.setGL_JournalBatch_ID(batch.getGL_JournalBatch_ID());
                journal.setClientOrg(imp.getAD_Client_ID(), imp.getAD_OrgDoc_ID());
                //
                String description = imp.getBatchDescription();
                if (description == null || description.length() == 0)
                    description = "(Import)";
                journal.setDescription(description);
                if (imp.getJournalDocumentNo() != null && imp.getJournalDocumentNo().length() > 0)
                    journal.setDocumentNo(imp.getJournalDocumentNo());
                //
                journal.setC_AcctSchema_ID(imp.getC_AcctSchema_ID());
                journal.setC_DocType_ID(imp.getC_DocType_ID());
                journal.setGL_Category_ID(imp.getGL_Category_ID());
                journal.setPostingType(imp.getPostingType());
                journal.setGL_Budget_ID(imp.getGL_Budget_ID());
                //
                journal.setCurrency(imp.getC_Currency_ID(), imp.getC_ConversionType_ID(), imp.getCurrencyRate());
                //
                journal.setC_Period_ID(imp.getC_Period_ID());
                //	sets Period if not defined
                journal.setDateAcct(imp.getDateAcct());
                journal.setDateDoc(imp.getDateAcct());
                //
                if (!journal.save()) {
                    log.log(Level.SEVERE, "Journal not saved");
                    Exception ex = CLogger.retrieveException();
                    if (ex != null) {
                        addLog(0, null, null, ex.getLocalizedMessage());
                        throw ex;
                    }
                    break;
                }
                noInsertJournal++;
            }
            //	Lines
            MJournalLine line = new MJournalLine(journal);
            //
            line.setDescription(imp.getDescription());
            line.setCurrency(imp.getC_Currency_ID(), imp.getC_ConversionType_ID(), imp.getCurrencyRate());
            //	Set/Get Account Combination
            if (imp.getC_ValidCombination_ID() == 0) {
                MAccount acct = MAccount.get(getCtx(), imp.getAD_Client_ID(), imp.getAD_Org_ID(), imp.getC_AcctSchema_ID(), imp.getAccount_ID(), 0, imp.getM_Product_ID(), imp.getC_BPartner_ID(), imp.getAD_OrgTrx_ID(), imp.getC_LocFrom_ID(), imp.getC_LocTo_ID(), imp.getC_SalesRegion_ID(), imp.getC_Project_ID(), imp.getC_Campaign_ID(), imp.getC_Activity_ID(), imp.getUser1_ID(), imp.getUser2_ID(), imp.getUser3_ID(), imp.getUser4_ID(), 0, 0, null);
                if (acct != null && acct.get_ID() == 0)
                    acct.saveEx();
                if (acct == null || acct.get_ID() == 0) {
                    imp.setI_ErrorMsg("ERROR creating Account");
                    imp.setI_IsImported(false);
                    imp.saveEx();
                    continue;
                } else {
                    line.setC_ValidCombination_ID(acct.get_ID());
                    imp.setC_ValidCombination_ID(acct.get_ID());
                }
            } else
                line.setC_ValidCombination_ID(imp.getC_ValidCombination_ID());
            //
            line.setLine(imp.getLine());
            line.setAmtSourceCr(imp.getAmtSourceCr());
            line.setAmtSourceDr(imp.getAmtSourceDr());
            //	only if not 0
            line.setAmtAcct(imp.getAmtAcctDr(), imp.getAmtAcctCr());
            line.setDateAcct(imp.getDateAcct());
            //
            line.setC_UOM_ID(imp.getC_UOM_ID());
            line.setQty(imp.getQty());
            //
            if (line.save()) {
                imp.setGL_JournalBatch_ID(batch.getGL_JournalBatch_ID());
                imp.setGL_Journal_ID(journal.getGL_Journal_ID());
                imp.setGL_JournalLine_ID(line.getGL_JournalLine_ID());
                imp.setI_IsImported(true);
                imp.setProcessed(true);
                if (imp.save())
                    noInsertLine++;
            }
        }
        //	while records
        rs.close();
        pstmt.close();
    } catch (Exception e) {
        log.log(Level.SEVERE, "", e);
    }
    //	clean up
    try {
        if (pstmt != null)
            pstmt.close();
    } catch (SQLException ex1) {
    }
    pstmt = null;
    //	Set Error to indicator to not imported
    sql = new StringBuffer("UPDATE I_GLJournal " + "SET I_IsImported='N', Updated=SysDate " + "WHERE I_IsImported<>'Y'").append(clientCheck);
    no = DB.executeUpdate(sql.toString(), get_TrxName());
    addLog(0, null, new BigDecimal(no), "@Errors@");
    //
    addLog(0, null, new BigDecimal(noInsert), "@GL_JournalBatch_ID@: @Inserted@");
    addLog(0, null, new BigDecimal(noInsertJournal), "@GL_Journal_ID@: @Inserted@");
    addLog(0, null, new BigDecimal(noInsertLine), "@GL_JournalLine_ID@: @Inserted@");
    return "";
}
Also used : SQLException(java.sql.SQLException) MJournalLine(org.compiere.model.MJournalLine) MAccount(org.compiere.model.MAccount) PreparedStatement(java.sql.PreparedStatement) X_I_GLJournal(org.compiere.model.X_I_GLJournal) Timestamp(java.sql.Timestamp) BigDecimal(java.math.BigDecimal) SQLException(java.sql.SQLException) ResultSet(java.sql.ResultSet) MJournal(org.compiere.model.MJournal) MJournalBatch(org.compiere.model.MJournalBatch)

Example 4 with MAccount

use of org.compiere.model.MAccount in project adempiere by adempiere.

the class ImportAccount method updateDefaultAccount.

/**
	 * 	Update Default Account.
	 *  This is the sql to delete unused accounts - with the import still in the table(!):
		DELETE C_ElementValue e
		WHERE NOT EXISTS (SELECT * FROM Fact_Acct f WHERE f.Account_ID=e.C_ElementValue_ID)
		 AND NOT EXISTS (SELECT * FROM C_ValidCombination vc WHERE vc.Account_ID=e.C_ElementValue_ID)
		 AND NOT EXISTS (SELECT * FROM I_ElementValue i WHERE i.C_ElementValue_ID=e.C_ElementValue_ID);
	 * 	@param TableName Table Name
	 * 	@param ColumnName Column Name
	 * 	@param C_AcctSchema_ID Account Schema
	 * 	@param C_ElementValue_ID new Account
	 * 	@return UPDATE_* status
	 */
private int updateDefaultAccount(String TableName, String ColumnName, int C_AcctSchema_ID, int C_ElementValue_ID) {
    log.fine(TableName + "." + ColumnName + " - " + C_ElementValue_ID);
    int retValue = UPDATE_ERROR;
    StringBuffer sql = new StringBuffer("SELECT x.").append(ColumnName).append(",Account_ID FROM ").append(TableName).append(" x INNER JOIN C_ValidCombination vc ON (x.").append(ColumnName).append("=vc.C_ValidCombination_ID) ").append("WHERE x.C_AcctSchema_ID=").append(C_AcctSchema_ID);
    try {
        PreparedStatement pstmt = DB.prepareStatement(sql.toString(), get_TrxName());
        ResultSet rs = pstmt.executeQuery();
        if (rs.next()) {
            int C_ValidCombination_ID = rs.getInt(1);
            int Account_ID = rs.getInt(2);
            //	The current account value is the same
            if (Account_ID == C_ElementValue_ID) {
                retValue = UPDATE_SAME;
                log.fine("Account_ID same as new value");
            } else //	We need to update the Account Value
            {
                if (m_createNewCombination) {
                    MAccount acct = MAccount.get(getCtx(), C_ValidCombination_ID);
                    acct.setAccount_ID(C_ElementValue_ID);
                    if (acct.save()) {
                        retValue = UPDATE_YES;
                        int newC_ValidCombination_ID = acct.getC_ValidCombination_ID();
                        if (C_ValidCombination_ID != newC_ValidCombination_ID) {
                            sql = new StringBuffer("UPDATE ").append(TableName).append(" SET ").append(ColumnName).append("=").append(newC_ValidCombination_ID).append(" WHERE C_AcctSchema_ID=").append(C_AcctSchema_ID);
                            int no = DB.executeUpdate(sql.toString(), get_TrxName());
                            log.fine("New #" + no + " - " + TableName + "." + ColumnName + " - " + C_ElementValue_ID + " -- " + C_ValidCombination_ID + " -> " + newC_ValidCombination_ID);
                            if (no == 1)
                                retValue = UPDATE_YES;
                        }
                    } else
                        log.log(Level.SEVERE, "Account not saved - " + acct);
                } else //	Replace Combination
                {
                    //	Only Acct Combination directly
                    sql = new StringBuffer("UPDATE C_ValidCombination SET Account_ID=").append(C_ElementValue_ID).append(" WHERE C_ValidCombination_ID=").append(C_ValidCombination_ID);
                    int no = DB.executeUpdate(sql.toString(), get_TrxName());
                    log.fine("Replace #" + no + " - " + "C_ValidCombination_ID=" + C_ValidCombination_ID + ", New Account_ID=" + C_ElementValue_ID);
                    if (no == 1) {
                        retValue = UPDATE_YES;
                        //	Where Acct was used
                        sql = new StringBuffer("UPDATE C_ValidCombination SET Account_ID=").append(C_ElementValue_ID).append(" WHERE Account_ID=").append(Account_ID);
                        no = DB.executeUpdate(sql.toString(), get_TrxName());
                        log.fine("ImportAccount.updateDefaultAccount - Replace VC #" + no + " - " + "Account_ID=" + Account_ID + ", New Account_ID=" + C_ElementValue_ID);
                        sql = new StringBuffer("UPDATE Fact_Acct SET Account_ID=").append(C_ElementValue_ID).append(" WHERE Account_ID=").append(Account_ID);
                        no = DB.executeUpdate(sql.toString(), get_TrxName());
                        log.fine("ImportAccount.updateDefaultAccount - Replace Fact #" + no + " - " + "Account_ID=" + Account_ID + ", New Account_ID=" + C_ElementValue_ID);
                    }
                }
            //	replace combination
            }
        //	need to update
        } else
            //	for all default accounts
            log.log(Level.SEVERE, "Account not found " + sql);
        rs.close();
        pstmt.close();
    } catch (SQLException e) {
        log.log(Level.SEVERE, sql.toString(), e);
    }
    return retValue;
}
Also used : SQLException(java.sql.SQLException) MAccount(org.compiere.model.MAccount) ResultSet(java.sql.ResultSet) PreparedStatement(java.sql.PreparedStatement)

Example 5 with MAccount

use of org.compiere.model.MAccount in project adempiere by adempiere.

the class ImportAccount method updateCharge.

//	doIt
private void updateCharge(X_I_ElementValue impEV, MElementValue ev) {
    MCharge charge = (MCharge) impEV.getC_Charge();
    if (charge.get_ID() == 0 && !Util.isEmpty(impEV.getChargeName())) {
        charge.setName(impEV.getChargeName());
        charge.setAD_Org_ID(0);
        if (impEV.getC_TaxCategory_ID() == 0) {
            String sql = "SELECT C_TaxCategory_ID FROM C_TaxCategory WHERE AD_Client_ID = ? ORDER BY IsDefault DESC ";
            int taxc = DB.getSQLValue(get_TrxName(), sql, m_AD_Client_ID);
            charge.setC_TaxCategory_ID(taxc);
        } else {
            charge.setC_TaxCategory_ID(impEV.getC_TaxCategory_ID());
        }
        charge.saveEx();
        impEV.setC_Charge_ID(charge.getC_Charge_ID());
    }
    // add/update charge accounting 
    if (ev != null && !charge.is_new()) {
        // for accounting schemas
        for (MAcctSchema schema : MAcctSchema.getClientAcctSchema(getCtx(), m_AD_Client_ID)) {
            // with the same Account Element as the import
            if (schema.getAcctSchemaElement(MAcctSchemaElement.ELEMENTTYPE_Account).getC_Element_ID() == ev.getC_Element_ID()) {
                MChargeAcct chargeacct = MChargeAcct.get(schema, charge.getC_Charge_ID(), get_TrxName());
                if (chargeacct == null) {
                    chargeacct = new MChargeAcct(getCtx(), 0, get_TrxName());
                    chargeacct.setAD_Org_ID(charge.getAD_Org_ID());
                    chargeacct.setC_AcctSchema_ID(schema.getC_AcctSchema_ID());
                    chargeacct.setC_Charge_ID(charge.getC_Charge_ID());
                }
                MAccount expenseAccount = (MAccount) chargeacct.getCh_Expense_A();
                if (expenseAccount == null) {
                    //  optional null
                    expenseAccount = MAccount.getDefault(schema, true);
                }
                if (expenseAccount.getAccount_ID() != ev.getC_ElementValue_ID()) {
                    MAccount account = MAccount.get(Env.getCtx(), charge.getAD_Client_ID(), charge.getAD_Org_ID(), schema.getC_AcctSchema_ID(), ev.getC_ElementValue_ID(), expenseAccount.getC_SubAcct_ID(), expenseAccount.getM_Product_ID(), expenseAccount.getC_BPartner_ID(), expenseAccount.getAD_OrgTrx_ID(), expenseAccount.getC_LocFrom_ID(), expenseAccount.getC_LocTo_ID(), expenseAccount.getC_SalesRegion_ID(), expenseAccount.getC_Project_ID(), expenseAccount.getC_Campaign_ID(), expenseAccount.getC_Activity_ID(), expenseAccount.getUser1_ID(), expenseAccount.getUser2_ID(), expenseAccount.getUser3_ID(), expenseAccount.getUser4_ID(), expenseAccount.getUserElement1_ID(), expenseAccount.getUserElement2_ID(), get_TrxName());
                    chargeacct.setCh_Expense_Acct(account.getC_ValidCombination_ID());
                }
                MAccount revenueAccount = (MAccount) chargeacct.getCh_Revenue_A();
                if (revenueAccount == null) {
                    //  optional null
                    revenueAccount = MAccount.getDefault(schema, true);
                }
                if (revenueAccount.getAccount_ID() != ev.getC_ElementValue_ID()) {
                    MAccount account = MAccount.get(Env.getCtx(), charge.getAD_Client_ID(), charge.getAD_Org_ID(), schema.getC_AcctSchema_ID(), ev.getC_ElementValue_ID(), revenueAccount.getC_SubAcct_ID(), revenueAccount.getM_Product_ID(), revenueAccount.getC_BPartner_ID(), revenueAccount.getAD_OrgTrx_ID(), revenueAccount.getC_LocFrom_ID(), revenueAccount.getC_LocTo_ID(), revenueAccount.getC_SalesRegion_ID(), revenueAccount.getC_Project_ID(), revenueAccount.getC_Campaign_ID(), revenueAccount.getC_Activity_ID(), revenueAccount.getUser1_ID(), revenueAccount.getUser2_ID(), revenueAccount.getUser3_ID(), revenueAccount.getUser4_ID(), revenueAccount.getUserElement1_ID(), revenueAccount.getUserElement2_ID(), get_TrxName());
                    chargeacct.setCh_Revenue_Acct(account.getC_ValidCombination_ID());
                }
                chargeacct.saveEx();
            }
        }
    }
}
Also used : MAcctSchema(org.compiere.model.MAcctSchema) MAccount(org.compiere.model.MAccount) MCharge(org.compiere.model.MCharge) MChargeAcct(org.compiere.model.MChargeAcct)

Aggregations

MAccount (org.compiere.model.MAccount)42 BigDecimal (java.math.BigDecimal)25 ArrayList (java.util.ArrayList)16 MCostDetail (org.compiere.model.MCostDetail)8 PreparedStatement (java.sql.PreparedStatement)7 ResultSet (java.sql.ResultSet)7 MProduct (org.compiere.model.MProduct)6 SQLException (java.sql.SQLException)5 MCostElement (org.compiere.model.MCostElement)5 MJournalLine (org.compiere.model.MJournalLine)4 MCostType (org.compiere.model.MCostType)3 Timestamp (java.sql.Timestamp)2 MAcctSchemaElement (org.compiere.model.MAcctSchemaElement)2 MCharge (org.compiere.model.MCharge)2 MElementValue (org.compiere.model.MElementValue)2 MInvoice (org.compiere.model.MInvoice)2 AdempiereSystemError (org.compiere.util.AdempiereSystemError)2 TreeMap (java.util.TreeMap)1 AtomicInteger (java.util.concurrent.atomic.AtomicInteger)1 I_C_Project (org.compiere.model.I_C_Project)1