InRequestProtocolHandler.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 org.openspcoop2.core.constants.Costanti;
import org.openspcoop2.pdd.config.OpenSPCoop2Properties;
import org.openspcoop2.pdd.core.controllo_traffico.handler.InRequestProtocolHandlerGestioneControlloTraffico;
import org.openspcoop2.pdd.core.credenziali.Credenziali;
import org.openspcoop2.pdd.core.credenziali.engine.GestoreCredenzialiEngine;
import org.openspcoop2.pdd.core.handlers.HandlerException;
import org.openspcoop2.pdd.core.handlers.InRequestProtocolContext;
import org.openspcoop2.pdd.core.transazioni.Transaction;
import org.openspcoop2.pdd.core.transazioni.TransactionContext;
import org.openspcoop2.pdd.core.transazioni.TransactionDeletedException;
import org.openspcoop2.pdd.core.transazioni.TransactionNotExistsException;
/**
* InRequestProtocolHandler
*
* @author Poli Andrea (poli@link.it)
* @author $Author$
* @version $Rev$, $Date$
*/
public class InRequestProtocolHandler extends FirstPositionHandler implements org.openspcoop2.pdd.core.handlers.InRequestProtocolHandler{
@Override
public void invoke(InRequestProtocolContext context) throws HandlerException {
OpenSPCoop2Properties op2Properties = OpenSPCoop2Properties.getInstance();
if(op2Properties.isTransazioniEnabled()==false) {
return;
}
String idTransazione = (String) context.getPddContext().getObject(Costanti.ID_TRANSAZIONE);
//System.out.println("------------- InRequestHandler ("+idTransazione+")("+context.getTipoPorta().getTipo()+") -------------------");
try{
Transaction tr = TransactionContext.getTransaction(idTransazione);
if(context.getConnettore()!=null){
Credenziali credenziali = context.getConnettore().getCredenziali();
String credenzialiFornite = "";
if(credenziali!=null){
credenzialiFornite = credenziali.toString(!Credenziali.SHOW_BASIC_PASSWORD,
Credenziali.SHOW_ISSUER,
!Credenziali.SHOW_DIGEST_CLIENT_CERT,
Credenziali.SHOW_SERIAL_NUMBER_CLIENT_CERT,
"","","\n"); // riporto anche l'issuer ed il serial number del cert e formatto differentemente
}
boolean credenzialiModificateTramiteGateway = false;
if(tr.getCredenziali()!=null){
if(tr.getCredenziali().equals(credenzialiFornite) == false){
credenzialiModificateTramiteGateway=true;
}
}
if(credenzialiModificateTramiteGateway==true){
if(context.getPddContext()!=null && context.getPddContext().containsKey(Costanti.IDENTITA_GESTORE_CREDENZIALI)) {
String identitaGateway = (String) context.getPddContext().getObject(Costanti.IDENTITA_GESTORE_CREDENZIALI);
tr.setCredenziali(GestoreCredenzialiEngine.getDBValuePrefixGatewayCredenziali(identitaGateway,credenzialiFornite));
//System.out.println("SET CREDENZIALI VIA GATEWAY ["+credenzialiFornite+"]");
}
}
}
if(op2Properties.isControlloTrafficoEnabled()){
tr.getTempiElaborazione().startControlloTraffico_rateLimiting();
try {
InRequestProtocolHandlerGestioneControlloTraffico inRequestProtocolHandler_gestioneControlloTraffico =
new InRequestProtocolHandlerGestioneControlloTraffico();
inRequestProtocolHandler_gestioneControlloTraffico.process(context, tr);
}finally {
tr.getTempiElaborazione().endControlloTraffico_rateLimiting();
}
}
}catch(TransactionDeletedException e){
throw new HandlerException(e);
// Non dovrebbe avvenire in questo handler
}catch(TransactionNotExistsException e){
throw new HandlerException(e);
// Non dovrebbe avvenire in questo handler
}
}
}