DBOggettiInUsoUtils_serviziApplicativi.java

  1. /*
  2.  * GovWay - A customizable API Gateway
  3.  * https://govway.org
  4.  *
  5.  * Copyright (c) 2005-2025 Link.it srl (https://link.it).
  6.  *
  7.  * This program is free software: you can redistribute it and/or modify
  8.  * it under the terms of the GNU General Public License version 3, as published by
  9.  * the Free Software Foundation.
  10.  *
  11.  * This program is distributed in the hope that it will be useful,
  12.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  14.  * GNU General Public License for more details.
  15.  *
  16.  * You should have received a copy of the GNU General Public License
  17.  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
  18.  *
  19.  */

  20. package org.openspcoop2.protocol.engine.utils;

  21. import java.sql.Connection;
  22. import java.sql.PreparedStatement;
  23. import java.sql.ResultSet;
  24. import java.util.ArrayList;
  25. import java.util.List;
  26. import java.util.Map;
  27. import java.util.Set;

  28. import org.openspcoop2.core.commons.DBUtils;
  29. import org.openspcoop2.core.commons.ErrorsHandlerCostant;
  30. import org.openspcoop2.core.config.constants.RuoloTipoMatch;
  31. import org.openspcoop2.core.constants.CostantiDB;
  32. import org.openspcoop2.core.id.IDServizioApplicativo;
  33. import org.openspcoop2.protocol.engine.ProtocolFactoryManager;
  34. import org.openspcoop2.utils.UtilsException;
  35. import org.openspcoop2.utils.jdbc.JDBCUtilities;
  36. import org.openspcoop2.utils.sql.ISQLQueryObject;
  37. import org.openspcoop2.utils.sql.SQLObjectFactory;

  38. /**
  39.  * DBOggettiInUsoUtils_serviziApplicativi
  40.  *
  41.  * @author Andrea Poli (apoli@link.it)
  42.  * @author $Author$
  43.  * @version $Rev$, $Date$
  44.  *
  45.  */
  46. public class DBOggettiInUsoUtils_serviziApplicativi {


  47.     protected static boolean isServizioApplicativoInUso(Connection con, String tipoDB, IDServizioApplicativo idServizioApplicativo,
  48.             Map<ErrorsHandlerCostant, List<String>> whereIsInUso, boolean isRegistroServiziLocale, boolean normalizeObjectIds,
  49.             boolean verificaRuoli) throws UtilsException {

  50.         String nomeMetodo = "isServizioApplicativoInUso";

  51.         PreparedStatement stmt = null;
  52.         ResultSet risultato = null;
  53.         PreparedStatement stmt2 = null;
  54.         ResultSet risultato2 = null;
  55.         String queryString;
  56.         try {
  57.             boolean isInUso = false;

  58.             long idServizioApplicativoLong = DBUtils.getIdServizioApplicativo(idServizioApplicativo.getNome(),
  59.                     idServizioApplicativo.getIdSoggettoProprietario().getTipo(),
  60.                     idServizioApplicativo.getIdSoggettoProprietario().getNome(),
  61.                     con, tipoDB);
  62.             if(idServizioApplicativoLong<=0){
  63.                 throw new UtilsException("Servizio Applicativo con id ["+idServizioApplicativo+"] non trovato");
  64.             }


  65.             List<String> autorizzazionePD_mapping_list = whereIsInUso.get(ErrorsHandlerCostant.AUTORIZZAZIONE_MAPPING);
  66.             List<String> autorizzazionePD_list = whereIsInUso.get(ErrorsHandlerCostant.AUTORIZZAZIONE);
  67.             List<String> autorizzazionePA_mapping_list = whereIsInUso.get(ErrorsHandlerCostant.AUTORIZZAZIONE_MAPPING_PA);
  68.             List<String> autorizzazionePA_list = whereIsInUso.get(ErrorsHandlerCostant.AUTORIZZAZIONE_PA);
  69.             List<String> autorizzazionePA_mapping_modi_list = whereIsInUso.get(ErrorsHandlerCostant.AUTORIZZAZIONE_MAPPING_PA_MODI);
  70.             List<String> autorizzazionePA_modi_list = whereIsInUso.get(ErrorsHandlerCostant.AUTORIZZAZIONE_PA_MODI);
  71.             List<String> autorizzazioneTokenPD_mapping_list = whereIsInUso.get(ErrorsHandlerCostant.AUTORIZZAZIONE_TOKEN_MAPPING_PD);
  72.             List<String> autorizzazioneTokenPD_list = whereIsInUso.get(ErrorsHandlerCostant.AUTORIZZAZIONE_TOKEN_PD);
  73.             List<String> autorizzazioneTokenPA_mapping_list = whereIsInUso.get(ErrorsHandlerCostant.AUTORIZZAZIONE_TOKEN_MAPPING_PA);
  74.             List<String> autorizzazioneTokenPA_list = whereIsInUso.get(ErrorsHandlerCostant.AUTORIZZAZIONE_TOKEN_PA);
  75.             List<String> ruoliPD_mapping_list = whereIsInUso.get(ErrorsHandlerCostant.RUOLI_MAPPING);
  76.             List<String> ruoliPD_list = whereIsInUso.get(ErrorsHandlerCostant.RUOLI);
  77.             List<String> ruoliPA_mapping_list = whereIsInUso.get(ErrorsHandlerCostant.RUOLI_MAPPING_PA);
  78.             List<String> ruoliPA_list = whereIsInUso.get(ErrorsHandlerCostant.RUOLI_PA);
  79.             List<String> ruoliTokenPD_mapping_list = whereIsInUso.get(ErrorsHandlerCostant.RUOLI_TOKEN_MAPPING_PD);
  80.             List<String> ruoliTokenPD_list = whereIsInUso.get(ErrorsHandlerCostant.RUOLI_TOKEN_PD);
  81.             List<String> ruoliTokenPA_mapping_list = whereIsInUso.get(ErrorsHandlerCostant.RUOLI_TOKEN_MAPPING_PA);
  82.             List<String> ruoliTokenPA_list = whereIsInUso.get(ErrorsHandlerCostant.RUOLI_TOKEN_PA);
  83.             List<String> ruoliTokenPA_mapping_modi_list = whereIsInUso.get(ErrorsHandlerCostant.RUOLI_TOKEN_MAPPING_PA_MODI);
  84.             List<String> ruoliTokenPA_modi_list = whereIsInUso.get(ErrorsHandlerCostant.RUOLI_TOKEN_PA_MODI);
  85.             List<String> porte_applicative_list = whereIsInUso.get(ErrorsHandlerCostant.IN_USO_IN_PORTE_APPLICATIVE);
  86.             List<String> porte_applicative_mapping_list = whereIsInUso.get(ErrorsHandlerCostant.IN_USO_IN_MAPPING_EROGAZIONE_PA);
  87.             List<String> ct_list = whereIsInUso.get(ErrorsHandlerCostant.CONTROLLO_TRAFFICO);
  88.             List<String> allarme_list = whereIsInUso.get(ErrorsHandlerCostant.ALLARMI);
  89.             List<String> trasformazionePD_mapping_list = whereIsInUso.get(ErrorsHandlerCostant.TRASFORMAZIONE_MAPPING_PD);
  90.             List<String> trasformazionePD_list = whereIsInUso.get(ErrorsHandlerCostant.TRASFORMAZIONE_PD);
  91.             List<String> trasformazionePA_mapping_list = whereIsInUso.get(ErrorsHandlerCostant.TRASFORMAZIONE_MAPPING_PA);
  92.             List<String> trasformazionePA_list = whereIsInUso.get(ErrorsHandlerCostant.TRASFORMAZIONE_PA);
  93.            
  94.             if (autorizzazionePD_mapping_list == null) {
  95.                 autorizzazionePD_mapping_list = new ArrayList<>();
  96.                 whereIsInUso.put(ErrorsHandlerCostant.AUTORIZZAZIONE_MAPPING, autorizzazionePD_mapping_list);
  97.             }
  98.             if (autorizzazionePD_list == null) {
  99.                 autorizzazionePD_list = new ArrayList<>();
  100.                 whereIsInUso.put(ErrorsHandlerCostant.AUTORIZZAZIONE, autorizzazionePD_list);
  101.             }
  102.             if (autorizzazionePA_mapping_list == null) {
  103.                 autorizzazionePA_mapping_list = new ArrayList<>();
  104.                 whereIsInUso.put(ErrorsHandlerCostant.AUTORIZZAZIONE_MAPPING_PA, autorizzazionePA_mapping_list);
  105.             }
  106.             if (autorizzazionePA_list == null) {
  107.                 autorizzazionePA_list = new ArrayList<>();
  108.                 whereIsInUso.put(ErrorsHandlerCostant.AUTORIZZAZIONE_PA, autorizzazionePA_list);
  109.             }
  110.             if (autorizzazionePA_mapping_modi_list == null) {
  111.                 autorizzazionePA_mapping_modi_list = new ArrayList<>();
  112.                 whereIsInUso.put(ErrorsHandlerCostant.AUTORIZZAZIONE_MAPPING_PA_MODI, autorizzazionePA_mapping_modi_list);
  113.             }
  114.             if (autorizzazionePA_modi_list == null) {
  115.                 autorizzazionePA_modi_list = new ArrayList<>();
  116.                 whereIsInUso.put(ErrorsHandlerCostant.AUTORIZZAZIONE_PA_MODI, autorizzazionePA_modi_list);
  117.             }
  118.            
  119.             if (autorizzazioneTokenPD_mapping_list == null) {
  120.                 autorizzazioneTokenPD_mapping_list = new ArrayList<>();
  121.                 whereIsInUso.put(ErrorsHandlerCostant.AUTORIZZAZIONE_TOKEN_MAPPING_PD, autorizzazioneTokenPD_mapping_list);
  122.             }
  123.             if (autorizzazioneTokenPD_list == null) {
  124.                 autorizzazioneTokenPD_list = new ArrayList<>();
  125.                 whereIsInUso.put(ErrorsHandlerCostant.AUTORIZZAZIONE_TOKEN_PD, autorizzazioneTokenPD_list);
  126.             }
  127.             if (autorizzazioneTokenPA_mapping_list == null) {
  128.                 autorizzazioneTokenPA_mapping_list = new ArrayList<>();
  129.                 whereIsInUso.put(ErrorsHandlerCostant.AUTORIZZAZIONE_TOKEN_MAPPING_PA, autorizzazioneTokenPA_mapping_list);
  130.             }
  131.             if (autorizzazioneTokenPA_list == null) {
  132.                 autorizzazioneTokenPA_list = new ArrayList<>();
  133.                 whereIsInUso.put(ErrorsHandlerCostant.AUTORIZZAZIONE_TOKEN_PA, autorizzazioneTokenPA_list);
  134.             }
  135.            
  136.             if (ruoliPD_mapping_list == null) {
  137.                 ruoliPD_mapping_list = new ArrayList<>();
  138.                 whereIsInUso.put(ErrorsHandlerCostant.RUOLI_MAPPING, ruoliPD_mapping_list);
  139.             }
  140.             if (ruoliPD_list == null) {
  141.                 ruoliPD_list = new ArrayList<>();
  142.                 whereIsInUso.put(ErrorsHandlerCostant.RUOLI, ruoliPD_list);
  143.             }
  144.             if (ruoliPA_mapping_list == null) {
  145.                 ruoliPA_mapping_list = new ArrayList<>();
  146.                 whereIsInUso.put(ErrorsHandlerCostant.RUOLI_MAPPING_PA, ruoliPA_mapping_list);
  147.             }
  148.             if (ruoliPA_list == null) {
  149.                 ruoliPA_list = new ArrayList<>();
  150.                 whereIsInUso.put(ErrorsHandlerCostant.RUOLI_PA, ruoliPA_list);
  151.             }
  152.            
  153.             if (ruoliTokenPD_mapping_list == null) {
  154.                 ruoliTokenPD_mapping_list = new ArrayList<>();
  155.                 whereIsInUso.put(ErrorsHandlerCostant.RUOLI_TOKEN_MAPPING_PD, ruoliPD_mapping_list);
  156.             }
  157.             if (ruoliTokenPD_list == null) {
  158.                 ruoliTokenPD_list = new ArrayList<>();
  159.                 whereIsInUso.put(ErrorsHandlerCostant.RUOLI_TOKEN_PD, ruoliTokenPD_list);
  160.             }
  161.             if (ruoliTokenPA_mapping_list == null) {
  162.                 ruoliTokenPA_mapping_list = new ArrayList<>();
  163.                 whereIsInUso.put(ErrorsHandlerCostant.RUOLI_TOKEN_MAPPING_PA, ruoliTokenPA_mapping_list);
  164.             }
  165.             if (ruoliTokenPA_list == null) {
  166.                 ruoliTokenPA_list = new ArrayList<>();
  167.                 whereIsInUso.put(ErrorsHandlerCostant.RUOLI_TOKEN_PA, ruoliTokenPA_list);
  168.             }
  169.             if (ruoliTokenPA_mapping_modi_list == null) {
  170.                 ruoliTokenPA_mapping_modi_list = new ArrayList<>();
  171.                 whereIsInUso.put(ErrorsHandlerCostant.RUOLI_TOKEN_MAPPING_PA_MODI, ruoliTokenPA_mapping_modi_list);
  172.             }
  173.             if (ruoliTokenPA_modi_list == null) {
  174.                 ruoliTokenPA_modi_list = new ArrayList<>();
  175.                 whereIsInUso.put(ErrorsHandlerCostant.RUOLI_TOKEN_PA_MODI, ruoliTokenPA_modi_list);
  176.             }
  177.            
  178.             if (porte_applicative_list == null) {
  179.                 porte_applicative_list = new ArrayList<>();
  180.                 whereIsInUso.put(ErrorsHandlerCostant.IN_USO_IN_PORTE_APPLICATIVE, porte_applicative_list);
  181.             }
  182.             if (porte_applicative_mapping_list == null) {
  183.                 porte_applicative_mapping_list = new ArrayList<>();
  184.                 whereIsInUso.put(ErrorsHandlerCostant.IN_USO_IN_MAPPING_EROGAZIONE_PA, porte_applicative_mapping_list);
  185.             }
  186.             if (ct_list == null) {
  187.                 ct_list = new ArrayList<>();
  188.                 whereIsInUso.put(ErrorsHandlerCostant.CONTROLLO_TRAFFICO, ct_list);
  189.             }
  190.             if (allarme_list == null) {
  191.                 allarme_list = new ArrayList<>();
  192.                 whereIsInUso.put(ErrorsHandlerCostant.ALLARMI, allarme_list);
  193.             }
  194.             if (trasformazionePD_mapping_list == null) {
  195.                 trasformazionePD_mapping_list = new ArrayList<>();
  196.                 whereIsInUso.put(ErrorsHandlerCostant.TRASFORMAZIONE_MAPPING_PD, trasformazionePD_mapping_list);
  197.             }
  198.             if (trasformazionePD_list == null) {
  199.                 trasformazionePD_list = new ArrayList<>();
  200.                 whereIsInUso.put(ErrorsHandlerCostant.TRASFORMAZIONE_PD, trasformazionePD_list);
  201.             }
  202.             if (trasformazionePA_mapping_list == null) {
  203.                 trasformazionePA_mapping_list = new ArrayList<>();
  204.                 whereIsInUso.put(ErrorsHandlerCostant.TRASFORMAZIONE_MAPPING_PA, trasformazionePA_mapping_list);
  205.             }
  206.             if (trasformazionePA_list == null) {
  207.                 trasformazionePA_list = new ArrayList<>();
  208.                 whereIsInUso.put(ErrorsHandlerCostant.TRASFORMAZIONE_PA, trasformazionePA_list);
  209.             }

  210.             // Porte delegate, autorizzazione
  211.             ISQLQueryObject sqlQueryObject = SQLObjectFactory.createSQLQueryObject(tipoDB);
  212.             sqlQueryObject.addFromTable(CostantiDB.PORTE_DELEGATE_SA);
  213.             sqlQueryObject.addFromTable(CostantiDB.PORTE_DELEGATE);
  214.             sqlQueryObject.addSelectField("nome_porta");
  215.             sqlQueryObject.setANDLogicOperator(true);
  216.             sqlQueryObject.addWhereCondition(CostantiDB.PORTE_DELEGATE_SA+".id_porta="+CostantiDB.PORTE_DELEGATE+".id");
  217.             sqlQueryObject.addWhereCondition("id_servizio_applicativo=?");
  218.             queryString = sqlQueryObject.createSQLQuery();
  219.             stmt = con.prepareStatement(queryString);
  220.             stmt.setLong(1, idServizioApplicativoLong);
  221.             risultato = stmt.executeQuery();
  222.             while (risultato.next()){
  223.                 String nome = risultato.getString("nome_porta");
  224.                 ResultPorta resultPorta = DBOggettiInUsoUtils.formatPortaDelegata(nome, tipoDB, con, normalizeObjectIds);
  225.                 if(resultPorta.mapping) {
  226.                     autorizzazionePD_mapping_list.add(resultPorta.label);
  227.                 }
  228.                 else {
  229.                     autorizzazionePD_list.add(resultPorta.label);
  230.                 }
  231.                 isInUso = true;
  232.             }
  233.             risultato.close();
  234.             stmt.close();
  235.            
  236.            
  237.             // Porte delegate, autorizzazione (token)
  238.             sqlQueryObject = SQLObjectFactory.createSQLQueryObject(tipoDB);
  239.             sqlQueryObject.addFromTable(CostantiDB.PORTE_DELEGATE_TOKEN_SA);
  240.             sqlQueryObject.addFromTable(CostantiDB.PORTE_DELEGATE);
  241.             sqlQueryObject.addSelectField("nome_porta");
  242.             sqlQueryObject.setANDLogicOperator(true);
  243.             sqlQueryObject.addWhereCondition(CostantiDB.PORTE_DELEGATE_TOKEN_SA+".id_porta="+CostantiDB.PORTE_DELEGATE+".id");
  244.             sqlQueryObject.addWhereCondition("id_servizio_applicativo=?");
  245.             queryString = sqlQueryObject.createSQLQuery();
  246.             stmt = con.prepareStatement(queryString);
  247.             stmt.setLong(1, idServizioApplicativoLong);
  248.             risultato = stmt.executeQuery();
  249.             while (risultato.next()){
  250.                 String nome = risultato.getString("nome_porta");
  251.                 ResultPorta resultPorta = DBOggettiInUsoUtils.formatPortaDelegata(nome, tipoDB, con, normalizeObjectIds);
  252.                 if(resultPorta.mapping) {
  253.                     autorizzazioneTokenPD_mapping_list.add(resultPorta.label);
  254.                 }
  255.                 else {
  256.                     autorizzazioneTokenPD_list.add(resultPorta.label);
  257.                 }
  258.                 isInUso = true;
  259.             }
  260.             risultato.close();
  261.             stmt.close();
  262.            
  263.            
  264.             // Porte applicative, autorizzazione
  265.             sqlQueryObject = SQLObjectFactory.createSQLQueryObject(tipoDB);
  266.             sqlQueryObject.addFromTable(CostantiDB.PORTE_APPLICATIVE_SA_AUTORIZZATI);
  267.             sqlQueryObject.addFromTable(CostantiDB.PORTE_APPLICATIVE);
  268.             sqlQueryObject.addSelectField("nome_porta");
  269.             sqlQueryObject.setANDLogicOperator(true);
  270.             sqlQueryObject.addWhereCondition(CostantiDB.PORTE_APPLICATIVE_SA_AUTORIZZATI+".id_porta="+CostantiDB.PORTE_APPLICATIVE+".id");
  271.             sqlQueryObject.addWhereCondition("id_servizio_applicativo=?");
  272.             queryString = sqlQueryObject.createSQLQuery();
  273.             stmt = con.prepareStatement(queryString);
  274.             stmt.setLong(1, idServizioApplicativoLong);
  275.             risultato = stmt.executeQuery();
  276.             while (risultato.next()){
  277.                 String nome = risultato.getString("nome_porta");
  278.                 ResultPorta resultPorta = DBOggettiInUsoUtils.formatPortaApplicativa(nome, tipoDB, con, normalizeObjectIds);
  279.                 if(resultPorta.mapping) {
  280.                     if(resultPorta.erogazioneModi)
  281.                         autorizzazionePA_mapping_modi_list.add(resultPorta.label);
  282.                     else
  283.                         autorizzazionePA_mapping_list.add(resultPorta.label);
  284.                 }
  285.                 else {
  286.                     if(resultPorta.erogazioneModi)
  287.                         autorizzazionePA_modi_list.add(resultPorta.label);
  288.                     else
  289.                         autorizzazionePA_list.add(resultPorta.label);
  290.                 }
  291.                 isInUso = true;
  292.             }
  293.             risultato.close();
  294.             stmt.close();
  295.            
  296.            
  297.             // Porte applicative, autorizzazione (token)
  298.             sqlQueryObject = SQLObjectFactory.createSQLQueryObject(tipoDB);
  299.             sqlQueryObject.addFromTable(CostantiDB.PORTE_APPLICATIVE_TOKEN_SA);
  300.             sqlQueryObject.addFromTable(CostantiDB.PORTE_APPLICATIVE);
  301.             sqlQueryObject.addSelectField("nome_porta");
  302.             sqlQueryObject.setANDLogicOperator(true);
  303.             sqlQueryObject.addWhereCondition(CostantiDB.PORTE_APPLICATIVE_TOKEN_SA+".id_porta="+CostantiDB.PORTE_APPLICATIVE+".id");
  304.             sqlQueryObject.addWhereCondition("id_servizio_applicativo=?");
  305.             queryString = sqlQueryObject.createSQLQuery();
  306.             stmt = con.prepareStatement(queryString);
  307.             stmt.setLong(1, idServizioApplicativoLong);
  308.             risultato = stmt.executeQuery();
  309.             while (risultato.next()){
  310.                 String nome = risultato.getString("nome_porta");
  311.                 ResultPorta resultPorta = DBOggettiInUsoUtils.formatPortaApplicativa(nome, tipoDB, con, normalizeObjectIds);
  312.                 if(resultPorta.mapping) {
  313.                     autorizzazioneTokenPA_mapping_list.add(resultPorta.label);
  314.                 }
  315.                 else {
  316.                     autorizzazioneTokenPA_list.add(resultPorta.label);
  317.                 }
  318.                 isInUso = true;
  319.             }
  320.             risultato.close();
  321.             stmt.close();

  322.            
  323.            
  324.             if(verificaRuoli) {
  325.                
  326.                 // Raccolgo prima i ruoli
  327.                 List<String> listRuoliSA = new ArrayList<>();
  328.                 sqlQueryObject = SQLObjectFactory.createSQLQueryObject(tipoDB);
  329.                 sqlQueryObject.addFromTable(CostantiDB.SERVIZI_APPLICATIVI);
  330.                 sqlQueryObject.addFromTable(CostantiDB.SERVIZI_APPLICATIVI_RUOLI);
  331.                 sqlQueryObject.addSelectField("ruolo");
  332.                 sqlQueryObject.setANDLogicOperator(true);
  333.                 sqlQueryObject.addWhereCondition(CostantiDB.SERVIZI_APPLICATIVI+".id=?");
  334.                 sqlQueryObject.addWhereCondition(CostantiDB.SERVIZI_APPLICATIVI_RUOLI+".id_servizio_applicativo="+CostantiDB.SERVIZI_APPLICATIVI+".id");
  335.                 queryString = sqlQueryObject.createSQLQuery();
  336.                 stmt = con.prepareStatement(queryString);
  337.                 stmt.setLong(1, idServizioApplicativoLong);
  338.                 risultato = stmt.executeQuery();
  339.                 while (risultato.next()){
  340.                     String ruolo = risultato.getString("ruolo");
  341.                     listRuoliSA.add(ruolo);
  342.                 }
  343.                 risultato.close();
  344.                 stmt.close();
  345.                
  346.                 if(!listRuoliSA.isEmpty()) {
  347.                
  348.                     _checkServizioApplicativo_ruoloInUsoInPorteDelegate(con, tipoDB, normalizeObjectIds,
  349.                             CostantiDB.PORTE_DELEGATE_RUOLI,
  350.                             listRuoliSA,
  351.                             ruoliPD_mapping_list, ruoliPD_list);
  352.                    
  353.                     _checkServizioApplicativo_ruoloInUsoInPorteDelegate(con, tipoDB, normalizeObjectIds,
  354.                             CostantiDB.PORTE_DELEGATE_TOKEN_RUOLI,
  355.                             listRuoliSA,
  356.                             ruoliTokenPD_mapping_list, ruoliTokenPD_list);
  357.                                    
  358.                     boolean isInUsoRuoli = _checkServizioApplicativo_ruoloInUsoInPorteApplicative(con, tipoDB, normalizeObjectIds,
  359.                             CostantiDB.PORTE_APPLICATIVE_RUOLI,
  360.                             listRuoliSA,
  361.                             ruoliPA_mapping_list, ruoliPA_list,
  362.                             ruoliPA_mapping_list, ruoliPA_list);
  363.                     if(isInUsoRuoli) {
  364.                         isInUso = true;
  365.                     }
  366.                    
  367.                     boolean isInUsoRuoliToken = _checkServizioApplicativo_ruoloInUsoInPorteApplicative(con, tipoDB, normalizeObjectIds,
  368.                             CostantiDB.PORTE_APPLICATIVE_TOKEN_RUOLI,
  369.                             listRuoliSA,
  370.                             ruoliTokenPA_mapping_list, ruoliTokenPA_list,
  371.                             ruoliTokenPA_mapping_modi_list, ruoliTokenPA_modi_list);
  372.                     if(isInUsoRuoliToken) {
  373.                         isInUso = true;
  374.                     }
  375.                 }
  376.             }
  377.            


  378.             // Porte applicative
  379.             sqlQueryObject = SQLObjectFactory.createSQLQueryObject(tipoDB);
  380.             sqlQueryObject.addFromTable(CostantiDB.PORTE_APPLICATIVE_SA);
  381.             sqlQueryObject.addFromTable(CostantiDB.PORTE_APPLICATIVE);
  382.             sqlQueryObject.addSelectField("*");
  383.             sqlQueryObject.setANDLogicOperator(true);
  384.             sqlQueryObject.addWhereCondition(CostantiDB.PORTE_APPLICATIVE_SA+".id_porta="+CostantiDB.PORTE_APPLICATIVE+".id");
  385.             sqlQueryObject.addWhereCondition("id_servizio_applicativo=?");
  386.             queryString = sqlQueryObject.createSQLQuery();
  387.             stmt = con.prepareStatement(queryString);
  388.             stmt.setLong(1, idServizioApplicativoLong);
  389.             risultato = stmt.executeQuery();
  390.             while (risultato.next()){
  391.                 String nome = risultato.getString("nome_porta");
  392.                 ResultPorta resultPorta = DBOggettiInUsoUtils.formatPortaApplicativa(nome, tipoDB, con, normalizeObjectIds);
  393.                 if(resultPorta.mapping) {
  394.                     porte_applicative_mapping_list.add(resultPorta.label);
  395.                 }
  396.                 else {
  397.                     porte_applicative_list.add(resultPorta.label);
  398.                 }
  399.                 isInUso = true;
  400.             }
  401.             risultato.close();
  402.             stmt.close();

  403.            
  404.             // Controllo che il servizio aplicativo non sia associato a policy di controllo del traffico o allarmi
  405.            
  406.             int max = 2;
  407.             if(!CostantiDB.isAllarmiEnabled()) {
  408.                 max=1;
  409.             }
  410.             for (int i = 0; i < max; i++) {
  411.                
  412.                 String tabella = CostantiDB.CONTROLLO_TRAFFICO_ACTIVE_POLICY;
  413.                 String identificativo_column = "active_policy_id";
  414.                 String alias_column = "policy_alias";
  415.                 List<String> list = ct_list;
  416.                 String oggetto = "Policy";
  417.                 boolean allarmi = false;
  418.                 if(i==1) {
  419.                     tabella = CostantiDB.ALLARMI;
  420.                     identificativo_column = "nome";
  421.                     alias_column = "alias";
  422.                     list = allarme_list;
  423.                     oggetto = "Allarme";
  424.                     allarmi=true;
  425.                 }
  426.                
  427.                 sqlQueryObject = SQLObjectFactory.createSQLQueryObject(tipoDB);
  428.                 sqlQueryObject.addFromTable(tabella);
  429.                 sqlQueryObject.addSelectField(identificativo_column);
  430.                 sqlQueryObject.addSelectField(alias_column);
  431.                 sqlQueryObject.addSelectField("filtro_ruolo");
  432.                 sqlQueryObject.addSelectField("filtro_porta");
  433.                 sqlQueryObject.setANDLogicOperator(false); // OR
  434.                 sqlQueryObject.addWhereCondition(true,
  435.                         tabella+".filtro_tipo_fruitore = ?",
  436.                         tabella+".filtro_nome_fruitore = ?",
  437.                         tabella+".filtro_sa_fruitore = ?");
  438.                 if(!allarmi) {
  439.                     sqlQueryObject.addWhereCondition(true,
  440.                             tabella+".filtro_tipo_erogatore = ?",
  441.                             tabella+".filtro_nome_erogatore = ?",
  442.                             tabella+".filtro_sa_erogatore = ?");
  443.                 }
  444.                 sqlQueryObject.addOrderBy("filtro_ruolo");
  445.                 sqlQueryObject.addOrderBy("filtro_porta");
  446.                 queryString = sqlQueryObject.createSQLQuery();
  447.                 stmt = con.prepareStatement(queryString);
  448.                 int index = 1;
  449.                 stmt.setString(index++, idServizioApplicativo.getIdSoggettoProprietario().getTipo());
  450.                 stmt.setString(index++, idServizioApplicativo.getIdSoggettoProprietario().getNome());
  451.                 stmt.setString(index++, idServizioApplicativo.getNome());
  452.                 if(!allarmi) {
  453.                     stmt.setString(index++, idServizioApplicativo.getIdSoggettoProprietario().getTipo());
  454.                     stmt.setString(index++, idServizioApplicativo.getIdSoggettoProprietario().getNome());
  455.                     stmt.setString(index++, idServizioApplicativo.getNome());
  456.                 }
  457.                 risultato = stmt.executeQuery();
  458.                 while (risultato.next()) {
  459.                    
  460.                     String alias = risultato.getString(alias_column);
  461.                     if(alias== null || "".equals(alias)) {
  462.                         alias = risultato.getString(identificativo_column);
  463.                     }
  464.                    
  465.                     String nomePorta = risultato.getString("filtro_porta");
  466.                     String filtro_ruolo = risultato.getString("filtro_ruolo");
  467.                     if(nomePorta!=null) {
  468.                         String tipo = null;
  469.                         String label = null;
  470.                         if("delegata".equals(filtro_ruolo)) {
  471.                             try {
  472.                                 ResultPorta resultPorta = DBOggettiInUsoUtils.formatPortaDelegata(nomePorta, tipoDB, con, normalizeObjectIds);
  473.                                 if(resultPorta.mapping) {
  474.                                     label = "Fruizione di Servizio "+ resultPorta.label;
  475.                                 }
  476.                             }catch(Exception e) {
  477.                                 tipo = "Outbound";
  478.                             }
  479.                         }
  480.                         else if("applicativa".equals(filtro_ruolo)) {
  481.                             try {
  482.                                 ResultPorta resultPorta = DBOggettiInUsoUtils.formatPortaApplicativa(nomePorta, tipoDB, con, normalizeObjectIds);
  483.                                 if(resultPorta.mapping) {
  484.                                     label = "Erogazione di Servizio "+ resultPorta.label;
  485.                                 }
  486.                             }catch(Exception e) {
  487.                                 tipo = "Inbound";
  488.                             }
  489.                         }
  490.                         else {
  491.                             tipo = filtro_ruolo;
  492.                         }
  493.                         if(label==null) {
  494.                             list.add(oggetto+" '"+alias+"' attiva nella porta '"+tipo+"' '"+nomePorta+"' ");
  495.                         }
  496.                         else {
  497.                             list.add(oggetto+" '"+alias+"' attiva nella "+label);
  498.                         }
  499.                     }
  500.                     else {
  501.                         list.add(oggetto+" '"+alias+"'");
  502.                     }
  503.    
  504.                     isInUso = true;
  505.                 }
  506.                 risultato.close();
  507.                 stmt.close();
  508.             }
  509.            
  510.            
  511.            
  512.             // Porte delegate, trasformazioni
  513.             sqlQueryObject = SQLObjectFactory.createSQLQueryObject(tipoDB);
  514.             sqlQueryObject.addFromTable(CostantiDB.PORTE_DELEGATE_TRASFORMAZIONI_SA);
  515.             sqlQueryObject.addFromTable(CostantiDB.PORTE_DELEGATE_TRASFORMAZIONI);
  516.             sqlQueryObject.addFromTable(CostantiDB.PORTE_DELEGATE);
  517.             sqlQueryObject.addSelectField("nome_porta");
  518.             sqlQueryObject.setANDLogicOperator(true);
  519.             sqlQueryObject.addWhereCondition(CostantiDB.PORTE_DELEGATE_TRASFORMAZIONI+".id_porta="+CostantiDB.PORTE_DELEGATE+".id");
  520.             sqlQueryObject.addWhereCondition(CostantiDB.PORTE_DELEGATE_TRASFORMAZIONI_SA+".id_trasformazione="+CostantiDB.PORTE_DELEGATE_TRASFORMAZIONI+".id");
  521.             sqlQueryObject.addWhereCondition("id_servizio_applicativo=?");
  522.             queryString = sqlQueryObject.createSQLQuery();
  523.             stmt = con.prepareStatement(queryString);
  524.             stmt.setLong(1, idServizioApplicativoLong);
  525.             risultato = stmt.executeQuery();
  526.             while (risultato.next()){
  527.                 String nome = risultato.getString("nome_porta");
  528.                 ResultPorta resultPorta = DBOggettiInUsoUtils.formatPortaDelegata(nome, tipoDB, con, normalizeObjectIds);
  529.                 if(resultPorta.mapping) {
  530.                     trasformazionePD_mapping_list.add(resultPorta.label);
  531.                 }
  532.                 else {
  533.                     trasformazionePD_list.add(resultPorta.label);
  534.                 }
  535.                 isInUso = true;
  536.             }
  537.             risultato.close();
  538.             stmt.close();
  539.            
  540.            
  541.            
  542.             // Porte applicative, trasformazioni
  543.             sqlQueryObject = SQLObjectFactory.createSQLQueryObject(tipoDB);
  544.             sqlQueryObject.addFromTable(CostantiDB.PORTE_APPLICATIVE_TRASFORMAZIONI_SA);
  545.             sqlQueryObject.addFromTable(CostantiDB.PORTE_APPLICATIVE_TRASFORMAZIONI);
  546.             sqlQueryObject.addFromTable(CostantiDB.PORTE_APPLICATIVE);
  547.             sqlQueryObject.addSelectField("nome_porta");
  548.             sqlQueryObject.setANDLogicOperator(true);
  549.             sqlQueryObject.addWhereCondition(CostantiDB.PORTE_APPLICATIVE_TRASFORMAZIONI+".id_porta="+CostantiDB.PORTE_APPLICATIVE+".id");
  550.             sqlQueryObject.addWhereCondition(CostantiDB.PORTE_APPLICATIVE_TRASFORMAZIONI_SA+".id_trasformazione="+CostantiDB.PORTE_APPLICATIVE_TRASFORMAZIONI+".id");
  551.             sqlQueryObject.addWhereCondition("id_servizio_applicativo=?");
  552.             queryString = sqlQueryObject.createSQLQuery();
  553.             stmt = con.prepareStatement(queryString);
  554.             stmt.setLong(1, idServizioApplicativoLong);
  555.             risultato = stmt.executeQuery();
  556.             while (risultato.next()){
  557.                 String nome = risultato.getString("nome_porta");
  558.                 ResultPorta resultPorta = DBOggettiInUsoUtils.formatPortaApplicativa(nome, tipoDB, con, normalizeObjectIds);
  559.                 if(resultPorta.mapping) {
  560.                     trasformazionePA_mapping_list.add(resultPorta.label);
  561.                 }
  562.                 else {
  563.                     trasformazionePA_list.add(resultPorta.label);
  564.                 }
  565.                 isInUso = true;
  566.             }
  567.             risultato.close();
  568.             stmt.close();
  569.            
  570.            
  571.            
  572.             return isInUso;

  573.         } catch (Exception se) {
  574.             throw new UtilsException("[DBOggettiInUsoUtils::" + nomeMetodo + "] Exception: " + se.getMessage(),se);
  575.         } finally {
  576.             // Chiudo statement and resultset
  577.             JDBCUtilities.closeResources(risultato2, stmt2);
  578.             JDBCUtilities.closeResources(risultato, stmt);
  579.         }
  580.     }
  581.    
  582.     private static boolean _checkServizioApplicativo_ruoloInUsoInPorteDelegate(Connection con, String tipoDB, boolean normalizeObjectIds,
  583.             String nomeTabella,
  584.             List<String> listRuoliSA,
  585.             List<String> ruoliPD_mapping_list, List<String> ruoliPD_list) throws Exception {
  586.         boolean isInUso = false;
  587.         PreparedStatement stmt = null;
  588.         ResultSet risultato = null;
  589.         try {
  590.            
  591.             List<String> distinctPorteDelegate = new ArrayList<>();
  592.             List<String> verificaPorteDelegateAll = new ArrayList<>();
  593.            
  594.             for (String ruolo : listRuoliSA) {
  595.                 ISQLQueryObject sqlQueryObject = SQLObjectFactory.createSQLQueryObject(tipoDB);
  596.                 sqlQueryObject.addFromTable(nomeTabella);
  597.                 sqlQueryObject.addFromTable(CostantiDB.PORTE_DELEGATE);
  598.                 sqlQueryObject.addSelectField("nome_porta");
  599.                 sqlQueryObject.addSelectField("ruoli_match");
  600.                 sqlQueryObject.setANDLogicOperator(true);
  601.                 sqlQueryObject.addWhereCondition(nomeTabella+".id_porta="+CostantiDB.PORTE_DELEGATE+".id");
  602.                 sqlQueryObject.addWhereCondition(nomeTabella+".ruolo=?");
  603.                 String queryString = sqlQueryObject.createSQLQuery();
  604.                 stmt = con.prepareStatement(queryString);
  605.                 stmt.setString(1, ruolo);
  606.                 risultato = stmt.executeQuery();
  607.                 while (risultato.next()){
  608.                     String nome = risultato.getString("nome_porta");
  609.                     String ruolo_match = risultato.getString("ruoli_match");
  610.                     if(RuoloTipoMatch.ANY.getValue().equals(ruolo_match)) {
  611.                         if(distinctPorteDelegate.contains(nome)) {
  612.                             continue;
  613.                         }
  614.                         else {
  615.                             distinctPorteDelegate.add(nome);
  616.                         }
  617.                         ResultPorta resultPorta = DBOggettiInUsoUtils.formatPortaDelegata(nome, tipoDB, con, normalizeObjectIds);
  618.                         if(resultPorta.mapping) {
  619.                             ruoliPD_mapping_list.add(resultPorta.label);
  620.                         }
  621.                         else {
  622.                             ruoliPD_list.add(resultPorta.label);
  623.                         }
  624.                         isInUso = true;
  625.                     }
  626.                     else {
  627.                         // devo verificare tutti i ruoli richiesti
  628.                         if(verificaPorteDelegateAll.contains(nome)) {
  629.                             continue;
  630.                         }
  631.                         else {
  632.                             verificaPorteDelegateAll.add(nome);
  633.                         }
  634.                     }
  635.                 }
  636.                 risultato.close();
  637.                 stmt.close();  
  638.             }
  639.            
  640.             // autorizzazione 'all'
  641.             if(!verificaPorteDelegateAll.isEmpty()) {
  642.                 for (String nome : verificaPorteDelegateAll) {
  643.                    
  644.                     // Raccolgo prima i ruoli della porta
  645.                     List<String> listRuoliPorta = new ArrayList<>();
  646.                     ISQLQueryObject sqlQueryObject = SQLObjectFactory.createSQLQueryObject(tipoDB);
  647.                     sqlQueryObject.addFromTable(CostantiDB.PORTE_DELEGATE);
  648.                     sqlQueryObject.addFromTable(nomeTabella);
  649.                     sqlQueryObject.addSelectField("ruolo");
  650.                     sqlQueryObject.setANDLogicOperator(true);
  651.                     sqlQueryObject.addWhereCondition(CostantiDB.PORTE_DELEGATE+".nome_porta=?");
  652.                     sqlQueryObject.addWhereCondition(nomeTabella+".id_porta="+CostantiDB.PORTE_DELEGATE+".id");
  653.                     String queryString = sqlQueryObject.createSQLQuery();
  654.                     stmt = con.prepareStatement(queryString);
  655.                     stmt.setString(1, nome);
  656.                     risultato = stmt.executeQuery();
  657.                     while (risultato.next()){
  658.                         String ruolo = risultato.getString("ruolo");
  659.                         listRuoliPorta.add(ruolo);
  660.                     }
  661.                     risultato.close();
  662.                     stmt.close();
  663.                    
  664.                     if(!listRuoliPorta.isEmpty()) {
  665.                         boolean match = true;
  666.                         for (String ruoloPorta : listRuoliPorta) {
  667.                             if(!listRuoliSA.contains(ruoloPorta)) {
  668.                                 match = false;
  669.                                 break;
  670.                             }
  671.                         }
  672.                         if(match) {
  673.                             if(distinctPorteDelegate.contains(nome)) {
  674.                                 continue;
  675.                             }
  676.                             else {
  677.                                 distinctPorteDelegate.add(nome);
  678.                             }
  679.                             ResultPorta resultPorta = DBOggettiInUsoUtils.formatPortaDelegata(nome, tipoDB, con, normalizeObjectIds);
  680.                             if(resultPorta.mapping) {
  681.                                 ruoliPD_mapping_list.add(resultPorta.label);
  682.                             }
  683.                             else {
  684.                                 ruoliPD_list.add(resultPorta.label);
  685.                             }
  686.                             isInUso = true;
  687.                         }
  688.                     }
  689.                    
  690.                 }
  691.             }
  692.            
  693.         } finally {
  694.             // Chiudo statement and resultset
  695.             try {
  696.                 if (risultato != null) {
  697.                     risultato.close();
  698.                 }
  699.             } catch (Exception e) {
  700.                 // ignore
  701.             }
  702.             try {
  703.                 if (stmt != null) {
  704.                     stmt.close();
  705.                 }
  706.             } catch (Exception e) {
  707.                 // ignore
  708.             }
  709.         }
  710.         return isInUso;
  711.     }
  712.    
  713.     private static boolean _checkServizioApplicativo_ruoloInUsoInPorteApplicative(Connection con, String tipoDB, boolean normalizeObjectIds,
  714.             String nomeTabella,
  715.             List<String> listRuoliSA,
  716.             List<String> ruoliPA_mapping_list, List<String> ruoliPA_list,
  717.             List<String> ruoliPA_mapping_modi_list, List<String> ruoliPA_modi_list) throws Exception {
  718.         boolean isInUso = false;
  719.         PreparedStatement stmt = null;
  720.         ResultSet risultato = null;
  721.         try {
  722.            
  723.             List<String> distinctPorteApplicative = new ArrayList<>();
  724.             List<String> verificaPorteApplicativeAll = new ArrayList<>();
  725.            
  726.             for (String ruolo : listRuoliSA) {
  727.                 ISQLQueryObject sqlQueryObject = SQLObjectFactory.createSQLQueryObject(tipoDB);
  728.                 sqlQueryObject.addFromTable(nomeTabella);
  729.                 sqlQueryObject.addFromTable(CostantiDB.PORTE_APPLICATIVE);
  730.                 sqlQueryObject.addSelectField("nome_porta");
  731.                 sqlQueryObject.addSelectField("ruoli_match");
  732.                 sqlQueryObject.setANDLogicOperator(true);
  733.                 sqlQueryObject.addWhereCondition(nomeTabella+".id_porta="+CostantiDB.PORTE_APPLICATIVE+".id");
  734.                 sqlQueryObject.addWhereCondition(nomeTabella+".ruolo=?");
  735.                 String queryString = sqlQueryObject.createSQLQuery();
  736.                 stmt = con.prepareStatement(queryString);
  737.                 stmt.setString(1, ruolo);
  738.                 risultato = stmt.executeQuery();
  739.                 while (risultato.next()){
  740.                     String nome = risultato.getString("nome_porta");
  741.                     String ruolo_match = risultato.getString("ruoli_match");
  742.                     if(RuoloTipoMatch.ANY.getValue().equals(ruolo_match)) {
  743.                         if(distinctPorteApplicative.contains(nome)) {
  744.                             continue;
  745.                         }
  746.                         else {
  747.                             distinctPorteApplicative.add(nome);
  748.                         }
  749.                         ResultPorta resultPorta = DBOggettiInUsoUtils.formatPortaApplicativa(nome, tipoDB, con, normalizeObjectIds);
  750.                         if(resultPorta.mapping) {
  751.                             if(resultPorta.erogazioneModi)
  752.                                 ruoliPA_mapping_modi_list.add(resultPorta.label);
  753.                             else
  754.                                 ruoliPA_mapping_list.add(resultPorta.label);
  755.                         }
  756.                         else {
  757.                             if(resultPorta.erogazioneModi)
  758.                                 ruoliPA_modi_list.add(resultPorta.label);
  759.                             else
  760.                                 ruoliPA_list.add(resultPorta.label);
  761.                         }
  762.                         isInUso = true;
  763.                     }
  764.                     else {
  765.                         // devo verificare tutti i ruoli richiesti
  766.                         if(verificaPorteApplicativeAll.contains(nome)) {
  767.                             continue;
  768.                         }
  769.                         else {
  770.                             verificaPorteApplicativeAll.add(nome);
  771.                         }
  772.                     }
  773.                 }
  774.                 risultato.close();
  775.                 stmt.close();  
  776.             }
  777.            
  778.             // autorizzazione 'all'
  779.             if(!verificaPorteApplicativeAll.isEmpty()) {
  780.                 for (String nome : verificaPorteApplicativeAll) {
  781.                    
  782.                     // Raccolgo prima i ruoli della porta
  783.                     List<String> listRuoliPorta = new ArrayList<>();
  784.                     ISQLQueryObject sqlQueryObject = SQLObjectFactory.createSQLQueryObject(tipoDB);
  785.                     sqlQueryObject.addFromTable(CostantiDB.PORTE_APPLICATIVE);
  786.                     sqlQueryObject.addFromTable(nomeTabella);
  787.                     sqlQueryObject.addSelectField("ruolo");
  788.                     sqlQueryObject.setANDLogicOperator(true);
  789.                     sqlQueryObject.addWhereCondition(CostantiDB.PORTE_APPLICATIVE+".nome_porta=?");
  790.                     sqlQueryObject.addWhereCondition(nomeTabella+".id_porta="+CostantiDB.PORTE_APPLICATIVE+".id");
  791.                     String queryString = sqlQueryObject.createSQLQuery();
  792.                     stmt = con.prepareStatement(queryString);
  793.                     stmt.setString(1, nome);
  794.                     risultato = stmt.executeQuery();
  795.                     while (risultato.next()){
  796.                         String ruolo = risultato.getString("ruolo");
  797.                         listRuoliPorta.add(ruolo);
  798.                     }
  799.                     risultato.close();
  800.                     stmt.close();
  801.                    
  802.                     if(!listRuoliPorta.isEmpty()) {
  803.                         boolean match = true;
  804.                         for (String ruoloPorta : listRuoliPorta) {
  805.                             if(!listRuoliSA.contains(ruoloPorta)) {
  806.                                 match = false;
  807.                                 break;
  808.                             }
  809.                         }
  810.                         if(match) {
  811.                             if(distinctPorteApplicative.contains(nome)) {
  812.                                 continue;
  813.                             }
  814.                             else {
  815.                                 distinctPorteApplicative.add(nome);
  816.                             }
  817.                             ResultPorta resultPorta = DBOggettiInUsoUtils.formatPortaApplicativa(nome, tipoDB, con, normalizeObjectIds);
  818.                             if(resultPorta.mapping) {
  819.                                 if(resultPorta.erogazioneModi)
  820.                                     ruoliPA_mapping_modi_list.add(resultPorta.label);
  821.                                 else
  822.                                     ruoliPA_mapping_list.add(resultPorta.label);
  823.                             }
  824.                             else {
  825.                                 if(resultPorta.erogazioneModi)
  826.                                     ruoliPA_modi_list.add(resultPorta.label);
  827.                                 else
  828.                                     ruoliPA_list.add(resultPorta.label);
  829.                             }
  830.                             isInUso = true;
  831.                         }
  832.                     }
  833.                    
  834.                 }
  835.             }
  836.         } finally {
  837.             // Chiudo statement and resultset
  838.             try {
  839.                 if (risultato != null) {
  840.                     risultato.close();
  841.                 }
  842.             } catch (Exception e) {
  843.                 // ignore
  844.             }
  845.             try {
  846.                 if (stmt != null) {
  847.                     stmt.close();
  848.                 }
  849.             } catch (Exception e) {
  850.                 // ignore
  851.             }
  852.         }
  853.         return isInUso;
  854.     }

  855.     protected static String toString(IDServizioApplicativo idServizioApplicativo, Map<ErrorsHandlerCostant, List<String>> whereIsInUso, boolean prefix, String separator, boolean normalizeObjectIds){
  856.        
  857.         StringBuilder bf = new StringBuilder();
  858.         if(normalizeObjectIds) {
  859.             try {
  860.                 String protocollo = ProtocolFactoryManager.getInstance().getProtocolByOrganizationType(idServizioApplicativo.getIdSoggettoProprietario().getTipo());
  861.                 String labelSA = DBOggettiInUsoUtils.getProtocolPrefix(protocollo)+idServizioApplicativo.getNome()+DBOggettiInUsoUtils.getSubjectSuffix(protocollo, idServizioApplicativo.getIdSoggettoProprietario());
  862.                 bf.append(labelSA);
  863.             }catch(Exception e) {
  864.                 bf.append(idServizioApplicativo.getIdSoggettoProprietario().toString()+"_"+idServizioApplicativo.getNome());
  865.             }
  866.         }
  867.         else {
  868.             bf.append(idServizioApplicativo.getIdSoggettoProprietario().toString()+"_"+idServizioApplicativo.getNome());
  869.         }
  870.        
  871.         Set<ErrorsHandlerCostant> keys = whereIsInUso.keySet();
  872.         String msg = "Applicativo '" +bf.toString() +"' non eliminabile perch&egrave; :"+separator;
  873.         if(prefix==false){
  874.             msg = "";
  875.         }
  876.         String separatorCategorie = "";
  877.         if(whereIsInUso.size()>1) {
  878.             separatorCategorie = separator;
  879.         }
  880.         for (ErrorsHandlerCostant key : keys) {
  881.             List<String> messages = whereIsInUso.get(key);

  882.             if ( messages!=null && messages.size() > 0) {
  883.                 msg += separatorCategorie;
  884.             }
  885.            
  886.             switch (key) {
  887.             case AUTORIZZAZIONE_MAPPING:
  888.                 if ( messages!=null && messages.size() > 0) {
  889.                     msg += "utilizzato nel Controllo degli Accessi (Autorizzazione Trasporto - Richiedenti Autorizzati) delle Fruizioni: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  890.                 }
  891.                 break;
  892.             case AUTORIZZAZIONE:
  893.                 if ( messages!=null && messages.size() > 0) {
  894.                     msg += "utilizzato nelle Porte Outbound (Controllo degli Accessi - Autorizzazione Trasporto -  Richiedenti Autorizzati): " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  895.                 }
  896.                 break;
  897.             case AUTORIZZAZIONE_MAPPING_PA:
  898.                 if ( messages!=null && messages.size() > 0) {
  899.                     msg += "utilizzato nel Controllo degli Accessi (Autorizzazione Trasporto - Richiedenti Autorizzati) delle Erogazioni: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  900.                 }
  901.                 break;
  902.             case AUTORIZZAZIONE_PA:
  903.                 if ( messages!=null && messages.size() > 0) {
  904.                     msg += "utilizzato nelle Porte Inbound (Controllo degli Accessi - Autorizzazione Trasporto - Richiedenti Autorizzati): " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  905.                 }
  906.                 break;
  907.             case AUTORIZZAZIONE_MAPPING_PA_MODI:
  908.                 if ( messages!=null && messages.size() > 0) {
  909.                     msg += "utilizzato nel Controllo degli Accessi (Autorizzazione Messaggio - Richiedenti Autorizzati) delle Erogazioni: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  910.                 }
  911.                 break;
  912.             case AUTORIZZAZIONE_PA_MODI:
  913.                 if ( messages!=null && messages.size() > 0) {
  914.                     msg += "utilizzato nelle Porte Inbound (Controllo degli Accessi - Autorizzazione Messaggio - Richiedenti Autorizzati): " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  915.                 }
  916.                 break;
  917.                
  918.             case AUTORIZZAZIONE_TOKEN_MAPPING_PD:
  919.                 if ( messages!=null && messages.size() > 0) {
  920.                     msg += "utilizzato nel Controllo degli Accessi (Autorizzazione Token - Richiedenti Autorizzati) delle Fruizioni: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  921.                 }
  922.                 break;
  923.             case AUTORIZZAZIONE_TOKEN_PD:
  924.                 if ( messages!=null && messages.size() > 0) {
  925.                     msg += "utilizzato nelle Porte Outbound (Controllo degli Accessi - Autorizzazione Token - Richiedenti Autorizzati): " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  926.                 }
  927.                 break;
  928.             case AUTORIZZAZIONE_TOKEN_MAPPING_PA:
  929.                 if ( messages!=null && messages.size() > 0) {
  930.                     msg += "utilizzato nel Controllo degli Accessi (Autorizzazione Token - Richiedenti Autorizzati) delle Erogazioni: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  931.                 }
  932.                 break;
  933.             case AUTORIZZAZIONE_TOKEN_PA:
  934.                 if ( messages!=null && messages.size() > 0) {
  935.                     msg += "utilizzato nelle Porte Inbound (Controllo degli Accessi - Autorizzazione Token - Richiedenti Autorizzati): " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  936.                 }
  937.                 break;
  938.                
  939.             case RUOLI_MAPPING:
  940.                 if ( messages!=null && messages.size() > 0) {
  941.                     msg += "compatibile con l'Autorizzazione Trasporto per Ruoli indicata nel Controllo degli Accessi delle Fruizioni: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  942.                 }
  943.                 break;
  944.             case RUOLI:
  945.                 if ( messages!=null && messages.size() > 0) {
  946.                     msg += "compatibile con l'Autorizzazione Trasporto per Ruoli indicata nel Controllo degli Accessi delle Porte Outbound: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  947.                 }
  948.                 break;
  949.             case RUOLI_MAPPING_PA:
  950.                 if ( messages!=null && messages.size() > 0) {
  951.                     msg += "compatibile con l'Autorizzazione Trasporto per Ruoli indicata nel Controllo degli Accessi delle Erogazioni: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  952.                 }
  953.                 break;
  954.             case RUOLI_PA:
  955.                 if ( messages!=null && messages.size() > 0) {
  956.                     msg += "compatibile con l'Autorizzazione Trasporto per Ruoli indicata nel Controllo degli Accessi delle Porte Inbound: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  957.                 }
  958.                 break;
  959.                
  960.             case RUOLI_TOKEN_MAPPING_PD:
  961.                 if ( messages!=null && messages.size() > 0) {
  962.                     msg += "compatibile con l'Autorizzazione Token per Ruoli indicata nel Controllo degli Accessi delle Fruizioni: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  963.                 }
  964.                 break;
  965.             case RUOLI_TOKEN_PD:
  966.                 if ( messages!=null && messages.size() > 0) {
  967.                     msg += "compatibile con l'Autorizzazione Token per Ruoli indicata nel Controllo degli Accessi delle Porte Outbound: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  968.                 }
  969.                 break;
  970.             case RUOLI_TOKEN_MAPPING_PA:
  971.                 if ( messages!=null && messages.size() > 0) {
  972.                     msg += "compatibile con l'Autorizzazione Token per Ruoli indicata nel Controllo degli Accessi delle Erogazioni: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  973.                 }
  974.                 break;
  975.             case RUOLI_TOKEN_PA:
  976.                 if ( messages!=null && messages.size() > 0) {
  977.                     msg += "compatibile con l'Autorizzazione Token per Ruoli indicata nel Controllo degli Accessi delle Porte Inbound: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  978.                 }
  979.                 break;
  980.             case RUOLI_TOKEN_MAPPING_PA_MODI:
  981.                 if ( messages!=null && messages.size() > 0) {
  982.                     msg += "compatibile con l'Autorizzazione Messaggio per Ruoli indicata nel Controllo degli Accessi delle Erogazioni: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  983.                 }
  984.                 break;
  985.             case RUOLI_TOKEN_PA_MODI:
  986.                 if ( messages!=null && messages.size() > 0) {
  987.                     msg += "compatibile con l'Autorizzazione Messaggio per Ruoli indicata nel Controllo degli Accessi delle Porte Inbound: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  988.                 }
  989.                 break;
  990.                
  991.             case IN_USO_IN_MAPPING_EROGAZIONE_PA:
  992.                 if ( messages!=null && messages.size() > 0 ) {
  993.                     msg += "utilizzato come applicativo server nei connettori delle Erogazioni: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  994.                 }
  995.                 break;
  996.             case IN_USO_IN_PORTE_APPLICATIVE:
  997.                 if ( messages!=null && messages.size() > 0 ) {
  998.                     msg += "in uso in Porte Inbound: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  999.                 }
  1000.                 break;
  1001.             case CONTROLLO_TRAFFICO:
  1002.                 if ( messages!=null && messages.size() > 0 ) {
  1003.                     msg += "utilizzato in policy di Rate Limiting: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  1004.                 }
  1005.                 break;
  1006.             case ALLARMI:
  1007.                 if ( messages!=null && messages.size() > 0 ) {
  1008.                     msg += "utilizzato in Allarmi: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  1009.                 }
  1010.                 break;
  1011.             case TRASFORMAZIONE_MAPPING_PD:
  1012.                 if ( messages!=null && messages.size() > 0) {
  1013.                     msg += "utilizzato nel criterio di applicabilità della Trasformazione (Applicativi) per le Fruizioni: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  1014.                 }
  1015.                 break;
  1016.             case TRASFORMAZIONE_PD:
  1017.                 if ( messages!=null && messages.size() > 0) {
  1018.                     msg += "utilizzato nelle Porte Outbound (Criterio di applicabilità della Trasformazione - Applicativi): " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  1019.                 }
  1020.                 break;
  1021.             case TRASFORMAZIONE_MAPPING_PA:
  1022.                 if ( messages!=null && messages.size() > 0) {
  1023.                     msg += "utilizzato nel criterio di applicabilità della Trasformazione (Applicativi) per le Erogazioni: " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  1024.                 }
  1025.                 break;
  1026.             case TRASFORMAZIONE_PA:
  1027.                 if ( messages!=null && messages.size() > 0) {
  1028.                     msg += "utilizzato nelle Porte Inbound (Criterio di applicabilità della Trasformazione - Applicativi): " + DBOggettiInUsoUtils.formatList(messages,separator) + separator;
  1029.                 }
  1030.                 break;
  1031.             default:
  1032.                 msg += "utilizzato in oggetto non codificato ("+key+")"+separator;
  1033.                 break;
  1034.             }

  1035.         }// chiudo for

  1036.         return msg;
  1037.     }
  1038.    
  1039. }