GeneratoreMessaggiDiagnostici.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.pdd.core.controllo_traffico;

import java.util.HashMap;
import java.util.Map;

import org.slf4j.Logger;
import org.openspcoop2.pdd.logger.MsgDiagnosticiProperties;
import org.openspcoop2.pdd.logger.MsgDiagnostico;

/**     
 * GeneratoreMessaggiDiagnostici
 *
 * @author Poli Andrea (poli@link.it)
 * @author $Author$
 * @version $Rev$, $Date$
 */
public class GeneratoreMessaggiDiagnostici {

	
	public static final int NUMERO_TEMPLATE_DINAMICI_ERRORI_GENERICI = 4; // sono i diagnostici emessi dai moduli ricezione contenuti o buste
	public static final int NUMERO_TEMPLATE_DINAMICI_DETTAGLI_SINGOLO_ERRORE = 10; // sono i diagnostici di "appoggio" registrati nel modulo 'all' utilizzati per generare l'errore
	// NOTA: siccome tanto viene salvato direttamente il diagnostico emesso dai moduli ricezione contenuti o buste non sembra necessario salvare i singoli dettagli visto che sono già nell'errore generico
	
	public static final boolean saveSingleValueOfMessageError = false;
	
	public static void cleanPolicyValues(MsgDiagnostico msgDiag) throws Exception{
		
		Map<String, String> keywords = msgDiag.getKeywordLogPersonalizzati();
		if(keywords==null || keywords.size()<=0){
			return;
		}
		keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_ACTIVE_ID);
		keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_VIOLATA_MOTIVO);
		keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_FILTRATA_MOTIVO);
		keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_NON_APPLICABILE_MOTIVO);
		if(saveSingleValueOfMessageError){
			keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_VALORE_SOGLIA);
			keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_TIPOLOGIA_TEMPO_MEDIO);
			keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_VALORE_RILEVATO);
			keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_AVG_TIME_RILEVATO);
			keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_VALORE_SOGLIA_DEGRADO_PRESTAZIONALE);
			keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_GRUPPO);
			keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_INTERVALLO_TEMPORALE);
			keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_NOME_ALLARME);
			keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_STATO_ALLARME);
			keywords.remove(GeneratoreMessaggiErrore.TEMPLATE_POLICY_STATO_ALLARME_ATTESO);
		}
		
	}
	
	public static void emitDiagnostic(MsgDiagnostico msgDiag,String idDiagnostico, Logger log) {
		
		Map<String, String> keywords = msgDiag.getKeywordLogPersonalizzati();
		StringBuilder bf = new StringBuilder();
		try{
			if(keywords!=null && keywords.size()>0){
				addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_ACTIVE_ID);
				addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_VIOLATA_MOTIVO);
				addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_FILTRATA_MOTIVO);
				addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_NON_APPLICABILE_MOTIVO);
				if(saveSingleValueOfMessageError){
					addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_VALORE_SOGLIA);
					addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_TIPOLOGIA_TEMPO_MEDIO);
					addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_VALORE_RILEVATO);
					addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_AVG_TIME_RILEVATO);
					addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_VALORE_SOGLIA_DEGRADO_PRESTAZIONALE);
					addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_GRUPPO);
					addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_INTERVALLO_TEMPORALE);
					addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_NOME_ALLARME);
					addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_STATO_ALLARME);
					addNextValue(keywords, bf, GeneratoreMessaggiErrore.TEMPLATE_POLICY_STATO_ALLARME_ATTESO);
				}
			}
		}catch(Exception e){
			log.error(e.getMessage(),e);
		}
				
		if(bf.length()>0){
			msgDiag.getProperties().put(MsgDiagnosticiProperties.DIAGNOSTIC_WITH_DYNAMIC_INFO_TYPE,MsgDiagnosticiProperties.DIAGNOSTIC_TYPE_POLICY_CONTROLLO_TRAFFICO);
			msgDiag.getProperties().put(MsgDiagnosticiProperties.DIAGNOSTIC_WITH_DYNAMIC_INFO_VALUE,bf.toString());
		}		
		
		msgDiag.logPersonalizzato(idDiagnostico);
		
		if(bf.length()>0){
			msgDiag.getProperties().remove(MsgDiagnosticiProperties.DIAGNOSTIC_WITH_DYNAMIC_INFO_TYPE);
			msgDiag.getProperties().remove(MsgDiagnosticiProperties.DIAGNOSTIC_WITH_DYNAMIC_INFO_VALUE);
		}		
		
	}
	private static void addNextValue(Map<String, String> keywords,StringBuilder bf, String keyId) throws Exception{
		if(bf.length()>0){
			bf.append(MsgDiagnosticiProperties.DIAGNOSTIC_WITH_DYNAMIC_INFO_SEPARATOR);
		}
		if(keywords.containsKey(keyId)){
			String v = keywords.get(keyId);
			if(v==null || v.length()<=0){
				bf.append(MsgDiagnosticiProperties.NON_PRESENTE);
			}
			else{
				if(v.contains(MsgDiagnosticiProperties.DIAGNOSTIC_WITH_DYNAMIC_INFO_SEPARATOR)){
					throw new Exception("Valore ["+v+"] della chiave ["+keyId+"] non simulabile poichè contiene il separatore ["+MsgDiagnosticiProperties.DIAGNOSTIC_WITH_DYNAMIC_INFO_SEPARATOR+"]");
				}
				if(v.contains(MsgDiagnosticiProperties.DIAGNOSTIC_WITH_DYNAMIC_INFO_DIAG_SEPARATOR)){
					throw new Exception("Valore ["+v+"] della chiave ["+keyId+"] non simulabile poichè contiene il separatore di diagnostici ["+MsgDiagnosticiProperties.DIAGNOSTIC_WITH_DYNAMIC_INFO_DIAG_SEPARATOR+"]");
				}
				bf.append(v);
			}
		}
		else{
			bf.append(MsgDiagnosticiProperties.NON_PRESENTE);
		}
	}
	
	public static Map<String, String> convertToProperties(String value) throws Exception{
		if(value.contains(MsgDiagnosticiProperties.DIAGNOSTIC_WITH_DYNAMIC_INFO_SEPARATOR)){
			
			String [] tmp = value.split(MsgDiagnosticiProperties.DIAGNOSTIC_WITH_DYNAMIC_INFO_SEPARATOR);
			if(tmp==null || tmp.length<=0){
				throw new Exception("Split value ["+value+"] with ["+MsgDiagnosticiProperties.DIAGNOSTIC_WITH_DYNAMIC_INFO_SEPARATOR+"] failed");
			}
			int NUMERO_TEMPLATE_DINAMICI = NUMERO_TEMPLATE_DINAMICI_ERRORI_GENERICI;
			if(saveSingleValueOfMessageError){
				NUMERO_TEMPLATE_DINAMICI+=NUMERO_TEMPLATE_DINAMICI_DETTAGLI_SINGOLO_ERRORE;
			}
			if(tmp.length!=NUMERO_TEMPLATE_DINAMICI){
				throw new Exception("Split value ["+value+"] with ["+MsgDiagnosticiProperties.DIAGNOSTIC_WITH_DYNAMIC_INFO_SEPARATOR+
						"] failed (expected:"+NUMERO_TEMPLATE_DINAMICI+" found:"+tmp.length+")");
			}
			
			Map<String, String> map = new HashMap<>();
			
			for (int i = 0; i < tmp.length; i++) {
				
				String v = tmp[i];
				if(v==null || (v.length()==1 && MsgDiagnosticiProperties.NON_PRESENTE.equals(v))){
					continue;
				}
				
				if(i==0)
					map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_ACTIVE_ID,v);
				else if(i==1)
					map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_VIOLATA_MOTIVO,v);
				else if(i==2)
					map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_FILTRATA_MOTIVO,v);
				else if(i==3)
					map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_NON_APPLICABILE_MOTIVO,v);
				
				if(saveSingleValueOfMessageError){
					if(i==4)
						map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_VALORE_SOGLIA,v);
					else if(i==5)
						map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_TIPOLOGIA_TEMPO_MEDIO,v);
					else if(i==6)
						map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_VALORE_RILEVATO,v);
					else if(i==7)
						map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_AVG_TIME_RILEVATO,v);
					else if(i==8)
						map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_VALORE_SOGLIA_DEGRADO_PRESTAZIONALE,v);
					else if(i==9)
						map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_GRUPPO,v);
					else if(i==10)
						map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_INTERVALLO_TEMPORALE,v);
					else if(i==11)
						map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_NOME_ALLARME,v);
					else if(i==12)
						map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_STATO_ALLARME,v);
					else if(i==13)
						map.put(GeneratoreMessaggiErrore.TEMPLATE_POLICY_STATO_ALLARME_ATTESO,v);
				}
				
			}
			
			return map;
			
		}
		throw new Exception("Value is null");
	}
}