MsgDiagnosticoOpenSPCoopProtocolAppender.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.pdd.logger;

  21. import java.sql.Connection;
  22. import java.util.Enumeration;

  23. import org.openspcoop2.core.commons.CoreException;
  24. import org.openspcoop2.core.config.OpenspcoopAppender;
  25. import org.openspcoop2.protocol.engine.ProtocolFactoryManager;
  26. import org.openspcoop2.protocol.sdk.IProtocolFactory;
  27. import org.openspcoop2.protocol.sdk.ProtocolException;
  28. import org.openspcoop2.protocol.sdk.diagnostica.IDiagnosticProducer;
  29. import org.openspcoop2.protocol.sdk.diagnostica.MsgDiagnostico;
  30. import org.openspcoop2.protocol.sdk.diagnostica.MsgDiagnosticoException;
  31. import org.openspcoop2.utils.resources.MapReader;


  32. /**
  33.  * Contiene l'implementazione di un appender personalizzato,
  34.  * per la registrazione dei msg diagnostici su database.
  35.  *
  36.  * @author Poli Andrea (apoli@link.it)
  37.  * @author $Author$
  38.  * @version $Rev$, $Date$
  39.  */
  40. public class MsgDiagnosticoOpenSPCoopProtocolAppender implements IDiagnosticProducer{

  41.     private static java.util.HashMap<String, IDiagnosticProducer> mappingProtocolToAppenders = new java.util.HashMap<String, IDiagnosticProducer>();
  42.    
  43.     private static synchronized void initProtocolAppender(String protocol,OpenspcoopAppender appenderProperties) throws ProtocolException{
  44.         if(MsgDiagnosticoOpenSPCoopProtocolAppender.mappingProtocolToAppenders.containsKey(protocol)==false){
  45.             IProtocolFactory<?> p = ProtocolFactoryManager.getInstance().getProtocolFactoryByName(protocol);
  46.             IDiagnosticProducer msgDiag = p.createDiagnosticProducer();
  47.             if(msgDiag==null){
  48.                 throw new ProtocolException("IDiagnosticProducer not defined for protocol ["+protocol+"]");
  49.             }
  50.             try{
  51.                 msgDiag.initializeAppender(appenderProperties);
  52.             }catch(Exception e){
  53.                 throw new ProtocolException(e.getMessage(), e);
  54.             }
  55.             MsgDiagnosticoOpenSPCoopProtocolAppender.mappingProtocolToAppenders.put(protocol, msgDiag);
  56.         }
  57.     }
  58.    
  59.     private static IDiagnosticProducer getProtocolAppender(String protocol) throws ProtocolException{
  60.         if(MsgDiagnosticoOpenSPCoopProtocolAppender.mappingProtocolToAppenders.containsKey(protocol)==false){
  61.             throw new ProtocolException("ProtocolAppender per protocollo["+protocol+"] non inizializzato");
  62.         }
  63.         return  MsgDiagnosticoOpenSPCoopProtocolAppender.mappingProtocolToAppenders.get(protocol);
  64.     }
  65.    
  66.     /**
  67.      * Inizializza l'engine di un appender per la registrazione
  68.      * di un msg Diagnostico emesso da una porta di dominio.
  69.      *
  70.      * @param appenderProperties Proprieta' dell'appender
  71.      * @throws MsgDiagnosticoException
  72.      */
  73.     @Override
  74.     public void initializeAppender(OpenspcoopAppender appenderProperties) throws MsgDiagnosticoException{
  75.         try{
  76.             MapReader<String, IProtocolFactory<?>> table = ProtocolFactoryManager.getInstance().getProtocolFactories();
  77.             Enumeration<String> keys = table.keys();
  78.             while (keys.hasMoreElements()) {
  79.                 String protocol = keys.nextElement();
  80.                 MsgDiagnosticoOpenSPCoopProtocolAppender.initProtocolAppender(protocol,appenderProperties);
  81.             }
  82.         }catch(Exception e){
  83.             throw new MsgDiagnosticoException(e.getMessage(),e);
  84.         }
  85.     }

  86.    
  87.     /**
  88.      * Registra un msg Diagnostico emesso da una porta di dominio,
  89.      * utilizzando le informazioni definite dalla specifica SPC.
  90.      *
  91.      * @param msgDiagnostico Messaggio diagnostico
  92.      * @throws MsgDiagnosticoException
  93.      */
  94.     @Override
  95.     public void log(Connection conOpenSPCoopPdD,MsgDiagnostico msgDiagnostico) throws MsgDiagnosticoException{
  96.         try{
  97.             if(msgDiagnostico.getProtocollo()!=null){
  98.                 MsgDiagnosticoOpenSPCoopProtocolAppender.getProtocolAppender(msgDiagnostico.getProtocollo()).log(conOpenSPCoopPdD,msgDiagnostico);
  99.             }
  100.         }catch(Exception e){
  101.             throw new MsgDiagnosticoException(e.getMessage(),e);
  102.         }
  103.     }
  104.    
  105.    
  106.     /**
  107.      * Metodo che verica la connessione ad una risorsa.
  108.      * Se la connessione non e' presente, viene lanciata una eccezione che contiene il motivo della mancata connessione
  109.      *
  110.      * @throws DriverException eccezione che contiene il motivo della mancata connessione
  111.      */
  112.     @Override
  113.     public void isAlive() throws CoreException{
  114.         try{
  115.             Enumeration<String> protocols = ProtocolFactoryManager.getInstance().getProtocolNames();
  116.             while(protocols.hasMoreElements()){
  117.                 String protocol = protocols.nextElement();
  118.                 MsgDiagnosticoOpenSPCoopProtocolAppender.getProtocolAppender(protocol).isAlive();
  119.             }
  120.         }catch(Exception e){
  121.             throw new CoreException(e.getMessage(),e);
  122.         }
  123.     }
  124.        
  125.     @Override
  126.     public IProtocolFactory<?> getProtocolFactory() {
  127.         return null; // non e' possibile localizzarla
  128.     }

  129. }