DumpRaw.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.connettori;

import java.util.Date;
import java.util.List;
import java.util.Map;

import org.openspcoop2.core.config.DumpConfigurazione;
import org.openspcoop2.core.config.constants.StatoFunzionalita;
import org.openspcoop2.core.constants.TipoPdD;
import org.openspcoop2.core.id.IDPortaApplicativa;
import org.openspcoop2.core.id.IDSoggetto;
import org.openspcoop2.core.transazioni.TransazioneApplicativoServer;
import org.openspcoop2.message.constants.MessageType;
import org.openspcoop2.pdd.config.OpenSPCoop2Properties;
import org.openspcoop2.pdd.core.PdDContext;
import org.openspcoop2.pdd.logger.Dump;
import org.openspcoop2.pdd.services.connector.ConnectorException;
import org.openspcoop2.protocol.sdk.dump.DumpException;
import org.openspcoop2.utils.io.DumpByteArrayOutputStream;

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

	@SuppressWarnings("unused")
	private ConnettoreLogger logger;
	@SuppressWarnings("unused")
	private boolean pd;
	private Dump dump;
	private boolean dumpBinario;
	private boolean dumpBinario_registrazioneDatabase = false;
	private DumpConfigurazione dumpDatabaseConfigurazione;
	private boolean dumpDatabaseRichiestaUscitaHeaders;
	private boolean dumpDatabaseRichiestaUscitaPayload;
	private boolean dumpDatabaseRispostaIngressoHeaders;
	private boolean dumpDatabaseRispostaIngressoPayload;
	private boolean onlyLogFileTraceRichiestaUscitaHeaders = false;
	private boolean onlyLogFileTraceRichiestaUscitaPayload = false;
	private boolean onlyLogFileTraceRispostaIngressoHeaders = false;
	private boolean onlyLogFileTraceRispostaIngressoPayload = false;
	
	private IDSoggetto dominio;
	private String modulo;
	private TipoPdD tipoPdD;
	
	public DumpRaw(ConnettoreLogger log,IDSoggetto dominio,String modulo,TipoPdD tipoPdD, 
			boolean dumpBinario, 
			DumpConfigurazione dumpConfigurazione,
			boolean fileTraceHeaders, boolean fileTracePayload) throws ConnectorException{
		this.logger = log;
		
		switch (tipoPdD) {
		case DELEGATA:
			this.pd = true;
			break;
		default:
			this.pd = false;
			break;
		}
		
		this.dumpBinario = dumpBinario;
		if(this.dumpBinario) {
			this.dumpBinario_registrazioneDatabase = OpenSPCoop2Properties.getInstance().isDumpBinarioRegistrazioneDatabase();
		}
		
		if(dumpConfigurazione!=null) {
			if(dumpConfigurazione.getRichiestaUscita()!=null) {
				// il parsing deve essere gestito con l'altra modalità, che dovrà gestire anche gli header, senno sul db si troveranno 2 messaggi
				boolean payloadParsing = StatoFunzionalita.ABILITATO.equals(dumpConfigurazione.getRichiestaUscita().getPayload()) &&
						StatoFunzionalita.ABILITATO.equals(dumpConfigurazione.getRichiestaUscita().getPayloadParsing());
				if(!payloadParsing) {
					if(StatoFunzionalita.ABILITATO.equals(dumpConfigurazione.getRichiestaUscita().getHeaders())){
						this.dumpDatabaseRichiestaUscitaHeaders = true;
					}
					if(StatoFunzionalita.ABILITATO.equals(dumpConfigurazione.getRichiestaUscita().getPayload())){
						this.dumpDatabaseRichiestaUscitaPayload = true;
					}
				}
			}
			if(dumpConfigurazione.getRispostaIngresso()!=null) {
				// il parsing deve essere gestito con l'altra modalità, che dovrà gestire anche gli header, senno sul db si troveranno 2 messaggi
				boolean payloadParsing = StatoFunzionalita.ABILITATO.equals(dumpConfigurazione.getRispostaIngresso().getPayload()) &&
						StatoFunzionalita.ABILITATO.equals(dumpConfigurazione.getRispostaIngresso().getPayloadParsing());
				if(!payloadParsing) {
					if(StatoFunzionalita.ABILITATO.equals(dumpConfigurazione.getRispostaIngresso().getHeaders())){
						this.dumpDatabaseRispostaIngressoHeaders = true;
					}
					if(StatoFunzionalita.ABILITATO.equals(dumpConfigurazione.getRispostaIngresso().getPayload())){
						this.dumpDatabaseRispostaIngressoPayload = true;
					}
				}
			}
			this.dumpDatabaseConfigurazione = dumpConfigurazione;
		}
		
		if(!this.dumpDatabaseRichiestaUscitaHeaders && (!dumpBinario || !this.dumpBinario_registrazioneDatabase) ) {
			this.onlyLogFileTraceRichiestaUscitaHeaders = fileTraceHeaders;
		}
		if(!this.dumpDatabaseRichiestaUscitaPayload && (!dumpBinario || !this.dumpBinario_registrazioneDatabase) ) {
			this.onlyLogFileTraceRichiestaUscitaPayload = fileTracePayload;
		}
		if(!this.dumpDatabaseRispostaIngressoHeaders && (!dumpBinario || !this.dumpBinario_registrazioneDatabase) ) {
			this.onlyLogFileTraceRispostaIngressoHeaders = fileTraceHeaders;
		}
		if(!this.dumpDatabaseRispostaIngressoPayload && (!dumpBinario || !this.dumpBinario_registrazioneDatabase) ) {
			this.onlyLogFileTraceRispostaIngressoPayload = fileTracePayload;
		}
				
		this.dominio = dominio;
		this.modulo = modulo;
		this.tipoPdD = tipoPdD;
	}
	
	public boolean isActiveDumpDatabase() {
		return this.isDumpBinarioRegistrazioneDatabase() || isRegistrazioneDatabase() || onlyLogFileTrace();
	}
	public boolean isActiveDumpDatabaseRichiesta() {
		return this.dumpBinario || isRegistrazioneDatabaseRichiesta() || onlyLogFileTraceRichiesta();
	}
	public boolean isActiveDumpDatabaseRisposta() {
		return this.dumpBinario || isRegistrazioneDatabaseRisposta() || onlyLogFileTraceRisposta();
	}
	
	private boolean isRegistrazioneDatabase() {
		return this.isRegistrazioneDatabaseRichiesta()
				||
			   this.isRegistrazioneDatabaseRisposta()
			   ;
	}
	private boolean isRegistrazioneDatabaseRichiesta() {
		return this.dumpDatabaseRichiestaUscitaHeaders
				||
			   this.dumpDatabaseRichiestaUscitaPayload
			   ;
	}
	private boolean isRegistrazioneDatabaseRisposta() {
		return this.dumpDatabaseRispostaIngressoHeaders
				||
			   this.dumpDatabaseRispostaIngressoPayload
			   ;
	}
	
	private boolean onlyLogFileTrace() {
		return this.onlyLogFileTraceRichiesta()
				||
			   this.onlyLogFileTraceRisposta()
			   ;
	}
	private boolean onlyLogFileTraceRichiesta() {
		return this.onlyLogFileTraceRichiestaUscitaHeaders
				||
			   this.onlyLogFileTraceRichiestaUscitaPayload
				||
			   this.onlyLogFileTraceRispostaIngressoHeaders
				||
			   this.onlyLogFileTraceRispostaIngressoPayload
			   ;
	}
	private boolean onlyLogFileTraceRisposta() {
		return this.onlyLogFileTraceRichiestaUscitaHeaders
				||
			   this.onlyLogFileTraceRichiestaUscitaPayload
				||
			   this.onlyLogFileTraceRispostaIngressoHeaders
				||
			   this.onlyLogFileTraceRispostaIngressoPayload
			   ;
	}
	
	private boolean isDumpBinarioRegistrazioneDatabase() {
		return this.dumpBinario && this.dumpBinario_registrazioneDatabase;
	}
	
	public void initDump(String interfaceName, PdDContext pddContext) throws DumpException {
		initDump(interfaceName, pddContext, 
				null,
				null, null);
	}
	public void initDump(String interfaceName, PdDContext pddContext, 
			TransazioneApplicativoServer transazioneApplicativoServer,
			IDPortaApplicativa idPA, Date dataConsegnaTransazioneApplicativoServer) throws DumpException {
		
		if(!isActiveDumpDatabase()) {
			return;
		}
		
		if(this.isRegistrazioneDatabase() || this.isDumpBinarioRegistrazioneDatabase() || this.onlyLogFileTrace()) {
			this.dump = new Dump(this.dominio, this.modulo, this.tipoPdD, interfaceName, pddContext, this.dumpDatabaseConfigurazione);
			if(transazioneApplicativoServer!=null) {
				this.dump.setTransazioneApplicativoServer(transazioneApplicativoServer, 
						idPA, dataConsegnaTransazioneApplicativoServer);
			}
		}	
	}
		
	public void emitDiagnosticStartDumpBinarioRichiestaUscita() {
		if(!isActiveDumpDatabaseRichiesta()) {
			return;
		}
		
		if(this.dump!=null) {
			boolean onlyFileTrace = !isRegistrazioneDatabaseRichiesta();
			this.dump.emitDiagnosticStartDumpBinarioRichiestaUscita(onlyFileTrace);
		}
	}
	public void dumpRequest(DumpByteArrayOutputStream content, MessageType messageType, InfoConnettoreUscita infoConnettoreUscita) throws DumpException {
		
		if(!isActiveDumpDatabaseRichiesta()) {
			return;
		}
		
		if(this.dump!=null) {
			//if(content!=null){ // devono essere registrati anche solamente gli header
			this.dump.dumpBinarioRichiestaUscita(this.isDumpBinarioRegistrazioneDatabase(), this.onlyLogFileTraceRichiestaUscitaHeaders, this.onlyLogFileTraceRichiestaUscitaPayload, 
					content, messageType,
					infoConnettoreUscita);
			//}
		}
	}
	
	public void emitDiagnosticStartDumpBinarioRispostaIngresso() {
		if(!isActiveDumpDatabaseRisposta()) {
			return;
		}
		
		if(this.dump!=null) {
			boolean onlyFileTrace = !isRegistrazioneDatabaseRisposta();
			this.dump.emitDiagnosticStartDumpBinarioRispostaIngresso(onlyFileTrace);
		}
	}
	public void dumpResponse(DumpByteArrayOutputStream content, MessageType messageType, InfoConnettoreUscita infoConnettoreUscita, Map<String, List<String>> trasportoRisposta) throws DumpException {
		
		if(!isActiveDumpDatabaseRisposta()) {
			return;
		}
		
		if(this.dump!=null) {
			//if(content!=null){ // devono essere registrati anche solamente gli header
			this.dump.dumpBinarioRispostaIngresso(this.isDumpBinarioRegistrazioneDatabase(), this.onlyLogFileTraceRispostaIngressoHeaders, this.onlyLogFileTraceRispostaIngressoPayload, 
					content, messageType, 
					infoConnettoreUscita, trasportoRisposta);
			//}
		}
	}
	
}