AutorizzazioneContenutoBuiltIn.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.autorizzazione.pa;

import java.util.List;

import org.openspcoop2.core.config.Proprieta;
import org.openspcoop2.core.id.IDServizioApplicativo;
import org.openspcoop2.core.id.IDSoggetto;
import org.openspcoop2.message.OpenSPCoop2Message;
import org.openspcoop2.pdd.core.autorizzazione.AutorizzazioneException;
import org.openspcoop2.pdd.core.autorizzazione.GestoreAutorizzazioneContenutiBuiltIn;
import org.openspcoop2.pdd.logger.OpenSPCoop2Logger;
import org.openspcoop2.protocol.sdk.constants.CodiceErroreCooperazione;
import org.openspcoop2.protocol.sdk.constants.ErroriCooperazione;
import org.openspcoop2.protocol.sdk.constants.IntegrationFunctionError;

/**
 * Esempio di AutorizzazioneContenutoBuiltIn
 *
 * @author Andrea Poli (apoli@link.it)
 * @author $Author$
 * @version $Rev$, $Date$
 */

public class AutorizzazioneContenutoBuiltIn extends AbstractAutorizzazioneContenutoBase {

	@Override
	public EsitoAutorizzazionePortaApplicativa process(DatiInvocazionePortaApplicativa datiInvocazione, OpenSPCoop2Message msg) throws AutorizzazioneException {
		
		EsitoAutorizzazionePortaApplicativa esito = new EsitoAutorizzazionePortaApplicativa();
    	
    	// Autorizzazzione servizio applicativo
    	try{
    		
    		if(datiInvocazione.getPa()==null) {
				throw new Exception("Porta Applicativa non presente");
			}
    		List<Proprieta> regole = datiInvocazione.getPa().getProprietaAutorizzazioneContenutoList();
    		
    		GestoreAutorizzazioneContenutiBuiltIn gestore = new GestoreAutorizzazioneContenutiBuiltIn();
    		gestore.process(msg, datiInvocazione, this.getPddContext(), regole);
    		
    		if(!gestore.isAutorizzato()) {
    			
    			IDServizioApplicativo idSA = datiInvocazione.getIdentitaServizioApplicativoFruitore();
        		IDSoggetto soggettoFruitore = datiInvocazione.getIdSoggettoFruitore();
        		//IDServizio servizio = datiInvocazione.getIdServizio();
    			
        		String mittente = null;
        		if(idSA!=null && idSA.getNome()!=null) {
        			IDSoggetto soggettoProprietario = null;
        			if(idSA.getIdSoggettoProprietario()!=null) {
        				soggettoProprietario = idSA.getIdSoggettoProprietario();
        			}
        			else if(soggettoFruitore!=null) {
        				soggettoProprietario = soggettoFruitore;
        			}
        			if(soggettoProprietario!=null) {
        				mittente = "L'applicativo "+idSA.getNome()+" ("+soggettoProprietario.getTipo()+"/"+soggettoProprietario.getNome()+")";
        			}
        			else {
        				mittente = "L'applicativo "+idSA.getNome();
        			}
        		}
        		else if(soggettoFruitore!=null) {
        			mittente = "Il soggetto "+soggettoFruitore.getTipo()+"/"+soggettoFruitore.getNome(); 
        		}
        		else {
        			mittente = "Il chiamante";
        		}
        		
        		String errore = mittente+" non รจ autorizzato ad invocare l'API";
    			
        		esito.setErroreCooperazione(IntegrationFunctionError.CONTENT_AUTHORIZATION_DENY, ErroriCooperazione.AUTORIZZAZIONE_FALLITA.getErroreAutorizzazione(errore, CodiceErroreCooperazione.SICUREZZA_AUTORIZZAZIONE_FALLITA));
    			esito.setAutorizzato(false);
    			esito.setDetails(gestore.getErrorMessage());
    		}
    		else {
    			esito.setAutorizzato(true);
    		}
			
        	return esito;
    		
    	}catch(Exception e){
    		esito.setEccezioneProcessamento(e);
    		OpenSPCoop2Logger.getLoggerOpenSPCoopCore().error("Autorizzazione per contenuto non riuscita",e);
    		throw new AutorizzazioneException("Errore inatteso durante la gestione dell'autorizzazione per contenuti: "+e.getMessage(),e);
    	}
	}

	
	
}