ConnettoreLogger.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.core.connettori;

  21. import org.slf4j.Logger;
  22. import org.openspcoop2.core.constants.Costanti;
  23. import org.openspcoop2.pdd.core.PdDContext;
  24. import org.openspcoop2.pdd.logger.OpenSPCoop2Logger;

  25. /**
  26.  * ConnettoreLogger
  27.  *
  28.  * @author Poli Andrea (apoli@link.it)
  29.  * @author $Author$
  30.  * @version $Rev$, $Date$
  31.  */
  32. public class ConnettoreLogger {

  33.     private boolean debug;
  34.     private Logger loggerConnettore;
  35.     private Logger loggerCore;
  36.     private String idMessaggio;
  37.     private PdDContext pddContext;
  38.     private String idTransazione;
  39.    
  40.     public ConnettoreLogger(boolean debug,String idMessaggio,PdDContext pddContext){
  41.         this.debug = debug;
  42.         this.idMessaggio = idMessaggio;
  43.         this.pddContext = pddContext;
  44.        
  45.         Object oIdTransazione = this.pddContext.getObject(Costanti.ID_TRANSAZIONE);
  46.         if(oIdTransazione!=null && (oIdTransazione instanceof String)){
  47.             this.idTransazione = (String) oIdTransazione;
  48.         }
  49.        
  50.         this.loggerConnettore = OpenSPCoop2Logger.getLoggerOpenSPCoopConnettori();
  51.        
  52.         this.loggerCore = OpenSPCoop2Logger.getLoggerOpenSPCoopCore();
  53.     }
  54.    
  55.     public Logger getLogger(){
  56.         if(this.debug){
  57.             return this.loggerConnettore;
  58.         }
  59.         else{
  60.             return this.loggerCore;
  61.         }
  62.     }
  63.    
  64.     public String buildMsg(String msg){
  65.         StringBuilder bf = new StringBuilder();
  66.         if(this.idTransazione!=null){
  67.             bf.append("id:").append(this.idTransazione);
  68.         }
  69.         if(this.idMessaggio!=null){
  70.             if(bf.length()>0){
  71.                 bf.append(" ");
  72.             }
  73.             bf.append("(id-busta:").append(this.idMessaggio);
  74.         }
  75.         if(bf.length()>0){
  76.             return "<"+bf.toString()+"> "+msg;
  77.         }
  78.         else{
  79.             return  msg;
  80.         }
  81.     }
  82.    
  83.     public void error(String msg){
  84.         this.loggerCore.error(this.buildMsg(msg));
  85.         if(this.debug){
  86.             this.loggerConnettore.error(this.buildMsg(msg));
  87.         }
  88.     }
  89.    
  90.     public void error(String msg, Throwable t){
  91.         this.loggerCore.error(this.buildMsg(msg),t);
  92.         if(this.debug){
  93.             this.loggerConnettore.error(this.buildMsg(msg),t);
  94.         }
  95.     }
  96.    
  97.     public void warn(String msg){
  98.         this.loggerCore.warn(this.buildMsg(msg));
  99.         if(this.debug){
  100.             this.loggerConnettore.warn(this.buildMsg(msg));
  101.         }
  102.     }
  103.     public void warn(String msg, Throwable t){
  104.         this.loggerCore.warn(this.buildMsg(msg),t);
  105.         if(this.debug){
  106.             this.loggerConnettore.warn(this.buildMsg(msg),t);
  107.         }
  108.     }

  109.     public void info(String msg, boolean logInCore){
  110.         if(logInCore){
  111.             this.loggerCore.info(this.buildMsg(msg));
  112.         }
  113.         if(this.debug){
  114.             this.loggerConnettore.info(this.buildMsg(msg));
  115.         }
  116.     }
  117.    
  118.     public void debug(String msg){
  119.         if(this.debug){
  120.             this.loggerConnettore.debug(this.buildMsg(msg));
  121.         }
  122.     }
  123.     public void debug(String msg, Throwable t){
  124.         if(this.debug){
  125.             this.loggerConnettore.debug(this.buildMsg(msg), t);
  126.         }
  127.     }

  128.    
  129.    
  130. }