ControlStationLogger.java
/*
* GovWay - A customizable API Gateway
* https://govway.org
*
* Copyright (c) 2005-2024 Link.it srl (https://link.it).
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3, as published by
* the Free Software Foundation.
*
* 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
package org.openspcoop2.web.ctrlstat.core;
import java.io.FileInputStream;
import java.io.IOException;
import java.util.Enumeration;
import java.util.Properties;
import org.slf4j.Logger;
import org.openspcoop2.pdd.core.CostantiPdD;
import org.openspcoop2.pdd.logger.OpenSPCoop2Logger;
import org.openspcoop2.pdd.services.OpenSPCoop2Startup;
import org.openspcoop2.utils.LoggerWrapperFactory;
import org.openspcoop2.utils.Utilities;
import org.openspcoop2.utils.UtilsException;
import org.openspcoop2.utils.properties.CollectionProperties;
import org.openspcoop2.utils.properties.PropertiesUtilities;
import org.openspcoop2.web.ctrlstat.costanti.CostantiControlStation;
import org.openspcoop2.web.ctrlstat.costanti.CostantiUtilities;
import org.openspcoop2.web.ctrlstat.costanti.TipoProperties;
/**
* ControlStationLogger
*
* @author Poli Andrea (apoli@link.it)
* @author $Author$
* @version $Rev$, $Date$
*/
public class ControlStationLogger {
public static void initialize(Logger logConsole,String rootDirectory, String confPropertyName, String confLocalPathPrefix,Properties objectProperties,boolean appendActualConfiguration) throws IOException, UtilsException{
// Originale
java.util.Properties loggerProperties = new java.util.Properties();
java.io.File loggerFile = null;
if(rootDirectory!=null)
loggerFile = new java.io.File(rootDirectory+"console.log4j2.properties");
else
loggerFile = new java.io.File("console.log4j2.properties");
if(loggerFile .exists() == false ){
loggerProperties.load(OpenSPCoop2Logger.class.getResourceAsStream("/console.log4j2.properties"));
}else{
FileInputStream fin = null;
try{
fin = new java.io.FileInputStream(loggerFile);
loggerProperties.load(fin);
}finally{
try{
if(fin!=null){
fin.close();
}
}catch(Exception eClose){
// close
}
}
}
// File Local Implementation
CollectionProperties loggerPropertiesRidefinito =
PropertiesUtilities.searchLocalImplementation(CostantiPdD.OPENSPCOOP2_LOCAL_HOME,logConsole,
CostantiUtilities.get_PROPERTY_NAME(TipoProperties.LOGGER, confPropertyName),
CostantiUtilities.get_LOCAL_PATH(TipoProperties.LOGGER, confLocalPathPrefix),
rootDirectory);
if(loggerPropertiesRidefinito!=null && loggerPropertiesRidefinito.size()>0){
Enumeration<?> ridefinito = loggerPropertiesRidefinito.keys();
while (ridefinito.hasMoreElements()) {
String key = (String) ridefinito.nextElement();
String value = (String) loggerPropertiesRidefinito.get(key);
if(loggerProperties.containsKey(key)){
//Object o =
loggerProperties.remove(key);
}
loggerProperties.put(key, value);
//System.out.println("CHECK NUOVO VALORE: "+loggerProperties.get(key));
}
}
// File Object Implementation
if(objectProperties!=null && objectProperties.size()>0){
Enumeration<?> ridefinito = objectProperties.keys();
while (ridefinito.hasMoreElements()) {
String key = (String) ridefinito.nextElement();
String value = (String) objectProperties.get(key);
if(loggerProperties.containsKey(key)){
//Object o =
loggerProperties.remove(key);
}
loggerProperties.put(key, value);
//System.out.println("CHECK NUOVO VALORE: "+loggerProperties.get(key));
}
}
if(appendActualConfiguration){
System.out.println("[govwayConsole] Attendo inizializzazione GovWay prima di appender la configurazione Log4J ...");
int i=0;
int limit = 60;
while(OpenSPCoop2Startup.initialize==false && i<limit){
Utilities.sleep(1000);
i++;
if(i%10==0){
System.out.println("[govwayConsole] Attendo inizializzazione GovWay ...");
}
}
if(OpenSPCoop2Startup.initialize==false){
throw new UtilsException("[govwayConsole] Inizializzazione GovWay non rilevata");
}
System.out.println("[govwayConsole] Configurazione Log4J ...");
LoggerWrapperFactory.setLogConfiguration(loggerProperties,true);
System.out.println("[govwayConsole] Configurazione Log4J aggiunta");
}
else{
LoggerWrapperFactory.setLogConfiguration(loggerProperties);
}
}
public static Logger getPddConsoleCoreLogger(){
return LoggerWrapperFactory.getLogger("govwayConsole.core");
}
public static Logger getSmistatoreLogger(){
return LoggerWrapperFactory.getLogger("govwayConsole.gestori.smistatore");
}
public static Logger getGestorePddLogger(){
return LoggerWrapperFactory.getLogger("govwayConsole.gestori.config");
}
public static Logger getGestoreGELogger(){
return LoggerWrapperFactory.getLogger("govwayConsole.gestori.gestoreEventi");
}
public static Logger getGestoreRegistroLogger(){
return LoggerWrapperFactory.getLogger("govwayConsole.gestori.registry");
}
public static Logger getGestoreAutorizzazioneLogger(){
return LoggerWrapperFactory.getLogger("govwayConsole.gestori.auth");
}
public static Logger getDriverDBPddConsoleLogger(){
return LoggerWrapperFactory.getLogger(CostantiControlStation.DRIVER_DB_PDD_CONSOLE_LOGGER);
}
public static Logger getSincronizzatoreLogger(){
return LoggerWrapperFactory.getLogger("govwayConsole.sincronizzatore");
}
}