DumpOpenSPCoopProtocolAppender.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.dump.DumpException;
  29. import org.openspcoop2.protocol.sdk.dump.IDumpProducer;
  30. import org.openspcoop2.protocol.sdk.dump.Messaggio;
  31. import org.openspcoop2.utils.resources.MapReader;

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

  40. public class DumpOpenSPCoopProtocolAppender implements IDumpProducer{

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

  87.    
  88.    
  89.     /**
  90.      * Dump di un messaggio
  91.      *
  92.      * @param conOpenSPCoopPdD Connessione verso il database
  93.      * @param messaggio
  94.      * @throws DumpException
  95.      */
  96.     @SuppressWarnings("deprecation")
  97.     @Deprecated
  98.     @Override
  99.     public void dump(Connection conOpenSPCoopPdD,Messaggio messaggio) throws DumpException{
  100.         try{
  101.             if(messaggio.getProtocollo()!=null){
  102.                 DumpOpenSPCoopProtocolAppender.getProtocolAppender(messaggio.getProtocollo()).dump(conOpenSPCoopPdD,messaggio);
  103.             }
  104.         }catch(Exception e){
  105.             throw new DumpException(e.getMessage(),e);
  106.         }
  107.     }
  108.     @Override
  109.     public void dump(Connection conOpenSPCoopPdD,Messaggio messaggio,boolean headersCompact) throws DumpException{
  110.         try{
  111.             if(messaggio.getProtocollo()!=null){
  112.                 IDumpProducer dumpAppender = DumpOpenSPCoopProtocolAppender.getProtocolAppender(messaggio.getProtocollo());
  113.                 dumpAppender.dump(conOpenSPCoopPdD,messaggio,headersCompact);
  114.             }
  115.         }catch(Exception e){
  116.             throw new DumpException(e.getMessage(),e);
  117.         }
  118.     }



  119.     @Override
  120.     public void isAlive() throws CoreException {
  121.         try{
  122.             Enumeration<String> protocols = ProtocolFactoryManager.getInstance().getProtocolNames();
  123.             while(protocols.hasMoreElements()){
  124.                 String protocol = protocols.nextElement();
  125.                 DumpOpenSPCoopProtocolAppender.getProtocolAppender(protocol).isAlive();
  126.             }
  127.         }catch(Exception e){
  128.             throw new CoreException(e.getMessage(),e);
  129.         }
  130.     }



  131.     @Override
  132.     public IProtocolFactory<?> getProtocolFactory() {
  133.         return null; // non e' possibile localizzarla
  134.     }

  135. }