ExceptionSerialzerFileSystem.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.handlers.transazioni;

import java.io.ByteArrayOutputStream;
import java.util.Date;

import org.openspcoop2.core.constants.Costanti;
import org.openspcoop2.core.diagnostica.ElencoMessaggiDiagnostici;
import org.openspcoop2.core.diagnostica.MessaggioDiagnostico;
import org.openspcoop2.core.transazioni.DumpMessaggio;
import org.openspcoop2.core.transazioni.Transazione;
import org.openspcoop2.core.transazioni.TransazioneApplicativoServer;
import org.openspcoop2.pdd.core.FileSystemSerializer;
import org.openspcoop2.pdd.core.transazioni.Transaction;
import org.openspcoop2.protocol.sdk.diagnostica.MsgDiagnostico;
import org.openspcoop2.protocol.sdk.dump.Messaggio;
import org.openspcoop2.utils.beans.WriteToSerializerType;
import org.openspcoop2.utils.date.DateUtils;
import org.slf4j.Logger;

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

	private Logger logger;
	public ExceptionSerialzerFileSystem(Logger log){
		this.logger = log;
	}
	
	public void registrazioneFileSystem(Transazione transazione,String idTransazione){
		// Registro transazioni non registrate su database su file system
		try{
			ByteArrayOutputStream bout = new ByteArrayOutputStream();
			transazione.writeTo(bout, WriteToSerializerType.XML_JAXB);
	    	bout.flush();
	    	bout.close();
			FileSystemSerializer.getInstance().registraTransazione(bout.toByteArray(), transazione.getDataIngressoRichiesta());
		}catch(Throwable eSerializer){
			this.logger.error("Errore durante la registrazione su file system della transazione ["+idTransazione+"]: "+eSerializer.getMessage(),eSerializer);
		}
	}
	
	public void registrazioneFileSystemDiagnosticiTracceDumpEmessiPdD(Transaction transaction,String idTransazione, Transazione transazioneDTO,
			boolean registraTracciaRichiesta, boolean registraTracciaRisposta, boolean registrazioneMessaggiDiagnostici, boolean registrazioneDumpMessaggi){
		if(registraTracciaRichiesta && transaction.getTracciaRichiesta()!=null){
			// Registro tracce non registrate su database su file system
			try{
				transaction.getTracciaRichiesta().addPropertyInBusta(Costanti.ID_TRANSAZIONE.getValue(), idTransazione);
				org.openspcoop2.core.tracciamento.Traccia tr = transaction.getTracciaRichiesta().getTraccia();
				ByteArrayOutputStream bout = new ByteArrayOutputStream();
				tr.writeTo(bout, WriteToSerializerType.XML_JAXB);
		    	bout.flush();
		    	bout.close();
				FileSystemSerializer.getInstance().registraTraccia(bout.toByteArray(), tr.getOraRegistrazione());
				if(transazioneDTO!=null)
					transazioneDTO.setTracciaRichiesta(null);
			}catch(Throwable eSerializer){
				this.logger.error("Errore durante la registrazione su file system della traccia di richiesta [idTransazione: "+idTransazione+"]: "+eSerializer.getMessage(),eSerializer);
			}
		}
		if(registraTracciaRisposta && transaction.getTracciaRisposta()!=null){
			// Registro tracce non registrate su database su file system
			try{
				transaction.getTracciaRisposta().addPropertyInBusta(Costanti.ID_TRANSAZIONE.getValue(), idTransazione);
				org.openspcoop2.core.tracciamento.Traccia tr = transaction.getTracciaRisposta().getTraccia();
				ByteArrayOutputStream bout = new ByteArrayOutputStream();
				tr.writeTo(bout, WriteToSerializerType.XML_JAXB);
		    	bout.flush();
		    	bout.close();
				FileSystemSerializer.getInstance().registraTraccia(bout.toByteArray(), tr.getOraRegistrazione());
				if(transazioneDTO!=null)
					transazioneDTO.setTracciaRisposta(null);
			}catch(Throwable eSerializer){
				this.logger.error("Errore durante la registrazione su file system della traccia di risposta [idTransazione: "+idTransazione+"]: "+eSerializer.getMessage(),eSerializer);
			}
		}
		if(registrazioneMessaggiDiagnostici && transaction.getMsgDiagnostici()!=null && transaction.getMsgDiagnostici().size()>0){
			boolean error = false;
			boolean registrazioneSingoloDiagnostico = false;
			if(registrazioneSingoloDiagnostico) {
				for (MsgDiagnostico msgDiag : transaction.getMsgDiagnostici()) {
					try{
						MessaggioDiagnostico msgDiagOp2 = msgDiag.getMessaggioDiagnostico();
						ByteArrayOutputStream bout = new ByteArrayOutputStream();
						msgDiagOp2.writeTo(bout, WriteToSerializerType.XML_JAXB);
				    	bout.flush();
				    	bout.close();
						FileSystemSerializer.getInstance().registraDiagnostico(bout.toByteArray(), msgDiagOp2.getOraRegistrazione());
					}catch(Throwable eSerializer){
						error = true;
						this.logger.error("Errore durante la registrazione su file system del messaggio diagnostico [idTransazione: "+idTransazione+"]: "+eSerializer.getMessage(),eSerializer);
					}
				}
			}
			else {
				ElencoMessaggiDiagnostici elencoDiagnostici = new ElencoMessaggiDiagnostici();
				Date oraRegistrazione = null;
				for (MsgDiagnostico msgDiag : transaction.getMsgDiagnostici()) {
					MessaggioDiagnostico msgDiagOp2 = msgDiag.getMessaggioDiagnostico();
					elencoDiagnostici.addMessaggioDiagnostico(msgDiagOp2);
					if(oraRegistrazione==null) {
						oraRegistrazione=msgDiagOp2.getOraRegistrazione();
					}
				}
				try{
					ByteArrayOutputStream bout = new ByteArrayOutputStream();
					elencoDiagnostici.writeTo(bout, WriteToSerializerType.XML_JAXB);
					bout.flush();
					bout.close();
					FileSystemSerializer.getInstance().registraDiagnostico(bout.toByteArray(), oraRegistrazione);
				}catch(Throwable eSerializer){
					error = true;
					this.logger.error("Errore durante la registrazione su file system dei messaggi diagnostici [idTransazione: "+idTransazione+"]: "+eSerializer.getMessage(),eSerializer);
				}
			}
			if(!error && transazioneDTO!=null){
				transazioneDTO.setDiagnostici(null);
				transazioneDTO.setDiagnosticiList1(null);
				transazioneDTO.setDiagnosticiList2(null);
				transazioneDTO.setDiagnosticiListExt(null);
				transazioneDTO.setDiagnosticiExt(null);
			}
		}
		if(registrazioneDumpMessaggi && transaction.getMessaggi()!=null && transaction.getMessaggi().size()>0){
			boolean error = false;
			for (Messaggio messaggio : transaction.getMessaggi()) {
				try{
					DumpMessaggio messaggioOp2 = messaggio.toDumpMessaggio();
					ByteArrayOutputStream bout = new ByteArrayOutputStream();
					messaggioOp2.writeTo(bout, WriteToSerializerType.XML_JAXB);
			    	bout.flush();
			    	bout.close();
					FileSystemSerializer.getInstance().registraDump(bout.toByteArray(), messaggioOp2.getDumpTimestamp());
				}catch(Throwable eSerializer){
					error = true;
					this.logger.error("Errore durante la registrazione su file system del messaggio [idTransazione: "+idTransazione+"]: "+eSerializer.getMessage(),eSerializer);
				}
				finally {
					try {
						if(messaggio.getBody()!=null) {
							messaggio.getBody().unlock();
							messaggio.getBody().clearResources();
						}
					}catch(Throwable t){
						this.logger.error("Errore durante il rilascio delle risorse su del messaggio [idTransazione: "+idTransazione+"]: "+t.getMessage(),t);
					}
				}
			}
			if(!error && transazioneDTO!=null){
				transazioneDTO.getDumpMessaggioList().clear();
			}
		}
	}
	
	
	public void registrazioneFileSystemDiagnosticoEmessoPdD(MsgDiagnostico msgDiag, String idTransazione, String applicativoServer){
		try{
			MessaggioDiagnostico msgDiagOp2 = msgDiag.getMessaggioDiagnostico();
			
			// forzo
			msgDiagOp2.setIdTransazione(idTransazione);
			msgDiagOp2.setApplicativo(applicativoServer);
			
			ByteArrayOutputStream bout = new ByteArrayOutputStream();
			msgDiagOp2.writeTo(bout, WriteToSerializerType.XML_JAXB);
	    	bout.flush();
	    	bout.close();
			FileSystemSerializer.getInstance().registraDiagnostico(bout.toByteArray(), msgDiagOp2.getOraRegistrazione());
		}catch(Throwable eSerializer){
			this.logger.error("Errore durante la registrazione su file system del messaggio diagnostico [idTransazione: "+idTransazione+"][server: "+applicativoServer+"]: "+eSerializer.getMessage(),eSerializer);
		}
	}
	
	public void registrazioneFileSystemDumpEmessoPdD(Messaggio messaggio, String idTransazione, String applicativoServer, Date dataConsegna){
		try{
			DumpMessaggio messaggioOp2 = messaggio.toDumpMessaggio();
			
			// forzo
			messaggio.setIdTransazione(idTransazione);
			messaggio.setServizioApplicativoErogatore(applicativoServer);
			messaggio.setDataConsegna(dataConsegna);
			
			ByteArrayOutputStream bout = new ByteArrayOutputStream();
			messaggioOp2.writeTo(bout, WriteToSerializerType.XML_JAXB);
	    	bout.flush();
	    	bout.close();
			FileSystemSerializer.getInstance().registraDump(bout.toByteArray(), messaggioOp2.getDumpTimestamp());
		}catch(Throwable eSerializer){
			this.logger.error("Errore durante la registrazione su file system del messaggio [idTransazione: "+idTransazione+"][server: "+applicativoServer+"][data:"+DateUtils.getSimpleDateFormatMs().format(dataConsegna)+"]: "+eSerializer.getMessage(),eSerializer);
		}
	}
	
	public void registrazioneFileSystemTransazioneApplicativoServerEmessoPdD(TransazioneApplicativoServer transazioneApplicativoServer, String idTransazione, String applicativoServer){
		try{
			// forzo
			transazioneApplicativoServer.setIdTransazione(idTransazione);
			transazioneApplicativoServer.setServizioApplicativoErogatore(applicativoServer);
			
			ByteArrayOutputStream bout = new ByteArrayOutputStream();
			transazioneApplicativoServer.writeTo(bout, WriteToSerializerType.XML_JAXB);
	    	bout.flush();
	    	bout.close();
			FileSystemSerializer.getInstance().registraTransazioneApplicativoServer(bout.toByteArray(), transazioneApplicativoServer.getDataAccettazioneRichiesta());
		}catch(Throwable eSerializer){
			this.logger.error("Errore durante la registrazione su file system dell'applicativo server [idTransazione: "+idTransazione+"][server: "+applicativoServer+"]: "+eSerializer.getMessage(),eSerializer);
		}
	}
	
	public void registrazioneFileSystemTransazioneApplicativoServerConsegnaTerminata(TransazioneApplicativoServer transazioneApplicativoServer, String idTransazione, String applicativoServer){
		try{
			// forzo
			transazioneApplicativoServer.setIdTransazione(idTransazione);
			transazioneApplicativoServer.setServizioApplicativoErogatore(applicativoServer);
			
			ByteArrayOutputStream bout = new ByteArrayOutputStream();
			transazioneApplicativoServer.writeTo(bout, WriteToSerializerType.XML_JAXB);
	    	bout.flush();
	    	bout.close();
			FileSystemSerializer.getInstance().registraTransazioneApplicativoServerConsegnaTerminata(bout.toByteArray(), transazioneApplicativoServer.getDataAccettazioneRichiesta());
		}catch(Throwable eSerializer){
			this.logger.error("Errore durante la registrazione su file system dell'informazione di consegna terminata [idTransazione: "+idTransazione+"][server: "+applicativoServer+"]: "+eSerializer.getMessage(),eSerializer);
		}
	}
}