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

it.cnr.contab.utenze00.bulk.RuoloHome 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.utenze00.bulk;

import it.cnr.jada.bulk.BulkHome;
import it.cnr.jada.persistency.IntrospectionException;
import it.cnr.jada.persistency.PersistencyException;
import it.cnr.jada.persistency.PersistentCache;
import it.cnr.jada.persistency.sql.CompoundFindClause;
import it.cnr.jada.persistency.sql.FindClause;
import it.cnr.jada.persistency.sql.PersistentHome;
import it.cnr.jada.persistency.sql.SQLBuilder;

import java.util.Optional;

public class RuoloHome extends BulkHome {
    /**
     * 
     * Costruisce un RuoloHome
     *
     * @param conn La java.sql.Connection su cui vengono effettuate le operazione di persistenza
     */
    public RuoloHome(java.sql.Connection conn) {
        super(RuoloBulk.class, conn);
    }

    /**
     * 
     * Costruisce un RuoloHome
     *
     * @param conn            La java.sql.Connection su cui vengono effettuate le operazione di persistenza
     * @param persistentCache La PersistentCache in cui vengono cachati gli oggetti persistenti caricati da questo Home
     */
    public RuoloHome(java.sql.Connection conn, PersistentCache persistentCache) {
        super(RuoloBulk.class, conn, persistentCache);
    }

    /**
     * Recupera la lista di accessi (AccessoBulk) di tipo pubblico ordinandoli per codice
     *
     * @param gestore parametro non usato
     * @return List lista di AccessoBulk
     */

    public java.util.List findAccessi_disponibili(UtenteBulk gestore, RuoloBulk ruolo, CompoundFindClause compoundFindClause) throws IntrospectionException, PersistencyException {
        PersistentHome accessoHome = getHomeCache().getHome(AccessoBulk.class);
        SQLBuilder sql = accessoHome.createSQLBuilder();
        Optional.ofNullable(compoundFindClause)
                .ifPresent(compoundFindClause1 -> sql.addClause(compoundFindClause1));
        if (!"*".equals(gestore.getCd_cds_configuratore()))
            sql.addSQLClause("AND", "TI_ACCESSO", SQLBuilder.EQUALS, AccessoBulk.TIPO_PUBBLICO);
        else {
            sql.openParenthesis("AND");
            sql.addSQLClause("AND", "TI_ACCESSO", SQLBuilder.EQUALS, AccessoBulk.TIPO_PUBBLICO);
            sql.addSQLClause("OR", "TI_ACCESSO", SQLBuilder.EQUALS, AccessoBulk.TIPO_RISERVATO_CNR);
            sql.closeParenthesis();
        }
        if (Optional.ofNullable(ruolo).filter(ruoloBulk -> Optional.ofNullable(ruoloBulk.getCd_ruolo()).isPresent()).isPresent()) {
            PersistentHome ruoloAccessoHome = getHomeCache().getHome(Ruolo_accessoBulk.class);
            SQLBuilder sqlRuoloAccesso = ruoloAccessoHome.createSQLBuilder();
            sqlRuoloAccesso.addSQLClause("AND", "CD_RUOLO", SQLBuilder.EQUALS, ruolo.getCd_ruolo());
            sqlRuoloAccesso.addSQLJoin("ACCESSO.CD_ACCESSO","RUOLO_ACCESSO.CD_ACCESSO");
            sql.addSQLNotExistsClause(FindClause.AND,sqlRuoloAccesso);
        }

        //sql.addSQLClause("AND","TI_ACCESSO",sql.NOT_EQUALS,AccessoBulk.TIPO_RISERVATO_CNR);
        //sql.addSQLClause("AND","TI_ACCESSO",sql.NOT_EQUALS,AccessoBulk.TIPO_SUPERUTENTE);
        //sql.addSQLClause("AND","TI_ACCESSO",sql.NOT_EQUALS,AccessoBulk.TIPO_AMMIN_UTENZE);
        sql.addOrderBy("CD_ACCESSO");
        return accessoHome.fetchAll(sql);

    }

    /**
     * Recupera la lista di associazioni ruolo-accesso (Ruolo_accessoBulk) definite per un ruolo
     *
     * @param ruolo RuoloBulk per cui cercare le associazioni
     * @return List lista di Ruolo_accessoBulk
     */

    public java.util.Collection findRuolo_accessi(RuoloBulk ruolo) throws IntrospectionException, PersistencyException {
        PersistentHome raHome = getHomeCache().getHome(Ruolo_accessoBulk.class);
        SQLBuilder sql = raHome.createSQLBuilder();
        sql.addSQLClause("AND", "CD_RUOLO", sql.EQUALS, ruolo.getCd_ruolo());
        return raHome.fetchAll(sql);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy