GestioneToken.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.token.pd;
import org.openspcoop2.core.id.IDServizio;
import org.openspcoop2.core.id.IDSoggetto;
import org.openspcoop2.core.registry.driver.DriverRegistroServiziException;
import org.openspcoop2.core.registry.driver.IDServizioFactory;
import org.openspcoop2.pdd.core.PdDContext;
import org.openspcoop2.pdd.core.token.EsitoDynamicDiscovery;
import org.openspcoop2.pdd.core.token.EsitoGestioneToken;
import org.openspcoop2.pdd.core.token.EsitoPresenzaToken;
import org.openspcoop2.pdd.core.token.GestoreToken;
import org.openspcoop2.pdd.core.token.InformazioniToken;
import org.openspcoop2.pdd.core.token.TokenException;
import org.openspcoop2.protocol.sdk.Busta;
import org.openspcoop2.protocol.sdk.IProtocolFactory;
import org.openspcoop2.protocol.sdk.constants.CodiceErroreIntegrazione;
import org.openspcoop2.protocol.sdk.constants.ErroriIntegrazione;
import org.slf4j.Logger;
/**
* Classe che implementala gestione token
*
* @author Andrea Poli (apoli@link.it)
* @author $Author$
* @version $Rev$, $Date$
*/
public class GestioneToken {
private Logger log;
private String idTransazione;
private PdDContext pddContext;
private IProtocolFactory<?> protocolFactory;
public GestioneToken(Logger log, String idTransazione,
PdDContext pddContext, IProtocolFactory<?> protocolFactory) {
this.log = log;
this.idTransazione = idTransazione;
this.pddContext = pddContext;
this.protocolFactory = protocolFactory;
}
public EsitoPresenzaTokenPortaDelegata verificaPresenzaToken(DatiInvocazionePortaDelegata datiInvocazione) {
EsitoPresenzaTokenPortaDelegata esito = (EsitoPresenzaTokenPortaDelegata) GestoreToken.verificaPosizioneToken(datiInvocazione, GestoreToken.PORTA_DELEGATA);
if(esito.getEccezioneProcessamento()!=null) {
esito.setErroreIntegrazione(ErroriIntegrazione.ERRORE_5XX_GENERICO_PROCESSAMENTO_MESSAGGIO.
get5XX_ErroreProcessamento(CodiceErroreIntegrazione.CODICE_560_GESTIONE_TOKEN));
}
else if(!esito.isPresente() &&
esito.getErrorMessage()==null) {
esito.setErroreIntegrazione(ErroriIntegrazione.ERRORE_443_TOKEN_NON_PRESENTE.getErroreIntegrazione());
}
return esito;
}
public EsitoDynamicDiscoveryPortaDelegata dynamicDiscovery(DatiInvocazionePortaDelegata datiInvocazione, EsitoPresenzaToken token) throws TokenException {
try {
IDSoggetto soggettoFruitore = getDominio(datiInvocazione);
IDServizio idServizio = getServizio(datiInvocazione);
Busta busta = getBusta(datiInvocazione, soggettoFruitore, idServizio);
EsitoDynamicDiscoveryPortaDelegata esito = (EsitoDynamicDiscoveryPortaDelegata) GestoreToken.dynamicDiscovery(this.log, datiInvocazione,
this.pddContext, this.protocolFactory,
token, GestoreToken.PORTA_DELEGATA,
busta, soggettoFruitore, idServizio);
if(esito.getEccezioneProcessamento()!=null) {
esito.setErroreIntegrazione(ErroriIntegrazione.ERRORE_5XX_GENERICO_PROCESSAMENTO_MESSAGGIO.
get5XX_ErroreProcessamento(CodiceErroreIntegrazione.CODICE_560_GESTIONE_TOKEN));
}
else if(!esito.isValido() &&
esito.getErrorMessage()==null) {
esito.setErroreIntegrazione(ErroriIntegrazione.ERRORE_444_TOKEN_NON_VALIDO.getErroreIntegrazione());
}
return esito;
}catch(Exception e) {
throw new TokenException(e.getMessage(),e); // errore di processamento
}
}
public EsitoGestioneTokenPortaDelegata validazioneJWTToken(DatiInvocazionePortaDelegata datiInvocazione, EsitoPresenzaToken token, EsitoDynamicDiscovery esitoDynamicDiscovery) throws TokenException {
try {
IDSoggetto soggettoFruitore = getDominio(datiInvocazione);
IDServizio idServizio = getServizio(datiInvocazione);
Busta busta = getBusta(datiInvocazione, soggettoFruitore, idServizio);
EsitoGestioneTokenPortaDelegata esito = (EsitoGestioneTokenPortaDelegata) GestoreToken.validazioneJWTToken(this.log, datiInvocazione,
this.pddContext, this.protocolFactory,
token, esitoDynamicDiscovery, GestoreToken.PORTA_DELEGATA,
busta, soggettoFruitore, idServizio);
if(esito.getEccezioneProcessamento()!=null) {
esito.setErroreIntegrazione(ErroriIntegrazione.ERRORE_5XX_GENERICO_PROCESSAMENTO_MESSAGGIO.
get5XX_ErroreProcessamento(CodiceErroreIntegrazione.CODICE_560_GESTIONE_TOKEN));
}
else if(!esito.isValido() &&
esito.getErrorMessage()==null) {
esito.setErroreIntegrazione(ErroriIntegrazione.ERRORE_444_TOKEN_NON_VALIDO.getErroreIntegrazione());
}
return esito;
}catch(Exception e) {
throw new TokenException(e.getMessage(),e); // errore di processamento
}
}
public EsitoGestioneTokenPortaDelegata introspectionToken(DatiInvocazionePortaDelegata datiInvocazione, EsitoPresenzaToken token, EsitoDynamicDiscovery esitoDynamicDiscovery) throws TokenException {
try {
IDSoggetto soggettoFruitore = getDominio(datiInvocazione);
IDServizio idServizio = getServizio(datiInvocazione);
Busta busta = getBusta(datiInvocazione, soggettoFruitore, idServizio);
EsitoGestioneTokenPortaDelegata esito = (EsitoGestioneTokenPortaDelegata) GestoreToken.introspectionToken(this.log, datiInvocazione,
this.pddContext, this.protocolFactory,
token, esitoDynamicDiscovery, GestoreToken.PORTA_DELEGATA,
busta, soggettoFruitore, idServizio);
if(esito.getEccezioneProcessamento()!=null) {
esito.setErroreIntegrazione(ErroriIntegrazione.ERRORE_5XX_GENERICO_PROCESSAMENTO_MESSAGGIO.
get5XX_ErroreProcessamento(CodiceErroreIntegrazione.CODICE_560_GESTIONE_TOKEN));
}
else if(!esito.isValido() &&
esito.getErrorMessage()==null) {
esito.setErroreIntegrazione(ErroriIntegrazione.ERRORE_444_TOKEN_NON_VALIDO.getErroreIntegrazione());
}
return esito;
}catch(Exception e) {
throw new TokenException(e.getMessage(),e); // errore di processamento
}
}
public EsitoGestioneTokenPortaDelegata userInfoToken(DatiInvocazionePortaDelegata datiInvocazione, EsitoPresenzaToken token, EsitoDynamicDiscovery esitoDynamicDiscovery) throws TokenException {
try {
IDSoggetto soggettoFruitore = getDominio(datiInvocazione);
IDServizio idServizio = getServizio(datiInvocazione);
Busta busta = getBusta(datiInvocazione, soggettoFruitore, idServizio);
EsitoGestioneTokenPortaDelegata esito = (EsitoGestioneTokenPortaDelegata) GestoreToken.userInfoToken(this.log, datiInvocazione,
this.pddContext, this.protocolFactory,
token, esitoDynamicDiscovery, GestoreToken.PORTA_DELEGATA,
busta, soggettoFruitore, idServizio);
if(esito.getEccezioneProcessamento()!=null) {
esito.setErroreIntegrazione(ErroriIntegrazione.ERRORE_5XX_GENERICO_PROCESSAMENTO_MESSAGGIO.
get5XX_ErroreProcessamento(CodiceErroreIntegrazione.CODICE_560_GESTIONE_TOKEN));
}
else if(!esito.isValido() &&
esito.getErrorMessage()==null) {
esito.setErroreIntegrazione(ErroriIntegrazione.ERRORE_444_TOKEN_NON_VALIDO.getErroreIntegrazione());
}
return esito;
}catch(Exception e) {
throw new TokenException(e.getMessage(),e); // errore di processamento
}
}
public void forwardToken(DatiInvocazionePortaDelegata datiInvocazione, EsitoPresenzaTokenPortaDelegata esitoPresenzaToken,
EsitoGestioneToken esitoValidazioneJWT, EsitoGestioneToken esitoIntrospection, EsitoGestioneToken esitoUserInfo,
InformazioniToken informazioniTokenNormalizzate) throws TokenException {
try {
IDSoggetto soggettoFruitore = getDominio(datiInvocazione);
IDServizio idServizio = getServizio(datiInvocazione);
Busta busta = getBusta(datiInvocazione, soggettoFruitore, idServizio);
GestoreToken.forwardToken(this.log, this.idTransazione,
datiInvocazione, esitoPresenzaToken,
esitoValidazioneJWT, esitoIntrospection, esitoUserInfo,
informazioniTokenNormalizzate,
GestoreToken.PORTA_DELEGATA,
this.pddContext, busta);
}catch(Exception e) {
throw new TokenException(e.getMessage(),e); // errore di processamento
}
}
private IDSoggetto getDominio(DatiInvocazionePortaDelegata datiInvocazione) {
IDSoggetto soggetto = null;
if(datiInvocazione.getPd()!=null) {
soggetto = new IDSoggetto(datiInvocazione.getPd().getTipoSoggettoProprietario(), datiInvocazione.getPd().getNomeSoggettoProprietario());
}
return soggetto;
}
private IDServizio getServizio(DatiInvocazionePortaDelegata datiInvocazione) throws DriverRegistroServiziException {
IDServizio servizio = null;
if(datiInvocazione.getPd()!=null) {
servizio = IDServizioFactory.getInstance().getIDServizioFromValues(datiInvocazione.getPd().getServizio().getTipo(), datiInvocazione.getPd().getServizio().getNome(),
datiInvocazione.getPd().getSoggettoErogatore().getTipo(), datiInvocazione.getPd().getSoggettoErogatore().getNome(),
datiInvocazione.getPd().getServizio().getVersione());
}
return servizio;
}
private Busta getBusta(DatiInvocazionePortaDelegata datiInvocazione, IDSoggetto soggettoFruitore, IDServizio idServizio) {
Busta busta = new Busta(this.protocolFactory.getProtocol());
if(soggettoFruitore!=null) {
busta.setTipoMittente(soggettoFruitore.getTipo());
busta.setMittente(soggettoFruitore.getNome());
}
if(idServizio!=null) {
if(idServizio.getSoggettoErogatore()!=null) {
busta.setTipoDestinatario(idServizio.getSoggettoErogatore().getTipo());
busta.setDestinatario(idServizio.getSoggettoErogatore().getNome());
}
busta.setTipoServizio(idServizio.getTipo());
busta.setServizio(idServizio.getNome());
busta.setVersioneServizio(idServizio.getVersione());
if(datiInvocazione.getRequestInfo()!=null && datiInvocazione.getRequestInfo().getIdServizio()!=null) {
busta.setAzione(datiInvocazione.getRequestInfo().getIdServizio().getAzione());
}
}
return busta;
}
}