aboutsummaryrefslogtreecommitdiff
path: root/id/server/modules/moa-id-module-elga_mandate_service/src/main/java/at/gv/egovernment/moa/id/auth/modules/elgamandates/utils/ELGAMandateServiceMetadataProvider.java
diff options
context:
space:
mode:
Diffstat (limited to 'id/server/modules/moa-id-module-elga_mandate_service/src/main/java/at/gv/egovernment/moa/id/auth/modules/elgamandates/utils/ELGAMandateServiceMetadataProvider.java')
-rw-r--r--id/server/modules/moa-id-module-elga_mandate_service/src/main/java/at/gv/egovernment/moa/id/auth/modules/elgamandates/utils/ELGAMandateServiceMetadataProvider.java182
1 files changed, 126 insertions, 56 deletions
diff --git a/id/server/modules/moa-id-module-elga_mandate_service/src/main/java/at/gv/egovernment/moa/id/auth/modules/elgamandates/utils/ELGAMandateServiceMetadataProvider.java b/id/server/modules/moa-id-module-elga_mandate_service/src/main/java/at/gv/egovernment/moa/id/auth/modules/elgamandates/utils/ELGAMandateServiceMetadataProvider.java
index c9485104b..8153fa2a8 100644
--- a/id/server/modules/moa-id-module-elga_mandate_service/src/main/java/at/gv/egovernment/moa/id/auth/modules/elgamandates/utils/ELGAMandateServiceMetadataProvider.java
+++ b/id/server/modules/moa-id-module-elga_mandate_service/src/main/java/at/gv/egovernment/moa/id/auth/modules/elgamandates/utils/ELGAMandateServiceMetadataProvider.java
@@ -23,14 +23,17 @@
package at.gv.egovernment.moa.id.auth.modules.elgamandates.utils;
import java.util.List;
+import java.util.Timer;
import javax.xml.namespace.QName;
import org.opensaml.saml2.metadata.EntitiesDescriptor;
import org.opensaml.saml2.metadata.EntityDescriptor;
import org.opensaml.saml2.metadata.RoleDescriptor;
+import org.opensaml.saml2.metadata.provider.ChainingMetadataProvider;
import org.opensaml.saml2.metadata.provider.HTTPMetadataProvider;
import org.opensaml.saml2.metadata.provider.MetadataFilter;
+import org.opensaml.saml2.metadata.provider.MetadataProvider;
import org.opensaml.saml2.metadata.provider.MetadataProviderException;
import org.opensaml.xml.XMLObject;
import org.springframework.beans.factory.annotation.Autowired;
@@ -55,58 +58,47 @@ public class ELGAMandateServiceMetadataProvider extends SimpleMOAMetadataProvide
@Autowired AuthConfiguration authConfig;
- private HTTPMetadataProvider metadataProvider = null;
-
+ private ChainingMetadataProvider metadataProvider = new ChainingMetadataProvider();
- public void initialize(String metadataURL) throws MetadataProviderException {
- if (metadataProvider == null) {
- internalInitialize(metadataURL);
-
- } else {
- Logger.info("ELGA Mandate-Service metadata-provider is already initialized.");
-
- }
+
+ public ELGAMandateServiceMetadataProvider() {
+ metadataProvider.setRequireValidMetadata(true);
}
+
+ public void addMetadataWithMetadataURL(String metadataURL) throws MetadataProviderException {
+ internalInitialize(metadataURL);
+
+ }
+ public void destroy() {
+ fullyDestroy();
/* (non-Javadoc)
* @see org.opensaml.saml2.metadata.provider.MetadataProvider#requireValidMetadata()
*/
@Override
public boolean requireValidMetadata() {
- if (metadataProvider == null) {
- Logger.fatal("ELGA Mandate-Service metadata-provider is not initialized");
- return false;
-
- } else
return metadataProvider.requireValidMetadata();
+
}
/* (non-Javadoc)
* @see org.opensaml.saml2.metadata.provider.MetadataProvider#setRequireValidMetadata(boolean)
*/
@Override
- public void setRequireValidMetadata(boolean requireValidMetadata) {
- if (metadataProvider == null) {
- Logger.fatal("ELGA Mandate-Service metadata-provider is not initialized");
-
- } else
- metadataProvider.setRequireValidMetadata(requireValidMetadata);;
-
+ public void setRequireValidMetadata(boolean requireValidMetadata) {
+ metadataProvider.setRequireValidMetadata(requireValidMetadata);
+
}
/* (non-Javadoc)
* @see org.opensaml.saml2.metadata.provider.MetadataProvider#getMetadataFilter()
*/
@Override
- public MetadataFilter getMetadataFilter() {
- if (metadataProvider == null) {
- Logger.fatal("ELGA Mandate-Service metadata-provider is not initialized");
- return null;
-
- } else
+ public MetadataFilter getMetadataFilter() {
return metadataProvider.getMetadataFilter();
+
}
/* (non-Javadoc)
@@ -122,14 +114,9 @@ public class ELGAMandateServiceMetadataProvider extends SimpleMOAMetadataProvide
* @see org.opensaml.saml2.metadata.provider.MetadataProvider#getMetadata()
*/
@Override
- public XMLObject getMetadata() throws MetadataProviderException {
- if (metadataProvider == null) {
- Logger.error("ELGA Mandate-Service metadata-provider is not initialized");
- throw new MetadataProviderException("ELGA Mandate-Service metadata-provider is not initialized");
-
- }
-
+ public XMLObject getMetadata() throws MetadataProviderException {
return metadataProvider.getMetadata();
+
}
/* (non-Javadoc)
@@ -137,12 +124,8 @@ public class ELGAMandateServiceMetadataProvider extends SimpleMOAMetadataProvide
*/
@Override
public EntitiesDescriptor getEntitiesDescriptor(String name) throws MetadataProviderException {
- if (metadataProvider == null) {
- Logger.fatal("ELGA Mandate-Service metadata-provider is not initialized");
- throw new MetadataProviderException("ELGA Mandate-Service metadata-provider is not initialized");
-
- } else
- return metadataProvider.getEntitiesDescriptor(name);
+ return metadataProvider.getEntitiesDescriptor(name);
+
}
/* (non-Javadoc)
@@ -150,9 +133,24 @@ public class ELGAMandateServiceMetadataProvider extends SimpleMOAMetadataProvide
*/
@Override
public EntityDescriptor getEntityDescriptor(String entityID) throws MetadataProviderException {
- if (metadataProvider == null)
- internalInitialize(entityID);
-
+ try {
+ //search if metadata is already loaded
+ EntityDescriptor entityDesc = metadataProvider.getEntityDescriptor(entityID);
+
+ if (entityDesc != null)
+ return entityDesc;
+ else
+ Logger.info("No ELGA Mandate-Service: " + entityID + " Starting refresh process ...");
+
+ } catch (MetadataProviderException e) {
+ Logger.info("Access ELGA Mandate-Service: " + entityID + " FAILED. Reason:" + e.getMessage() + " Starting refresh process ...");
+
+ }
+
+ //(re)initialize ELGA Mandate-Service
+ internalInitialize(entityID);
+
+ //search again after reload (re)initialization
try {
EntityDescriptor entityDesc = metadataProvider.getEntityDescriptor(entityID);
if (entityDesc == null) {
@@ -174,9 +172,24 @@ public class ELGAMandateServiceMetadataProvider extends SimpleMOAMetadataProvide
*/
@Override
public List<RoleDescriptor> getRole(String entityID, QName roleName) throws MetadataProviderException {
- if (metadataProvider == null)
- internalInitialize(entityID);
+ try {
+ //search if metadata is already loaded
+ List<RoleDescriptor> role = metadataProvider.getRole(entityID, roleName);
+
+ if (role != null)
+ return role;
+ else
+ Logger.info("No ELGA Mandate-Service: " + entityID + " Starting refresh process ...");
+
+ } catch (MetadataProviderException e) {
+ Logger.info("Access ELGA Mandate-Service: " + entityID + " FAILED. Reason:" + e.getMessage() + " Starting refresh process ...");
+
+ }
+
+ //(re)initialize ELGA Mandate-Service
+ internalInitialize(entityID);
+ //search again after reload (re)initialization
return metadataProvider.getRole(entityID, roleName);
}
@@ -185,23 +198,52 @@ public class ELGAMandateServiceMetadataProvider extends SimpleMOAMetadataProvide
*/
@Override
public RoleDescriptor getRole(String entityID, QName roleName, String supportedProtocol)
- throws MetadataProviderException {
- if (metadataProvider == null)
- internalInitialize(entityID);
+ throws MetadataProviderException {
+ try {
+ //search if metadata is already loaded
+ RoleDescriptor role = metadataProvider.getRole(entityID, roleName, supportedProtocol);
+
+ if (role != null)
+ return role;
+ else
+ Logger.info("No ELGA Mandate-Service: " + entityID + " Starting refresh process ...");
+
+ } catch (MetadataProviderException e) {
+ Logger.info("Access ELGA Mandate-Service: " + entityID + " FAILED. Reason:" + e.getMessage() + " Starting refresh process ...");
+
+ }
+
+ //(re)initialize ELGA Mandate-Service
+ internalInitialize(entityID);
+ //search again after reload (re)initialization
return metadataProvider.getRole(entityID, roleName, supportedProtocol);
}
- private synchronized void internalInitialize(String metdataURL) throws MetadataProviderException {
- if (metadataProvider == null) {
- Logger.info("Initialize PVP MetadataProvider to connect ELGA Mandate-Service");
+ private synchronized void internalInitialize(String metdataURL) throws MetadataProviderException {
+
+ //check if metadata with EntityID already exists in chaining metadata provider
+ boolean addNewMetadata = true;
+ try {
+ addNewMetadata = (metadataProvider.getEntityDescriptor(metdataURL) == null);
+
+ } catch (MetadataProviderException e) {}
+
+ //switch between metadata refresh and add new metadata
+ if (addNewMetadata) {
+ //Metadata provider seems not loaded --> Add new metadata provider
+ Logger.info("Initialize PVP MetadataProvider:" + metdataURL + " to connect ELGA Mandate-Service");
String trustProfileID = authConfig.getBasicMOAIDConfiguration(ELGAMandatesAuthConstants.CONFIG_PROPS_METADATA_TRUSTPROFILE);
if (MiscUtil.isEmpty(trustProfileID)) {
Logger.error("Create ELGA Mandate-Service Client FAILED: No trustProfileID to verify PVP metadata." );
throw new MetadataProviderException("No trustProfileID to verify PVP metadata.");
}
-
+
+ //initialize Timer if it is null
+ if (timer == null)
+ timer = new Timer(true);
+
//create metadata validation filter chain
MetadataFilterChain filter = new MetadataFilterChain();
filter.addFilter(new SchemaValidationFilter(true));
@@ -211,13 +253,41 @@ public class ELGAMandateServiceMetadataProvider extends SimpleMOAMetadataProvide
filter,
ELGAMandatesAuthConstants.MODULE_NAME_FOR_LOGGING);
- if (metadataProvider == null) {
+ if (idpMetadataProvider == null) {
Logger.error("Create ELGA Mandate-Service Client FAILED.");
- throw new MetadataProviderException("Can not initialize ELGA Mandate-Service metadaa provider.");
+ throw new MetadataProviderException("Can not initialize ELGA Mandate-Service metadata provider.");
}
- metadataProvider.setRequireValidMetadata(true);
+ idpMetadataProvider.setRequireValidMetadata(true);
+ metadataProvider.addMetadataProvider(idpMetadataProvider);
+
+ } else {
+ //Metadata provider seems already loaded --> start refresh process
+ List<MetadataProvider> loadedProvider = metadataProvider.getProviders();
+ for (MetadataProvider el : loadedProvider) {
+ if (el instanceof HTTPMetadataProvider) {
+ HTTPMetadataProvider prov = (HTTPMetadataProvider)el;
+ if (prov.getMetadataURI().equals(metdataURL))
+ prov.refresh();
+
+ } else
+ Logger.warn("ELGA Metadata provider is not of Type 'HTTPMetadataProvider'! Something is suspect!!!!");
+
+ }
}
}
+
+ /* (non-Javadoc)
+ * @see at.gv.egovernment.moa.id.auth.IDestroyableObject#fullyDestroy()
+ */
+ @Override
+ public void fullyDestroy() {
+ if (metadataProvider != null) {
+ metadataProvider.destroy();
+
+ }
+
+
+ }
}