All Downloads are FREE. Search and download functionalities are using the official Maven repository.

it.cnr.contab.doccont00.intcass.bulk.V_mandato_reversaleHome Maven / Gradle / Ivy

/*
 * Copyright (C) 2019  Consiglio Nazionale delle Ricerche
 *
 *     This program is free software: you can redistribute it and/or modify
 *     it under the terms of the GNU Affero General Public License as
 *     published by the Free Software Foundation, either version 3 of the
 *     License, or (at your option) any later version.
 *
 *     This program is distributed in the hope that it will be useful,
 *     but WITHOUT ANY WARRANTY; without even the implied warranty of
 *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *     GNU Affero General Public License for more details.
 *
 *     You should have received a copy of the GNU Affero General Public License
 *     along with this program.  If not, see .
 */

package it.cnr.contab.doccont00.intcass.bulk;

import it.cnr.contab.config00.sto.bulk.Unita_organizzativaBulk;
import it.cnr.contab.config00.sto.bulk.Unita_organizzativa_enteBulk;
import it.cnr.contab.consultazioni.bulk.ConsultazioniRestHome;
import it.cnr.contab.doccont00.core.bulk.*;
import it.cnr.contab.doccont00.service.DocumentiContabiliService;
import it.cnr.contab.missioni00.docs.bulk.RimborsoBulk;
import it.cnr.contab.missioni00.docs.bulk.RimborsoHome;
import it.cnr.contab.service.SpringUtil;
import it.cnr.contab.utenze00.bp.CNRUserContext;
import it.cnr.contab.util.enumeration.EsitoOperazione;
import it.cnr.jada.UserContext;
import it.cnr.jada.bulk.BulkHome;
import it.cnr.jada.bulk.OggettoBulk;
import it.cnr.jada.comp.ApplicationException;
import it.cnr.jada.comp.ComponentException;
import it.cnr.jada.persistency.IntrospectionException;
import it.cnr.jada.persistency.PersistencyException;
import it.cnr.jada.persistency.Persistent;
import it.cnr.jada.persistency.PersistentCache;
import it.cnr.jada.persistency.sql.*;

import java.util.Collection;
import java.util.Enumeration;
import java.util.List;

public class V_mandato_reversaleHome extends BulkHome implements ConsultazioniRestHome {
    private DocumentiContabiliService documentiContabiliService;

    public V_mandato_reversaleHome(java.sql.Connection conn) {
        super(V_mandato_reversaleBulk.class, conn);
        documentiContabiliService = SpringUtil.getBean("documentiContabiliService",
                DocumentiContabiliService.class);
    }

    public V_mandato_reversaleHome(java.sql.Connection conn, PersistentCache persistentCache) {
        super(V_mandato_reversaleBulk.class, conn, persistentCache);
        documentiContabiliService = SpringUtil.getBean("documentiContabiliService",
                DocumentiContabiliService.class);
    }

    public V_mandato_reversaleBulk findDocContabile(Distinta_cassiere_detBulk dettaglio) throws PersistencyException, ApplicationException {
        SQLBuilder sql = createSQLBuilder();
        if (dettaglio.getPg_mandato() != null) {
            sql.addClause("AND", "cd_tipo_documento_cont", sql.EQUALS, Numerazione_doc_contBulk.TIPO_MAN);
            sql.addClause("AND", "pg_documento_cont", sql.EQUALS, dettaglio.getPg_mandato());
        } else if (dettaglio.getPg_reversale() != null) {
            sql.addClause("AND", "cd_tipo_documento_cont", sql.EQUALS, Numerazione_doc_contBulk.TIPO_REV);
            sql.addClause("AND", "pg_documento_cont", sql.EQUALS, dettaglio.getPg_reversale());
        } else
            return null;
        sql.addClause("AND", "esercizio", sql.EQUALS, dettaglio.getEsercizio());
        sql.addClause("AND", "cd_cds", sql.EQUALS, dettaglio.getCd_cds());
        sql.addClause("AND", "cd_unita_organizzativa", sql.EQUALS, dettaglio.getCd_unita_organizzativa());
        List result = fetchAll(sql);
        if (result.size() == 0)
            throw new ApplicationException("Attenzione! Mandato/Reversale non trovato per il dettaglio distinta");
        if (result.size() > 1)
            throw new ApplicationException("Attenzione! Esiste più di un Mandato/Reversale  per il dettaglio distinta");
        return (V_mandato_reversaleBulk) result.get(0);

    }

    public V_mandato_reversaleBulk findDocContabilePadre(V_mandato_reversaleBulk docContabile) throws PersistencyException {

        SQLBuilder sql = createSQLBuilder();
        sql.addClause("AND", "cd_tipo_documento_cont", sql.EQUALS, docContabile.getCd_tipo_documento_cont_padre());
        sql.addClause("AND", "pg_documento_cont", sql.EQUALS, docContabile.getPg_documento_cont_padre());
        sql.addClause("AND", "esercizio", sql.EQUALS, docContabile.getEsercizio());
        sql.addClause("AND", "cd_cds", sql.EQUALS, docContabile.getCd_cds());
        sql.addClause("AND", "cd_unita_organizzativa", sql.EQUALS, docContabile.getCd_unita_organizzativa());
        List result = fetchAll(sql);
        if (result != null && result.size() > 0)
            return (V_mandato_reversaleBulk) result.get(0);
        return null;
    }

    public Collection findDocContabiliAnnullatiDaRitrasmettere(Distinta_cassiereBulk distinta, boolean annulliTuttaSac, boolean tesoreria) throws PersistencyException {
        SQLBuilder sql = createSQLBuilder();
        sql.addClause("AND", "esercizio", sql.EQUALS, distinta.getEsercizio());
        if (!tesoreria) {
            sql.addClause("AND", "cd_cds", sql.EQUALS, distinta.getCd_cds());
            if (!annulliTuttaSac) {
                //solo per la 000.407, devono essere ritrasmessi i doc. di tutta la SAC
                sql.addClause("AND", "cd_unita_organizzativa", sql.EQUALS, distinta.getCd_unita_organizzativa());
            }
        }
        sql.addSQLClause("AND", "dt_annullamento > dt_trasmissione");
        sql.addClause("AND", "dt_ritrasmissione", sql.ISNULL, null);
        if (tesoreria)
            sql.addClause("AND", "stato_trasmissione", sql.EQUALS, MandatoBulk.STATO_TRASMISSIONE_PRIMA_FIRMA);
        return fetchAll(sql);

    }

    /* ritorna la collezione dei mandati figli */
    public List findMandatiCollegati(V_mandato_reversaleBulk docContabile) throws PersistencyException {
        SQLBuilder sql = createSQLBuilder();
        sql.addClause("AND", "cd_tipo_documento_cont", sql.EQUALS, Numerazione_doc_contBulk.TIPO_MAN);
        sql.addClause("AND", "pg_documento_cont_padre", sql.EQUALS, docContabile.getPg_documento_cont());
        sql.addClause("AND", "cd_tipo_documento_cont_padre", sql.EQUALS, docContabile.getCd_tipo_documento_cont());
        sql.openParenthesis("AND");
        sql.addClause("AND", "pg_documento_cont", sql.NOT_EQUALS, docContabile.getPg_documento_cont());
        sql.addClause("OR", "cd_tipo_documento_cont", sql.NOT_EQUALS, docContabile.getCd_tipo_documento_cont());
        sql.closeParenthesis();
        sql.addClause("AND", "esercizio", sql.EQUALS, docContabile.getEsercizio());
        sql.addClause("AND", "cd_cds", sql.EQUALS, docContabile.getCd_cds());
        sql.addClause("AND", "cd_unita_organizzativa", sql.EQUALS, docContabile.getCd_unita_organizzativa());
        return fetchAll(sql);
    }

    /* ritorna la collezione dei mandati figli */
    public List findReversaliCollegate(V_mandato_reversaleBulk docContabile) throws PersistencyException {
        SQLBuilder sql = createSQLBuilder();
        sql.addClause("AND", "cd_tipo_documento_cont", sql.EQUALS, Numerazione_doc_contBulk.TIPO_REV);
        sql.addClause("AND", "pg_documento_cont_padre", sql.EQUALS, docContabile.getPg_documento_cont());
        sql.addClause("AND", "cd_tipo_documento_cont_padre", sql.EQUALS, docContabile.getCd_tipo_documento_cont());
        sql.openParenthesis("AND");
        sql.addClause("AND", "pg_documento_cont", sql.NOT_EQUALS, docContabile.getPg_documento_cont());
        sql.addClause("OR", "cd_tipo_documento_cont", sql.NOT_EQUALS, docContabile.getCd_tipo_documento_cont());
        sql.closeParenthesis();
        sql.addClause("AND", "esercizio", sql.EQUALS, docContabile.getEsercizio());
        sql.addClause("AND", "cd_cds", sql.EQUALS, docContabile.getCd_cds());
        sql.addClause("AND", "cd_unita_organizzativa", sql.EQUALS, docContabile.getCd_unita_organizzativa());
        return fetchAll(sql);
    }

    /* ritorna la collezione dei documenti contabili figli */
    public Collection findDocContabiliCollegati(V_mandato_reversaleBulk docContabile) throws PersistencyException {

        SQLBuilder sql = createSQLBuilder();
        sql.addClause("AND", "pg_documento_cont_padre", sql.EQUALS, docContabile.getPg_documento_cont());
        sql.addClause("AND", "cd_tipo_documento_cont_padre", sql.EQUALS, docContabile.getCd_tipo_documento_cont());
        sql.openParenthesis("AND");
        sql.addClause("AND", "pg_documento_cont", sql.NOT_EQUALS, docContabile.getPg_documento_cont());
        sql.addClause("OR", "cd_tipo_documento_cont", sql.NOT_EQUALS, docContabile.getCd_tipo_documento_cont());
        sql.closeParenthesis();
        sql.addClause("AND", "esercizio", sql.EQUALS, docContabile.getEsercizio());
        sql.addClause("AND", "cd_cds", sql.EQUALS, docContabile.getCd_cds());
        sql.addClause("AND", "cd_unita_organizzativa", sql.EQUALS, docContabile.getCd_unita_organizzativa());
        return fetchAll(sql);
    }

    /* dato un documento contabile figlio restituisce la lista dei fratelli */
    public Collection findDocContabiliCollegatiEccetto(V_mandato_reversaleBulk docContabileDaEscludere) throws PersistencyException {

        SQLBuilder sql = createSQLBuilder();
		/*
		if ( docContabileDaEscludere.getCd_tipo_documento_cont().equals( Numerazione_doc_contBulk.TIPO_REV ) )
			sql.addClause( "AND", "cd_tipo_documento_cont", sql.EQUALS, Numerazione_doc_contBulk.TIPO_REV);
		else if ( docContabileDaEscludere.getCd_tipo_documento_cont().equals( Numerazione_doc_contBulk.TIPO_MAN ) )
			sql.addClause( "AND", "cd_tipo_documento_cont", sql.EQUALS, Numerazione_doc_contBulk.TIPO_MAN);
		*/
        sql.addClause("AND", "pg_documento_cont_padre", sql.EQUALS, docContabileDaEscludere.getPg_documento_cont_padre());
        sql.addClause("AND", "cd_tipo_documento_cont_padre", sql.EQUALS, docContabileDaEscludere.getCd_tipo_documento_cont_padre());
        sql.openParenthesis("AND");
        sql.addClause("AND", "pg_documento_cont", sql.NOT_EQUALS, docContabileDaEscludere.getPg_documento_cont());
        sql.addClause("OR", "cd_tipo_documento_cont", sql.NOT_EQUALS, docContabileDaEscludere.getCd_tipo_documento_cont());
        sql.closeParenthesis();
        sql.addClause("AND", "pg_documento_cont", sql.NOT_EQUALS, docContabileDaEscludere.getPg_documento_cont());
        sql.addClause("AND", "esercizio", sql.EQUALS, docContabileDaEscludere.getEsercizio());
        sql.addClause("AND", "cd_cds", sql.EQUALS, docContabileDaEscludere.getCd_cds());
        sql.addClause("AND", "cd_unita_organizzativa", sql.EQUALS, docContabileDaEscludere.getCd_unita_organizzativa());
        return fetchAll(sql);
    }

    public List findReversaliAssociabili(it.cnr.jada.UserContext userContext, MandatoBulk mandato) throws PersistencyException, IntrospectionException {

        SQLBuilder sql = createSQLBuilder();
        sql.addClause("AND", "cd_tipo_documento_cont", sql.EQUALS, Numerazione_doc_contBulk.TIPO_REV);

        sql.addClause("AND", "cd_cds", sql.EQUALS, mandato.getCd_cds());
        sql.addClause("AND", "esercizio", sql.EQUALS, mandato.getEsercizio());
        sql.addClause("AND", "cd_unita_organizzativa", sql.EQUALS, mandato.getCd_unita_organizzativa());

        sql.addClause("AND", "cd_cds_origine", sql.EQUALS, mandato.getCd_cds_origine());
        sql.addClause("AND", "cd_uo_origine", sql.EQUALS, mandato.getCd_uo_origine());

        sql.addClause("AND", "stato", sql.EQUALS, ReversaleIBulk.STATO_REVERSALE_EMESSO);
        sql.addClause("AND", "stato_trasmissione", sql.EQUALS, ReversaleIBulk.STATO_TRASMISSIONE_NON_INSERITO);

        MandatoHome home = (MandatoHome) getHomeCache().getHome(mandato.getClass());
        Mandato_terzoBulk terzo = home.findMandato_terzo(userContext, mandato);
        sql.addClause("AND", "cd_terzo", sql.EQUALS, terzo.getCd_terzo());

        return fetchAll(sql);
    }

    /**
     * Metodo per cercare i riscontri associati alla reversale selezionata.
     *
     * @return result i riscontri associati alla reversale
     */
    public Collection findRiscontriDiEntrata(V_mandato_reversaleBulk v_man_rev) throws PersistencyException, IntrospectionException {
        PersistentHome home = getHomeCache().getHome(SospesoBulk.class);
        SQLBuilder sql = home.createSQLBuilder();
        sql.addTableToHeader("SOSPESO_DET_ETR");
        sql.addSQLClause("AND", "SOSPESO_DET_ETR.esercizio", sql.EQUALS, v_man_rev.getEsercizio());
        sql.addSQLClause("AND", "SOSPESO_DET_ETR.cd_cds", sql.EQUALS, v_man_rev.getCd_cds());
        sql.addSQLClause("AND", "SOSPESO_DET_ETR.pg_reversale", sql.EQUALS, v_man_rev.getPg_documento_cont());
        sql.addSQLClause("AND", "SOSPESO_DET_ETR.ti_sospeso_riscontro", sql.EQUALS, SospesoBulk.TI_RISCONTRO);
        sql.addSQLClause("AND", "SOSPESO_DET_ETR.ti_entrata_spesa", sql.EQUALS, SospesoBulk.TIPO_ENTRATA);
        sql.addSQLClause("AND", "SOSPESO_DET_ETR.STATO", sql.EQUALS, Sospeso_det_etrBulk.STATO_DEFAULT);

        sql.addSQLJoin("SOSPESO_DET_ETR.ESERCIZIO", "SOSPESO.ESERCIZIO");
        sql.addSQLJoin("SOSPESO_DET_ETR.CD_CDS", "SOSPESO.CD_CDS");
        sql.addSQLJoin("SOSPESO_DET_ETR.CD_SOSPESO", "SOSPESO.CD_SOSPESO");
        sql.addSQLJoin("SOSPESO_DET_ETR.TI_ENTRATA_SPESA", "SOSPESO.TI_ENTRATA_SPESA");
        sql.addSQLJoin("SOSPESO_DET_ETR.TI_SOSPESO_RISCONTRO", "SOSPESO.TI_SOSPESO_RISCONTRO");

        return home.fetchAll(sql);
    }

    /**
     * Metodo per cercare i riscontri associati al mandato selezionato.
     *
     * @return result i riscontri associati al mandato
     */
    public Collection findRiscontriDiSpesa(V_mandato_reversaleBulk v_man_rev) throws PersistencyException, IntrospectionException {
        PersistentHome home = getHomeCache().getHome(SospesoBulk.class);
        SQLBuilder sql = home.createSQLBuilder();
        sql.addTableToHeader("SOSPESO_DET_USC");
        sql.addSQLClause("AND", "SOSPESO_DET_USC.esercizio", sql.EQUALS, v_man_rev.getEsercizio());
        sql.addSQLClause("AND", "SOSPESO_DET_USC.cd_cds", sql.EQUALS, v_man_rev.getCd_cds());
        sql.addSQLClause("AND", "SOSPESO_DET_USC.pg_mandato", sql.EQUALS, v_man_rev.getPg_documento_cont());
        sql.addSQLClause("AND", "SOSPESO_DET_USC.ti_sospeso_riscontro", sql.EQUALS, SospesoBulk.TI_RISCONTRO);
        sql.addSQLClause("AND", "SOSPESO_DET_USC.ti_entrata_spesa", sql.EQUALS, SospesoBulk.TIPO_SPESA);
        sql.addSQLClause("AND", "SOSPESO_DET_USC.STATO", sql.EQUALS, Sospeso_det_uscBulk.STATO_DEFAULT);

        sql.addSQLJoin("SOSPESO_DET_USC.ESERCIZIO", "SOSPESO.ESERCIZIO");
        sql.addSQLJoin("SOSPESO_DET_USC.CD_CDS", "SOSPESO.CD_CDS");
        sql.addSQLJoin("SOSPESO_DET_USC.CD_SOSPESO", "SOSPESO.CD_SOSPESO");
        sql.addSQLJoin("SOSPESO_DET_USC.TI_ENTRATA_SPESA", "SOSPESO.TI_ENTRATA_SPESA");
        sql.addSQLJoin("SOSPESO_DET_USC.TI_SOSPESO_RISCONTRO", "SOSPESO.TI_SOSPESO_RISCONTRO");

        return home.fetchAll(sql);
    }

    @Override
    public Persistent completeBulkRowByRow(UserContext userContext, Persistent persistent) throws PersistencyException {
        persistent = super.completeBulkRowByRow(userContext, persistent);
        if (persistent instanceof V_mandato_reversaleBulk) {
            V_mandato_reversaleBulk bulk = (V_mandato_reversaleBulk) persistent;
            if (!bulk.getStato_trasmissione().equals(MandatoBulk.STATO_TRASMISSIONE_NON_INSERITO) &&
                    !(bulk.isReversale() && bulk.getCd_tipo_documento_cont_padre().equals(Numerazione_doc_contBulk.TIPO_MAN))) {
                if (((CNRUserContext) userContext).isFromBootstrap()) {
                    bulk.setDocumento("");
                } else {
                    bulk.setDocumento("");
                }
            }
            if (bulk.isReversaleTrasferimento()) {
                SQLBuilder sql = getHomeCache().getHome(Distinta_cassiere_detBulk.class).createSQLBuilder();
                sql.addClause("AND", "esercizio", SQLBuilder.EQUALS, bulk.getEsercizio());
                sql.addClause("AND", "cd_cds", SQLBuilder.EQUALS, bulk.getCd_cds());
                sql.addClause("AND", "cd_unita_organizzativa", SQLBuilder.EQUALS, bulk.getCd_unita_organizzativa());
                sql.addClause("AND", "pg_reversale", SQLBuilder.EQUALS, bulk.getPg_documento_cont());
                sql.addOrderBy("PG_DISTINTA DESC");

                java.util.List list = getHomeCache().getHome(Distinta_cassiere_detBulk.class).fetchAll(sql);
                if (!list.isEmpty())
                    bulk.setPg_distinta(((Distinta_cassiere_detBulk) list.get(0)).getPg_distinta());
                return (Persistent) bulk;
            }
        }
        return persistent;
    }

    @Override
    public SQLBuilder restSelect(UserContext userContext, SQLBuilder sql, CompoundFindClause compoundfindclause, OggettoBulk oggettobulk) throws ComponentException, PersistencyException {
        if (compoundfindclause != null && compoundfindclause.getClauses() != null) {
            Boolean trovataCondizioneSoloAnticipi = false;
            CompoundFindClause newClauses = new CompoundFindClause();
            Enumeration e = compoundfindclause.getClauses();
            SQLBuilder sqlExists = null;
            SQLBuilder sqlNotExists = null;
            while (e.hasMoreElements()) {
                FindClause findClause = (FindClause) e.nextElement();
                if (findClause instanceof SimpleFindClause) {
                    SimpleFindClause clause = (SimpleFindClause) findClause;
                    int operator = clause.getOperator();
                    if (clause.getPropertyName() != null && clause.getPropertyName().equals("soloAnticipi") &&
                            operator == SQLBuilder.EQUALS) {
                        trovataCondizioneSoloAnticipi = true;
                        Mandato_rigaHome home = (Mandato_rigaHome) getHomeCache().getHome(Mandato_rigaBulk.class);
                        sqlExists = home.createSQLBuilder();
                        sqlExists.addTableToHeader("ANTICIPO");
                        sqlExists.addSQLJoin("V_MANDATO_REVERSALE.ESERCIZIO", "MANDATO_RIGA.ESERCIZIO");
                        sqlExists.addSQLJoin("V_MANDATO_REVERSALE.CD_CDS", "MANDATO_RIGA.CD_CDS");
                        sqlExists.addSQLJoin("V_MANDATO_REVERSALE.PG_DOCUMENTO_CONT", "MANDATO_RIGA.PG_MANDATO");
                        sqlExists.addSQLJoin("ANTICIPO.CD_CDS", "MANDATO_RIGA.CD_CDS_DOC_AMM");
                        sqlExists.addSQLJoin("ANTICIPO.ESERCIZIO", "MANDATO_RIGA.ESERCIZIO_DOC_AMM");
                        sqlExists.addSQLJoin("ANTICIPO.CD_UNITA_ORGANIZZATIVA", "MANDATO_RIGA.CD_UO_DOC_AMM");
                        sqlExists.addSQLJoin("ANTICIPO.PG_ANTICIPO", "MANDATO_RIGA.PG_DOC_AMM");
                        sqlExists.addSQLClause("AND", "MANDATO_RIGA.CD_TIPO_DOCUMENTO_AMM", SQLBuilder.EQUALS, "ANTICIPO");
                        sqlExists.addSQLClause("AND", "ANTICIPO.FL_ASSOCIATO_MISSIONE", SQLBuilder.EQUALS, "N");


                        RimborsoHome homeRimborso = (RimborsoHome) getHomeCache().getHome(RimborsoBulk.class);
                        sqlNotExists = homeRimborso.createSQLBuilder();
                        sqlNotExists.addTableToHeader("MANDATO_RIGA");
                        sqlNotExists.addSQLJoin("V_MANDATO_REVERSALE.ESERCIZIO", "MANDATO_RIGA.ESERCIZIO");
                        sqlNotExists.addSQLJoin("V_MANDATO_REVERSALE.CD_CDS", "MANDATO_RIGA.CD_CDS");
                        sqlNotExists.addSQLJoin("V_MANDATO_REVERSALE.PG_DOCUMENTO_CONT", "MANDATO_RIGA.PG_MANDATO");
                        sqlNotExists.addSQLJoin("RIMBORSO.CD_CDS", "MANDATO_RIGA.CD_CDS_DOC_AMM");
                        sqlNotExists.addSQLJoin("RIMBORSO.ESERCIZIO", "MANDATO_RIGA.ESERCIZIO_DOC_AMM");
                        sqlNotExists.addSQLJoin("RIMBORSO.CD_UNITA_ORGANIZZATIVA", "MANDATO_RIGA.CD_UO_DOC_AMM");
                        sqlNotExists.addSQLJoin("RIMBORSO.PG_ANTICIPO", "MANDATO_RIGA.PG_DOC_AMM");
                        sqlNotExists.addSQLClause("AND", "MANDATO_RIGA.CD_TIPO_DOCUMENTO_AMM", SQLBuilder.EQUALS, "ANTICIPO");
                    } else {
                        newClauses.addClause(clause.getLogicalOperator(), clause.getPropertyName(), clause.getOperator(), clause.getValue());
                    }
                }
            }
            if (trovataCondizioneSoloAnticipi) {
                sql = selectByClause(userContext, newClauses);
                sql.addSQLExistsClause("AND", sqlExists);
                sql.addSQLNotExistsClause("AND", sqlNotExists);
            }
        }
        if (!isUoEnte(userContext)) {
            sql.addSQLClause("AND", "CD_UNITA_ORGANIZZATIVA", sql.EQUALS, it.cnr.contab.utenze00.bp.CNRUserContext.getCd_unita_organizzativa(userContext));
            sql.addSQLClause("AND", "CD_CDS", sql.EQUALS, it.cnr.contab.utenze00.bp.CNRUserContext.getCd_cds(userContext));
        }
        return sql;
    }

    private Boolean isUoEnte(UserContext userContext) throws PersistencyException {
        Unita_organizzativa_enteBulk uoEnte = getUoEnte(userContext);
        if (((CNRUserContext) userContext).getCd_unita_organizzativa().equals(uoEnte.getCd_unita_organizzativa())) {
            return true;
        }
        return false;
    }

    private Unita_organizzativa_enteBulk getUoEnte(UserContext userContext)
            throws PersistencyException {
        Unita_organizzativa_enteBulk uoEnte = (Unita_organizzativa_enteBulk) getHomeCache().getHome(Unita_organizzativa_enteBulk.class).findAll().get(0);
        return uoEnte;
    }

    private Unita_organizzativaBulk getUoScrivania(UserContext userContext) throws PersistencyException {
        return (Unita_organizzativaBulk) getHomeCache().getHome(Unita_organizzativaBulk.class)
                .findByPrimaryKey(new Unita_organizzativaBulk(CNRUserContext.getCd_unita_organizzativa(userContext)));
    }

    public SQLBuilder selectByClauseForFirmaMandati(UserContext usercontext, V_mandato_reversaleBulk v_mandato_reversaleBulk, CompoundFindClause compoundfindclause) throws PersistencyException {
        SQLBuilder sqlBuilder = createSQLBuilder();
        if(compoundfindclause == null){
            if(v_mandato_reversaleBulk != null)
                compoundfindclause = v_mandato_reversaleBulk.buildFindClauses(null);
        } else {
            compoundfindclause = CompoundFindClause.and(compoundfindclause, v_mandato_reversaleBulk.buildFindClauses(Boolean.FALSE));
        }
        sqlBuilder.addClause(compoundfindclause);
        sqlBuilder.addClause(FindClause.AND, "esercizio", SQLBuilder.EQUALS, CNRUserContext.getEsercizio(usercontext));
        if (!isUoEnte(usercontext)) {
            sqlBuilder.openParenthesis(FindClause.AND);
                sqlBuilder.addClause(FindClause.AND, "cd_cds", SQLBuilder.EQUALS, CNRUserContext.getCd_cds(usercontext));
                sqlBuilder.openParenthesis(FindClause.OR);
                    sqlBuilder.addClause(FindClause.AND, "cd_cds_origine", SQLBuilder.EQUALS, CNRUserContext.getCd_cds(usercontext));
                    sqlBuilder.openParenthesis(FindClause.AND);
                        sqlBuilder.addClause(FindClause.AND, "ti_documento_cont", SQLBuilder.EQUALS, ReversaleIBulk.TIPO_REGOLAM_SOSPESO);
                        sqlBuilder.openParenthesis(FindClause.OR);
                            sqlBuilder.addClause(FindClause.AND, "ti_documento_cont", SQLBuilder.EQUALS, ReversaleIBulk.TIPO_INCASSO);
                            sqlBuilder.addJoin("cd_tipo_documento_cont", "cd_tipo_documento_cont_padre");
                            sqlBuilder.addJoin("pg_documento_cont", "pg_documento_cont_padre");
                            sqlBuilder.addJoin("ti_documento_cont", "ti_documento_cont_padre");
                        sqlBuilder.closeParenthesis();
                    sqlBuilder.closeParenthesis();
                    sqlBuilder.addClause(FindClause.AND, "cd_tipo_documento_cont", SQLBuilder.EQUALS, Numerazione_doc_contBulk.TIPO_REV);
                sqlBuilder.closeParenthesis();
            sqlBuilder.closeParenthesis();
        }
        if (!getUoScrivania(usercontext).isUoCds()) {
            sqlBuilder.openParenthesis(FindClause.AND);
                sqlBuilder.addClause(FindClause.AND, "cd_unita_organizzativa", SQLBuilder.EQUALS, CNRUserContext.getCd_unita_organizzativa(usercontext));
                sqlBuilder.openParenthesis(FindClause.OR);
                    sqlBuilder.addClause(FindClause.AND, "cd_uo_origine", SQLBuilder.EQUALS, CNRUserContext.getCd_unita_organizzativa(usercontext));
                    sqlBuilder.addClause(FindClause.AND, "ti_documento_cont", SQLBuilder.EQUALS, ReversaleIBulk.TIPO_REGOLAM_SOSPESO);
                    sqlBuilder.addClause(FindClause.AND, "cd_tipo_documento_cont", SQLBuilder.EQUALS, Numerazione_doc_contBulk.TIPO_REV);
                sqlBuilder.closeParenthesis();
            sqlBuilder.closeParenthesis();
        }

        sqlBuilder.openParenthesis(FindClause.AND);
            sqlBuilder.addClause(FindClause.AND, "ti_documento_cont", SQLBuilder.NOT_EQUALS, MandatoBulk.TIPO_REGOLARIZZAZIONE);

            sqlBuilder.openParenthesis(FindClause.AND);
                sqlBuilder.addClause(FindClause.AND, "ti_documento_cont", SQLBuilder.NOT_EQUALS, ReversaleIBulk.TIPO_INCASSO);
                sqlBuilder.openParenthesis(FindClause.OR);
                    sqlBuilder.addClause(FindClause.AND, "ti_documento_cont", SQLBuilder.EQUALS, ReversaleIBulk.TIPO_INCASSO);
                    sqlBuilder.addJoin("cd_tipo_documento_cont", "cd_tipo_documento_cont_padre");
                    sqlBuilder.addJoin("pg_documento_cont", "pg_documento_cont_padre");
                    sqlBuilder.addJoin("ti_documento_cont", "ti_documento_cont_padre");
                sqlBuilder.closeParenthesis();
            sqlBuilder.closeParenthesis();

            sqlBuilder.openParenthesis(FindClause.OR);
                sqlBuilder.addClause(FindClause.AND, "stato", SQLBuilder.EQUALS, MandatoBulk.STATO_MANDATO_ANNULLATO);
                sqlBuilder.addClause(FindClause.AND, "esitoOperazione", SQLBuilder.EQUALS, EsitoOperazione.ACQUISITO.value());
                sqlBuilder.addJoin("pg_documento_cont", "pg_documento_cont_padre");
                sqlBuilder.addClause(FindClause.AND, "cd_tipo_documento_cont", SQLBuilder.EQUALS, Numerazione_doc_contBulk.TIPO_REV);
            sqlBuilder.closeParenthesis();
        sqlBuilder.closeParenthesis();

        sqlBuilder.openParenthesis(FindClause.AND);
            sqlBuilder.addClause(FindClause.AND, "stato", SQLBuilder.NOT_EQUALS, MandatoBulk.STATO_MANDATO_ANNULLATO);
            sqlBuilder.openParenthesis(FindClause.OR);
                sqlBuilder.addClause(FindClause.AND, "stato", SQLBuilder.EQUALS, MandatoBulk.STATO_MANDATO_ANNULLATO);
                sqlBuilder.addClause(FindClause.AND, "dt_trasmissione", SQLBuilder.ISNOTNULL, null);
                sqlBuilder.addClause(FindClause.AND, "esitoOperazione", SQLBuilder.NOT_EQUALS, EsitoOperazione.NON_ACQUISITO.value());
            sqlBuilder.closeParenthesis();
        sqlBuilder.closeParenthesis();

        sqlBuilder.openParenthesis(FindClause.AND);
            sqlBuilder.addJoin("pg_documento_cont", "pg_documento_cont_padre");
            sqlBuilder.openParenthesis(FindClause.OR);
                sqlBuilder.addJoin("pg_documento_cont", SQLBuilder.NOT_EQUALS,"pg_documento_cont_padre");
                sqlBuilder.addClause(FindClause.AND, "cd_tipo_documento_cont", SQLBuilder.EQUALS, Numerazione_doc_contBulk.TIPO_MAN);
                sqlBuilder.addClause(FindClause.AND, "cd_tipo_documento_cont_padre", SQLBuilder.EQUALS, Numerazione_doc_contBulk.TIPO_MAN);
            sqlBuilder.closeParenthesis();
        sqlBuilder.closeParenthesis();

        return sqlBuilder;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy