ModIKeystoreConfig.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.modipa.utils;
import java.util.List;
import org.openspcoop2.core.config.ServizioApplicativo;
import org.openspcoop2.core.id.IDSoggetto;
import org.openspcoop2.core.registry.AccordoServizioParteSpecifica;
import org.openspcoop2.core.registry.ProtocolProperty;
import org.openspcoop2.protocol.modipa.config.ModIProperties;
import org.openspcoop2.protocol.modipa.constants.ModICostanti;
import org.openspcoop2.protocol.sdk.ProtocolException;
import org.openspcoop2.protocol.sdk.properties.ProtocolPropertiesUtils;
import org.openspcoop2.protocol.utils.ModIKeystoreUtils;
import org.openspcoop2.utils.UtilsException;
import org.openspcoop2.utils.certificate.KeystoreParams;
/**
* ModIKeystoreConfig
*
* @author Poli Andrea (apoli@link.it)
* @author $Author$
* @version $Rev$, $Date$
*/
public class ModIKeystoreConfig extends ModIKeystoreUtils {
public static boolean isKeystoreDefinitoInFruizione(IDSoggetto soggettoFruitore, AccordoServizioParteSpecifica asps) throws ProtocolException {
String mode = getKeystoreDefinitoIn(soggettoFruitore, asps);
return mode!=null && ModICostanti.MODIPA_KEYSTORE_FRUIZIONE.equals(mode);
}
public static boolean isKeystoreDefinitoInTokenPolicy(IDSoggetto soggettoFruitore, AccordoServizioParteSpecifica asps) throws ProtocolException {
String mode = getKeystoreDefinitoIn(soggettoFruitore, asps);
return mode!=null && ModICostanti.MODIPA_KEYSTORE_FRUIZIONE_TOKEN_POLICY.equals(mode);
}
private static String getKeystoreDefinitoIn(IDSoggetto soggettoFruitore, AccordoServizioParteSpecifica asps) throws ProtocolException {
boolean fruizione = true;
List<ProtocolProperty> listProtocolProperties = ModIPropertiesUtils.getProtocolProperties(fruizione, soggettoFruitore, asps);
return ProtocolPropertiesUtils.getOptionalStringValuePropertyRegistry(listProtocolProperties,
ModICostanti.MODIPA_PROFILO_SICUREZZA_MESSAGGIO_FRUIZIONE_KEYSTORE_MODE);
}
public ModIKeystoreConfig(ServizioApplicativo sa, String securityMessageProfile) throws ProtocolException, UtilsException {
super(sa, securityMessageProfile);
}
public ModIKeystoreConfig(boolean fruizione, IDSoggetto soggettoFruitore, AccordoServizioParteSpecifica asps, String securityMessageProfile) throws ProtocolException, UtilsException {
super(fruizione, soggettoFruitore, asps, securityMessageProfile,
getSicurezzaMessaggioCertificatiKeyStoreTipo(),
getSicurezzaMessaggioCertificatiKeyStorePath(),
getSicurezzaMessaggioCertificatiKeyStorePassword(),
getSicurezzaMessaggioCertificatiKeyAlias(),
getSicurezzaMessaggioCertificatiKeyPassword());
}
public ModIKeystoreConfig(KeystoreParams kp) throws ProtocolException, UtilsException {
super(kp);
}
private static ModIProperties modIProperties = null;
private static synchronized void initModiProperties() throws ProtocolException {
if(modIProperties==null) {
modIProperties = ModIProperties.getInstance();
}
}
private static ModIProperties getModiProperties() throws ProtocolException {
if(modIProperties==null) {
initModiProperties();
}
return modIProperties;
}
private static String getSicurezzaMessaggioCertificatiKeyStoreTipo() throws ProtocolException {
try {
return getModiProperties().getSicurezzaMessaggioCertificatiKeyStoreTipo();
}catch(Exception e) {
throw new ProtocolException(e.getMessage(),e);
}
}
private static String getSicurezzaMessaggioCertificatiKeyStorePath() throws ProtocolException {
try {
if(getSicurezzaMessaggioCertificatiKeyStoreTipo()!=null) {
return getModiProperties().getSicurezzaMessaggioCertificatiKeyStorePath();
}
return null;
}catch(Exception e) {
throw new ProtocolException(e.getMessage(),e);
}
}
private static String getSicurezzaMessaggioCertificatiKeyStorePassword() throws ProtocolException {
try {
if(getSicurezzaMessaggioCertificatiKeyStoreTipo()!=null) {
return getModiProperties().getSicurezzaMessaggioCertificatiKeyStorePassword();
}
return null;
}catch(Exception e) {
throw new ProtocolException(e.getMessage(),e);
}
}
private static String getSicurezzaMessaggioCertificatiKeyAlias() throws ProtocolException {
try {
if(getSicurezzaMessaggioCertificatiKeyStoreTipo()!=null) {
return getModiProperties().getSicurezzaMessaggioCertificatiKeyAlias();
}
return null;
}catch(Exception e) {
throw new ProtocolException(e.getMessage(),e);
}
}
private static String getSicurezzaMessaggioCertificatiKeyPassword() throws ProtocolException {
try {
if(getSicurezzaMessaggioCertificatiKeyStoreTipo()!=null) {
return getModiProperties().getSicurezzaMessaggioCertificatiKeyPassword();
}
return null;
}catch(Exception e) {
throw new ProtocolException(e.getMessage(),e);
}
}
}