ModalitaIdentificazione.java

/*
 * GovWay - A customizable API Gateway 
 * https://govway.org
 * 
 * Copyright (c) 2005-2025 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.protocol.engine.constants;


/**
 * Enumerazione sulle modalita' di identificazione dei servizi
 *
 * @author Poli Andrea (apoli@link.it)
 * @author $Author$
 * @version $Rev$, $Date$
 */
public enum ModalitaIdentificazione {
	
	/*
	# Modalita' possibili per i dati su mittente, destinatario, servizio e azione:
	# - static: il valore viene indicato nell'omonima proprieta' con suffisso '.value'
	# - pluginBased: l'identificazione del valore viene delegato al plugin di protocollo
	# - urlBased: il valore viene recuperato tramite l'espressione regolare indicata  nell'omonima proprieta' con suffisso '.pattern'
	# - contentBased: il valore viene recuperato tramite l'espressione xpath indicata  nell'omonima proprieta' con suffisso '.pattern'
	# - inputBased: il valore viene recuperato tramite gli header di integrazione di default per il protocollo
	# - headerBased: il valore viene recuperato dall'header indicato nell'omonima proprieta' con suffisso '.name'
	# - identityBased: (opzione valida solo per il mittente) 
	#					il valore viene recuperato dalle credenziali ottenute in uno dei seguenti metodi alternativi (il primo che matcha viene utilizzato):
	#                   - getUserPrincipal (servlet API)
	#                   - subject certificato client
	#                   - username fornito tramite un header http basic
	#                   E' possibile fornire una espressione regolare in cui indicare come recuperare il nome a partire dalla credenziale recuperata 
	#					L'espressione regolare deve essere indicata nell'omonima proprieta' con suffisso '.pattern'
	#                   Se l'espressione regolare non ritorna un valore, viene utilizzato interamente la credenziale recuperata
	# 
	# NOTA-Mittente: le proprieta' relative al tipo-mittente ed al mittente possono contenere anche una ulteriore proprieta' con suffisso '.anonymous'
	#                Il valore indicato viene utilizzato come nome associato al soggetto che non e' stato identificato.
	#                In questa maniera e' possibile far rappresentare ad un soggetto unico gli accessi anonimi.
	#                Basta associare questo soggetto come fruitore di un servizio per rendere il servizio accessibile in forma anonima.
	#
	# NOTA: La modalita' 'principalBased' dell'identificazione presente sulla porta delegata e della porta applicativa 
	#       e' differente dalla modalita' 'identityTransportBased' indicata sopra.
	#       La modalita' utilizzata sulla PD e PA si basa solo sul metodo getUserPrincipal, e inoltre non usa il principal recuperato 
	#       direttamente come nome del soggetto, ma invece lo utilizza come chiave di ricerca per identificare un un soggetto registrato in base dati che lo possiede.
	#
	# Per quanto riguarda invece l'identificaizone delle informazioni di protocollo (Profilo di Collaborazione,FiltroDuplicati) le modalita' possibili sono:
	# - pluginBased: l'identificazione del valore viene delegato al plugin di protocollo
	# - static: l'identificazione viene letta dai valori presenti sul registro associati al servizio e operazione identificata
	#
	# Per quanto riguarda infine l'identificaizone dell'identificativo unico le modalita' possibili sono:
	# - pluginBased: l'identificazione del valore viene delegato al plugin di protocollo
	# - static: un identificatore viene generato ex-nove utilizzando la factory fornita con il protocollo
	*/
	
	STATIC("static"), 
	PLUGIN_BASED("pluginBased"), 
	URL_BASED("urlBased"), 
	CONTENT_BASED("contentBased"),
	INPUT_BASED("inputBased"),
	HEADER_BASED("+headerBased+"), 
	IDENTITY_BASED("identityBased");
	
	
	
	private final String valore;

	ModalitaIdentificazione(String valore)
	{
		this.valore = valore;
	}

	public String getValore()
	{
		return this.valore;
	}

	public static String[] toStringArray(){
		String[] res = new String[ModalitaIdentificazione.values().length];
		int i=0;
		for (ModalitaIdentificazione tmp : ModalitaIdentificazione.values()) {
			res[i]=tmp.getValore();
			i++;
		}
		return res;
	}
	public static String[] toEnumNameArray(){
		String[] res = new String[ModalitaIdentificazione.values().length];
		int i=0;
		for (ModalitaIdentificazione tmp : ModalitaIdentificazione.values()) {
			res[i]=tmp.name();
			i++;
		}
		return res;
	}


	public static ModalitaIdentificazione toEnumConstant(String val){

		ModalitaIdentificazione res = null;

		if(ModalitaIdentificazione.STATIC.toString().equals(val)){
			res = ModalitaIdentificazione.STATIC;
		}
		else if(ModalitaIdentificazione.PLUGIN_BASED.toString().equals(val)){
			res = ModalitaIdentificazione.PLUGIN_BASED;
		} 
		else if(ModalitaIdentificazione.URL_BASED.toString().equals(val)){
			res = ModalitaIdentificazione.URL_BASED;
		}  
		else if(ModalitaIdentificazione.CONTENT_BASED.toString().equals(val)){
			res = ModalitaIdentificazione.CONTENT_BASED;
		}
		else if(ModalitaIdentificazione.INPUT_BASED.toString().equals(val)){
			res = ModalitaIdentificazione.INPUT_BASED;
		}   
		else if(ModalitaIdentificazione.HEADER_BASED.toString().equals(val)){
			res = ModalitaIdentificazione.HEADER_BASED;
		} 
		else if(ModalitaIdentificazione.IDENTITY_BASED.toString().equals(val)){
			res = ModalitaIdentificazione.IDENTITY_BASED;
		} 
		return res;
	}

	
	@Override
	public String toString(){
		return this.valore;
	}
	public boolean equals(String esito){
		if(esito==null) {
			return false;
		}
		return this.toString().equals(esito);
	}
}