diff options
Diffstat (limited to 'id')
44 files changed, 5731 insertions, 398 deletions
| diff --git a/id/moa-id-webgui/pom.xml b/id/moa-id-webgui/pom.xml new file mode 100644 index 000000000..76660eac2 --- /dev/null +++ b/id/moa-id-webgui/pom.xml @@ -0,0 +1,53 @@ +<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> +   +    <parent> +        <groupId>MOA</groupId> +        <artifactId>id</artifactId> +        <version>2.x</version> +    </parent> +   +  <modelVersion>4.0.0</modelVersion> +  <groupId>MOA.id</groupId> +  <artifactId>moa-id-webgui</artifactId> +  <version>1.0-SNAPSHOT</version> +  <name>MOA-ID WebGUI Module</name> +   +  <properties> +    <repositoryPath>${basedir}/../../repository</repositoryPath> +  </properties> +   +  <build> +    <sourceDirectory>src/main/jave</sourceDirectory> +    <plugins> +      <plugin> +        <artifactId>maven-compiler-plugin</artifactId> +        <version>3.1</version> +        <configuration> +          <source>1.7</source> +          <target>1.7</target> +        </configuration> +      </plugin> +    </plugins> +  </build> +   +  <dependencies> +  	<dependency> +    	<groupId>at.gv.egiz.components</groupId> +    	<artifactId>egiz-configuration-meta-api</artifactId> +    	<version>0.2</version> +    </dependency> +    <dependency> +    	<groupId>at.gv.egiz.components</groupId> +    	<artifactId>egiz-spring-api</artifactId> +    	<version>0.1</version> +    </dependency> +     +    <dependency> +    	<groupId>MOA.id.server</groupId> +      <artifactId>moa-id-commons</artifactId> +    </dependency> +     +  </dependencies> +   +   +</project>
\ No newline at end of file diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/MOAIDConfigurationModul.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/MOAIDConfigurationModul.java new file mode 100644 index 000000000..72e2321e9 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/MOAIDConfigurationModul.java @@ -0,0 +1,244 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui; + +import java.io.IOException; +import java.io.InputStream; +import java.util.ArrayList; +import java.util.Iterator; +import java.util.List; +import java.util.Map; +import java.util.Map.Entry; + +import org.apache.commons.io.IOUtils; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; + +import at.gv.egiz.components.configuration.api.Configuration; +import at.gv.egiz.components.configuration.api.ConfigurationException; +import at.gv.egiz.components.configuration.file.PropertiesBasedConfiguration; +import at.gv.egiz.components.configuration.meta.api.ConfigurationModul; +import at.gv.egiz.components.configuration.meta.api.ConfigurationStorageException; +import at.gv.egiz.components.configuration.meta.api.MetadataConfiguration; +import at.gv.egiz.components.configuration.meta.api.SchemaEntry; +import at.gv.egiz.components.configuration.meta.api.impl.BaseMetadataConfiguration; +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationValidationException; +import at.gv.egovernment.moa.id.config.webgui.validation.MOAIDConfigurationValidator; + +/** + * @author tlenz + * + */ +@Service +public class MOAIDConfigurationModul implements ConfigurationModul{ + +	private static final String MODULE_NAME = "MOAIDConfigurationModul"; +	 +	private static Configuration config; +	private static Configuration meta; +	private static MetadataConfiguration metadata = null; +	 +	private List<SchemaEntry> schemaList = new ArrayList<SchemaEntry>(); +	private static final Logger logger = LoggerFactory.getLogger(MOAIDConfigurationModul.class); +	 +	static { +		logger.info("Loading class {}", MOAIDConfigurationModul.class.getName()); +		try { +			meta = new PropertiesBasedConfiguration(MOAIDConfigurationModul.class.getResourceAsStream("/gui/meta.properties")); +			 +		} catch (IOException | ConfigurationException e) { +			logger.error("Failed to build internal datasets in MOAIDConfiguration modul!"); +			 +		} +	} +	 +	@Autowired +	public void setDatabaseConfiguration(Configuration dbconfig) { +		config = dbconfig; +	} +	 +	/** +	 *  +	 */ +	public MOAIDConfigurationModul() {		 +		loadType("general", "/gui/types/general.json"); +		 +//		loadType("oa", "/gui/types/oa.json"); +		 +		//TODO: load correct types +//		loadType("vidp", "/gui/types/oa.json"); +//		loadType("iidp", "/gui/types/oa.json"); +//		loadType("gateway", "/gui/types/oa.json"); +		 +		 +	} +	 +	/* (non-Javadoc) +	 * @see at.gv.egiz.components.configuration.meta.api.ConfigurationModul#getSchemas() +	 */ +	@Override +	public List<SchemaEntry> getSchemas() { +		return schemaList; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egiz.components.configuration.meta.api.ConfigurationModul#getName() +	 */ +	@Override +	public String getName() { +		return MODULE_NAME; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egiz.components.configuration.meta.api.ConfigurationModul#getPrefix() +	 */ +	@Override +	public String getPrefix() { +		return MOAIDConfigurationConstants.PREFIX_MOAID; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egiz.components.configuration.meta.api.ConfigurationModul#getConfigurationAccess() +	 */ +	@Override +	public Configuration getConfigurationAccess() { +		return config; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egiz.components.configuration.meta.api.ConfigurationModul#getMetadataConfiguration() +	 */ +	@Override +	public MetadataConfiguration getMetadataConfiguration() { +		if (metadata == null) { +			metadata = new BaseMetadataConfiguration(config, meta);			 +			 +		} +		return metadata; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egiz.components.configuration.meta.api.ConfigurationModul#buildArrayIdentifier(java.lang.String, int, java.util.Map) +	 */ +	@Override +	public String buildArrayIdentifier(String arrayId, int refCounter, +			Map<String, String> properties) throws ConfigurationException { +		// TODO Auto-generated method stub +		return null; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egiz.components.configuration.meta.api.ConfigurationModul#storeChanges(java.util.Map, java.util.Map, java.util.List) +	 */ +	@Override +	public void storeChanges(Map<String, String> changed, +			Map<String, String> added, List<String> deleted) +			throws ConfigurationStorageException { + +		logger.debug("Start configuration saving process ..."); +		MOAIDConfigurationValidator configValidator = new MOAIDConfigurationValidator();		  +		int numOfGroups = configValidator.preProcess(changed, added, deleted); +		 +		if (configValidator.getPreProcessedConfigurationData() != null &&  +				numOfGroups > 0) { +			logger.trace("Validate {} groups of key/value pairs", numOfGroups); +			try { +				configValidator.validate(); +			 +			} catch (ConfigurationValidationException e) { +				logger.warn("Validation of MOA-ID configuration FAILED."); +				 +				//TODO: update ConfigurationStorageException to add specific information of validation errors				 +				throw new ConfigurationStorageException( +						"Configuration validation finds " + e.getValidationErrors().size() + " errors!", +						e, false, false);				 +			} +		 +			try { +				logger.trace("PreProcess configuration before saving."); +				Map<String, String> configToStore = configValidator.postProcessing(deleted); +		 +				//store all keys +				logger.debug("Store {} key/value pairs to configuration", configToStore.size()); +				Iterator<Entry<String, String>> storageInterator = configToStore.entrySet().iterator(); +				while (storageInterator.hasNext()) { +					Entry<String, String> el = storageInterator.next(); +					try { +						config.setStringValue(el.getKey(), el.getValue()); +						logger.trace("Store key: " + el.getKey() + " with value: "  +								+ el.getValue()); +					 +					} catch (ConfigurationException e) { +						logger.error("Store key: " + el.getKey() + " with value: "  +								+ el.getValue() + " FAILED.", e);				 +				 +					}				 +				} +			 +				//delete all unused keys +				logger.debug("Delete {} keys pairs from configuration", deleted.size()); +				Iterator<String> deleteInterator = deleted.iterator(); +				while (deleteInterator.hasNext()) { +					String el = deleteInterator.next(); +					try {					 +						config.deleteIds(el); +						logger.trace("Delete key {}", el); +				 +					} catch (ConfigurationException e) { +						logger.error("Delete key: " + el + " FAILED.", e);				 +					 +					}			 +				} +				 +			} catch (Exception e) { +				logger.warn("Configuration post-processing FAILED.", e); +				throw new ConfigurationStorageException("Configuration can not be stored.", e); +				 +			} +			 +			 +		} else { +			logger.info("Configuration saving process finished: No key/value pairs found.");  +			 +		} +	} +	 +	private void loadType(String name, String resource) { +		InputStream is = null; +		try { +			SchemaEntry entry = new SchemaEntry(); +			is = MOAIDConfigurationModul.class.getResourceAsStream(resource); +			entry.jsonSchema = IOUtils.toString(is); +			entry.typeName = name; +			schemaList.add(entry); +		} catch (IOException e) { +			logger.error("Failed to load Type OA!", e); +		} finally { +			IOUtils.closeQuietly(is); +		} +	} + +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/MOAIDSpringResourceProvider.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/MOAIDSpringResourceProvider.java new file mode 100644 index 000000000..61e1a1192 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/MOAIDSpringResourceProvider.java @@ -0,0 +1,65 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui; + +import org.springframework.core.io.ClassPathResource; +import org.springframework.core.io.Resource; + +import at.gv.egiz.components.spring.api.SpringResourceProvider; + +/** + * @author tlenz + * + */ +public class MOAIDSpringResourceProvider implements SpringResourceProvider { + +	private static final String SYSTEM_PROP_CONFIG = "moa.id.webconfig"; +	 +	/* (non-Javadoc) +	 * @see at.gv.egiz.components.spring.api.SpringResourceProvider#getResourcesToLoad() +	 */ +	@Override +	public Resource[] getResourcesToLoad() {			 +		ClassPathResource webguicontextconfig = new ClassPathResource("/moaid.webgui.beans.xml", MOAIDSpringResourceProvider.class); +		ClassPathResource databasecontextconfig = new ClassPathResource("/configuration.beans.xml", MOAIDSpringResourceProvider.class); +		return new Resource[] {webguicontextconfig, databasecontextconfig}; +		 +	} + +	/* (non-Javadoc) +	 * @see at.gv.egiz.components.spring.api.SpringResourceProvider#getPackagesToScan() +	 */ +	@Override +	public String[] getPackagesToScan() { +		return null; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egiz.components.spring.api.SpringResourceProvider#getName() +	 */ +	@Override +	public String getName() { +		return "MOAIDConfiguration_SpringResourceDefinition"; +	} + +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/exception/ConfigurationModulValidationException.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/exception/ConfigurationModulValidationException.java new file mode 100644 index 000000000..b2103da54 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/exception/ConfigurationModulValidationException.java @@ -0,0 +1,53 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.exception; + +import java.util.Arrays; +import java.util.List; + +/** + * @author tlenz + * + */ +public class ConfigurationModulValidationException extends +		ConfigurationValidationException { + +	/** +	 * @param errors +	 */ +	public ConfigurationModulValidationException( +			List<ValidationObjectIdentifier> errors) { +		super(errors); +	} + +	/** +	 * @param validationObjectIdentifier +	 */ +	public ConfigurationModulValidationException( +			ValidationObjectIdentifier validationObjectIdentifier) { +		super(Arrays.asList(validationObjectIdentifier)); +	} + +	private static final long serialVersionUID = 2961444276927305856L; +	 +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/exception/ConfigurationTaskValidationException.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/exception/ConfigurationTaskValidationException.java new file mode 100644 index 000000000..6ce2ccbb6 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/exception/ConfigurationTaskValidationException.java @@ -0,0 +1,54 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.exception; + +import java.util.Arrays; +import java.util.List; + +/** + * @author tlenz + * + */ +public class ConfigurationTaskValidationException extends +		ConfigurationModulValidationException { + +	/** +	 * @param errors +	 */ +	public ConfigurationTaskValidationException( +			List<ValidationObjectIdentifier> errors) { +		super(errors); +	} + +	/** +	 * @param validationObjectIdentifier +	 */ +	public ConfigurationTaskValidationException( +			ValidationObjectIdentifier validationObjectIdentifier) { +		super(Arrays.asList(validationObjectIdentifier)); +		 +	} + +	private static final long serialVersionUID = -8983804572579884044L; + +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/exception/ConfigurationValidationException.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/exception/ConfigurationValidationException.java new file mode 100644 index 000000000..859f2e45e --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/exception/ConfigurationValidationException.java @@ -0,0 +1,49 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.exception; + +import java.util.List; + +/** + * @author tlenz + * + */ +public class ConfigurationValidationException extends Exception { + +	private static final long serialVersionUID = 1L; +	 +	List<ValidationObjectIdentifier> errors = null; +	 +	/** +	 *  +	 */ +	public ConfigurationValidationException(List<ValidationObjectIdentifier> errors) { +		this.errors = errors; +	} +	 +	public List<ValidationObjectIdentifier> getValidationErrors() { +		return this.errors; +		 +	} + +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/exception/ValidationObjectIdentifier.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/exception/ValidationObjectIdentifier.java new file mode 100644 index 000000000..0a6112ebb --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/exception/ValidationObjectIdentifier.java @@ -0,0 +1,66 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.exception; + +/** + * @author tlenz + * + */ +public class ValidationObjectIdentifier { +	private String key; +	private String friendlyName; +	private String message; +	 +	/** +	 * Create a validation error object identifier +	 *  +	 * @param key configuration key +	 * @param friendlyName friendly name in configuration GUI +	 * @param message error message +	 */ +	public ValidationObjectIdentifier(String key, String friendlyName, String message) { +		this.key = key; +		this.friendlyName = friendlyName; +		this.message = message; +	} +	 +	 +	/** +	 * @return the configuration key +	 */ +	public String getKey() { +		return key; +	} +	/** +	 * @return the friendly name, which is used in the GUI  +	 */ +	public String getFriendlyName() { +		return friendlyName; +	} +	/** +	 * @return the error message +	 */ +	public String getMessage() { +		return message; +	}		 +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/helper/LanguageHelper.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/helper/LanguageHelper.java new file mode 100644 index 000000000..122626ae8 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/helper/LanguageHelper.java @@ -0,0 +1,81 @@ +/******************************************************************************* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + *******************************************************************************/ +package at.gv.egovernment.moa.id.config.webgui.helper; + +import java.text.MessageFormat; +import java.util.Locale; +import java.util.ResourceBundle; + + +public class LanguageHelper { + +	 +    private static String errorLanguage(String code, Locale locale) {            +            return ResourceBundle.getBundle("applicationResources", locale).getString(code); +             +    } + +    private static String guiLanguage(String code, Locale locale) {             +           return ResourceBundle.getBundle("applicationResources", locale).getString(code);             +             +    } + +    public static String getGUIString(String code) { +        return guiLanguage(code, getLangFromConfig()); +    } + + +    public static String getErrorString(String code) { +        return errorLanguage(code, getLangFromConfig()); +    } + +    public static String getGUIString(String code, String parameter) { +        return MessageFormat.format(getGUIString(code), parameter); +    } + +    public static String getErrorString(String code, Object[] parameter) { + +        return MessageFormat.format(getGUIString(code), parameter); +    } + +     +    private static Locale getLangFromConfig() { +    	 +    	Locale defaultLanguage = Locale.forLanguageTag("de"); +    	 +//		try { +//			ConfigurationProvider configurationProvider = ConfigurationProvider.getInstance(); +//			defaultLanguage = Locale.forLanguageTag(configurationProvider.getDefaultLanguage()); +//			 +//		} catch (ConfigurationException e) { +//			log.error("Configuration exception while getting ConfigurationProvider instance", e); +//		}  +    	 +    	 +		return defaultLanguage; +    		 + +    	 +    } +} + diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/MOAIDConfigurationValidator.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/MOAIDConfigurationValidator.java new file mode 100644 index 000000000..a1cafe702 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/MOAIDConfigurationValidator.java @@ -0,0 +1,302 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation; + +import java.util.HashMap; +import java.util.Iterator; +import java.util.List; +import java.util.Map; +import java.util.ServiceLoader; +import java.util.Map.Entry; +import java.util.Set; + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Autowired; + +import at.gv.egiz.components.configuration.api.Configuration; +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; +import at.gv.egovernment.moa.id.commons.utils.KeyValueUtils; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationModulValidationException; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationValidationException; +import at.gv.egovernment.moa.id.config.webgui.validation.modul.IModuleValidator; +import at.gv.egovernment.moa.id.config.webgui.validation.task.IDynamicLoadableTaskValidator; + +/** + * @author tlenz + * + */ +public class MOAIDConfigurationValidator { +	private static final Logger logger = LoggerFactory.getLogger(MOAIDConfigurationValidator.class); +	private static Configuration dbconfig;	 + +	private static ServiceLoader<IModuleValidator> moduleLoader =  +			ServiceLoader.load(IModuleValidator.class); +	private static Map<String, IModuleValidator> moduleValidator = null; +	 +	private static ServiceLoader<IDynamicLoadableTaskValidator> taskLoader =  +			ServiceLoader.load(IDynamicLoadableTaskValidator.class); +	 +	private Map<String, Map<String,String>> data = null; +	private boolean isDataValidated = false; +	 +	@Autowired +	public void setDatabaseConfiguration(Configuration config) { +		dbconfig = config; +		 +	} +	 +	/** +	 *  +	 */ +	public MOAIDConfigurationValidator() { +		//load modules +		if (moduleValidator == null ) { +			moduleValidator = new HashMap<String, IModuleValidator>();		 +			Iterator<IModuleValidator> moduleLoaderInterator = moduleLoader.iterator(); +			while (moduleLoaderInterator.hasNext()) { +				IModuleValidator modul = moduleLoaderInterator.next(); +				logger.info("Load validation module for key: {}", modul.getKeyPrefix()); +				moduleValidator.put(modul.getKeyPrefix(), modul); +				 +			} + +			//load tasks +			Iterator<IDynamicLoadableTaskValidator> taskLoaderInterator = taskLoader.iterator(); +			while (taskLoaderInterator.hasNext()) { +				IDynamicLoadableTaskValidator task = taskLoaderInterator.next(); +				List<String> modulesToInject = task.getModulValidatorPrefix(); +				for (String el : modulesToInject) { +					if (moduleValidator.containsKey(el)) { +						moduleValidator.get(el).addTaskValidator(task); +						logger.info("Task " + task.getName()  +								+ " is injected to module with prefix " + el); +						 +					} else { +						logger.warn("Task " + task.getName()  +								+ " could NOT injected: No module with prefix " + el); +						 +					}					 +				}				 +			}			 +		}				 +	} +	 +	/** +	 * Get the internal key/value configuration data set +	 *  +	 * @return full configuration block of key/value pairs {Map<String, String>} sorted by MOA-ID configuration groups or null if preprocessing was done +	 */ +	public Map<String, Map<String,String>> getPreProcessedConfigurationData() { +		return data; +	} +	 +	/** +	 * PreProcess MOA-ID key/value configuration before validation and sort the keys into MOA-ID configuration groups +	 *  +	 * @param changed all changed key/value pairs +	 * @param added all added key/value pairs +	 * @param deleted all deleted key/value pairs +	 * @return Number of MOA-ID configuration groups which was found +	 */	 +	public int preProcess(Map<String, String> changed, +			Map<String, String> added, List<String> deleted) {		 +		data = new HashMap<String, Map<String, String>>(); + +		//classify changed key/value pairs +		keyValueClassification(changed.entrySet().iterator(), data); +		 +		//classify new key/value pairs +		keyValueClassification(added.entrySet().iterator(), data); +		 +		return data.size(); +	} +	 +	/** +	 * Validate MOA-ID key/value configuration before saving +	 *  +	 * @throws ConfigurationValidationException +	 */ +	 +	public void validate() throws ConfigurationValidationException { +		logger.trace("Starting MOA-ID configuration validation process ..."); +		 +		Iterator<Entry<String, Map<String, String>>> groupInterator = data.entrySet().iterator(); +		while (groupInterator.hasNext()) { +			Entry<String, Map<String, String>> groupEl = groupInterator.next(); +			 +			try { +				if (groupEl.getKey().startsWith(MOAIDConfigurationConstants.PREFIX_MOAID_SERVICES)) { +					String moduleID = KeyValueUtils.getParentKey(groupEl.getKey()); +					if (moduleValidator.containsKey(moduleID)) { +						logger.trace("Starting validation process of keyGroup: " + groupEl.getKey() +								+ " with module: " + moduleValidator.get(moduleID).getName()); +						moduleValidator.get(moduleID) +							.validate(KeyValueUtils.removePrefixFromKeys(groupEl.getValue(), groupEl.getKey())); +				 +					} else +						logger.info("No ModulValidator for keygroup {} found.", moduleID); +					 +				} else if (moduleValidator.containsKey(groupEl.getKey())) { +					logger.trace("Starting validation process of keyGroup: " + groupEl.getKey() +							+ " with module: " + moduleValidator.get(groupEl.getKey()).getName()); +					moduleValidator.get(groupEl.getKey()) +						.validate(KeyValueUtils.removePrefixFromKeys(groupEl.getValue(), groupEl.getKey())); +								 +				} else { +					logger.info("No ModulValidator for keygroup {} found.", groupEl.getKey()); +				 +				} +				 +			} catch (ConfigurationModulValidationException e) { +				logger.warn("Validation of keyGroup: " + groupEl.getKey()  +						+ " FAILED with " + e.getValidationErrors().size() + " errors"); +				throw e; +				 +			} +			 +		}		 +		isDataValidated = true; +	} +	 +	/** +	 * Post-process the validated configuration to generate storeable key/value pairs    +	 * @param deleted  +	 *  +	 * @return {Map<String, String>} of key/value pairs which could be stored into configuration  +	 */ +	 +	public Map<String, String> postProcessing(List<String> deleted) { +		if (!isDataValidated) +			logger.warn("Post-Processing non validated key/value pairs!"); +		 +		Map<String, String> configToStore = new HashMap<String, String>(); +		 +		Iterator<Entry<String, Map<String, String>>> groupInterator = data.entrySet().iterator(); +		while (groupInterator.hasNext()) { +			Entry<String, Map<String, String>> groupEl = groupInterator.next(); +			 +			try { +				if (groupEl.getKey().startsWith(MOAIDConfigurationConstants.PREFIX_MOAID_SERVICES)) { +					String moduleID = KeyValueUtils.getParentKey(groupEl.getKey()); +					if (moduleValidator.containsKey(moduleID)) { +						logger.trace("Start postProcessing of keyGroup: " + groupEl.getKey() +								+ " with module: " + moduleValidator.get(moduleID).getName()); +						postProcessing(groupEl, moduleValidator.get(moduleID), configToStore, deleted); +					 +					} else +						logger.info("No Module for keygroup {} found.", moduleID); +					 +				} else if (moduleValidator.containsKey(groupEl.getKey())) { +					logger.trace("Start postProcessing of keyGroup: " + groupEl.getKey() +							+ " with module: " + moduleValidator.get(groupEl.getKey()).getName()); +					postProcessing(groupEl, moduleValidator.get(groupEl.getKey()), configToStore, deleted); +								 +				} else { +					logger.info("No ModulValidator for keygroup {} found.", groupEl.getKey()); +				 +				} +				 +			} catch (Exception e) { +				logger.error("Post-Processing for keygroup: " + groupEl.getKey() + " FAILED!", e); +				 +			} +			 +		}		 +		return configToStore;		 +	} +	 +	private void postProcessing(Entry<String, Map<String, String>> groupEl, +			IModuleValidator module, Map<String, String> configToStore, List<String> deleted ) { +		 +		//add all key/value pairs from user configuration GUI +		configToStore.putAll(KeyValueUtils.makeKeysAbsolut( +				groupEl.getValue(),  +				groupEl.getKey(),  +				MOAIDConfigurationConstants.PREFIX_MOAID));  +		 +		//add or update key/value pairs from users with module or task specific information  +		Map<String, String> toBeAdded = module.postProcessing( +				KeyValueUtils.removePrefixFromKeys(groupEl.getValue(), groupEl.getKey()),  +				deleted,  +				dbconfig);		 +		if (toBeAdded != null) { +			toBeAdded = KeyValueUtils.makeKeysAbsolut(toBeAdded, groupEl.getKey(), MOAIDConfigurationConstants.PREFIX_MOAID); +			for (Entry<String, String> el : toBeAdded.entrySet()) { +				if (configToStore.containsKey(el.getKey())) { +					logger.info("Overwrite key: " + el.getKey()  +							+ " userValue:" + configToStore.get(el.getKey())  +							+ " postProcessing: " + toBeAdded.get(el.getKey()));					 +					 +				} +				configToStore.put(el.getKey(), el.getValue()); +			} +		} +		 +	} +	 +	private void keyValueClassification(Iterator<Entry<String, String>> config, Map<String, Map<String,String>> result) {		 +		Set<String> validationModuleKeys = moduleValidator.keySet(); +		 +		while(config.hasNext()) { +			Entry<String, String> el = config.next(); +			logger.trace("Preprocess configuration element with key: "  +					+ el.getKey() + " value: " + el.getValue()); +			 +			//search configuration module +			IModuleValidator selectedModul = null; +			for (String key : validationModuleKeys) { +				if (el.getKey().startsWith(key)) { +					selectedModul = moduleValidator.get(key); +				} +			} +			 +			//group key/value pair to configuration modules +			if (selectedModul != null) { +				String groupkey = null; +				if (selectedModul.getKeyPrefix().startsWith(MOAIDConfigurationConstants.PREFIX_MOAID_SERVICES)) { +					String oaIndex = KeyValueUtils.getFirstChildAfterPrefix(el.getKey(), selectedModul.getKeyPrefix()); +					groupkey = selectedModul + "." + oaIndex; +					 +				} else +					groupkey = selectedModul.getKeyPrefix(); +				 +				if (!result.containsKey(groupkey)) { +					result.put(groupkey, new HashMap<String, String>()); +					 +				}				 +				Map<String, String> resultElement = result.get(groupkey); +				logger.trace("Put key/value pair to keyGroup: " +						+ groupkey + "with friendlyName: " + selectedModul.getName()); +				resultElement.put(el.getKey(), el.getValue()); +								 +			} else { +				logger.warn("Configuration Key {} is not part of a loaded MOA-ID configuration validation-module!", el.getKey()); +				 +			} +			 +		} +	} +	 +	 +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/AbstractModuleValidator.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/AbstractModuleValidator.java new file mode 100644 index 000000000..076f5c75e --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/AbstractModuleValidator.java @@ -0,0 +1,148 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.modul; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.regex.Pattern; + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import at.gv.egiz.components.configuration.api.Configuration; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationModulValidationException; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationTaskValidationException; +import at.gv.egovernment.moa.id.config.webgui.exception.ValidationObjectIdentifier; +import at.gv.egovernment.moa.id.config.webgui.validation.task.IDynamicLoadableTaskValidator; +import at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator; + +/** + * @author tlenz + * + */ +public abstract class AbstractModuleValidator implements IModuleValidator { +	private static final Logger logger = LoggerFactory.getLogger(AbstractModuleValidator.class); +	protected List<ITaskValidator>taskValidator = new ArrayList<ITaskValidator>(); +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.modul.IModuleValidator#validate(java.util.Map) +	 */ +	@Override +	public void validate(Map<String, String> input) +			throws ConfigurationModulValidationException {		 +		List<ValidationObjectIdentifier> errors = new ArrayList<ValidationObjectIdentifier>(); +		 +//		//perform whitelist checks +//		List<Pattern> allowedPatterns = new ArrayList<Pattern>(); +//		for (ITaskValidator task  : taskValidator) +//			allowedPatterns.addAll(task.getAllAllowedPatterns()); +// +//		for (String el : input.keySet()) { +//			boolean valid = false; +//			 +//			for (Pattern pat : allowedPatterns) { +//				if (pat.matcher(el).matches()) { +//					valid = true; +//					break; +//				} +//			} +//			 +//			if (!valid) { +//				logger.warn("Task-Validator for keyPrefix: "  +//						+ getKeyPrefix() + " found a non-whitelisted key: " + el); +//				throw new ConfigurationModulValidationException( +//						new ValidationObjectIdentifier(el, "unkown", "This key is not allowed!")); +//				 +//			} +//		} +		 +		for (ITaskValidator task  : taskValidator) { +			try { +				task.validate(input); +				 +			} catch (ConfigurationTaskValidationException e) { +				logger.debug("Task " + task.getName()  +							+ " found " + e.getValidationErrors().size()  +							+ " errors in configuration"); +				errors.addAll(e.getValidationErrors()); +			}			 +		} +		 +		if (!errors.isEmpty()) +			throw new ConfigurationModulValidationException(errors); +	} +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.modul.IModuleValidator#validate(java.util.Map) +	 */ +	public Map<String, String> postProcessing(Map<String, String> input, +			List<String> keysToDelete, Configuration dbconfig) { +		Map<String, String> added = new HashMap<String, String>(); +				 +		for (ITaskValidator task  : taskValidator) { +			try { +				Map<String, String> taskResult = task.postProcessing(input, keysToDelete, dbconfig); +				if (taskResult != null) +					added.putAll(taskResult); +				 +			} catch (Exception e) { +				logger.warn("Post processing of task: " + task.getName()  +						+ " FAILED!", e); +				 +			}			 +		} +		if (added.isEmpty()) +			return null; +		else +			return added; +		 +	} +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.modul.IModuleValidator#getKeyPrefix() +	 */ +	@Override +	abstract public String getKeyPrefix(); + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.modul.IModuleValidator#getName() +	 */ +	@Override +	abstract public String getName(); + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.modul.IModuleValidator#addTaskValidator(at.gv.egovernment.moa.id.config.webgui.validation.task.IDynamicTaskValidator) +	 */ +	@Override +	public void addTaskValidator(IDynamicLoadableTaskValidator validator) { +		taskValidator.add(validator); + +	} + +	protected void addTaskValidator(ITaskValidator validator) { +		taskValidator.add(validator); +	} +	 +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/IModuleValidator.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/IModuleValidator.java new file mode 100644 index 000000000..3ee665a87 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/IModuleValidator.java @@ -0,0 +1,79 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.modul; + +import java.util.List; +import java.util.Map; + +import at.gv.egiz.components.configuration.api.Configuration; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationModulValidationException; +import at.gv.egovernment.moa.id.config.webgui.validation.task.IDynamicLoadableTaskValidator; + +/** + * @author tlenz + * + */ +public interface IModuleValidator { + +	/** +	 * Validate a specific key/value configuration +	 *  +	 * @param input key/value configuration pairs without prefix  +	 * @throws ConfigurationModulValidationException +	 */ +	public void validate(Map<String, String> input) throws ConfigurationModulValidationException; +	 +	/** +	 * Get module specific additional key/value pairs which must be added +	 *  +	 * @param input Set of key/value pairs +	 * @param keysToDelete List<String> of keys which should be deleted  +	 * @param dbconfig {Configuration} to access the current used configuration  +	 * @return {Map<String, String>} of key/value pairs which had to be added to configuration or null +	 */ +	public Map<String, String> postProcessing(Map<String, String> input, +			List<String> keysToDelete, Configuration dbconfig); +	 +	 +	/** +	 * Key prefix for which this validation module is sensitive +	 *  +	 * @return +	 */ +	public String getKeyPrefix(); +	 +	/** +	 * Friendly name of the validation module  +	 *  +	 * @return +	 */ +	public String getName(); +	 +	 +	/** +	 *  +	 *  +	 * @param validator +	 */ +	public void addTaskValidator(IDynamicLoadableTaskValidator validator); +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/GatewayValidator.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/GatewayValidator.java new file mode 100644 index 000000000..22281c973 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/GatewayValidator.java @@ -0,0 +1,65 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.modul.impl; + +import java.util.Map; + +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationModulValidationException; +import at.gv.egovernment.moa.id.config.webgui.validation.modul.AbstractModuleValidator; +import at.gv.egovernment.moa.id.config.webgui.validation.modul.IModuleValidator; + +/** + * @author tlenz + * + */ +public class GatewayValidator extends AbstractModuleValidator { + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.IModuleValidator#validate(java.util.Map) +	 */ +	@Override +	public void validate(Map<String, String> input) +			throws ConfigurationModulValidationException { +		// TODO Auto-generated method stub + +	} +	 + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.IModuleValidator#getKeyPrefix() +	 */ +	@Override +	public String getKeyPrefix() { +		return MOAIDConfigurationConstants.PREFIX_MOAID_SERVICES_GATEWAY; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.IModuleValidator#getName() +	 */ +	@Override +	public String getName() { +		return "MOA-ID STORK<->PVP Gateway Configuration"; +	} + +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/GeneralConfigurationValidator.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/GeneralConfigurationValidator.java new file mode 100644 index 000000000..01114d235 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/GeneralConfigurationValidator.java @@ -0,0 +1,62 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.modul.impl; + +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; +import at.gv.egovernment.moa.id.config.webgui.validation.modul.AbstractModuleValidator; +import at.gv.egovernment.moa.id.config.webgui.validation.task.impl.GeneralMOAIDConfigurationTask; +import at.gv.egovernment.moa.id.config.webgui.validation.task.impl.GeneralOpenIDConfigurationTask; +import at.gv.egovernment.moa.id.config.webgui.validation.task.impl.GeneralPVP2XConfigurationTask; + +/** + * @author tlenz + * + */ +public class GeneralConfigurationValidator extends AbstractModuleValidator { + + +	public GeneralConfigurationValidator() {		 +		//add default task to this module +		addTaskValidator(new GeneralMOAIDConfigurationTask()); +		addTaskValidator(new GeneralPVP2XConfigurationTask()); +		addTaskValidator(new GeneralOpenIDConfigurationTask()); +		 +	} +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.IModuleValidator#getKeyPrefix() +	 */ +	@Override +	public String getKeyPrefix() { +		return MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.IModuleValidator#getName() +	 */ +	@Override +	public String getName() { +		return "General MOA-ID Configuration"; +	} + +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/InterfederationIDPValidator.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/InterfederationIDPValidator.java new file mode 100644 index 000000000..2e9288415 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/InterfederationIDPValidator.java @@ -0,0 +1,50 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.modul.impl; + +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; +import at.gv.egovernment.moa.id.config.webgui.validation.modul.AbstractModuleValidator; + +/** + * @author tlenz + * + */ +public class InterfederationIDPValidator extends AbstractModuleValidator { + + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.IModuleValidator#getKeyPrefix() +	 */ +	@Override +	public String getKeyPrefix() { +		return MOAIDConfigurationConstants.PREFIX_MOAID_SERVICES_IIDP; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.IModuleValidator#getName() +	 */ +	@Override +	public String getName() { +		return "MOA-ID Interfederation IDP Configuration"; +	} +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/OnlineApplicationValidator.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/OnlineApplicationValidator.java new file mode 100644 index 000000000..a71d425f2 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/OnlineApplicationValidator.java @@ -0,0 +1,65 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.modul.impl; + +import java.util.Map; + +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationModulValidationException; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationValidationException; +import at.gv.egovernment.moa.id.config.webgui.validation.modul.AbstractModuleValidator; +import at.gv.egovernment.moa.id.config.webgui.validation.modul.IModuleValidator; + +/** + * @author tlenz + * + */ +public class OnlineApplicationValidator extends AbstractModuleValidator { + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.IModuleValidator#validate(java.util.Map) +	 */ +	@Override +	public void validate(Map<String, String> input) +			throws ConfigurationModulValidationException { +		// TODO Auto-generated method stub + +	} +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.IModuleValidator#getKeyPrefix() +	 */ +	@Override +	public String getKeyPrefix() { +		return MOAIDConfigurationConstants.PREFIX_MOAID_SERVICES_OA; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.IModuleValidator#getName() +	 */ +	@Override +	public String getName() { +		return "MOA-ID Online-Application Configuration"; +	} + +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/VIDPValidator.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/VIDPValidator.java new file mode 100644 index 000000000..17dc66550 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/modul/impl/VIDPValidator.java @@ -0,0 +1,65 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.modul.impl; + +import java.util.Map; + +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationModulValidationException; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationValidationException; +import at.gv.egovernment.moa.id.config.webgui.validation.modul.AbstractModuleValidator; +import at.gv.egovernment.moa.id.config.webgui.validation.modul.IModuleValidator; + +/** + * @author tlenz + * + */ +public class VIDPValidator extends AbstractModuleValidator { + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.IModuleValidator#validate(java.util.Map) +	 */ +	@Override +	public void validate(Map<String, String> input) +			throws ConfigurationModulValidationException { +		// TODO Auto-generated method stub + +	} +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.IModuleValidator#getKeyPrefix() +	 */ +	@Override +	public String getKeyPrefix() { +		return MOAIDConfigurationConstants.PREFIX_MOAID_SERVICES_VIDP; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.IModuleValidator#getName() +	 */ +	@Override +	public String getName() { +		return "MOA-ID V-IDP Configuration"; +	} + +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/AbstractTaskValidator.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/AbstractTaskValidator.java new file mode 100644 index 000000000..394bc4da7 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/AbstractTaskValidator.java @@ -0,0 +1,106 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.task; + +import java.util.ArrayList; +import java.util.List; +import java.util.Map; +import java.util.regex.Pattern; + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import at.gv.egiz.components.configuration.api.Configuration; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationTaskValidationException; +import at.gv.egovernment.moa.id.config.webgui.exception.ValidationObjectIdentifier; + +/** + * @author tlenz + * + */ +public abstract class AbstractTaskValidator implements ITaskValidator { +	private static final Logger logger = LoggerFactory.getLogger(AbstractTaskValidator.class); +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#validate(java.util.Map) +	 */ +	@Override +	public void validate(Map<String, String> input) +			throws ConfigurationTaskValidationException { +				 +		//start task specific validation +		tastValidate(input); + +	} + +	/** +	 * Validate a specific set of key/value pairs without whitelist checks +	 *  +	 * @param input Key/Value pairs of a module for validation +	 * @throws ConfigurationModulValidationException +	 */ +	abstract protected void tastValidate(Map<String, String> input) +			throws ConfigurationTaskValidationException; +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#postProcessing(java.util.Map, java.util.List, at.gv.egiz.components.configuration.api.Configuration) +	 */ +	@Override +	abstract public Map<String, String> postProcessing(Map<String, String> input, +			List<String> keysToDelete, Configuration dbconfig); + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#getKeyPrefix() +	 */ +	@Override +	abstract public String getKeyPrefix(); + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#getName() +	 */ +	@Override +	abstract public String getName(); + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#getAllAllowedKeys() +	 */ +	@Override +	abstract public List<Pattern> getAllAllowedPatterns(); + +	protected List<Pattern> generatePatternsFromKeys(List<String> keys) { +		List<Pattern> patterns = new ArrayList<Pattern>(); +		for (String key : keys) { +			if (key != null) { +				String patternKey; +				if (key.contains(".")) { +					patternKey = key.replaceAll("\\.", "\\\\."); +				} else +					patternKey = key; +			 +				patterns.add(Pattern.compile(patternKey)); +			} else +				logger.info("Found NULL key in whitelist of task: " + getName()); +		} +		return patterns; +	} +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/IDynamicLoadableTaskValidator.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/IDynamicLoadableTaskValidator.java new file mode 100644 index 000000000..b1a38ab67 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/IDynamicLoadableTaskValidator.java @@ -0,0 +1,39 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.task; + +import java.util.List; + +/** + * @author tlenz + * + */ +public interface IDynamicLoadableTaskValidator extends ITaskValidator { + +	/** +	 * Get a list of {IModuleValidator} prefixes  in which this task should be added +	 *  +	 * @return List of prefix keys +	 */ +	public List<String> getModulValidatorPrefix(); +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/ITaskValidator.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/ITaskValidator.java new file mode 100644 index 000000000..f91440d3a --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/ITaskValidator.java @@ -0,0 +1,79 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.task; + +import java.util.List; +import java.util.Map; +import java.util.regex.Pattern; + +import at.gv.egiz.components.configuration.api.Configuration; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationTaskValidationException; + +/** + * @author tlenz + * + */ +public interface ITaskValidator { + +	/** +	 * Validate a specific set of key/value pairs (whitelist checks are included) +	 *  +	 * @param input Key/Value pairs of a module for validation +	 * @throws ConfigurationModulValidationException +	 */ +	public void validate(Map<String, String> input) throws ConfigurationTaskValidationException; +	 +	/** +	 * Get task specific key/value pairs which must be added +	 * The return keys must be full qualified according to the MOA-ID key namespace definition +	 *  +	 * @param input Set of key/value pairs +	 * @param keysToDelete List<String> of keys which should be deleted  +	 * @param dbconfig {Configuration} to access the current used configuration  +	 * @return {Map<String, String>} of key/value pairs which had to be added to configuration or null +	 */ +	public Map<String, String> postProcessing(Map<String, String> input,  +			List<String> keysToDelete, Configuration dbconfig); +	 +	/** +	 * Get a key prefix for with this validation task is sensitive +	 *  +	 * @return keyPrefix {String} or null if no prefix is defined +	 */ +	public String getKeyPrefix(); +	 +	/** +	 * Get the friendly name of this validation task +	 *  +	 * @return friendlyName {String} +	 */ +	public String getName(); +	 +	/** +	 * Get a list of keys which are white listed for this task +	 *  +	 * @return {List<Pattern>} of keys which are allowed +	 */ +	public List<Pattern> getAllAllowedPatterns(); +		 +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/GeneralMOAIDConfigurationTask.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/GeneralMOAIDConfigurationTask.java new file mode 100644 index 000000000..e4646bc04 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/GeneralMOAIDConfigurationTask.java @@ -0,0 +1,578 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.task.impl; + +import java.util.ArrayList; +import java.util.Collections; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.regex.Pattern; + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import at.gv.egiz.components.configuration.api.Configuration; +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; +import at.gv.egovernment.moa.id.commons.utils.KeyValueUtils; +import at.gv.egovernment.moa.id.commons.validation.ValidationHelper; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationTaskValidationException; +import at.gv.egovernment.moa.id.config.webgui.exception.ValidationObjectIdentifier; +import at.gv.egovernment.moa.id.config.webgui.helper.LanguageHelper; +import at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator; +import at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator; +import at.gv.egovernment.moa.util.MiscUtil; + +/** + * @author tlenz + * + */ +public class GeneralMOAIDConfigurationTask extends AbstractTaskValidator implements ITaskValidator { + +	private static final Logger log = LoggerFactory.getLogger(GeneralMOAIDConfigurationTask.class); +	public static final List<String> KEYWHITELIST; +	 +	static { +		ArrayList<String> temp = new ArrayList<String>(); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PUBLICURLPREFIX, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL));		 +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_DEFAULTS_BKU_HANDY, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_DEFAULTS_BKU_LOCAL, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_DEFAULTS_BKU_ONLINE, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_DEFAULTS_TEMPLATES_HANDY, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_DEFAULTS_TEMPLATES_LOCAL, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_DEFAULTS_TEMPLATES_ONLINE, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		 +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_AUTHBLOCK_TRANSFORMATION_BASE64, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL));		 +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_AUTHBLOCK_TRANSFORMATION_BASE64, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_AUTHBLOCK_TRANSFORMATION_NAME, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_CERTSTORE_URL, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_AUTHBLOCK_TRANSFORM, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_TRUSTPROFILE_AUTHBLOCK_PROD, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_TRUSTPROFILE_AUTHBLOCK_TEST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_TRUSTPROFILE_IDL_PROD, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_TRUSTPROFILE_IDL_TEST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_URL, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_REVOCATIONCHECKING, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_SERVICES_OVS_URL, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_SERVICES_SZRGW_URL, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_SSO_AUTHBLOCK_TEXT, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_SSO_SERVICENAME, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_SSO_TARGET, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_TIMEOUS_SSO_CREATE, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_TIMEOUS_SSO_UPDATE, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_TIMEOUTS_TRANSACTION, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_TRUSTSTORE_URL, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		 +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_SAML1_ENABLED, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_SAML1_LEGACY, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL));			 +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_SAML1_SOURCEID, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		 +		KEYWHITELIST = Collections.unmodifiableList(temp); +	} +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#validate(java.util.Map) +	 */ +	@Override +	protected void tastValidate(Map<String, String> input) +			throws ConfigurationTaskValidationException { +		List<ValidationObjectIdentifier> errors = new ArrayList<ValidationObjectIdentifier>(); +		 +		//check all keys against key whitelist +		 +		 +		String check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_SAML1_SOURCEID, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(check)) { +			if (ValidationHelper.containsPotentialCSSCharacter(check, false)) { +				log.warn("SAML1 SourceID contains potentail XSS characters: " + check); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_PROTOCOLS_SAML1_SOURCEID,  +						"SAML1 - SourceID",  +						LanguageHelper.getErrorString("validation.general.SAML1SourceID",  +						new Object[] {ValidationHelper.getPotentialCSSCharacter(false)}))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PUBLICURLPREFIX, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(check)) { +			if (!ValidationHelper.validateURL(check)) { +				log.info("Public URL Prefix is not valid"); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_PUBLICURLPREFIX,  +						"Public URL Prefix", +						LanguageHelper.getErrorString("validation.general.publicURLprefix.valid"))); +			}				 +		} else { +			log.info("PublicURL Prefix is empty."); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_PUBLICURLPREFIX,  +					"Public URL Prefix", +					LanguageHelper.getErrorString("validation.general.publicURLprefix.empty"))); +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_TIMEOUTS_TRANSACTION, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(check)) { +			if (!ValidationHelper.validateNumber(check)) { +				log.warn("Assertion Timeout is no number " + check); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_AUTH_TIMEOUTS_TRANSACTION,  +						"Timeout - Transaction", +						LanguageHelper.getErrorString("validation.general.timeouts.assertion.valid",  +						new Object[] {ValidationHelper.getNotValidOAIdentifierCharacters()}) )); +			} +		} +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_TIMEOUS_SSO_CREATE, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(check)) { +			if (!ValidationHelper.validateNumber(check)) { +				log.warn("MOASessionCreated Timeout is no number " + check); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_AUTH_TIMEOUS_SSO_CREATE,  +						"Timeout - SSO created", +						LanguageHelper.getErrorString("validation.general.timeouts.moasessioncreated.valid",  +						new Object[] {ValidationHelper.getNotValidOAIdentifierCharacters()}) )); +			} +		} +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_TIMEOUS_SSO_UPDATE, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(check)) { +			if (!ValidationHelper.validateNumber(check)) { +				log.warn("MOASessionUpdated Timeout is no number " + check); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_AUTH_TIMEOUS_SSO_UPDATE,  +						"Timeout - SSO updated", +						LanguageHelper.getErrorString("validation.general.timeouts.moasessionupdated.valid",  +						new Object[] {ValidationHelper.getNotValidOAIdentifierCharacters()}) )); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_CERTSTORE_URL, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(check)) { +			if (ValidationHelper.isValidOAIdentifier(check)) { +				log.warn("CertStoreDirectory contains potentail XSS characters: " + check); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_AUTH_CERTSTORE_URL,  +						"Certificate - CertStore Directory", +						LanguageHelper.getErrorString("validation.general.certStoreDirectory.valid",  +						new Object[] {ValidationHelper.getNotValidOAIdentifierCharacters()}) )); +			} +		} else { +			log.info("CertStoreDirectory is empty."); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_AUTH_CERTSTORE_URL,  +					"Certificate - CertStore Directory", +					LanguageHelper.getErrorString("validation.general.certStoreDirectory.empty"))); +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_DEFAULTS_BKU_HANDY, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(check)) { +			if (!ValidationHelper.validateURL(check)) { +				log.info("Not valid Handy-BKU URL"); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_DEFAULTS_BKU_HANDY,  +						"Default BKUs - Handy", +						LanguageHelper.getErrorString("validation.general.bku.handy.valid"))); +			} +		} else { +			log.info("Empty Handy-BKU URL"); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_DEFAULTS_BKU_HANDY,  +					"Default BKUs - Handy", +					LanguageHelper.getErrorString("validation.general.bku.handy.empty"))); +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_DEFAULTS_BKU_LOCAL, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(check)) { +			if (!ValidationHelper.validateURL(check)) { +				log.info("Not valid Online-BKU URL"); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_DEFAULTS_BKU_LOCAL,  +						"Default BKUs - Local", +						LanguageHelper.getErrorString("validation.general.bku.local.valid"))); +			} +		} else { +			log.info("Empty Online-BKU URL"); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_DEFAULTS_BKU_LOCAL,  +					"Default BKUs - Local", +					LanguageHelper.getErrorString("validation.general.bku.local.empty"))); +			 +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_DEFAULTS_BKU_ONLINE, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(check)) { +			if (!ValidationHelper.validateURL(check)) { +				log.info("Not valid Online-BKU URL"); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_DEFAULTS_BKU_ONLINE,  +						"Default BKUs - Online", +						LanguageHelper.getErrorString("validation.general.bku.online.valid"))); +			} +		} else { +			log.info("Empty Online-BKU URL"); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_DEFAULTS_BKU_ONLINE,  +					"Default BKUs - Online", +					LanguageHelper.getErrorString("validation.general.bku.online.empty"))); +			 +		} +				 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_SERVICES_OVS_URL, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(check)) { +			if (!ValidationHelper.validateURL(check)) { +				log.info("Not valid Online-Mandate Service URL"); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_AUTH_SERVICES_OVS_URL,  +						"Services - OVS", +						LanguageHelper.getErrorString("validation.general.mandateservice.valid"))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_AUTHBLOCK_TRANSFORM, getKeyPrefix())); +		if (MiscUtil.isEmpty(check)) { +			log.info("Empty MoaspssAuthTransformation"); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_AUTHBLOCK_TRANSFORM,  +					"MOA-SP - AuthBlocktransformation", +					LanguageHelper.getErrorString("validation.general.moasp.auth.transformation.empty"))); +		} else { +			if (ValidationHelper.containsPotentialCSSCharacter(check, false)) { +				log.info("IdentityLinkSigners is not valid: " + check); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_AUTHBLOCK_TRANSFORM, +						"MOA-SP - AuthBlocktransformationx", +						LanguageHelper.getErrorString("validation.general.moasp.auth.transformation.valid",  +							new Object[] {ValidationHelper.getPotentialCSSCharacter(false)} ))); +					 +			}  +		}			 +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_TRUSTPROFILE_AUTHBLOCK_PROD, getKeyPrefix())); +		if (MiscUtil.isEmpty(check)) { +			log.info("Empty MOA-SP/SS Authblock TrustProfile"); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_TRUSTPROFILE_AUTHBLOCK_PROD,  +					"MOA-SP - TrustProfile AuthBlock", +					LanguageHelper.getErrorString("validation.general.moasp.auth.trustprofile.empty"))); +		} else { +			if (ValidationHelper.containsPotentialCSSCharacter(check, false)) { +				log.info("Authblock TrustProfile is not valid: " +check); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_TRUSTPROFILE_AUTHBLOCK_PROD,  +						"MOA-SP - TrustProfile AuthBlock", +						LanguageHelper.getErrorString("validation.general.moasp.auth.trustprofile.valid",  +						new Object[] {ValidationHelper.getPotentialCSSCharacter(false)}) )); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_TRUSTPROFILE_IDL_PROD, getKeyPrefix())); +		if (MiscUtil.isEmpty(check)) { +			log.info("Empty MOA-SP/SS IdentityLink TrustProfile"); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_TRUSTPROFILE_IDL_PROD,  +					"MOA-SP - TrustProfile IdL", +					LanguageHelper.getErrorString("validation.general.moasp.idl.trustprofile.empty"))); +		} else { +			if (ValidationHelper.containsPotentialCSSCharacter(check, false)) { +				log.info("IdentityLink TrustProfile is not valid: " +check); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_AUTH_MOASP_TRUSTPROFILE_IDL_PROD,  +						"MOA-SP - TrustProfile IdL", +						LanguageHelper.getErrorString("validation.general.moasp.idl.trustprofile.valid",  +						new Object[] {ValidationHelper.getPotentialCSSCharacter(false)}) )); +			} +		} +		 +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_DEFAULTS_TEMPLATES_HANDY, getKeyPrefix())); +		if (MiscUtil.isEmpty(check)) { +			log.info("Empty SLRequestTemplate Handy-BKU"); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_DEFAULTS_TEMPLATES_HANDY,  +					"Default SL-Templates - Handy", +					LanguageHelper.getErrorString("validation.general.slrequest.handy.empty"))); +		} else { +			if (ValidationHelper.isNotValidIdentityLinkSigner(check)) { +				log.info("SLRequestTemplate Handy-BKU is not valid"); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_DEFAULTS_TEMPLATES_HANDY,  +						"Default SL-Templates - ", +						LanguageHelper.getErrorString("validation.general.slrequest.handy.valid"))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_DEFAULTS_TEMPLATES_LOCAL, getKeyPrefix())); +		if (MiscUtil.isEmpty(check)) { +			log.info("Empty SLRequestTemplate local BKU"); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_DEFAULTS_TEMPLATES_LOCAL,  +					"Default SL-Templates - Local", +					LanguageHelper.getErrorString("validation.general.slrequest.local.empty"))); +		} else { +			if (ValidationHelper.isNotValidIdentityLinkSigner(check)) { +				log.info("SLRequestTemplate local BKU is not valid"); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_DEFAULTS_TEMPLATES_LOCAL,  +						"Default SL-Templates - Local", +						LanguageHelper.getErrorString("validation.general.slrequest.local.valid"))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_DEFAULTS_TEMPLATES_ONLINE, getKeyPrefix())); +		if (MiscUtil.isEmpty(check)) { +			log.info("Empty SLRequestTemplate Online-BKU"); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_DEFAULTS_TEMPLATES_ONLINE,  +					"Default SL-Templates - Online ", +					LanguageHelper.getErrorString("validation.general.slrequest.online.empty"))); +		} else { +			if (ValidationHelper.isNotValidIdentityLinkSigner(check)) { +				log.info("SLRequestTemplate Online-BKU is not valid"); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_DEFAULTS_TEMPLATES_ONLINE,  +						"Default SL-Templates - Online", +						LanguageHelper.getErrorString("validation.general.slrequest.online.valid"))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_SSO_SERVICENAME, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(check)) { +			if (ValidationHelper.containsPotentialCSSCharacter(check, false)) { +				log.info("SSO friendlyname is not valid: " + check); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_AUTH_SSO_SERVICENAME,  +						"SSO - Servicename", +						LanguageHelper.getErrorString("validation.general.sso.friendlyname.valid",  +						new Object[] {ValidationHelper.getPotentialCSSCharacter(false)}) )); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_SSO_AUTHBLOCK_TEXT, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(check)) { +			if (ValidationHelper.containsPotentialCSSCharacter(check, true)) { +				log.info("SSO SpecialText is not valid: " + check); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_AUTH_SSO_AUTHBLOCK_TEXT,  +						"SSO - AuthBlocktext", +						LanguageHelper.getErrorString("validation.general.sso.specialauthtext.valid",  +						new Object[] {ValidationHelper.getPotentialCSSCharacter(true)} ))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_SSO_TARGET, getKeyPrefix())); +		if (MiscUtil.isEmpty(check)) { +			log.info("Empty SSO Target"); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_AUTH_SSO_TARGET,  +					"SSO - Target", +					LanguageHelper.getErrorString("validation.general.sso.target.empty"))); +			 +		} else { +			 +			//TODO: maybe store full bPK target (incl. prefix) +			if (!ValidationHelper.isValidAdminTarget(check)) { +				 +				if (ValidationHelper.containsPotentialCSSCharacter(check, false)) { +					log.warn("IdentificationNumber contains potentail XSS characters: " + check); +					errors.add(new ValidationObjectIdentifier( +							MOAIDConfigurationConstants.GENERAL_AUTH_SSO_TARGET,  +							"SSO - Target", +							LanguageHelper.getErrorString("validation.general.sso.target.valid",  +							new Object[] {ValidationHelper.getPotentialCSSCharacter(false)}) )); +				} +				 +				String num = check.replaceAll(" ", ""); +				 +				boolean isSSOTargetValid = false; +				for (String allowedPrefix : MOAIDConfigurationConstants.ALLOWED_WBPK_PREFIXES) { +					if (num.startsWith(allowedPrefix)) { +						isSSOTargetValid = true; +						break; +					} +				} +				 +				if (!isSSOTargetValid) { +					log.info("Not valid SSO Target"); +					errors.add(new ValidationObjectIdentifier( +							MOAIDConfigurationConstants.GENERAL_AUTH_SSO_TARGET,  +							"SSO - Target", +							LanguageHelper.getErrorString("validation.general.sso.target.valid"))); +				} +								 +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_SERVICES_SZRGW_URL, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(check)) { +			if (!ValidationHelper.validateURL(check)) { +				log.info("SZRGW URL is not valid"); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_AUTH_SERVICES_SZRGW_URL,  +						"Services - SZR-GW URL", +						LanguageHelper.getErrorString("validation.general.szrgw.url.valid"))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_TRUSTSTORE_URL, getKeyPrefix())); +		if (MiscUtil.isEmpty(check)) { +			log.info("Empty TrustCACerts Directory"); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_AUTH_TRUSTSTORE_URL,  +					"Certificate - TrustStore Directory", +					LanguageHelper.getErrorString("validation.general.trustedcacerts.empty"))); +			 +		} else { +			if (ValidationHelper.isNotValidIdentityLinkSigner(check)) { +				log.info("Not valid TrustCACerts Directory"); +				errors.add(new ValidationObjectIdentifier( +						MOAIDConfigurationConstants.GENERAL_AUTH_TRUSTSTORE_URL,  +						"Certificate - TrustStore Directory", +						LanguageHelper.getErrorString("validation.general.trustedcacerts.valid",  +						new Object[] {ValidationHelper.getNotValidOAIdentifierCharacters()}) )); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_AUTHBLOCK_TRANSFORMATION_BASE64, getKeyPrefix())); +		if (MiscUtil.isEmpty(check)) { +			log.info("AuthBlock Transformation file is empty"); +			errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_AUTH_AUTHBLOCK_TRANSFORMATION_BASE64,  +					"AuthBlock - Transformation", +					LanguageHelper.getErrorString("validation.general.slrequest.file.empty"))); +			 +		} +				 +		if (!errors.isEmpty()) +			throw new ConfigurationTaskValidationException(errors); +		 + +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#postProcessing(java.util.Map, java.util.List, at.gv.egiz.components.configuration.api.Configuration) +	 */ +	@Override +	public Map<String, String> postProcessing(Map<String, String> input, +			List<String> keysToDelete, Configuration dbconfig) { +		 +		Map<String, String> newConfigValues = new HashMap<String, String>(); +		 +		String pubURLPrefix = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PUBLICURLPREFIX, getKeyPrefix()));  +		if(pubURLPrefix.endsWith("/")) { +			int length = pubURLPrefix.length(); +			pubURLPrefix = pubURLPrefix.substring(0, length-1); +			newConfigValues.put(MOAIDConfigurationConstants.GENERAL_PUBLICURLPREFIX, pubURLPrefix); +			log.debug("Change key: " + MOAIDConfigurationConstants.GENERAL_PUBLICURLPREFIX  +					+ " from value: " + input.get(MOAIDConfigurationConstants.GENERAL_PUBLICURLPREFIX) +					+ " to value: " + pubURLPrefix); +		} +		 +		String ssoTarget = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_SSO_TARGET, getKeyPrefix())); +		if (MiscUtil.isNotEmpty(ssoTarget)) {			 +			String newTarget = null; +			if (!ValidationHelper.isValidAdminTarget(ssoTarget)) { +				String num = ssoTarget.replaceAll(" ", ""); +				String pre = null; +				if (!num.startsWith(MOAIDConfigurationConstants.PREFIX_WPBK)) { +					//add wbPK prefix +					if (num.startsWith(MOAIDConfigurationConstants.IDENIFICATIONTYPE_FN)) { +						num = num.substring(MOAIDConfigurationConstants.IDENIFICATIONTYPE_FN.length()); +					 +						num = at.gv.egovernment.moa.util.StringUtils.deleteLeadingZeros(num); +						pre = MOAIDConfigurationConstants.IDENIFICATIONTYPE_FN; +					} +				 +					if (num.startsWith(MOAIDConfigurationConstants.IDENIFICATIONTYPE_ZVR)) { +						num = num.substring(MOAIDConfigurationConstants.IDENIFICATIONTYPE_ZVR.length()); +						pre = MOAIDConfigurationConstants.IDENIFICATIONTYPE_ZVR; +					} +				 +					if (num.startsWith(MOAIDConfigurationConstants.IDENIFICATIONTYPE_ERSB)){ +						num = num.substring(MOAIDConfigurationConstants.IDENIFICATIONTYPE_ERSB.length()); +						pre = MOAIDConfigurationConstants.IDENIFICATIONTYPE_ERSB; +					} +				 +					newTarget = MOAIDConfigurationConstants.PREFIX_WPBK + pre + "+" + num; +					 +				} else { +					//wbPK prefix is already added +					newTarget = num; +					 +				} +					 +				newConfigValues.put(MOAIDConfigurationConstants.GENERAL_AUTH_SSO_TARGET  +						, newTarget); +				log.debug("Change key: " + MOAIDConfigurationConstants.GENERAL_AUTH_SSO_TARGET  +						+ " from value: " + input.get(MOAIDConfigurationConstants.GENERAL_AUTH_SSO_TARGET) +						+ " to value: " + newTarget); +				 +			} else { +				//TODO: maybe store full bPK target (incl. prefix) +				newConfigValues.put(MOAIDConfigurationConstants.GENERAL_AUTH_SSO_TARGET  +						, ssoTarget); +				log.debug("Change key: " + MOAIDConfigurationConstants.GENERAL_AUTH_SSO_TARGET  +						+ " from value: " + input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_SSO_TARGET, getKeyPrefix())) +						+ " to value: " + ssoTarget); +				 +			} +		} +		 +		//TODO: add AuthBlock transformation filename +		String authBlockTransformation = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_AUTHBLOCK_TRANSFORMATION_BASE64, getKeyPrefix())); +		String[] splittet = authBlockTransformation.split(","); +		if (splittet.length > 1) { +			newConfigValues.put(MOAIDConfigurationConstants.GENERAL_AUTH_AUTHBLOCK_TRANSFORMATION_BASE64, +					splittet[1]); +			log.debug("Extract AuthBlock Transformation from GUI upload and add it to key: {}", MOAIDConfigurationConstants.GENERAL_AUTH_AUTHBLOCK_TRANSFORMATION_BASE64); +			 +		} +		 +		if (newConfigValues.isEmpty()) +			return null; +		else +			return newConfigValues; +				 +	} +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#getKeyPrefix() +	 */ +	@Override +	public String getKeyPrefix() { +		return MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#getName() +	 */ +	@Override +	public String getName() { +		return "General MOA-ID Configuration Task"; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator#getAllAllowedKeys() +	 */ +	@Override +	public List<Pattern> getAllAllowedPatterns() { +		return generatePatternsFromKeys(KEYWHITELIST); +	} +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/GeneralOpenIDConfigurationTask.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/GeneralOpenIDConfigurationTask.java new file mode 100644 index 000000000..95f6c8349 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/GeneralOpenIDConfigurationTask.java @@ -0,0 +1,95 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.task.impl; + +import java.util.ArrayList; +import java.util.Collections; +import java.util.List; +import java.util.Map; +import java.util.regex.Pattern; + +import at.gv.egiz.components.configuration.api.Configuration; +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; +import at.gv.egovernment.moa.id.commons.utils.KeyValueUtils; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationTaskValidationException; +import at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator; + +/** + * @author tlenz + * + */ +public class GeneralOpenIDConfigurationTask extends AbstractTaskValidator { + +	private static final List<String> KEYWHITELIST; +	 +	static { +		ArrayList<String> temp = new ArrayList<String>(); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_OPENID_ENABLED, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL));		 +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_OPENID_LEGACY, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL));		 +		 +		KEYWHITELIST = Collections.unmodifiableList(temp); +	} +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator#tastValidate(java.util.Map) +	 */ +	@Override +	protected void tastValidate(Map<String, String> input) +			throws ConfigurationTaskValidationException { + +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator#postProcessing(java.util.Map, java.util.List, at.gv.egiz.components.configuration.api.Configuration) +	 */ +	@Override +	public Map<String, String> postProcessing(Map<String, String> input, +			List<String> keysToDelete, Configuration dbconfig) { +		return null; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator#getKeyPrefix() +	 */ +	@Override +	public String getKeyPrefix() { +		return MOAIDConfigurationConstants.GENERAL_PROTOCOLS_OPENID; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator#getName() +	 */ +	@Override +	public String getName() { +		return "General OpenID Configuration Task"; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator#getAllAllowedKeys() +	 */ +	@Override +	public List<Pattern> getAllAllowedPatterns() { +		return generatePatternsFromKeys(KEYWHITELIST); +	} + +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/GeneralPVP2XConfigurationTask.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/GeneralPVP2XConfigurationTask.java new file mode 100644 index 000000000..46dce77a0 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/GeneralPVP2XConfigurationTask.java @@ -0,0 +1,236 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.task.impl; + +import java.util.ArrayList; +import java.util.Arrays; +import java.util.Collections; +import java.util.List; +import java.util.Map; +import java.util.regex.Pattern; + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import at.gv.egiz.components.configuration.api.Configuration; +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; +import at.gv.egovernment.moa.id.commons.utils.KeyValueUtils; +import at.gv.egovernment.moa.id.commons.validation.ValidationHelper; +import at.gv.egovernment.moa.id.config.webgui.exception.ValidationObjectIdentifier; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationTaskValidationException; +import at.gv.egovernment.moa.id.config.webgui.helper.LanguageHelper; +import at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator; +import at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator; +import at.gv.egovernment.moa.util.MiscUtil; + +/** + * @author tlenz + * + */ +public class GeneralPVP2XConfigurationTask extends AbstractTaskValidator implements ITaskValidator { +	private static final Logger logger = LoggerFactory.getLogger(GeneralPVP2XConfigurationTask.class); +	 +	private static final List<String> KEYWHITELIST; +	 +	static { +		ArrayList<String> temp = new ArrayList<String>(); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_ENABLED, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		 +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_LEGACY, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_COMPANY, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_FAMLIYNAME, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_GIVENNAME, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_MAIL, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_PHONE, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_TYPE, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_ORG_FULLNAME, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_ORG_SHORTNAME, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_ORG_URL, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_SERVICENAMME, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL));		 +		 +		KEYWHITELIST = Collections.unmodifiableList(temp); +	} +	 +	public static final List<String> AllowedTypes= Arrays.asList( +			"technical",  +			"support",  +			"administrative", +			"billing", +			"other"); +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#validate(java.util.Map) +	 */ +	@Override +	protected void tastValidate(Map<String, String> input) +			throws ConfigurationTaskValidationException { + +		List<ValidationObjectIdentifier> errors = new ArrayList<ValidationObjectIdentifier>(); +		 +		String check =  +				input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_SERVICENAMME, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		if (MiscUtil.isNotEmpty(check)) { +			if (ValidationHelper.containsPotentialCSSCharacter(check, false)) { +				logger.info("PVP2 IssuerName is not valid: " + check); +				errors.add(new ValidationObjectIdentifier(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_SERVICENAMME,  +						"Service Name",  +						LanguageHelper.getErrorString("validation.general.protocol.pvp2.issuername.valid",  +						new Object[] {ValidationHelper.getPotentialCSSCharacter(false)}))); +			} +		} +		 +		check =  +				input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_ORG_FULLNAME, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		if (MiscUtil.isNotEmpty(check)) { +			if (ValidationHelper.containsPotentialCSSCharacter(check, false)) { +				logger.info("PVP2 organisation display name is not valid: " + check); +				errors.add(new ValidationObjectIdentifier(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_ORG_FULLNAME,  +						"Organisation - Full name",						 +						LanguageHelper.getErrorString("validation.general.protocol.pvp2.org.displayname.valid",  +						new Object[] {ValidationHelper.getPotentialCSSCharacter(false)}))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_ORG_SHORTNAME, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		if (MiscUtil.isNotEmpty(check)) { +			if (ValidationHelper.containsPotentialCSSCharacter(check, false)) { +				logger.info("PVP2 organisation name is not valid: " + check); +				errors.add(new ValidationObjectIdentifier(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_ORG_SHORTNAME,  +						"Organisation - Short name",							 +						LanguageHelper.getErrorString("validation.general.protocol.pvp2.org.name.valid",  +						new Object[] {ValidationHelper.getPotentialCSSCharacter(false)}))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_ORG_URL, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		if (MiscUtil.isNotEmpty(check)) { +			if (!ValidationHelper.validateURL(check)) { +				logger.info("PVP2 organisation URL is not valid"); +				errors.add(new ValidationObjectIdentifier(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_ORG_URL,  +						"Organisation - URL",	 +						LanguageHelper.getErrorString("validation.general.protocol.pvp2.org.url.valid"))); +			} +		} +		 +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_COMPANY, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		if (MiscUtil.isNotEmpty(check)) { +			if (ValidationHelper.containsPotentialCSSCharacter(check, false)) { +				logger.info("PVP2 Contact: Company is not valid: " + check); +				errors.add(new ValidationObjectIdentifier(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_COMPANY,  +						"Contact - Company", +						LanguageHelper.getErrorString("validation.general.protocol.pvp2.contact.company.valid",  +						new Object[] {ValidationHelper.getPotentialCSSCharacter(false)}))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_GIVENNAME, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		if (MiscUtil.isNotEmpty(check)) { +			if (ValidationHelper.containsPotentialCSSCharacter(check, false)) { +				logger.info("PVP2 Contact: GivenName is not valid: " + check); +				errors.add(new ValidationObjectIdentifier(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_GIVENNAME,  +						"Contact - GivenName", +						LanguageHelper.getErrorString("validation.general.protocol.pvp2.contact.givenname.valid",  +						new Object[] {ValidationHelper.getPotentialCSSCharacter(false)}))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_FAMLIYNAME, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		if (MiscUtil.isNotEmpty(check)) { +			if (ValidationHelper.containsPotentialCSSCharacter(check, false)) { +				logger.info("PVP2 Contact: SureName is not valid: " + check); +				errors.add(new ValidationObjectIdentifier(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_FAMLIYNAME,  +						"Contact - FamilyName", +						LanguageHelper.getErrorString("validation.general.protocol.pvp2.contact.surename.valid",  +						new Object[] {ValidationHelper.getPotentialCSSCharacter(false)}))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_TYPE, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		if (MiscUtil.isNotEmpty(check)) { +			if (!AllowedTypes.contains(check)) { +				errors.add(new ValidationObjectIdentifier(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_TYPE,  +						"Contact - Type", +						LanguageHelper.getErrorString("validation.general.protocol.pvp2.contact.type.valid"))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_MAIL, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		if (MiscUtil.isNotEmpty(check)) { +			if (!ValidationHelper.isEmailAddressFormat(check)) { +				errors.add(new ValidationObjectIdentifier(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_MAIL,  +						"Contact - Mail", +						LanguageHelper.getErrorString("validation.general.protocol.pvp2.contact.mail.valid"))); +			} +		} +		 +		check = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_PHONE, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		if (MiscUtil.isNotEmpty(check)) { +			if (!ValidationHelper.validatePhoneNumber(check)) { +				errors.add(new ValidationObjectIdentifier(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_PHONE,  +						"Contact - Phone", +						LanguageHelper.getErrorString("validation.general.protocol.pvp2.contact.phone.valid"))); +			} +		} +		 +		if (!errors.isEmpty()) +			throw new ConfigurationTaskValidationException(errors); + +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#postProcessing(java.util.Map, java.util.List, at.gv.egiz.components.configuration.api.Configuration) +	 */ +	@Override +	public Map<String, String> postProcessing(Map<String, String> input, +			List<String> keysToDelete, Configuration dbconfig) { +		return null; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#getKeyPrefix() +	 */ +	@Override +	public String getKeyPrefix() { +		return MOAIDConfigurationConstants.GENERAL_PROTOCOLS_PVP2X; +		 +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#getName() +	 */ +	@Override +	public String getName() { +		return "General PVP2X Configuration Task"; +		 +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator#getAllAllowedKeys() +	 */ +	@Override +	public List<Pattern> getAllAllowedPatterns() { +		return generatePatternsFromKeys(KEYWHITELIST); +	} + +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/GeneralSTORKConfigurationTask.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/GeneralSTORKConfigurationTask.java new file mode 100644 index 000000000..a12c8f0cd --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/GeneralSTORKConfigurationTask.java @@ -0,0 +1,612 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.task.impl; + +import java.util.ArrayList; +import java.util.Arrays; +import java.util.Collections; +import java.util.HashMap; +import java.util.Iterator; +import java.util.List; +import java.util.Map; +import java.util.regex.Pattern; + +import org.apache.commons.collections4.map.HashedMap; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import at.gv.egiz.components.configuration.api.Configuration; +import at.gv.egiz.components.configuration.api.ConfigurationException; +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; +import at.gv.egovernment.moa.id.commons.utils.KeyValueUtils; +import at.gv.egovernment.moa.id.commons.validation.ValidationHelper; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationTaskValidationException; +import at.gv.egovernment.moa.id.config.webgui.exception.ValidationObjectIdentifier; +import at.gv.egovernment.moa.id.config.webgui.helper.LanguageHelper; +import at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator; +import at.gv.egovernment.moa.id.config.webgui.validation.task.IDynamicLoadableTaskValidator; +import at.gv.egovernment.moa.util.MiscUtil; + +/** + * @author tlenz + * + */ +public class GeneralSTORKConfigurationTask extends AbstractTaskValidator implements +		IDynamicLoadableTaskValidator { +	private static final Logger log = LoggerFactory.getLogger(GeneralSTORKConfigurationTask.class); +	 +public static final List<String> KEYWHITELIST; +	 +	static { +		ArrayList<String> temp = new ArrayList<String>(); +		temp.add( +				KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL) +				+ ".\\S?." + MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST_MANDATORY); +		 +		temp.add( +				KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL) +				+ ".\\S?." + MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST_NAME); +		 +		temp.add( +				KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL) +				+ ".\\S?." + MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST_SUPPORT_XMLDSIG); +		 +		temp.add( +				KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL) +				+ ".\\S?." + MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST_COUNTRY); +		 +		temp.add( +				KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL) +				+ ".\\S?." + MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST_URL); +		 +		temp.add( +				KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_QAA, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); + +		 +		KEYWHITELIST = Collections.unmodifiableList(temp); +	} +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#validate(java.util.Map) +	 */ +	@Override +	public void tastValidate(Map<String, String> input) +			throws ConfigurationTaskValidationException { +		List<ValidationObjectIdentifier> errors = new ArrayList<ValidationObjectIdentifier>(); +		Map<String, String> validatedCPeps = new HashedMap<String, String>(); +		List<String> validatedAttributes = new ArrayList<String>(); +		 +		//validate C-PEPS entries +		Map<String, String> cPepsList = KeyValueUtils.getSubSetWithPrefix(input,  +				KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +		if (!cPepsList.isEmpty()) { +			Iterator<String> cPepsKeys = cPepsList.keySet().iterator(); +			while (cPepsKeys.hasNext()) { +				String cpepsKey = cPepsKeys.next(); +				String index = KeyValueUtils.getParentKey(cpepsKey); +				 +				if (cpepsKey.endsWith(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST_COUNTRY)) { +					String cc = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL) +							+ "." + cpepsKey); +					String url = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL) +							+ "." + index + "."  +							+ MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST_URL); +					 +					log.trace("Extract C-PEPS for country: " + cc + " with URL:" + url); +					if (!validatedCPeps.containsKey(cc)) { +						if (MiscUtil.isNotEmpty(cc)) { +							if (ValidationHelper.containsPotentialCSSCharacter(cc, false)) { +								log.warn("CPEPS config countrycode contains potentail XSS characters: " + cc); +								errors.add(new ValidationObjectIdentifier( +										MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST +											+ "." + cpepsKey,  +										"STORK - CPEPS Country", +										LanguageHelper.getErrorString("validation.stork.cpeps.cc", +												new Object[] {ValidationHelper.getPotentialCSSCharacter(false)}))); +							} +							if(!cc.toLowerCase().matches("^[a-z][a-z]$")) { +								log.warn("CPEPS config countrycode does not comply to ISO 3166-2 : " + cc); +								errors.add(new ValidationObjectIdentifier( +										MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST +											+ "." + cpepsKey,  +										"STORK - CPEPS Country", +										LanguageHelper.getErrorString("validation.stork.cpeps.cc", +										new Object[] {cc}))); +							} +						} else { +							log.warn("CPEPS config countrycode is empty : " + cc); +							errors.add(new ValidationObjectIdentifier( +								MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST +									+ "." + cpepsKey,  +								"STORK - CPEPS Country", +								LanguageHelper.getErrorString("validation.stork.cpeps.empty", +								new Object[] {cc}))); +						} + +						// check url +						if (MiscUtil.isNotEmpty(url)) { +							if (!ValidationHelper.validateURL(url)) { +								log.info("CPEPS config URL is invalid : " + url); +								errors.add(new ValidationObjectIdentifier( +									MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST +										+ "." + index + "."  +										+ MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST_URL,  +									"STORK - CPEPS URL", +									LanguageHelper.getErrorString("validation.stork.cpeps.url"))); +							} +						} else { +							log.warn("CPEPS config url is empty : " + url); +							errors.add(new ValidationObjectIdentifier( +								MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST +									+ "." + index + "."  +									+ MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST_URL,  +								"STORK - CPEPS URL", +								LanguageHelper.getErrorString("validation.stork.cpeps.empty", +								new Object[] {url}))); +							 +						}					 +						validatedCPeps.put(cc, url); +						 +					} else { +						log.warn("Duplicated C-PEPS country with countryCode: " + cc + " found."); +						errors.add(new ValidationObjectIdentifier( +								MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST +								+ "." + cpepsKey,  +							"STORK - CPEPS Country", +							LanguageHelper.getErrorString("validation.stork.cpeps.duplicate"))); +						 +					} +				}				 +			}						 +		} +		 +	 +		// check qaa		 +		try { +			int qaa = Integer.valueOf(input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_QAA, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL))); +			if(1 > qaa && 4 < qaa) { +				log.warn("QAA is out of range : " + qaa); +				errors.add(new ValidationObjectIdentifier( +					MOAIDConfigurationConstants.GENERAL_AUTH_STORK_QAA,  +					"STORK - QAA Level", +					LanguageHelper.getErrorString("validation.stork.qaa.outofrange", +					new Object[] {qaa}))); +			} +		} catch (Exception e) { +			log.warn("STORK QAA can not parsed : " + input.get(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_QAA)); +			errors.add(new ValidationObjectIdentifier( +				MOAIDConfigurationConstants.GENERAL_AUTH_STORK_QAA,  +				"STORK - QAA Level", +				LanguageHelper.getErrorString("validation.stork.qaa.outofrange", +				new Object[] {input.get(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_QAA)}))); +			 +		} + +		 +		// check attributes +		Map<String, String> attributeList = KeyValueUtils.getSubSetWithPrefix(input,  +				KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL));		 +		if (!attributeList.isEmpty()) {			 +			for(String key : attributeList.keySet()) { +				if (key.endsWith(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST_NAME)) { +					String value = attributeList.get(key); +					if (!validatedAttributes.contains(value)) { +						if (ValidationHelper.containsPotentialCSSCharacter(value, true)) { +							log.warn("default attributes contains potentail XSS characters: " + value); +							errors.add(new ValidationObjectIdentifier( +									MOAIDConfigurationConstants.GENERAL_AUTH_STORK_QAA,  +									"STORK - Attributes", +									LanguageHelper.getErrorString("validation.stork.requestedattributes", +											new Object[] {ValidationHelper.getPotentialCSSCharacter(true)}))); +						} +						if(!value.toLowerCase().matches("^[a-z0-9]*$")) { +							log.warn("default attributes do not match the requested format : " + value); +							errors.add(new ValidationObjectIdentifier( +									MOAIDConfigurationConstants.GENERAL_AUTH_STORK_QAA,  +									"STORK - Attributes", +									LanguageHelper.getErrorString("validation.stork.requestedattributes", +											new Object[] {value}))); +						} +						validatedAttributes.add(value); +						 +					} else { +						log.warn("Duplicated STORK attribute: " + value + " found."); +						errors.add(new ValidationObjectIdentifier( +								MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST +								+ "." + key,  +							"STORK - Attributes", +							LanguageHelper.getErrorString("validation.stork.requestedattributes"))); +						 +					} +				} +			} +			 +		} +		 +		 +		if (!errors.isEmpty()) +			throw new ConfigurationTaskValidationException(errors); + +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#postProcessing(java.util.Map, java.util.List, at.gv.egiz.components.configuration.api.Configuration) +	 */ +	@Override +	public Map<String, String> postProcessing(Map<String, String> input, +			List<String> keysToDelete, Configuration dbconfig) { +		List<String> currentCEPSCountries = new ArrayList<String>(); +		List<String> currentAttributeNames = new ArrayList<String>(); +		 +		List<String> cPESCountriesToAdd = new ArrayList<String>(); +		List<String> attributeNamesToAdd = new ArrayList<String>(); +		List<String> cPESCountriesToDelete = new ArrayList<String>(); +		List<String> attributeNamesToDelete = new ArrayList<String>(); +		 +		Map<String, String> newConfigValues = new HashMap<String, String>(); +		 +		try { +			//load current configuration +			String[] currentCPEPSKeys = dbconfig.findConfigurationId( +					MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST  +						+ ".%." +						+ MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST_COUNTRY);			 +			if (currentCPEPSKeys != null) { +				for (String el : currentCPEPSKeys) { +					String cc = dbconfig.getStringValue(el); +					if (MiscUtil.isNotEmpty(cc)) +						currentCEPSCountries.add(cc); +					 +					else { +						//if empty, mark do delete +						String keyToDelete = KeyValueUtils.getParentKey(el) + ".*"; +						log.trace("Mark C-PEPS key: {} for deleting.", keyToDelete); +						keysToDelete.add(keyToDelete); +					} +				} +				cPESCountriesToDelete.addAll(currentCEPSCountries); +			} +			 +			String[] currentAttributeKeys = dbconfig.findConfigurationId( +					MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST  +						+ ".%." +						+ MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST_NAME); +			if (currentAttributeKeys != null) { +				for (String el : currentAttributeKeys) { +					String cc = dbconfig.getStringValue(el); +					if (MiscUtil.isNotEmpty(cc)) +						currentAttributeNames.add(cc); +					 +					else { +						//if empty, mark do delete +						String keyToDelete = KeyValueUtils.getParentKey(el) + ".*"; +						log.trace("Mark empty STORK attribute key: {} for deleting.", keyToDelete); +						keysToDelete.add(keyToDelete); +						 +					} +				} +				attributeNamesToDelete.addAll(currentAttributeNames); +			} +			 +			//parse new configuration +			Map<String, String> cPepsList = KeyValueUtils.getSubSetWithPrefix(input,  +					KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +			if (!cPepsList.isEmpty()) { +				Iterator<String> cPepsKeys = cPepsList.keySet().iterator(); +				while (cPepsKeys.hasNext()) { +					String cpepsKey = cPepsKeys.next(); +					 +					if (cpepsKey.endsWith(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST_COUNTRY)) { +						String cc = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL) +								+ "." + cpepsKey); +						 +						//check new configuration against current configuration +						if (currentCEPSCountries.contains(cc)) { +							log.trace("C-PEPS for country {} is already in configuration", cc); +							cPESCountriesToDelete.remove(cc); +							 +						} else { +							if (MiscUtil.isNotEmpty(cc)) { +								log.trace("C-PEPS for country {} must be added to Service configurations", cc); +								cPESCountriesToAdd.add(cc); +								 +							}  +						}						 +					} +				} +			} +			 +			Map<String, String> attributeList = KeyValueUtils.getSubSetWithPrefix(input,  +					KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL)); +			if (!attributeList.isEmpty()) { +				Iterator<String> attributeKeys = attributeList.keySet().iterator(); +				while (attributeKeys.hasNext()) { +					String attributeKey = attributeKeys.next(); +					 +					if (attributeKey.endsWith(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST_NAME)) { +						String attributeName = input.get(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST, MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL) +									+ "." + attributeKey); +						 +						//check new configuration against current configuration +						if (currentAttributeNames.contains(attributeName)) { +							log.trace("STORK Attribute {} is already in configuration", attributeName); +							attributeNamesToDelete.remove(attributeName); +							 +						} else { +							if (MiscUtil.isNotEmpty(attributeName)) { +								log.trace("STORK Attribute {} must be added to Service configurations", attributeName); +								attributeNamesToAdd.add(attributeName); +							 +							}						}						 +					} +				} +			} +			 +			//add new key/value pairs to online Applications +			if (!cPESCountriesToAdd.isEmpty() || !attributeNamesToAdd.isEmpty()) { +				String[] currentOAServices = dbconfig.findConfigurationId( +						MOAIDConfigurationConstants.PREFIX_MOAID_SERVICES_OA +						+ ".%." +						+ MOAIDConfigurationConstants.SERVICE_UNIQUEIDENTIFIER); +			 +				for(String el : currentOAServices) { +					String oaKey = KeyValueUtils.getParentKey(el);					 +					String[] oaCPEPSList = dbconfig.findConfigurationId( +							oaKey + "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_COUNTRIES_LIST							 +							+ ".%." +							+ MOAIDConfigurationConstants.SERVICE_AUTH_STORK_COUNTRIES_LIST_COUNTRYCODE); + +					int nextListCounter = KeyValueUtils.findNextFreeListCounter(oaCPEPSList, oaKey + "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_COUNTRIES_LIST); +					 +					//get all C-PEPS countries from OA   +					List<String> actuallyAddedOACPEPS = new ArrayList<String>(); +					for (String oaCPEPS : oaCPEPSList) { +						String oaCC = dbconfig.getStringValue(oaCPEPS); +						if (MiscUtil.isNotEmpty(oaCC) && !actuallyAddedOACPEPS.contains(oaCC)) +							actuallyAddedOACPEPS.add(oaCC); +						 +					} +						 +					for (String cc : cPESCountriesToAdd) { +						if (!actuallyAddedOACPEPS.contains(cc)) { +							log.debug("Add key: " +									+ oaKey +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_COUNTRIES_LIST +									+ "." + String.valueOf(nextListCounter) +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_COUNTRIES_LIST_COUNTRYCODE +									+ " and value: " + cc + " to configuration."); +							newConfigValues.put(oaKey +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_COUNTRIES_LIST +									+ "." + String.valueOf(nextListCounter) +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_COUNTRIES_LIST_COUNTRYCODE +									, cc); +						 +							log.debug("Add key: " +									+ oaKey +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_COUNTRIES_LIST +									+ "." + String.valueOf(nextListCounter) +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_COUNTRIES_LIST_ENABLED +									+ " and value: true" + " to configuration."); +							newConfigValues.put(oaKey +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_COUNTRIES_LIST +									+ "." + String.valueOf(nextListCounter) +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_COUNTRIES_LIST_ENABLED +									, String.valueOf(true)); +						 +							nextListCounter++; +							 +						} else { +							log.info("Configuration is maybe inconsistend! New C-PEPS country: " +									+ cc + " is already added on Service: " + oaKey); +							 +						} +					} +					 +					String[] oaAttributeList = dbconfig.findConfigurationId( +							oaKey + "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST							 +							+ ".%." +							+ MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST_NAME); + +					int nextAttributeListCounter = KeyValueUtils.findNextFreeListCounter(oaAttributeList, oaKey + "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST); +					 +					//get all STORK attributes from OA   +					List<String> actuallyAddedOAAttributes = new ArrayList<String>(); +					for (String oaAttr : oaAttributeList) { +						String oaAttrName = dbconfig.getStringValue(oaAttr); +						if (MiscUtil.isNotEmpty(oaAttrName) && !actuallyAddedOAAttributes.contains(oaAttrName)) +							actuallyAddedOAAttributes.add(oaAttrName); +						 +					} +					 +					for (String attrName : attributeNamesToAdd) { +						if (!actuallyAddedOAAttributes.contains(attrName)) { +							log.debug("Add key: " +									+ oaKey +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST +									+ "." + String.valueOf(nextAttributeListCounter) +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST_NAME +									+ " and value: " + attrName + " to configuration."); +							newConfigValues.put(oaKey +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST +									+ "." + String.valueOf(nextAttributeListCounter) +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST_NAME +									, attrName); +						 +							log.debug("Add key: " +									+ oaKey +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST +									+ "." + String.valueOf(nextAttributeListCounter) +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST_REQUESTED +									+ " and value: true" + " to configuration."); +							newConfigValues.put(oaKey +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST +									+ "." + String.valueOf(nextAttributeListCounter) +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST_REQUESTED +									, String.valueOf(true)); +						 +							log.debug("Add key: " +									+ oaKey +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST +									+ "." + String.valueOf(nextAttributeListCounter) +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST_MANDATORY +									+ " and value: false" + " to configuration."); +							newConfigValues.put(oaKey +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST +									+ "." + String.valueOf(nextAttributeListCounter) +									+ "." + MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST_MANDATORY +									, String.valueOf(false)); +							 +						} else { +							log.info("Configuration is maybe inconsistend! New STORK attribute: " +									+ attrName + " is already added on Service: " + oaKey); +							 +						} +					} +				} +			} +			 +				//delete unused key/value pairs from online applications +				if (!cPESCountriesToDelete.isEmpty()) { +					for (String el : cPESCountriesToDelete) { +						//mark general config to delete +						String[] generalCPEPS = dbconfig.findConfigurationId( +								MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST +								+ ".%." +								+ MOAIDConfigurationConstants.GENERAL_AUTH_STORK_CPEPS_LIST_COUNTRY); +						 +						for (String ccKey : generalCPEPS) { +							String storedCC = dbconfig.getStringValue(ccKey); +							if (el.equals(storedCC)) { +								//delete C-PEPS +								String keyToDelete = KeyValueUtils.getParentKey(ccKey) + ".*"; +								log.debug("Mark key: " + keyToDelete + " for deleting."); +								keysToDelete.add(keyToDelete); +								 +							}							 +						} +						 +						//mark service key to delete +						String[] servicesOAs = dbconfig.findConfigurationId( +								MOAIDConfigurationConstants.PREFIX_MOAID_SERVICES_OA +								+ ".%." +								+ MOAIDConfigurationConstants.SERVICE_AUTH_STORK_COUNTRIES_LIST +								+ ".%." +								+ MOAIDConfigurationConstants.SERVICE_AUTH_STORK_COUNTRIES_LIST_COUNTRYCODE); +						 +						for (String ccKey : servicesOAs) { +							String storedCC = dbconfig.getStringValue(ccKey); +							if (el.equals(storedCC)) { +								//delete C-PEPS +								String keyToDelete = KeyValueUtils.getParentKey(ccKey) + ".*"; +								log.debug("Mark key: " + keyToDelete + " for deleting."); +								keysToDelete.add(keyToDelete); +								 +							}							 +						} +					}					 +				} +				if (!attributeNamesToDelete.isEmpty()) {					 +					for (String el : attributeNamesToDelete) { +						//mark general config to delete +						String[] generalAttributes = dbconfig.findConfigurationId( +								MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST +								+ ".%." +								+ MOAIDConfigurationConstants.GENERAL_AUTH_STORK_ATTRIBUTES_LIST_NAME); +						 +						for (String attrKey : generalAttributes) { +							String storedAttr = dbconfig.getStringValue(attrKey); +							if (el.equals(storedAttr)) { +								//delete C-PEPS +								String keyToDelete = KeyValueUtils.getParentKey(attrKey) + ".*"; +								log.debug("Mark key: " + keyToDelete + " for deleting."); +								keysToDelete.add(keyToDelete); +								 +							}							 +						} +						 +						 +						//mark service key to delete +						String[] servicesOAs = dbconfig.findConfigurationId( +								MOAIDConfigurationConstants.PREFIX_MOAID_SERVICES_OA +								+ ".%." +								+ MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST +								+ ".%." +								+ MOAIDConfigurationConstants.SERVICE_AUTH_STORK_ATTRIBUTES_LIST_NAME); +						 +						for (String attrKey : servicesOAs) { +							String storedAttr = dbconfig.getStringValue(attrKey); +							if (el.equals(storedAttr)) { +								//delete C-PEPS +								String keyToDelete = KeyValueUtils.getParentKey(attrKey) + ".*"; +								log.debug("Mark key: " + keyToDelete + " for deleting."); +								keysToDelete.add(keyToDelete); +								 +							}							 +						} +					}					 +				} +			 +		} catch (ConfigurationException e) { +			log.error("Configuration is not accessable!", e); +			 +		} +		 +		if (newConfigValues.isEmpty()) +			return null; +		else +			return newConfigValues; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#getKeyPrefix() +	 */ +	@Override +	public String getKeyPrefix() { +		return MOAIDConfigurationConstants.GENERAL_AUTH_STORK; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#getName() +	 */ +	@Override +	public String getName() { +		return "General STORK Configuration Task"; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.IDynamicLoadableTaskValidator#getModulValidatorPrefix() +	 */ +	@Override +	public List<String> getModulValidatorPrefix() { +		return Arrays.asList(MOAIDConfigurationConstants.PREFIX_MOAID_GENERAL); +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator#getAllAllowedKeys() +	 */ +	@Override +	public List<Pattern> getAllAllowedPatterns() { +		return generatePatternsFromKeys(KEYWHITELIST); +	} + +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/ServicesGeneralInformationTask.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/ServicesGeneralInformationTask.java new file mode 100644 index 000000000..f27cb9ce7 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/task/impl/ServicesGeneralInformationTask.java @@ -0,0 +1,111 @@ +/* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + */ +package at.gv.egovernment.moa.id.config.webgui.validation.task.impl; + +import java.util.ArrayList; +import java.util.Collections; +import java.util.List; +import java.util.Map; +import java.util.regex.Pattern; + +import at.gv.egiz.components.configuration.api.Configuration; +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; +import at.gv.egovernment.moa.id.commons.utils.KeyValueUtils; +import at.gv.egovernment.moa.id.config.webgui.exception.ConfigurationTaskValidationException; +import at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator; +import at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator; + +/** + * @author tlenz + * + */ +public class ServicesGeneralInformationTask extends AbstractTaskValidator implements ITaskValidator { + +	private static final List<String> KEYWHITELIST; +	 +	static { +		ArrayList<String> temp = new ArrayList<String>(); +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_OPENID_ENABLED, MOAIDConfigurationConstants.PREFIX_GENERAL));		 +		temp.add(KeyValueUtils.removePrefixFromKey(MOAIDConfigurationConstants.GENERAL_PROTOCOLS_OPENID_LEGACY, MOAIDConfigurationConstants.PREFIX_GENERAL));		 +		 +		KEYWHITELIST = Collections.unmodifiableList(temp); +	} +	 +	 +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#validate(java.util.Map) +	 */ +	@Override +	public void validate(Map<String, String> input) +			throws ConfigurationTaskValidationException { +		// TODO Auto-generated method stub + +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#getKeyPrefix() +	 */ +	@Override +	public String getKeyPrefix() { +		// TODO Auto-generated method stub +		return null; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#getName() +	 */ +	@Override +	public String getName() { +		// TODO Auto-generated method stub +		return null; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.ITaskValidator#postProcessing(java.util.Map, java.util.List, at.gv.egiz.components.configuration.api.Configuration) +	 */ +	@Override +	public Map<String, String> postProcessing(Map<String, String> input, +			List<String> keysToDelete, Configuration dbconfig) { +		// TODO Auto-generated method stub +		return null; +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator#tastValidate(java.util.Map) +	 */ +	@Override +	protected void tastValidate(Map<String, String> input) +			throws ConfigurationTaskValidationException { +		// TODO Auto-generated method stub +		 +	} + +	/* (non-Javadoc) +	 * @see at.gv.egovernment.moa.id.config.webgui.validation.task.AbstractTaskValidator#getAllAllowedKeys() +	 */ +	@Override +	public List<Pattern> getAllAllowedPatterns() { +		return generatePatternsFromKeys(KEYWHITELIST); +	} + +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/utils/CompanyNumberValidator.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/utils/CompanyNumberValidator.java new file mode 100644 index 000000000..b9eb76857 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/utils/CompanyNumberValidator.java @@ -0,0 +1,78 @@ +/******************************************************************************* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + *******************************************************************************/ +package at.gv.egovernment.moa.id.config.webgui.validation.utils; + +import org.apache.commons.lang.StringUtils; + +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; + +public class CompanyNumberValidator implements IdentificationNumberValidator { + +	public boolean validate(String commercialRegisterNumber) { +		 +		String normalizedNumber = commercialRegisterNumber.replaceAll(" ", ""); +		if(normalizedNumber.startsWith(MOAIDConfigurationConstants.IDENIFICATIONTYPE_FN)) +			normalizedNumber = normalizedNumber.substring(2); +		 +		return checkCommercialRegisterNumber(normalizedNumber); +	} + +	private boolean checkCommercialRegisterNumber(String commercialRegisterNumber) { +		if (commercialRegisterNumber == null) { +			return false; +		} +		commercialRegisterNumber = StringUtils.leftPad(commercialRegisterNumber, 7, +		    '0'); +		if (!commercialRegisterNumber.matches("\\d{6}[abdfghikmpstvwxzy]")) { +			return false; +		} +		String digits = commercialRegisterNumber.substring(0, +		    commercialRegisterNumber.length() - 1); +		char checkDigit = commercialRegisterNumber.charAt(commercialRegisterNumber +		    .length() - 1); +		boolean result = calcCheckDigitFromCommercialRegisterNumber(digits) == checkDigit; +		return result; +	} + +	public static char calcCheckDigitFromCommercialRegisterNumber( +	    String commercialRegisterDigits) { +		final int[] WEIGHT = { 6, 4, 14, 15, 10, 1 }; +		final char[] CHECKDIGIT = { 'a', 'b', 'd', 'f', 'g', 'h', 'i', 'k', 'm', +		    'p', 's', 't', 'v', 'w', 'x', 'y', 'z' }; +		if (commercialRegisterDigits == null) { +			throw new NullPointerException("Commercial register number missing."); +		} +		commercialRegisterDigits = StringUtils.leftPad(commercialRegisterDigits, 6, +		    '0'); +		if (!commercialRegisterDigits.matches("\\d{6}")) { +			throw new IllegalArgumentException( +			    "Invalid commercial register number provided."); +		} +		int sum = 0; +		for (int i = 0; i < commercialRegisterDigits.length(); i++) { +			int value = commercialRegisterDigits.charAt(i) - '0'; +			sum += WEIGHT[i] * value; +		} +		return CHECKDIGIT[sum % 17]; +	} +} diff --git a/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/utils/IdentificationNumberValidator.java b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/utils/IdentificationNumberValidator.java new file mode 100644 index 000000000..1ecbd3f82 --- /dev/null +++ b/id/moa-id-webgui/src/main/java/at/gv/egovernment/moa/id/config/webgui/validation/utils/IdentificationNumberValidator.java @@ -0,0 +1,29 @@ +/******************************************************************************* + * Copyright 2014 Federal Chancellery Austria + * MOA-ID has been developed in a cooperation between BRZ, the Federal + * Chancellery Austria - ICT staff unit, and Graz University of Technology. + * + * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by + * the European Commission - subsequent versions of the EUPL (the "Licence"); + * You may not use this work except in compliance with the Licence. + * You may obtain a copy of the Licence at: + * http://www.osor.eu/eupl/ + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the Licence is distributed on an "AS IS" basis, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the Licence for the specific language governing permissions and + * limitations under the Licence. + * + * This product combines work with different licenses. See the "NOTICE" text + * file for details on the various modules and licenses. + * The "NOTICE" text file is part of the distribution. Any derivative works + * that you distribute must include a readable copy of the "NOTICE" text file. + *******************************************************************************/ +package at.gv.egovernment.moa.id.config.webgui.validation.utils; + +public interface IdentificationNumberValidator { + +	boolean validate(String idNumber); +	 +} diff --git a/id/moa-id-webgui/src/main/resources/META-INF/services/at.gv.egiz.components.configuration.meta.api.ConfigurationModul b/id/moa-id-webgui/src/main/resources/META-INF/services/at.gv.egiz.components.configuration.meta.api.ConfigurationModul new file mode 100644 index 000000000..f228893b9 --- /dev/null +++ b/id/moa-id-webgui/src/main/resources/META-INF/services/at.gv.egiz.components.configuration.meta.api.ConfigurationModul @@ -0,0 +1 @@ +at.gv.egovernment.moa.id.config.webgui.MOAIDConfigurationModul
\ No newline at end of file diff --git a/id/moa-id-webgui/src/main/resources/META-INF/services/at.gv.egiz.components.spring.api.SpringResourceProvider b/id/moa-id-webgui/src/main/resources/META-INF/services/at.gv.egiz.components.spring.api.SpringResourceProvider new file mode 100644 index 000000000..b0b17a83c --- /dev/null +++ b/id/moa-id-webgui/src/main/resources/META-INF/services/at.gv.egiz.components.spring.api.SpringResourceProvider @@ -0,0 +1 @@ +at.gv.egovernment.moa.id.config.webgui.MOAIDSpringResourceProvider
\ No newline at end of file diff --git a/id/moa-id-webgui/src/main/resources/META-INF/services/at.gv.egovernment.moa.id.config.webgui.validation.modul.IModuleValidator b/id/moa-id-webgui/src/main/resources/META-INF/services/at.gv.egovernment.moa.id.config.webgui.validation.modul.IModuleValidator new file mode 100644 index 000000000..8e29f32f0 --- /dev/null +++ b/id/moa-id-webgui/src/main/resources/META-INF/services/at.gv.egovernment.moa.id.config.webgui.validation.modul.IModuleValidator @@ -0,0 +1,5 @@ +at.gv.egovernment.moa.id.config.webgui.validation.modul.impl.GeneralConfigurationValidator +at.gv.egovernment.moa.id.config.webgui.validation.modul.impl.GatewayValidator +at.gv.egovernment.moa.id.config.webgui.validation.modul.impl.InterfederationIDPValidator +at.gv.egovernment.moa.id.config.webgui.validation.modul.impl.OnlineApplicationValidator +at.gv.egovernment.moa.id.config.webgui.validation.modul.impl.VIDPValidator diff --git a/id/moa-id-webgui/src/main/resources/META-INF/services/at.gv.egovernment.moa.id.config.webgui.validation.task.IDynamicLoadableTaskValidator b/id/moa-id-webgui/src/main/resources/META-INF/services/at.gv.egovernment.moa.id.config.webgui.validation.task.IDynamicLoadableTaskValidator new file mode 100644 index 000000000..42bc23c95 --- /dev/null +++ b/id/moa-id-webgui/src/main/resources/META-INF/services/at.gv.egovernment.moa.id.config.webgui.validation.task.IDynamicLoadableTaskValidator @@ -0,0 +1 @@ +at.gv.egovernment.moa.id.config.webgui.validation.task.impl.GeneralSTORKConfigurationTask diff --git a/id/moa-id-webgui/src/main/resources/applicationResources_de.properties b/id/moa-id-webgui/src/main/resources/applicationResources_de.properties new file mode 100644 index 000000000..2f36ab125 --- /dev/null +++ b/id/moa-id-webgui/src/main/resources/applicationResources_de.properties @@ -0,0 +1,523 @@ +title=MOA-ID 2.x Configuration Tool + + +config.01=Configfile is not found. ({0}) +config.02=Configfile is not readable. ({0}) +config.03=Hibernate Database connector can not be initialized +config.04=OpenSAML (PVP2 Login) can not be initialized +config.05=Configuration file not defined + +error.title=Fehler: +error.login.internal=W\u00E4hrend der Verarbeitung ist ein interner Fehler aufgetreten. Bitte Versuchen Sie es nocheinmal oder kontaktieren Sie den Administrator. +error.general.text=W\u00E4hrend der Verarbeitung ist ein interner Fehler aufgetreten. Bitte Versuchen Sie es nocheinmal oder kontaktieren Sie den Administrator. +errors.listOAs.noOA=Es wurden keine Online-Applikationen in der Datenbank gefunden. +errors.listIDPs.noIDP=Es wurden kein IdentityProvider f\u00FCr Interfederation in der Datenbank gefunden. +errors.edit.oa.oaid=Es wurde keine g\u00FCtige Online-Applikations-ID \u00FCbergeben. +errors.edit.oa.oaid.allowed=Sie besitzen nicht die ben\u00F6tigen Rechte um auf diese Online-Applikation zuzugreifen.  +error.oa.pvp2.certificate=Das hinterlegte PVP2 Zertifikat konnte nicht gelesen werden. +error.db.oa.store=Die Konfiguration konnte nicht in der Datenbank gespeichert werden. +errors.notallowed=Sie besitzen nicht die n\u00F6tigen Rechte um diese Funktion zu benutzen.  +errors.importexport.nofile=Es wurde keine Datei angegeben. +errors.importexport.legacyimport=Der Importvorgang der Legacy-Konfiguration wurde mit einem Fehler abgebrochen (Fehler={0}). +errors.importexport.export=Die MOA-ID 2.x Konfiguration konnte nicht in ein XML File exportiert werden. (Fehler={0}) +errors.importexport.import=Der Importvorgang der XML Konfiguration wurde mit einem Fehler abgebrochen (Fehler={0}). +errors.importexport.export.noconfig=Die Konfiguration kann nicht exportiert werden da keine MOA-ID Konfiguration vorhanden ist. +errors.edit.user.userid=Es wurde keine g\u00FCtige User ID \u00FCbergeben. +errors.edit.user.save=Der Benutzer konnte nicht in die Datenbank eingetragen werden. +errors.edit.user.notallowed=Das Bearbeiten fremder Benutzereinstellungen ist nur dem Admin erlaubt. +error.login=Der Anmeldevorgang wurde abgebrochen. Bitte Versuchen sie es noch einmal. +error.mail.send=An die angegebene Mailadresse konnte keine Nachticht versendet werden. +error.mail.verification=Der Verifikationsvorgang wurde durch einen internen Fehler unterbrochen. Bitte Versuchen sie es noch einmal.  +error.editoa.mailverification=Die Verwaltung von Online-Applikationen ist vor\u00FCbergehend deaktiviert, da die Mailadresse des Benutzeraccounts noch nicht verifiziert wurde. +error.bkuformpreview.notpossible="Die Vorschau konnte nicht generiert werden da ein interner Fehler auftreten ist." +error.oa.oauth.redirecturi=Redirect URL ist keine richtige URL +error.oa.oauth.clientSecret=Client-Secret darf nicht leer sein +error.oa.oauth.keyname=Key-Name darf nicht leer sein +error.oa.oauth.keystore=Keystore darf nicht leer sein und muss eine richtige URL sein. + + +mail.userrequest.subject=Accountanforderung MOA-ID 2.x Konfigurationstool + +webpages.slo.error=Der Abmeldevorgang bei allen Online-Applikationen war nicht erfolgreich. Bitte schlie \t\u00DFen Sie aus Sicherheitsgr\u00FCnden ihren Browser. +webpages.slo.success=Sie wurden erfolgreich bei allen Online-Applikationen abgemeldet. + +webpages.error.header=Es ist ein Fehler aufgetreten +webpages.index.header=Willkommen bei der MOA-ID 2.x Konfigurationsapplikation +webpages.index.desciption.head=Um dieses Service nutzen zu k\u00F6nnen m\u00FCssen sie sich einloggen. +webpages.index.login=Anmelden +webpages.index.logout=Abmelden +webpages.index.login.pvp2=Anmeldung mit B\u00FCrgerkarte oder Handy-Signature +webpages.index.login.notallowed=Entweder sind Benutzername oder Passwort sind nicht korrekt oder der Account wurde noch nicht aktiviert. +webpages.index.username.unkown=Der Benutzer ist nicht bekannt. +webpages.index.username.notactive=Der Benutzer wurde durch den Administrator noch nicht freigeschalten. +webpages.index.password.false=Das Passwort stimmt nicht. + +webpages.inportexport.header=Konfiguration Importieren/Exportieren +webpages.inportexport.success=Die Konfiguration konnte erfolgreich importiert werden. +webpages.inportexport.legacyimport.header=Legacy Konfiguration importieren (MOA-ID < 2.0) +webpages.inportexport.legacyimport.upload=Legacy Konfiguration +webpages.edit.import=Importieren +webpages.edit.export=Exportieren +webpages.inportexport.import.header=MOA-ID 2.x Konfiguration +webpages.inportexport.import.upload=Konfiguration importieren +webpages.inportexport.import.download=Konfiguration exportieren +webpages.inportexport.descripten=ACHTUNG\: Die importierte Konfiguration ersetzt eine aktuell vorhandene Konfiguration vollst\u00E4ndig\!  + +webpages.usermanagement.newuser=Neuen Benutzer erstellen +webpages.usermanagement.header=Benutzerverwaltung +webpages.listUsers.list.header=Liste aller vorhandenen Benutzer +webpages.listUsers.list.first=Familien-/Firmenname +webpages.listUsers.list.second=Vorname +webpages.listUsers.list.third=Benutzername +webpages.edituser.header=Benutzerdaten +webpages.edituser.givenname=Vorname +webpages.edituser.familyName=Familienname +webpages.edituser.institut=Organisation +webpages.edituser.phone=Telefonnummer +webpages.edituser.mail=EMail Adresse +webpages.edituser.access.header=Zugangsdaten +webpages.edituser.username=Benutzername +webpages.edituser.password=Kennwort +webpages.edituser.password_second=Kennwort wiederholen +webpages.edituser.bpk=BPK +webpages.edituser.role.header=Rechte und Role +webpages.edituser.active=Benutzer ist aktiviert +webpages.edituser.admin=Benutzer ist Admin +webpages.edit.delete.user=Benutzer l\u00F6schen +webpages.edit.newUser=Neuen Benutzer anfordern +webpages.edituser.isusernamepasswordallowed=Benutzername/Passwort erlauben +webpages.edituser.changemailaddress.verify=Bevor Sie Online-Applikationen verwalten k\u00F6nnen muss Ihre Mailadresse verifzieren werden. Eine entsprechende Mail wurde bereits an Ihr angegebenes Postfach versendet.    +webpages.edituser.verify.mail.button=Mailadresse pr\u00FCfen +webpages.edituser.verify.mail.message=Es wurde eine Verifikationsmail an Ihr Postfach versendet + +webpages.mainpage.menu.oa.insert=Neue Applikation anlegen +webpages.mainpage.menu.oa.display=Meine Applikationen +webpages.mainpage.menu.oa.search=Applikation suchen +webpages.mainpage.menu.general.user=Meine Daten +webpages.mainpage.menu.general.importexport=Importieren/Exportieren +webpages.mainpage.menu.general.config.moaid=Allgemeine Konfiguration +webpages.mainpage.menu.general.usermanagement=Benutzerverwaltung +webpages.mainpage.menu.general.adminrequests=Offene Anfragen +webpages.mainpage.menu.interfederation=Interfederation + +webpages.interfederation.header=IDP Interfederation Konfiguration +webpages.interfederation.list.header=Liste aller konfiguerierten IDPs  +webpages.inderfederation.moaid.header=Interfederation +webpages.inderfederation.moaid.businessServiceIDP=Privatwirtschaftlicher IDP +webpages.inderfederation.moaid.inboundSSO=Eingehendes SSO erlauben +webpages.inderfederation.moaid.outboundSSO=Ausgehendes SSO erlauben +webpages.inderfederation.moaid.storeSSOSession=SSO Session speichern +webpages.inderfederation.moaid.attributQueryURL=AttributQuery Service URL +webpages.inderfederation.moaid.sendPassivRequest=Verwende SAML2 isPassive Attribut +webpages.inderfederation.moaid.perfomLocalAuthOnError=Im Fehlerfall Authentifizierung lokal durchf\u00FChren +webpages.interfederation.new.header=Neuen Identity Provider hinzuf\u00FCgen +webpages.interfederation.new.vidp=STORK VIDP +webpages.interfederation.new.moaid=MOA-ID IDP +webpages.interfederation.new.gateway=STORK<->PVP Gateway +webpages.inderfederation.gateway.entityID=EntityID des PVP Portals + + + +webpages.moaconfig.save.success=Die MOA-ID Konfiguration wurde erfolgreich gespeichert. +webpages.moaconfig.header=Allgemeine Konfiguration +webpages.oaconfig.general.publicURLPreFix=Public URL Prefix +webpages.moaconfig.defaultbkus.header=Default BKUs +webpages.moaconfig.slrequesttemplates.header=SecurityLayer Request Templates +webpages.moaconfig.slrequesttemplates.local=Locale BKU +webpages.moaconfig.slrequesttemplates.handy=Handy BKU +webpages.moaconfig.slrequesttemplates.online=Online BKU +webpages.moaconfig.certificates.header=Zertifikatspr\u00FCfung +webpages.moaconfig.certificates.certstore=CertStoreDirecorty +webpages.moaconfig.certificates.trustmanagerrev=TrustManagerRevocationChecking +webpages.moaconfig.certificates.trustCACerts=TrustedCACertificates +webpages.moaconfig.certificates.chainingmode=ChainingMode +webpages.moaconfig.timeout.header=Session TimeOuts +webpages.moaconfig.timeout.assertion=Anmeldedaten [sec] +webpages.moaconfig.timeout.MOASessionCreated=SSO Session authentifiziert [sec] +webpages.moaconfig.timeout.MOASessionUpdated=SSO Session letzter Zugriff [sec] +webpages.moaconfig.moasp.header=MOA-SP Konfiguration +webpages.moaconfig.moasp.idltrustprofile=Personenbindung Trustprofil  +webpages.moaconfig.moasp.authtrustprofile=Authentfizierungsblock Trustprofil  +webpages.moaconfig.moasp.authblocktransform=Authentfizierungsblock Transformationen +webpages.moaconfig.moasp.url=URL zum MOA-SP Service +webpages.moaconfig.identitylinksigners=IdentityLinkSigners +webpages.moaconfig.services.header=Externe Services +webpages.moaconfig.services.mandates=Online-Vollmachten Service URL +webpages.moaconfig.services.szrgw=SZR Gateway Service URL +webpages.moaconfig.sso.header=Single Sign-On +webpages.moaconfig.sso.PublicUrl=SSO Service URL-Prefix +webpages.moaconfig.sso.FriendlyName=SSO Service Name +webpages.moaconfig.services.sso.Target=SSO Service Target +webpages.moaconfig.services.sso.SpecialText=SSO AuthBlockText +webpages.moaconfig.protocols.header=Protokolle  +webpages.moaconfig.protocols.allowed.header=Protokolle aktivieren +webpages.moaconfig.protocols.legacy.header=Legacy Modus aktivieren +webpages.moaconfig.protocols.legacy.saml1=SAML1 +webpages.moaconfig.protocols.legacy.pvp2=PVP2.1 +webpages.moaconfig.protocols.oauth=OpenID Connect +webpages.moaconfig.protocols.saml1.header=SAML1 Konfiguration +webpages.moaconfig.protocols.saml1.sourceID=SourceID +webpages.moaconfig.protocols.pvp2.header=PVP2 Konfiguration +webpages.moaconfig.protocols.pvp2.PublicUrlPrefix=PVP2 Service URL-Prefix +webpages.moaconfig.protocols.pvp2.IssuerName=PVP Service Name +webpages.moaconfig.protocols.pvp2.org.header=Organisation +webpages.moaconfig.protocols.pvp2.org.name=Kurzbezeichnung +webpages.moaconfig.protocols.pvp2.org.displayname=Vollst\u00E4ndiger Name +webpages.moaconfig.protocols.pvp2.org.url=URL der Organisation +webpages.moaconfig.protocols.pvp2.contact.header=Kontaktdaten +webpages.moaconfig.protocols.pvp2.contact.surename=Familienname +webpages.moaconfig.protocols.pvp2.contact.givenname=Vorname +webpages.moaconfig.protocols.pvp2.contact.email=Mailadresse +webpages.moaconfig.protocols.pvp2.contact.company=Unternehmen +webpages.moaconfig.protocols.pvp2.contact.phone=Telefonnummer +webpages.moaconfig.protocols.pvp2.contact.type=Type des Kontakts +webpages.moaconfig.sl.transormations.header=SecurityLayer Transformationen +webpages.moaconfig.sl.transormations.filename=Dateiname +webpages.moaconfig.sl.transormations.upload=Neue Transformation hochladen + +webpages.listOAs.list.elInfo=Type +webpages.listOAs.list.first=Eindeutige Kennung +webpages.listOAs.list.second=Name der Online-Applikation + +webpages.searchoa.header=Online-Applikation suchen +webpages.searchoa.search.friendlyname=Name der Online-Applikation +webpages.searchoa.butten.search=Suchen + +webpages.oaconfig.header=Konfiguration der Onlineapplikation +webpages.oaconfig.general.isActive=Online-Applikation ist aktiviert +webpages.oaconfig.general.bku.header=BKU Konfiguration +webpages.oaconfig.general.bku.local=Locale BKU +webpages.oaconfig.general.bku.online=Online BKU +webpages.oaconfig.general.bku.handy=Handy BKU +webpages.oaconfig.general.bku.slversion=SecurityLayer Version +webpages.oaconfig.general.bku.keyboxidentifier=KeyBoxIdentifier +webpages.oaconfig.general.bku.legacy=SecurityLayerTemplates (Legacy Request) +webpages.oaconfig.general.bku.sltemplate.first=SecurityLayer Template +webpages.oaconfig.general.bku.sltemplate.second=SecurityLayer Template (WhiteList) +webpages.oaconfig.general.bku.sltemplate.third=SecurityLayer Template (WhiteList) + +webpages.oaconfig.general.bku.delete=L\u00F6schen +webpages.oaconfig.general.bku.bkuselection.header=BKU-Selection Template +webpages.oaconfig.general.bku.bkuselection.filename=Dateiname +webpages.oaconfig.general.bku.bkuselection.upload=Neues Template hochladen +webpages.oaconfig.general.bku.sendassertion.header=Send-Assertion Template +webpages.oaconfig.general.bku.sendassertion.filename=Dateiname +webpages.oaconfig.general.bku.sendassertion.upload=Neues Template hochladen + +webpages.oaconfig.bPKEncDec.header=Fremd-bPK Konfiguration +webpages.oaconfig.bPKEncDec.keystore.header=KeyStore Konfiguration +webpages.oaconfig.bPKEncDec.filename=Dateiname +webpages.oaconfig.bPKEncDec.delete=L\u00F6schen +webpages.oaconfig.bPKEncDec.upload=KeyStore hochladen +webpages.oaconfig.bPKEncDec.keyStorePassword=KeyStore Password +webpages.oaconfig.bPKEncDec.keyAlias=Schl\u00FCsselname +webpages.oaconfig.bPKEncDec.keyPassword=Schl\u00FCsselpassword + +webpages.oaconfig.general.identification=Eindeutiger Identifikatior (PublicURLPrefix) +webpages.oaconfig.general.mandate.header=Vollmachten +webpages.oaconfig.general.mandate.profiles=Profile +webpages.oaconfig.general.mandate.usemandate=Vollmachten (ja/nein) +webpages.oaconfig.general.friendlyname=Name der Online-Applikation +webpages.oaconfig.general.isbusinessservice=Privatwirtschaftliche Applikation +webpages.oaconfig.general.isstorkservice=Stork Applikation +webpages.oaconfig.general.public.header=Öffentlicher Bereich +webpages.oaconfig.general.stork.header=STORK Bereich +webpages.oaconfig.general.stork.countrycode=Landesvorwahl +webpages.oaconfig.general.target.friendlyname=Bezeichnung des Bereichs (Frei w\u00E4hlbar) +webpages.oaconfig.general.target.admin.checkbox=Anderen Bereich frei definieren +webpages.oaconfig.general.target.admin=Bereich (Frei w\u00E4hlbar) +webpages.oaconfig.general.target.friendlyname.disabled=Bezeichnung des Bereichs (vom Administrator eingestellt) +webpages.oaconfig.general.target.admin.disabled=Bereich (vom Administrator eingestellt) +webpages.oaconfig.general.target=Bereich (Target) +webpages.oaconfig.general.target.subsector=Sub-Bereich +webpages.oaconfig.general.target.subsector.checkbox=Target verfeinern +webpages.oaconfig.general.business.header=Privatwirtschaftlicher Bereich +webpages.oaconfig.general.business.value=Identifikationsnummer +webpages.oaconfig.general.business.type=Type der Identifikationsnummer +webpages.oaconfig.general.aditional.header=Zusätzliche allgemeine Einstellungen +webpages.oaconfig.general.aditional.authblocktext=AuthblockText +webpages.oaconfig.general.aditional.iframe=B\u00FCrgerkartenauswahl im IFrame +webpages.oaconfig.general.aditional.useUTC=UTC Zeit verwenden +webpages.oaconfig.general.aditional.calculateHPI="TODO!" +webpages.oaconfig.general.isHideBPKAuthBlock=bPK/wbPK im AuthBlock ausblenden + +webpages.oaconfig.menu.saml1.show=SAML1 Konfiguration einblenden +webpages.oaconfig.menu.saml1.hidden=SAML1 Konfiguration ausblenden +webpages.oaconfig.menu.pvp2.show=PVP2 Konfiguration einblenden +webpages.oaconfig.menu.pvp2.hidden=PVP2 Konfiguration ausblenden +webpages.oaconfig.menu.oauth20.show=OAuth 2.0 Konfiguration einblenden +webpages.oaconfig.menu.oauth20.hidden=OAuth 2.0 Konfiguration ausblenden +webpages.oaconfig.menu.vidp.show=VIDP Konfiguration einblenden +webpages.oaconfig.menu.vidp.hidden=VIDP Konfiguration ausblenden + +webpages.oaconfig.menu.stork=STORK Konfiguration + +webpages.oaconfig.protocols.header=Authentifizierungsprotokolle + +webpages.oaconfig.general.BKUSelection.button.show=Login-Fenster Konfiguration einblenden +webpages.oaconfig.general.BKUSelection.button.hidden=Login-Fenster Konfiguration ausblenden +webpages.oaconfig.general.BKUSelection.header=Formularkonfiguration +webpages.oaconfig.general.BKUSelection.isOnlyMandateLoginAllowed=Nur Vollmachtenanmeldung erlauben +webpages.oaconfig.general.BKUSelection.backgroundcolor=Hintergrundfarbe der BKU-Auswahl +webpages.oaconfig.general.BKUSelection.frontcolor=Vordergrundfarbe der BKU-Auswahl +webpages.oaconfig.general.BKUSelection.header.backgroundcolor=Hintergrundfarbe der \u00DCberschrift +webpages.oaconfig.general.BKUSelection.header.frontcolor=Vordergrundfarbe der \u00DCberschrift +webpages.oaconfig.general.BKUSelection.header.text=\u00DCberschriftstext +webpages.oaconfig.general.BKUSelection.header.button.background=Hintergrundfarbe der Schaltfl\u00E4chen +webpages.oaconfig.general.BKUSelection.header.button.background.focus=Hintergrundfarbe der Schaltfl\u00E4chen (Focus) +webpages.oaconfig.general.BKUSelection.header.button.front=Vordergrundfarbe der Schaltfl\u00E4chen +webpages.oaconfig.general.BKUSelection.redirectTarget=Targetparameter +webpages.oaconfig.general.BKUSelection.fonttype=Formularschrifttyp +webpages.oaconfig.general.BKUSelection.fonttype.list=Formularschrifttypen +webpages.oaconfig.general.BKUSelection.header.applet.height=Appleth\u00F6he +webpages.oaconfig.general.BKUSelection.header.applet.width=Appletbreite + +webpages.oaconfig.general.testing.header=Test Identit\u00E4ten +webpages.oaconfig.general.testing.usetesting=Test Identit\u00E4ten erlauben +webpages.oaconfig.general.testing.oids=OIDs f\u00FCr Test Identit\u00E4ten einschr\u00E4nken. + +webpages.oaconfig.sso.header=Single Sign-On +webpages.oaconfig.sso.singlelogouturl=Single Log-Out URL +webpages.oaconfig.sso.useauthdataframe=Zus\u00E4tzliche Userabfrage +webpages.oaconfig.sso.usesso=Single Sign-On verwenden + +webpages.oaconfig.stork.header=Secure idenTity acrOss boRders linKed +webpages.oaconfig.stork.enabledcpeps=aktivierte Zielländer +webpages.oaconfig.stork.attributes.header=angeforderte Attribute +webpages.oaconfig.stork.attributes.used=anfordern? +webpages.oaconfig.stork.attributes.name=Attributname +webpages.oaconfig.stork.attributes.mandatory=obligatorisch? +webpages.oaconfig.stork.usestork=STORK Logon aktivieren +webpages.moaconfig.stork.pepslist=C-PEPS Konfiguration +webpages.moaconfig.stork.newpeps=Neuen PEPS konfigurieren +webpages.moaconfig.stork.removepeps=l\u00F6schen +webpages.moaconfig.stork.qaa.default=Standard QAA-Level ausw\u00E4hlen +webpages.moaconfig.stork.attributes.heading=Attributkonfiguration +webpages.moaconfig.stork.attributes.new=Neues Attribut hinzuf\u00FCgen +webpages.moaconfig.stork.attributes.heading.name=Attributname +webpages.moaconfig.stork.attributes.heading.mandatory=zwingend +webpages.moaconfig.stork.attributes.remove=l\u00F6schen +webpages.moaconfig.stork.qaa=Mindest-QAA-Level f\u00FCr diese OA ausw\u00E4hlen + +webpages.oaconfig.protocols.saml1.header=SAML1 Konfiguration +webpages.oaconfig.saml1.isActice=SAML1 aktivieren +webpages.oaconfig.saml1.provideStammZahl=Stammzahl \u00FCbertragen +webpages.oaconfig.saml1.provideAuthBlock=Authentifizierungsblock \u00FCbertragen +webpages.oaconfig.saml1.provideIdentityLink=Personenbindung \u00FCbertragen +webpages.oaconfig.saml1.provideCertificate=Zertifikat \u00FCbertragen +webpages.oaconfig.saml1.provideFullMandateData=Vollst\u00E4ndige Vollmacht \u00FCbertragen +webpages.oaconfig.saml1.useCondition=Usecondition +webpages.oaconfig.saml1.conditionLength=ConditionLength +webpages.oaconfig.saml1.provideAllErrors=Fehlermeldungen an OA \u00FCbertragen + +webpages.oaconfig.protocols.pvp2.header=PVP2.x Konfiguration +webpages.oaconfig.pvp2.reload=PVP2.x konfiguration neu laden +webpages.oaconfig.pvp2.metaDataURL=URL zu den Metadaten +webpages.oaconfig.pvp2.certifcate=Zertifikat hochladen +webpages.oaconfig.pvp2.certifcate.info=Infos zum Zertifikat + +webpages.oaconfig.protocols.oauth20.header=OAuth 2.0 Konfiguration +webpages.oaconfig.oauth20.clientId=Client ID +webpages.oaconfig.oauth20.clientSecret=Client Passwort +webpages.oaconfig.oauth20.redirectUri=Redirect Uri  + +webpages.oaconfig.vidp.enabled=VIDP interface aktiv +webpages.oaconfig.vidp.requireconsent=Zustimmung f\u00FCr das Ausliefern der Attribute vom Benutzer einholen? +webpages.oaconfig.vidp.ap.new=Neuen Attribut Provider erstellen +webpages.oaconfig.vidp.ap.remove=Entfernen +webpages.oaconfig.vidp.ap.list=Liste der konfigurierten Attribut Provider + +		 +message.title=Meldung: +webpages.oaconfig.success=Die Online-Applikation {0} konnte erfolgreich gespeichert werden. +webpages.oaconfig.success.admin=Die Online-Applikation {0} konnte erfolgreich gespeichert werden. Es ist jedoch eine Aktivierung durch den Administrator erforderlich.  +webpages.oaconfig.cancle=Die Bearbeitung der Online-Applikation {0} wurde abgebrochen. +webpages.idp.success=Der IdentityProvider {0} konnte erfolgreich gespeichert werden. +webpages.idp.cancle=Die Bearbeitung des IdentityProvider {0} wurde abgebrochen. + +webpages.oaconfig.delete.message=Die Online-Applikation {0} wurde erfolgreich gel\u00F6scht. +webpages.oaconfig.delete.error=Die Online-Applikation {0} konnte nicht gel\u00F6scht werden.  + +webpages.edit.save=\u00C4nderungen Speichern +webpages.edit.back=Zur\u00FCck und \u00C4nderungen verwerfen +webpages.edit.delete=Online-Applikation l\u00F6schen + +webpages.header.info=Sie sind angemeldet als: +webpages.header.lastlogin=Letzte Anmeldung am:  + +webpages.openadminrequests.header=Offene Antr\u00E4ge +webpages.openadminrequests.users.header=Benutzeraccounts +webpages.openadminrequests.oas.header=Online-Applikationen + + +validation.newuser.mailaddress=Die Validierung der Mailadresse konnte erfolgreich durchgef\u00FChrt werden. + +validation.edituser.familyname.empty=Der Familienname ist leer. +validation.edituser.familyname.valid=Der Familienname enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.edituser.givenname.empty=Der Vorname ist leer. +validation.edituser.givenname.valid=Der Vorname enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.edituser.institut.empty=Die Organisation ist leer. +validation.edituser.institut.valid=Die Organisation enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.edituser.mail.empty=Die EMail Adresse ist leer. +validation.edituser.mail.valid=Die EMail Adresse hat kein g\u00FCltiges Format. +validation.edituser.phone.empty=Die Telefonnummer ist leer. +validation.edituser.phone.valid=Die Telefonnummer hat kein g\u00FCltiges Form +validation.edituser.username.empty=Der Benutzername ist leer. +validation.edituser.username.valid=Der Benutzername enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.edituser.username.duplicate=Der Benutzername ist bereits vergeben +validation.edituser.password.empty=Das Passwort ist leer. +validation.edituser.password.valid=Das Passwort konnte nicht in einen g\u00FCltigen Schl\u00FCssel transferiert werden. +validation.edituser.password.equal=Die Passw\u00F6rter sind nicht identisch. +validation.edituser.bpk.valid=Die BPK enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} + +validation.general.SAML1SourceID=Die SAML1SourceID enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.publicURLprefix.empty=Public URL Prefix Feld ist leer. +validation.general.publicURLprefix.valid=Public URL Prefix hat kein g\u00F6ltiges Format. +validation.general.certStoreDirectory.empty=CertStoreDirectory Feld ist leer. +validation.general.certStoreDirectory.valid=Das CertStoreDirectory Feld enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.Defaultchainigmode.empty=Es wurde kein DefaultChainingMode gew\u00E4hlt. +validation.general.Defaultchainigmode.valid=Der DefaultChainingMode enth\u00E4lt einen ung\u00F6ltigen Wert. +validation.general.IdentityLinkSigners.empty=Es wurde kein IdentityLinkSigner angegeben +validation.general.IdentityLinkSigners.valid=Der IdentityLinkSigner in der Zeile {0} enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {1} +validation.general.mandateservice.valid=Die URL zum Online-Vollmachten Service hat kein g\u00F6ltiges Format. +validation.general.moasp.auth.transformation.empty=Die Transformation f\u00F6r den Authentfizierungsblock ist leer. +validation.general.moasp.auth.transformation.valid=Die Transformation f\u00F6r den Authentfizierungsblock  in der Zeile {0} enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {1} +validation.general.moasp.auth.trustprofile.empty=Das TrustProfile zur Pr\u00F6fung des Authentfizierungsblock ist leer. +validation.general.moasp.auth.trustprofile.valid=Das TrustProfile zur Pr\u00F6fung des Authentfizierungsblock enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.moasp.idl.trustprofile.empty=Das TrustProfile zur Pr\u00F6fung der Personenbindung ist leer. +validation.general.moasp.idl.trustprofile.valid=Das TrustProfile zur Pr\u00F6fung der Personenbindung  enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.moaspss.url.valid=Die URL zum MOA-SP/SS Service hat kein g\u00F6ltiges Format. +validation.general.protocol.pvp2.issuername.valid=PVP2\: Service Name enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.protocol.pvp2.org.displayname.valid=PVP2 Organisation\: Vollst\u00E4ndiger Name enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.protocol.pvp2.org.name.valid=PVP2 Organisation\: Kurzbezeichnung enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.protocol.pvp2.org.url.valid=PVP2 Organisation\: URL hat kein g\u00F6ltiges Format. +validation.general.protocol.pvp2.serviceurl.valid=PVP2\: Service URL-Prefix hat kein g\u00F6ltiges Format. +validation.general.protocol.pvp2.contact.company.valid=PVP2 Kontaktdaten\: Der Firmenname enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.protocol.pvp2.contact.givenname.valid=PVP2 Kontaktdaten\: Der Familienname enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.protocol.pvp2.contact.surename.valid=PVP2 Kontaktdaten\: Der Vorname enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.protocol.pvp2.contact.type.valid=PVP2 Kontaktdaten: Der angegebene Kontakttyp existiert nicht.  +validation.general.protocol.pvp2.contact.mail.valid=PVP2 Kontaktdaten\: Die EMail Adresse ist nicht g\u00FCltig. +validation.general.protocol.pvp2.contact.phone.valid=PVP2 Kontaktdaten\: Die Telefonnummer ist nicht g\u00FCltig. +validation.general.timeouts.assertion.valid=Das Feld Assertion TimeOut hat keinen g\u00F6ltigen Wert. +validation.general.timeouts.moasessioncreated.valid=Das Feld MOASessionCreated TimeOut hat keinen g\u00FCltigen Wert. +validation.general.timeouts.moasessionupdated.valid=Das Feld MOASessionUpdated TimeOut hat keinen g\u00FCltigen Wert. + +validation.general.slrequest.handy.empty=Die URL zum SecurityLayer Template f\u00F6r die Handy-BKU ist leer. +validation.general.slrequest.handy.valid=Die URL zum SecurityLayer Template f\u00F6r die Handy-BKU hat kein g\u00F6ltiges Format. +validation.general.slrequest.local.empty=Die URL zum SecurityLayer Template f\u00F6r die locale BKU ist leer. +validation.general.slrequest.local.valid=Die URL zum SecurityLayer Template f\u00F6r die locale BKU hat kein g\u00F6ltiges Format. +validation.general.slrequest.online.empty=Die URL zum SecurityLayer Template f\u00F6r die Online-BKU ist leer. +validation.general.slrequest.online.valid=Die URL zum SecurityLayer Template f\u00F6r die Online-BKU hat kein g\u00F6ltiges Format. +validation.general.sso.friendlyname.valid=Der SSO Service Name enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.sso.identificationnumber.valid=Die SSO IdentificationNumber enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.sso.publicurl.valid=Der SSO Service URL-Prefix hat kein g\u00F6ltiges Format. +validation.general.sso.specialauthtext.valid=Der SSO AuthBlockText enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.sso.target.empty=Das SSO Target Feld ist leer. +validation.general.sso.target.valid=Das SSO Target Feld enth\u00E4lt ein ung\u00FCltiges Target. +validation.general.szrgw.url.valid=Die URL des SZR Gateways hat kein g\u00F6ltiges Format. +validation.general.trustedcacerts.empty=Das Feld TrustedCACertificates ist leer. +validation.general.trustedcacerts.valid=Das Feld TrustedCACertificates enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.slrequest.filename.valid=Der Dateiname der angegebenen SecurtityLayer Transformation enth\u00E4lt ein ung\u00FCltiges Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.slrequest.file.valid=Die angegebenen AuthBlock Transformation konnte nicht geladen werden. +validation.general.slrequest.file.empty=Die AuthBlock Transformation ist leer. + +validation.general.aditionalauthblocktext=Der Zusatztext f\u00FCr den AuthBlock enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.bku.handy.empty=Die URL f\u00FCr die Handy-BKU ist leer. +validation.general.bku.handy.valid=Die URL f\u00FCr die Handy-BKU hat kein g\u00FCltiges Format. +validation.general.bku.local.empty=Die URL f\u00FCr die lokale BKU ist leer. +validation.general.bku.local.valid=Die URL f\u00FCr die locale BKU hat kein g\u00FCltiges Format. +validation.general.bku.online.empty=Die URL f\u00FCr die Online-BKU ist leer. +validation.general.bku.online.valid=Die URL f\u00FCr die Online-BKU hat kein g\u00FCltiges Format. +validation.general.oafriendlyname.empty=Es wurde kein Name f\u00FCr die Online-Applikation angegeben. +validation.general.oafriendlyname.valid=Der Name der Online-Applikation enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.keyboxidentifier.empty=Es wurde kein KeyBoxIdentifier ausgew\u00E4hlt. +validation.general.keyboxidentifier.valid=Der KeyBoxIdentifier hat ein ung\u00FCltiges Format. +validation.general.sltemplates.empty=Wenn der Legacymodus verwendet werden soll muss zumindest ein SecurityLayer Template angegeben werden. +validation.general.sltemplate1.valid=Die erste SecurityLayer Template URL hat kein g\u00FCltiges Format. +validation.general.sltemplate2.valid=Die zweite SecurityLayer Template URL hat kein g\u00FCltiges Format. +validation.general.sltemplate3.valid=Die dritte SecurityLayer Template URL hat kein g\u00FCltiges Format. +validation.general.mandate.profiles=Die Liste von Vollmachtsprofilen enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.mandate.usemandate=Die Konfiguration von Vollmachtsprofile ist nur mit aktivierten Vollmachten m\u00F6glich.  +validation.general.target.empty=Der Target f\u00FCr die Online-Applikation ist leer. +validation.general.target.valid=Der Target f\u00FCr die Online-Applikation hat kein g\u00FCltiges Format. +validation.general.target.subsector.valid=Der Target-Subsektor hat kein g\u00FCltiges Format. +validation.general.target.admin.valid=Der Admin-Target f\u00FCr die Online-Applikation hat kein g\u00FCltiges Format. +validation.general.target.publicserviceurl=Die Domain des eindeutigen Identifiers f\u00FCr die Online-Applikation erlaubt nur Applikationen aus dem privatwirtschaftlichen Bereich. +validation.general.slversion=Die SecurityLayer Version ist kein Zahlenformat. +validation.general.slversion.business=Im privatwirtschaftlichen Bereich muss die SecurityLayerversion mindestes 1.2 betragen. Die SLVersion wurde auf 1.2 ge\u00E4ndert. +validation.general.targetfriendlyname=Der Name des Bereichs (Target) enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.identificationtype.valid=Der Identifikationstype wird nicht unterst\u00FCtzt. +validation.general.identificationnumber.empty=Im privatwirtschaftlichen Bereich ist eine Identifikationsnummer erforderlich. +validation.general.identificationnumber.valid=Die Identifikationsnummer f\u00FCr den privatwirtschaftlichen Bereich enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.identificationnumber.fn.valid=Die Firmenbuchnummer hat kein g\u00FCltiges Format. +validation.general.oaidentifier.empty=Es wurde kein eindeutiger Identifier f\u00FCr die Online-Applikation angegeben. +validation.general.oaidentifier.valid=Der eindeutige Identifier f\u00FCr die Online-Applikation ist keine g\u00FCltige URL. +validation.general.oaidentifier.notunique=Der gew\u00E4hlte eindeutige Identifier ist bereits vorhanden. Eine Eintragung der Online-Applikation ist nicht m\u00F6glich. +validation.general.stork.sptarget=Der STORK SP-Target ist leer. +validation.general.stork.sptargetsize=Die Definition von STORK SP-Target ist nicht korrekt: zu viele Buchstaben. +validation.general.bkuselection.filename.valid=Der Dateiname des BKU-Selektion Templates enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.bkuselection.file.valid=Das BKU-Selektion Templates konnte nicht geladen werden. +validation.general.bkuselection.file.selected=Es kann nur EIN BKU-Selektion Template angegeben werden. +validation.general.sendassertion.filename.valid=Der Dateiname des Send-Assertion Templates enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.sendassertion.file.valid=Das Send-Assertion Templates konnte nicht geladen werden. +validation.general.sendassertion.file.selected=Es kann nur EIN Send-Assertion Template angegeben werden. +validation.general.testcredentials.oid.valid=Die Testdaten OID {0} ist ung\u00FCltig. + +validation.bPKDec.keyStorePassword.empty=Das Password f\u00FCr den KeyStore ist leer. +validation.bPKDec.keyStorePassword.valid=Das Password f\u00FCr den KeyStore enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.bPKDec.keyAlias.empty=Der Schl\u00FCsselname ist leer. +validation.bPKDec.keyAlias.valid=Der Schl\u00FCsselname enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.bPKDec.keyPassword.empty=Das Password f\u00FCr den privaten Schl\u00FCssel ist leer. +validation.bPKDec.keyPassword.valid=Das Password f\u00FCr den privaten Schl\u00FCssel enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.bPKDec.keyStore.filename.valid=Der Dateiname des KeyStores enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.bPKDec.keyStore.file.valid=Der KeyStore konnte nicht geladen oder ge\u00F6ffnet werden. Eventuell sind das Passwort oder der Schl\u00FCsselname nicht korrekt. +validation.bPKDec.keyStore.file.selected=Es kann nur EIN KeyStore angegeben werden. + +validation.stork.cpeps.cc=CPEPS L\u00E4ndercode folgt nicht ISO 3166-2 +validation.stork.cpeps.empty=CPEPS Konfiguration ist unvollst\u00E4ndig +validation.stork.cpeps.url=CPEPS URL ist ung\u00FCltig +validation.stork.cpeps.duplicate=L\u00E4ndercodes sind nicht eindeutig +validation.stork.requestedattributes=STORK Attribute sind fehlerhaft. Bsp.: attr1, attr2 +validation.stork.qaa.outofrange=G\u00FCltige QAA Werte sind 1, 2, 3, und 4 +validation.stork.attributes.empty=Es muss mindestens ein Attribut definiert sein +validation.stork.ap.url.valid=Ung\u00FCltige AttributProvider Url +validation.stork.ap.name.empty=Ung\u00FCltiger AttributProvider Name +validation.stork.ap.name.valid=Ung\u00FCltiger AttributProvider Name +validation.stork.ap.attributes.valid=Ung\u00FCltige Attributconfiguration f\u00FCr ein Attribut Provider Plugin. Feld darf nicht leer sein und ist als csv anzugeben. + +validation.pvp2.metadataurl.empty=Keine Metadaten URL angegeben. +validation.pvp2.metadataurl.valid=Die Metadaten URL wei\u00DFt kein g\u00FCltiges URL Format auf. +validation.pvp2.metadataurl.read=Unter der angegebenen Metadaten URL konnten keine Informationen abgerufen werden. +validation.pvp2.metadata.verify.sig=Die Metadaten konnten nicht mit dem angegebenen Zertifikat verifziert werden. +validation.pvp2.metadata.verify.schema=Die Schema-Validierung der Metadaten ist fehlgeschlagen. +validation.pvp2.metadata.verify.general=Bei der Validierung der Metadaten ist ein allgemeiner Fehler aufgetreten. +validation.pvp2.certificate.format=Das angegebene PVP2 Zertifikat wei\u00DFt kein g\u00FCltiges Format auf.  +validation.pvp2.certificate.notfound=Kein PVP2 Zertifikat eingef\u00FCgt. +validation.pvp2.metadata.ssl=Das SSL Serverzertifikat des Metadaten Service ist nicht vertrauensw\u00FCrdig. +validation.pvp2.metadata.validation=Die Metadaten konnten von der angegebenen URL geladen werden, jedoch schlug die Validierung der Metadaten fehl. + +validation.sso.logouturl.empty=Eine URL zum Single Log-Out Service ist erforderlich. +validation.sso.logouturl.valid=Die URL zum Single Log-Out Service wei\u00DFt kein g\u00FCltiges Format auf. + +validation.interfederation.moaidp.queryurl.valid=Die URL zum AttributQuery Service wei\u00DFt kein g\u00FCltiges Format auf. +validation.interfederation.moaidp.queryurl.empty=Die URL zum AttributQuery Service muss konfiguriert werden. +validation.interfederation.moaidp.metadataurl.publicservice=Die Domain des Metadaten Services f\u00FCr diesen IDP erlaubt nur Applikationen aus dem privatwirtschaftlichen Bereich. +validation.interfederation.gateway.entityID.valid=Die EntityID zum PVP Portal wei\u00DFt kein g\u00FCltiges Format auf. +validation.interfederation.gateway.entityID.empty=Die EntityID zum PVP Portal muss konfiguriert werden. + +validation.saml1.providestammzahl=ProvideStammZahl kann nicht mit Applikationen aus dem privatwirtschaftlichen Bereich kombiniert werden. + +validation.general.bkuselection.specialfeatures.valid=Die speziellen Einstellungen f\u00FCr die BKU Auswahl (Vollmachtsanmeldung ausblenden / zwingend voraussetzen) k\u00F6nnen nicht in Kombination mit SSO verwendet werden. +validation.general.bkuselection.specialfeatures.combination=Eine zwingend erforderliche Vollmachtenanmeldung in Kombination mit einer ausgeblendeten Vollmachtenauswahlcheckbox ist nicht m\u00F6glich. +validation.general.form.color.background=Die Hintergrundfarbe f\\u00FCr die BKU Auswahl enth\\u00E4lt keinen g\\u00FCltigen Hexadezimalwert. (z.B. \\\#FFFFFF) +validation.general.form.color.front=Die Vordergrundfarbe f\\u00FCr die BKU Auswahl enth\\u00E4lt keinen g\\u00FCltigen Hexadezimalwert. (z.B. \\\#FFFFFF) +validation.general.form.header.color.back=Die Hintergrundfarbe der BKU-Auswahl\\u00FCberschrift enth\\u00E4lt keinen g\\u00FCltigen Hexadezimalwert. (z.B. \\\#FFFFFF) +validation.general.form.header.color.front=Die Vordergrundfarbe der BKU-Auswahl\\u00FCberschrift enth\\u00E4lt keinen g\\u00FCltigen Hexadezimalwert. (z.B. \\\#FFFFFF) +validation.general.form.header.text=Die BKU-Auswahl\\u00FCberschrift enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.form.button.color.back.focus=Die Hintergrundfarbe f\\u00FCr Focus der BKU-Auswahlbuttons enth\\u00E4lt keinen g\\u00FCltigen Hexadezimalwert. (z.B. \\\#FFFFFF) +validation.general.form.button.color.back=Die Hintergrundfarbe der BKU-Auswahlbuttons enth\\u00E4lt keinen g\\u00FCltigen Hexadezimalwert. (z.B. \\\#FFFFFF) +validation.general.form.button.color.front=Die Vordergrundfarbe der BKU-Auswahlbuttons enth\\u00E4lt keinen g\\u00FCltigen Hexadezimalwert. (z.B. \\\#FFFFFF) +validation.general.form.appletredirecttarget=Der RedirectTarget beinhaltet einen ung\\u00FCltiten Wert. +validation.general.form.fonttype=Der BKU-Auswahl Schrifttyp enth\u00E4lt nicht erlaubte Zeichen. Folgende Zeichen sind nicht erlaubt\: {0} +validation.general.form.applet.width=Die Appleth\u00F6he ist keine g\\u00FCltige Zahl. +validation.general.form.applet.height=Die Appletbreite ist keine g\\u00FCltige Zahl. diff --git a/id/moa-id-webgui/src/main/resources/applicationResources_en.properties b/id/moa-id-webgui/src/main/resources/applicationResources_en.properties new file mode 100644 index 000000000..154f380ae --- /dev/null +++ b/id/moa-id-webgui/src/main/resources/applicationResources_en.properties @@ -0,0 +1,520 @@ +title=MOA-ID 2.x Configuration Tool + + +config.01=Configfile is not found. ({0}) +config.02=Configfile is not readable. ({0}) +config.03=Hibernate Database connector can not be initialized +config.04=OpenSAML (PVP2 Login) can not be initialized +config.05=Configuration file is not defined + +error.title=Error: +error.login.internal=The error occurred during the processing. Please try again or contact Administrator. +error.general.text=During the processing the error condition occured. Please try again or contact the administrator. +errors.listOAs.noOA=There is no Online-Application found in the database. +errors.listIDPs.noIDP=There is no interfederation IdentityProvider found in the database. +errors.edit.oa.oaid=There is no valid Online-Application ID transfered. +errors.edit.oa.oaid.allowed=You do not possess the necessary rights in order to access this Online-Application. +error.oa.pvp2.certificate=Provided PVP2 certificate could not be read. +error.db.oa.store=The configuration could not be saved in the database. +errors.notallowed=You do not posses necessary righs in order to use this function. +errors.importexport.nofile=There is no file provided. +errors.importexport.legacyimport=The Import of the legacy configuration was interrupted due to the error. (Error={0}). +errors.importexport.export=The MOA-ID 2.x configuration could not be exported to XML file. (Error={0}) +errors.importexport.import=The import of XML configuration was interrupted due to the error. (Error={0}). +errors.importexport.export.noconfig=The configuration could not be exported as there is no MOA-ID configuration available. +errors.edit.user.userid=There is no valid user ID provided. +errors.edit.user.save=The user could not be inserted in the database. +errors.edit.user.notallowed=The editing of the other users configuration can be only done by administrators. +error.login=The login procedure was interrupted. Please try again. +error.mail.send=The message could not be sent to the provided address. +error.mail.verification=The verification procedure was interrupted due to the error. Please try again. +error.editoa.mailverification=The administration of the Online-Applications is temporarly deactivated because the email address of user's account is not verified. +error.bkuformpreview.notpossible="The preview could not be generated as due to internal error." +error.oa.oauth.redirecturi=Redirect URL ist not valid URL +error.oa.oauth.clientSecret=Client-Secret cannot be blank +error.oa.oauth.keyname=Key-Name cannot be blank +error.oa.oauth.keystore=Keystore cannot be blank and has to be provided in the form of valid URL. + +mail.userrequest.subject=Requesting accounts - MOA-ID 2.x Config Tool + + +webpages.slo.error=LogOut process finished with an error. For security reasons, please close your browser.  +webpages.slo.success=LogOut process finished successful + +webpages.error.header=The error occured +webpages.index.header=Welcome to MOA-ID 2.x Configuration +webpages.index.desciption.head=In order to use this service you should log in +webpages.index.login=Login +webpages.index.logout=Logout +webpages.index.login.pvp2=Login with Buergerkarte or Handy-Signature +webpages.index.login.notallowed=The user name or password are wrong, or the user account is not activated. +webpages.index.username.unkown=The user is unknown. +webpages.index.username.notactive=The user is still not activated by the administrator. +webpages.index.password.false=The password is not valid. + +webpages.inportexport.header=Import/export configuration +webpages.inportexport.success=The configuration was imported successfully +webpages.inportexport.legacyimport.header=Import legacy configuration (MOA-ID < 2.0) +webpages.inportexport.legacyimport.upload=Legacy configuration +webpages.edit.import=Import +webpages.edit.export=Export +webpages.inportexport.import.header=MOA-ID 2.x configuration +webpages.inportexport.import.upload=Import configuration +webpages.inportexport.import.download=Export configuration +webpages.inportexport.descripten=WARNING\: The imported configuration will completely replace currently active configuration\! + +webpages.usermanagement.newuser=Create new user +webpages.usermanagement.header=User management +webpages.listUsers.list.header=List all users +webpages.listUsers.list.first=Surname-/Company +webpages.listUsers.list.second=Name +webpages.listUsers.list.third=User name +webpages.edituser.header=User data +webpages.edituser.givenname=Name +webpages.edituser.familyName=Surname +webpages.edituser.institut=Organization +webpages.edituser.phone=Phone number +webpages.edituser.mail=Email Address +webpages.edituser.access.header=Login +webpages.edituser.username=User name +webpages.edituser.password=Password +webpages.edituser.password_second=Repeat password +webpages.edituser.bpk=BPK +webpages.edituser.role.header=Rights and roles +webpages.edituser.active=The user is activated +webpages.edituser.admin=The user is admin +webpages.edit.delete.user=Remove user +webpages.edit.newUser=Request new user +webpages.edituser.isusernamepasswordallowed=Allow username/password +webpages.edituser.changemailaddress.verify=Your email address should be verified, in order to be able to manage Online-Applications. The verification email has been already sent to your email-address. +webpages.edituser.verify.mail.button=Check email address +webpages.edituser.verify.mail.message=Verification email has been sent to your inbox. + +webpages.mainpage.menu.oa.insert=Create new application +webpages.mainpage.menu.oa.display=My applications +webpages.mainpage.menu.oa.search=Find application +webpages.mainpage.menu.general.user=My data +webpages.mainpage.menu.general.importexport=Import/export +webpages.mainpage.menu.general.config.moaid=General configuration +webpages.mainpage.menu.general.usermanagement=User management +webpages.mainpage.menu.general.adminrequests=Open requests + +webpages.mainpage.menu.interfederation=Interfederation +webpages.interfederation.header=IDP Interfederation Configuration +webpages.interfederation.list.header=List of all interfederation IDPs +webpages.inderfederation.moaid.businessServiceIDP=BusinessService IDP  +webpages.inderfederation.moaid.header=Interfederation +webpages.inderfederation.moaid.inboundSSO=Allow inbound SSO +webpages.inderfederation.moaid.outboundSSO=Allow outbound SSO +webpages.inderfederation.moaid.storeSSOSession=Store SSO session +webpages.inderfederation.moaid.attributQueryURL=AttributQuery service URL +webpages.inderfederation.moaid.sendPassivRequest=Use SAML2 isPassive attribute +webpages.inderfederation.moaid.perfomLocalAuthOnError=Local authentication in case of an error +webpages.interfederation.new.header=Add new Identity Provider +webpages.interfederation.new.vidp=STORK VIDP +webpages.interfederation.new.moaid=MOA-ID IDP +webpages.interfederation.new.gateway=STORK<->PVP Gateway +webpages.inderfederation.gateway.entityID=PVP portal EntityID + +webpages.moaconfig.save.success=MOA-ID has been successfully saved. +webpages.moaconfig.header=General configuration +webpages.oaconfig.general.publicURLPreFix=Public URL Prefix +webpages.moaconfig.defaultbkus.header=Default CCE +webpages.moaconfig.slrequesttemplates.header=SecurityLayer Request Templates +webpages.moaconfig.slrequesttemplates.local=Local CCE +webpages.moaconfig.slrequesttemplates.handy=Mobile CCE +webpages.moaconfig.slrequesttemplates.online=Online CCE +webpages.moaconfig.certificates.header=Certificate check +webpages.moaconfig.certificates.certstore=CertStoreDirectory +webpages.moaconfig.certificates.trustmanagerrev=TrustManagerRevocationChecking +webpages.moaconfig.certificates.trustCACerts=TrustedCACertificates +webpages.moaconfig.certificates.chainingmode=ChainingMode +webpages.moaconfig.timeout.header=Session TimeOuts +webpages.moaconfig.timeout.assertion=Assertion [sec] +webpages.moaconfig.timeout.MOASessionCreated=SSO Session authenticated [sec] +webpages.moaconfig.timeout.MOASessionUpdated=SSO Session last access[sec] +webpages.moaconfig.moasp.header=MOA-SP configuration +webpages.moaconfig.moasp.idltrustprofile=Trustprofile for IdentityLink +webpages.moaconfig.moasp.authtrustprofile=Trustprofile for authentication block +webpages.moaconfig.moasp.authblocktransform=Transformations for authentication block +webpages.moaconfig.moasp.url=URL for MOA-SP Service +webpages.moaconfig.identitylinksigners=IdentityLinkSigners +webpages.moaconfig.services.header=External Services +webpages.moaconfig.services.mandates=Online-Mandate Service URL +webpages.moaconfig.services.szrgw=SZR Gateway Service URL +webpages.moaconfig.sso.header=Single Sign-On +webpages.moaconfig.sso.PublicUrl=SSO Service URL-Prefix +webpages.moaconfig.sso.FriendlyName=SSO Service Name +webpages.moaconfig.services.sso.Target=SSO Service Target +webpages.moaconfig.services.sso.SpecialText=SSO AuthBlockText +webpages.moaconfig.protocols.header=Logging +webpages.moaconfig.protocols.allowed.header=Activate logging +webpages.moaconfig.protocols.legacy.header=Activate Legacy Mode +webpages.moaconfig.protocols.legacy.saml1=SAML1 +webpages.moaconfig.protocols.legacy.pvp2=PVP2.1 +webpages.moaconfig.protocols.oauth=OpenID Connect +webpages.moaconfig.protocols.saml1.header=SAML1 Configuration +webpages.moaconfig.protocols.saml1.sourceID=SourceID +webpages.moaconfig.protocols.pvp2.header=PVP2 Configuration +webpages.moaconfig.protocols.pvp2.PublicUrlPrefix=PVP2 Service URL-Prefix +webpages.moaconfig.protocols.pvp2.IssuerName=PVP Service Name +webpages.moaconfig.protocols.pvp2.org.header=Organization +webpages.moaconfig.protocols.pvp2.org.name=Short description +webpages.moaconfig.protocols.pvp2.org.displayname=Complete name +webpages.moaconfig.protocols.pvp2.org.url=Organization's URL +webpages.moaconfig.protocols.pvp2.contact.header=Contact data +webpages.moaconfig.protocols.pvp2.contact.surename=Surname +webpages.moaconfig.protocols.pvp2.contact.givenname=Name +webpages.moaconfig.protocols.pvp2.contact.email=E-mail address +webpages.moaconfig.protocols.pvp2.contact.company=Company +webpages.moaconfig.protocols.pvp2.contact.phone=Phone number +webpages.moaconfig.protocols.pvp2.contact.type=Contact type +webpages.moaconfig.sl.transormations.header=SecurityLayer Transformations +webpages.moaconfig.sl.transormations.filename=File name +webpages.moaconfig.sl.transormations.upload=Upload new transformations + +webpages.listOAs.list.elInfo=Type +webpages.listOAs.list.first=Unique identifier +webpages.listOAs.list.second=Name of the Online-Application + +webpages.searchoa.header=Find Online-Application +webpages.searchoa.search.friendlyname=Name of the Online-Applikation +webpages.searchoa.butten.search=Search + +webpages.oaconfig.header=Configuration of the Online-Application +webpages.oaconfig.general.isActive=Online-Application is activated +webpages.oaconfig.general.bku.header=CCE configuration +webpages.oaconfig.general.bku.local=Local CCE +webpages.oaconfig.general.bku.online=Online CCE +webpages.oaconfig.general.bku.handy=Mobile CCE +webpages.oaconfig.general.bku.slversion=SecurityLayer Version +webpages.oaconfig.general.bku.keyboxidentifier=KeyBoxIdentifier +webpages.oaconfig.general.bku.legacy=SecurityLayerTemplates (Legacy Request) +webpages.oaconfig.general.bku.sltemplate.first=SecurityLayer Template +webpages.oaconfig.general.bku.sltemplate.second=SecurityLayer Template (WhiteList) +webpages.oaconfig.general.bku.sltemplate.third=SecurityLayer Template (WhiteList) + +webpages.oaconfig.general.testing.header=Test Credentials +webpages.oaconfig.general.testing.usetesting=Allow test credentials +webpages.oaconfig.general.testing.oids=Use special test credential OIDs + +webpages.oaconfig.general.bku.delete=Remove +webpages.oaconfig.general.bku.bkuselection.header=CCE-Selection Template +webpages.oaconfig.general.bku.bkuselection.filename=Filename +webpages.oaconfig.general.bku.bkuselection.upload=Upload new template +webpages.oaconfig.general.bku.sendassertion.header=Send-Assertion Template +webpages.oaconfig.general.bku.sendassertion.filename=Filename +webpages.oaconfig.general.bku.sendassertion.upload=Upload new template + +webpages.oaconfig.bPKEncDec.header=Foreign-bPK Configuration +webpages.oaconfig.bPKEncDec.keystore.header=Keystore configuration +webpages.oaconfig.bPKEncDec.filename=Filename +webpages.oaconfig.bPKEncDec.delete=Remove +webpages.oaconfig.bPKEncDec.upload=Upload new keystore +webpages.oaconfig.bPKEncDec.keyStorePassword=Keystore password +webpages.oaconfig.bPKEncDec.keyAlias=Key alias +webpages.oaconfig.bPKEncDec.keyPassword=Key password + +webpages.oaconfig.general.identification=Unique identifier (PublicURLPrefix) +webpages.oaconfig.general.mandate.header=Mandates +webpages.oaconfig.general.mandate.profiles=Profile +webpages.oaconfig.general.mandate.usemandate=Mandates (ja/nein) +webpages.oaconfig.general.friendlyname=Name of the Online-Application +webpages.oaconfig.general.isbusinessservice=Private sector application +webpages.oaconfig.general.isstorkservice=Stork application +webpages.oaconfig.general.public.header=Public sector +webpages.oaconfig.general.stork.header=STORK sector +webpages.oaconfig.general.stork.countrycode=Country code +webpages.oaconfig.general.target.friendlyname=Name of the sector (arbitrary defined) +webpages.oaconfig.general.target.admin.checkbox=Define other sector arbitrary +webpages.oaconfig.general.target.admin=Sector (arbitrary defined) +webpages.oaconfig.general.target.friendlyname.disabled=Name of the sector (defined by admin) +webpages.oaconfig.general.target.admin.disabled=Sector (defined by admin) +webpages.oaconfig.general.target=Sector (Target) +webpages.oaconfig.general.target.subsector=Sub-sector +webpages.oaconfig.general.target.subsector.checkbox=Refine target +webpages.oaconfig.general.business.header=Private sector +webpages.oaconfig.general.business.value=Identification number +webpages.oaconfig.general.business.type=Type of identification number +webpages.oaconfig.general.aditional.header=Additional general settings +webpages.oaconfig.general.aditional.authblocktext=AuthblockText +webpages.oaconfig.general.aditional.iframe=Selection of citizen card in IFrame +webpages.oaconfig.general.aditional.useUTC=Use UTC time +webpages.oaconfig.general.aditional.calculateHPI="TODO!" +webpages.oaconfig.general.isHideBPKAuthBlock=Hide bPK/wbPK from AuthBlock + +webpages.oaconfig.menu.saml1.show=Show SAML1 configuration +webpages.oaconfig.menu.saml1.hidden=Hide SAML1 configuration +webpages.oaconfig.menu.pvp2.show=Show PVP2 configuration +webpages.oaconfig.menu.pvp2.hidden=Hide PVP2 configuration +webpages.oaconfig.menu.oauth20.show=Show OAuth 2.0 configuration +webpages.oaconfig.menu.oauth20.hidden=Hide OAuth 2.0 configuration +webpages.oaconfig.menu.vidp.show=Show VIDP configuration +webpages.oaconfig.menu.vidp.hidden=Hide VIDP configuration + +webpages.oaconfig.menu.stork=STORK configuration + +webpages.oaconfig.protocols.header=Authentication protocols + +webpages.oaconfig.general.BKUSelection.button.show=Show configuration of login window +webpages.oaconfig.general.BKUSelection.button.hidden=Hide configuration of login window +webpages.oaconfig.general.BKUSelection.header=Configuration of form +webpages.oaconfig.general.BKUSelection.isOnlyMandateLoginAllowed=Allow mandated login only +webpages.oaconfig.general.BKUSelection.backgroundcolor=Background color of CCE-Auswahl +webpages.oaconfig.general.BKUSelection.frontcolor=Foreground color of CCE-Auswahl +webpages.oaconfig.general.BKUSelection.header.backgroundcolor=Background color of header +webpages.oaconfig.general.BKUSelection.header.frontcolor=Foreground color of header +webpages.oaconfig.general.BKUSelection.header.text=Header text +webpages.oaconfig.general.BKUSelection.header.button.background=Background color of button +webpages.oaconfig.general.BKUSelection.header.button.background.focus=Background color of button (focus) +webpages.oaconfig.general.BKUSelection.header.button.front=Foreground color of buton +webpages.oaconfig.general.BKUSelection.redirectTarget=Targetparameter +webpages.oaconfig.general.BKUSelection.fonttype=Form font type +webpages.oaconfig.general.BKUSelection.fonttype.list=Form font type list +webpages.oaconfig.general.BKUSelection.header.applet.height=Height of applet +webpages.oaconfig.general.BKUSelection.header.applet.width=Width of applet + +webpages.oaconfig.sso.header=Single Sign-On +webpages.oaconfig.sso.singlelogouturl=Single Log-Out URL +webpages.oaconfig.sso.useauthdataframe=Additional user request +webpages.oaconfig.sso.usesso=Use Single Sign-On + +webpages.oaconfig.stork.header=Secure idenTity acrOss boRders linKed +webpages.oaconfig.stork.usestork=Activate STORK Logon +webpages.oaconfig.stork.attributes.header=requested attributes +webpages.oaconfig.stork.attributes.used=require? +webpages.oaconfig.stork.attributes.name=Attribute name +webpages.oaconfig.stork.attributes.mandatory=mandatory? +webpages.oaconfig.stork.enabledcpeps=activated target countries +webpages.moaconfig.stork.pepslist=C-PEPS configuration +webpages.moaconfig.stork.newpeps=Configure new PEPS +webpages.moaconfig.stork.removepeps=remove +webpages.moaconfig.stork.qaa.default=Select standard QAA-Level +webpages.moaconfig.stork.attributes.heading=Configuration of attributes +webpages.moaconfig.stork.attributes.new=Add new attribute +webpages.moaconfig.stork.attributes.heading.name=Name of attribute +webpages.moaconfig.stork.attributes.heading.mandatory=mandatory +webpages.moaconfig.stork.attributes.remove=remove +webpages.moaconfig.stork.qaa=Select minimal QAA-Level for current OA + +webpages.oaconfig.protocols.saml1.header=SAML1 configuration +webpages.oaconfig.saml1.isActice=Activate SAML1 +webpages.oaconfig.saml1.provideStammZahl=Transfer SourcePIN +webpages.oaconfig.saml1.provideAuthBlock=Transfer Authentication block +webpages.oaconfig.saml1.provideIdentityLink=Transfer IdentityLink +webpages.oaconfig.saml1.provideCertificate=Transfer certificate +webpages.oaconfig.saml1.provideFullMandateData=Transfer complete mandate data +webpages.oaconfig.saml1.useCondition=Use condition +webpages.oaconfig.saml1.conditionLength=Condition length +webpages.oaconfig.saml1.provideAllErrors=Transfer errors to application + +webpages.oaconfig.protocols.pvp2.header=PVP2.x configuration +webpages.oaconfig.pvp2.reload=Load new PVP2.x configuration +webpages.oaconfig.pvp2.metaDataURL=Metadata URL +webpages.oaconfig.pvp2.certifcate=Upload certificate +webpages.oaconfig.pvp2.certifcate.info=Certificate infos + +webpages.oaconfig.protocols.oauth20.header=OAuth 2.0 configuration +webpages.oaconfig.oauth20.clientId=Client ID +webpages.oaconfig.oauth20.clientSecret=Client Password +webpages.oaconfig.oauth20.redirectUri=Redirect URI + +webpages.oaconfig.vidp.enabled=VIDP interface is active +webpages.oaconfig.vidp.requireconsent=Ask the user for attributes transfer consent? +webpages.oaconfig.vidp.ap.new=Create new attribute provider +webpages.oaconfig.vidp.ap.remove=Remove +webpages.oaconfig.vidp.ap.list=List of configured attribute providers + + +message.title=Announcement: +webpages.oaconfig.success=The Online-Application {0} could be saved. +webpages.oaconfig.success.admin=Online-Applikation {0} could be saved. The activation by the Administrator is necessary. +webpages.oaconfig.cancle=The processing of Online-Applikation {0} was interrupted. +webpages.idp.success=IdentityProvider {0} could be saved. +webpages.idp.cancle=The processing of IdentityProvider {0} was interrupted. + +webpages.oaconfig.delete.message=Online-Application {0} was succesfully removed. +webpages.oaconfig.delete.error=Online-Application {0} could not be removed. + +webpages.edit.save=Save changes +webpages.edit.back=Forget changes and go back +webpages.edit.delete=Remove Online-Application + +webpages.header.info=You are logged in as: +webpages.header.lastlogin=Last login on: + +webpages.openadminrequests.header=Active requests: +webpages.openadminrequests.users.header=User accounts +webpages.openadminrequests.oas.header=Online-Applications + + +validation.newuser.mailaddress=Validation of eMail address completed. + +validation.edituser.familyname.empty=The surname is blank. +validation.edituser.familyname.valid=The surname contains forbidden characters. The following characters are not allowed\: {0} +validation.edituser.givenname.empty=The name is blank. +validation.edituser.givenname.valid=The name contains forbidden characters. The following characters are not allowed\: {0} +validation.edituser.institut.empty=The organization is blank. +validation.edituser.institut.valid=The organization contains forbidden characters. The following characters are not allowed\: {0} +validation.edituser.mail.empty=The eMail address is blank. +validation.edituser.mail.valid=The eMail address has invalid format. +validation.edituser.phone.empty=The phone number is blank. +validation.edituser.phone.valid=The phone number has invalid form +validation.edituser.username.empty=The user name is blank. +validation.edituser.username.valid=The user name contains forbidden characters. The following characters are not allowed\: {0} +validation.edituser.username.duplicate=The user name is already used +validation.edituser.password.empty=The password is blank. +validation.edituser.password.valid=The password could not be transferred into valid key. +validation.edituser.password.equal=The passwords are not identical. +validation.edituser.bpk.valid=BPK contains forbidden characters. The following characters are not allowed\: {0} + +validation.general.SAML1SourceID=SAML1SourceID contains forbidden characters. The following characters are not allowed\: {0} +validation.general.publicURLprefix.empty=Public URL Prefix is blank. +validation.general.publicURLprefix.valid=Public URL Prefix has invalid format. +validation.general.certStoreDirectory.empty=CertStoreDirectory is blank. +validation.general.certStoreDirectory.valid=CertStoreDirectory Feld contains forbidden characters. The following characters are not allowed\: {0} +validation.general.Defaultchainigmode.empty=There is no DefaultChainingMode selected. +validation.general.Defaultchainigmode.valid=DefaultChainingMode contains invalid value. +validation.general.IdentityLinkSigners.empty=There is no IdentityLinkSigner given +validation.general.IdentityLinkSigners.valid=IdentityLinkSigner in the line {0} contains forbidden characters. The following characters are not allowed\: {1} +validation.general.mandateservice.valid=URL for Online-Mandating Service has invalid format. +validation.general.moasp.auth.transformation.empty=Transformation for authentication block is blank. +validation.general.moasp.auth.transformation.valid=Transformation for authentication block in the line {0} contians forbidden characters. The following characters are not allowed\: {1} +validation.general.moasp.auth.trustprofile.empty=TrustProfile for checking of authentication block is blank. +validation.general.moasp.auth.trustprofile.valid=TrustProfile for checking of authentication block contains forbidden characters. The following characters are not allowed\: {0} +validation.general.moasp.idl.trustprofile.empty=TrustProfile for checking of IdentityLink is blank. +validation.general.moasp.idl.trustprofile.valid=TrustProfile for checking of IdentityLink contain forbidden characters. The following characters are not allowed\: {0} +validation.general.moaspss.url.valid=URL for MOA-SP/SS service has invalid format. +validation.general.protocol.pvp2.issuername.valid=PVP2\: service name contains forbidden characters. The following characters are not allowed\: {0} +validation.general.protocol.pvp2.org.displayname.valid=PVP2 organization\: complete name contains forbidden characters. The following characters are not allowed\: {0} +validation.general.protocol.pvp2.org.name.valid=PVP2 organization\: Short description contains forbidden characters. The following characters are not allowed\: {0} +validation.general.protocol.pvp2.org.url.valid=PVP2 organization\: URL has invalid format. +validation.general.protocol.pvp2.serviceurl.valid=PVP2\: service URL-Prefix has invalid format. +validation.general.protocol.pvp2.contact.company.valid=PVP2 contact data\: the company name contains forbidden characters. The following characters are not allowed\: {0} +validation.general.protocol.pvp2.contact.givenname.valid=PVP2 contact data\: the surname contains forbidden characters. The following characters are not allowed\: {0} +validation.general.protocol.pvp2.contact.surename.valid=PVP2 contact data\: the name contains forbidden characters. The following characters are not allowed\: {0} +validation.general.protocol.pvp2.contact.type.valid=PVP2 contact data: the provided contact type is not existing. +validation.general.protocol.pvp2.contact.mail.valid=PVP2 contact data\: the e-Mail address provided is invalid. +validation.general.protocol.pvp2.contact.phone.valid=PVP2 contact data\: the phone number provided is invalid. +validation.general.timeouts.assertion.valid=The field assertion timeout has invalid value. +validation.general.timeouts.moasessioncreated.valid=The field MOASessionCreated TimeOut has invalid value. +validation.general.timeouts.moasessionupdated.valid=The field MOASessionUpdated TimeOut has invalid value. + +validation.general.slrequest.handy.empty=URL for SecurityLayer Template for die Handy-CCE is blank. +validation.general.slrequest.handy.valid=URL for SecurityLayer Template for Mobile-CCE has invalid format. +validation.general.slrequest.local.empty=URL for SecurityLayer Template for local CCE is blank. +validation.general.slrequest.local.valid=URL for SecurityLayer Template for local CCE has invalid format. +validation.general.slrequest.online.empty=URL for SecurityLayer Template for Online-CCE is blank. +validation.general.slrequest.online.valid=URL for SecurityLayer Template for die Online-CCE has invalid format. +validation.general.sso.friendlyname.valid=SSO Service Name contains forbidden characters. The following characters are not allowed\: {0} +validation.general.sso.identificationnumber.valid=SSO IdentificationNumber contains forbidden characters. The following characters are not allowed\: {0} +validation.general.sso.publicurl.valid=SSO Service URL-Prefix has invalid format. +validation.general.sso.specialauthtext.valid=SSO AuthBlockText contains forbidden characters. The following characters are not allowed\: {0} +validation.general.sso.target.empty=SSO Target field is blank. +validation.general.sso.target.valid=SSO Target field contains invalid target. +validation.general.szrgw.url.valid=URL for SZR Gateway has invalid format. +validation.general.trustedcacerts.empty=Field TrustedCACertificates is blank. +validation.general.trustedcacerts.valid=Das Feld TrustedCACertificates contains forbidden characters. The following characters are not allowed\: {0} +validation.general.slrequest.filename.valid=File name of provided AuthBlock transformation contains forbidden characters. The following characters are not allowed\: {0} +validation.general.slrequest.file.valid=The provided AuthBlock transformation could not be loaded. +validation.general.slrequest.file.empty=The AuthBlock transformation is empty + +validation.general.aditionalauthblocktext=The additional text for AuthBlock contains forbidden characters. The following characters are not allowed\: {0} +validation.general.bku.handy.empty=URL for Mobile-CCE is blank. +validation.general.bku.handy.valid=URL for Mobile-CCE has invalid format. +validation.general.bku.local.empty=URL for local CCE is blank. +validation.general.bku.local.valid=URL for local CCE has invalid format. +validation.general.bku.online.empty=URL for Online-CCE is blank. +validation.general.bku.online.valid=URL for Online-CCE has invalid format. +validation.general.oafriendlyname.empty=There is no name for Online-Application provided. +validation.general.oafriendlyname.valid=The name of Online-Application contains forbidden characters. The following characters are not allowed\: {0} +validation.general.keyboxidentifier.empty=There is no KeyBoxIdentifier selected. +validation.general.keyboxidentifier.valid=The KeyBoxIdentifier has invalid format. +validation.general.sltemplates.empty=When the Legacy mod is used werden, at least one SecurityLayer Template should be provided. +validation.general.sltemplate1.valid=First SecurityLayer Template URL has invalid format. +validation.general.sltemplate2.valid=Second SecurityLayer Template URL has invalid format. +validation.general.sltemplate3.valid=Third SecurityLayer Template URL has invalid format. +validation.general.mandate.profiles=The list of Mandate profiles contains forbidden characters. The following characters are not allowed\: {0} +validation.general.mandate.usemandate=The configuration of Mandate profile is only with activated mandating support possible. +validation.general.target.empty=The Target for the Online-Application is blank. +validation.general.target.valid=The Target for the Online-Application has invalid format. +validation.general.target.subsector.valid=The Target-Subsector has invalid format. +validation.general.target.admin.valid=The Admin-Target for the Online-Application has invalid format. +validation.general.target.publicserviceurl=The domain of unique identifier for the Online-Application permits applications from the private sector only. +validation.general.slversion=The version of SecurityLayer is not the number. +validation.general.slversion.business=In private sector the version of SecurityLayer should be at least 1.2. SLVersion was set on 1.2. +validation.general.targetfriendlyname=The name of the sector (Target) contains forbidden characters. The following characters are not allowed\: {0} +validation.general.identificationtype.valid=The identification type is not supported. +validation.general.identificationnumber.empty=The identification number is necessary for private sector. +validation.general.identificationnumber.valid=The identification number for the private sector contains forbidden characters. The following characters are not allowed\: {0} +validation.general.identificationnumber.fn.valid=The identification number has invalid format. +validation.general.oaidentifier.empty=There is no unique identifier for the Online-Application provided. +validation.general.oaidentifier.valid=The unique identifier for the Online-Application is not valid URL. +validation.general.oaidentifier.notunique=The selected unique identifier is already available. Registration of the Online-Application was not possible. +validation.general.stork.sptarget=STORK SP-Target is blank. +validation.general.stork.sptargetsize=The Definition of STORK SP-Target is incorrect: too many characters. +validation.general.bkuselection.filename.valid=The file name of CCE-selection template contains forbidden characters. The following characters are not allowed\: {0} +validation.general.bkuselection.file.valid=The CCE-selection template could not be loaded. +validation.general.bkuselection.file.selected=Only one CCE-selection template can be provided. +validation.general.sendassertion.filename.valid=The file name of Send-Assertion Templates contains forbidden characters. The following characters are not allowed\: {0} +validation.general.sendassertion.file.valid=Send-Assertion Templates could not be loaded. +validation.general.sendassertion.file.selected=Only one Send-Assertion Template can be provided. +validation.general.testcredentials.oid.valid=The OID {0} for test credentials is not a valid. + +validation.bPKDec.keyStorePassword.empty=KeyStore password is blank. +validation.bPKDec.keyStorePassword.valid=The keyStore password contains forbidden characters. The following characters are not allowed\: {0} +validation.bPKDec.keyAlias.empty=Key alias is blank. +validation.bPKDec.keyAlias.valid=The key alias contains forbidden characters. The following characters are not allowed\: {0} +validation.bPKDec.keyPassword.empty=Key password is blank. +validation.bPKDec.keyPassword.valid=The key password contains forbidden characters. The following characters are not allowed\: {0} +validation.bPKDec.keyStore.filename.valid=The keyStore filename contains forbidden characters. The following characters are not allowed\: {0} +validation.bPKDec.keyStore.file.valid=KeyStore can not loaded. Maybe keyStore password or key alias are wrong.  +validation.bPKDec.keyStore.file.selected=Only one keyStore can be provided. + +validation.stork.cpeps.cc=CPEPS country code is not based on 3166-2 +validation.stork.cpeps.empty=CPEPS configuration is incomplete +validation.stork.cpeps.url=CPEPS URL is invalid +validation.stork.cpeps.duplicate=Country codes are not unique +validation.stork.requestedattributes=STORK attributes are incorrect. Example: attr1, attr2 +validation.stork.qaa.outofrange=Valid QAA values are 1, 2, 3, and 4 +validation.stork.attributes.empty=Only one attribute can be provided +validation.stork.ap.url.valid=Invalid URL of AttributeProvider +validation.stork.ap.name.empty=Invalid name of AttributeProvider +validation.stork.ap.name.valid=Invalid Name of AttributeProvider +validation.stork.ap.attributes.valid=Invalid attribute configuration for Attribute Provider Plugin. The field may not be blank und must be provided as csv. + +validation.pvp2.metadataurl.empty=There is no metadata URL provided. +validation.pvp2.metadataurl.valid=The metadata URL has invalid URL format . +validation.pvp2.metadataurl.read=No information could be found under provided URL. +validation.pvp2.metadata.verify.sig=The metadata could not be verified with the provided certificate. +validation.pvp2.metadata.verify.schema=Metadata schema validation FAILED. +validation.pvp2.metadata.verify.general=Metadata validation has an generic error. +validation.pvp2.certificate.format=The provided PVP2 certificate has invalid format. +validation.pvp2.certificate.notfound=There is no PVP2 inserted. +validation.pvp2.metadata.ssl=The SSL server certificate is not trusted. + +validation.sso.logouturl.empty=URL for Single Log-Out Service is necessary. +validation.sso.logouturl.valid=URL for Single Log-Out Service has incorrect format. + +validation.interfederation.moaidp.queryurl.valid=URL for AttributQuery Service has incorrect format. +validation.interfederation.moaidp.queryurl.empty=URL for AttributQuery Service is necessary. +validation.interfederation.moaidp.metadataurl.publicservice=The domain of Metadata service for that IDP permits private sector only. +validation.interfederation.gateway.entityID.valid=PVP portal EntityID has an incorrect format. +validation.interfederation.gateway.entityID.empty=PVP portal EntityID is necessary. + +validation.saml1.providestammzahl=ProvideSourcePIN cannot be combined with applications from private sector. + +validation.general.bkuselection.specialfeatures.valid=The special settings for the selection of CCE (Hide mandate login / compulsory required) could not be used in combination with SSO. +validation.general.bkuselection.specialfeatures.combination=Required mandate based in combination with hidden checkbox for selection of mandating is not possible. +validation.general.form.color.background=Background color for CCE selection contains invalid hexadecimal value. (e.g. \\\#FFFFFF) +validation.general.form.color.front=Foreground color for CCE selection contains invalid hexadecimal value. (e.g. \\\#FFFFFF) +validation.general.form.header.color.back=Background color for the caption of CCE selection contains no valid hexadecimal value. (e.g. \\\#FFFFFF) +validation.general.form.header.color.front=Foreground collor for the caption of CCE selection contains no valid hexadecimal value. (e.g. \\\#FFFFFF) +validation.general.form.header.text=The caption of CCE contains forbidden characters. The following characters are not allowed\: {0} +validation.general.form.button.color.back.focus=Die Hintergrundfarbe f\\u00FCr Focus der CCE-Auswahlbuttons enth\\u00E4lt keinen g\\u00FCltigen Hexadezimalwert. (z.B. \\\#FFFFFF) +validation.general.form.button.color.back=Background color for selection buttons for CCE contains no valid hexadecimal value. (e.g. \\\#FFFFFF) +validation.general.form.button.color.front=Foreground color for selection buttons for CCE contains no valid hexadecimal value. (e.g. \\\#FFFFFF) +validation.general.form.appletredirecttarget=RedirectTarget contains invalud value. +validation.general.form.fonttype=Font type for CCE selection contains forbidden characters. The following characters are not allowed\: {0} +validation.general.form.applet.width=The height of applet is invalid number. +validation.general.form.applet.height=The width of applet is invalid number. diff --git a/id/moa-id-webgui/src/main/resources/gui/meta.properties b/id/moa-id-webgui/src/main/resources/gui/meta.properties new file mode 100644 index 000000000..177dff6f1 --- /dev/null +++ b/id/moa-id-webgui/src/main/resources/gui/meta.properties @@ -0,0 +1,28 @@ +__BASE__.moaid.0=moa.id.general + +#__BASE__.all.1=moa.id.gateway + +moa.id.general.__TY=general +moa.id.general.__CA=General Configuration +moa.id.general.__DE=General MOA-ID Configuration + +#moa.id.oa.__GR=moa.id +#moa.id.oa.__TY=ARRAY +#moa.id.oa.__ADD=true +#moa.id.oa.__DEL=true +#moa.id.oa.__CA=List of online Applications +#moa.id.oa.__DE=Long description of the list of online Applications... +#moa.id.oa.__CTY=OA +#moa.id.oa.__CCA=Name;Online Applications URL +#moa.id.oa.__CIDS=name;url +#moa.id.oa.__CDE=An online Application + + +#moa.id.oa.__TE.name=Online Application Template +#moa.id.oa.__TE.url=http://sampleonline.application.com/ +#moa.id.oa.__TE.attributes.0.name=Vorname +#moa.id.oa.__TE.attributes.0.type=FIRSTNAME +#moa.id.oa.__TE.attributes.0.required=true +#moa.id.oa.__TE.__CA=A Template for an online Application +#moa.id.oa.__TE.__DE=Long description of the list of online Applications... + diff --git a/id/moa-id-webgui/src/main/resources/gui/types/general.json b/id/moa-id-webgui/src/main/resources/gui/types/general.json new file mode 100644 index 000000000..a4addb5f8 --- /dev/null +++ b/id/moa-id-webgui/src/main/resources/gui/types/general.json @@ -0,0 +1,441 @@ +{ +    "$schema": "http://json-schema.org/draft-04/schema#", +    "id": "http://www.egiz.gv.at/dynUI/general", +    "typeName": "general", +    "type": "object", +    "title": "General MOA-ID Configuration", +    "format": "tabs", +    "properties": { +        "publicURLPrefix": { +            "id": "http://www.egiz.gv.at/dynUI/general/publicurlprefix", +            "type": "string", +            "format": "url", +            "title": "Public URL Prefix" +        }, +        "defaults.bku": { +            "id": "http://www.egiz.gv.at/dynUI/general/bkuurls", +            "type": "object", +            "title": "Default BKUs", +            "description": "Default BKUs for authentication", +            "options": { +    						"collapsed": true +    				}, +            "properties": { +            	"onlineBKU" : { +            		"id": "http://www.egiz.gv.at/dynUI/general/bkuurls/online", +            		"type": "string", +            		"title": "Online BKU" +            	}, +            	"handyBKU" : { +            		"id": "http://www.egiz.gv.at/dynUI/general/bkuurls/handy", +            		"type": "string", +            		"title": "Handy BKU" +            	}, +            	"localBKU" : { +            		"id": "http://www.egiz.gv.at/dynUI/general/bkuurls/local", +            		"type": "string", +            		"title": "Local BKU" +            	} +            } +        }, +        "defaults.templates": { +            "id": "http://www.egiz.gv.at/dynUI/general/templates", +            "type": "object", +            "title": "Default SL-Templates", +            "description": "Default SecurityLayer templates", +            "options": { +    						"collapsed": true +    				}, +            "properties": { +            	"onlineBKU" : { +            		"id": "http://www.egiz.gv.at/dynUI/general/templates/online", +            		"type": "string", +            		"title": "Online BKU" +            	}, +            	"handyBKU" : { +            		"id": "http://www.egiz.gv.at/dynUI/general/templates/handy", +            		"type": "string", +            		"title": "Handy BKU" +            	}, +            	"localBKU" : { +            		"id": "http://www.egiz.gv.at/dynUI/general/templates/local", +            		"type": "string", +            		"title": "Local BKU" +            	} +            } +        }, +        "auth": { +            "id": "http://www.egiz.gv.at/dynUI/general/auth", +            "type": "object", +            "title": "Authentication", +            "description": "Authentication configuration", +            "options": { +    						"collapsed": true +    				}, +            "properties": { +                  "authblock.transformation": { +                    "id": "http://www.egiz.gv.at/dynUI/general/auth/authblock/transform", +                    "type": "object", +                    "format": "file", +                    "title": "AuthBlock transformation", +                    "description": "XML Transformation for AuthBlock generation", +                    "properties": { +            	         "data" : { +            		          "id": "http://www.egiz.gv.at/dynUI/general/auth/authblock/transform/data", +            		          "type": "string" +            	         }, +            	         "preview" : { +            		          "id": "http://www.egiz.gv.at/dynUI/general/auth/authblock/transform/preview", +            		          "type": "string" +            	        } +                    } +                }, +            		"timeouts": { +            				"id": "http://www.egiz.gv.at/dynUI/general/auth/timeouts", +            				"type": "object", +            				"title": "Timeout Configuration", +            				"description": "Session and Process timeout configuration", +            				"options": { +    										"collapsed": true +    								}, +            				"properties": { +            						"sso.create" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/timeouts/ss/create", +            								"type": "integer", +            								"title": "SSO created" +            						}, +            						"sso.update" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/timeouts/sso/update", +            								"type": "integer", +            								"title": "SSO updated" +            						}, +            						"transaction" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/timeouts/transaction", +            								"type": "integer", +            								"title": "Transaction" +            						} +                    } +            		}, +            		"moasp": { +            				"id": "http://www.egiz.gv.at/dynUI/general/auth/moasp", +            				"type": "object", +            				"title": "MOA-SP", +            				"description": "IdentityLink and Authblock validation", +            				"options": { +    										"collapsed": true +    								}, +            				"properties": { +            						"trustprofile.idl.prod" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/moasp/trust/idl", +            								"type": "string", +            								"title": "TrustProfile IdentityLink" +            						}, +            						"trustprofile.authblock.prod" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/moasp/trust/authblock", +            								"type": "string", +            								"title": "TrustProfile AuthBlock" +            						}, +            						"authblock.transform" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/moasp/authblock/transform", +            								"type": "string", +            								"title": "AuthBlock Transformation" +            						} +                    } +            		},                                               +                "certificate": { +            				"id": "http://www.egiz.gv.at/dynUI/general/auth/certificate", +            				"type": "object", +            				"title": "X509 validation", +            				"description": "Validation of X509 certificates", +            				"options": { +    										"collapsed": true +    								}, +            				"properties": { +            						"certstore.url" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/certificate/certstore", +            								"type": "string", +            								"title": "CertStore URL (relative to MOA-ID config directory)" +            						}, +            						"truststore.url" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/certificate/truststore", +            								"type": "string", +            								"title": "TrustStore URL (relative to MOA-ID config directory)" +            						}, +            						"revocationchecking" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/certificate/revocationchecking", +            								"type": "boolean", +                            "format" : "checkbox", +            								"title": "Activate X509 certificate revocation check" +            						} +                    } +            		}, +                "services": { +            				"id": "http://www.egiz.gv.at/dynUI/general/auth/services", +            				"type": "object", +            				"title": "External services", +            				"description": "Configuration of externel services", +            				"options": { +    										"collapsed": true +    								}, +            				"properties": { +            						"ovs.url" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/services/ovs/url", +            								"type": "string", +                            "format": "url", +            								"title": "URL to online mandate service (OVS)" +            						}, +            						"szrgw.url" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/services/szrgw/url", +            								"type": "string", +                            "format": "url", +            								"title": "URL to Stammzahlenregistergateway (SZR-GW)" +            						} +                    } +            		}, +                "sso": { +            				"id": "http://www.egiz.gv.at/dynUI/general/auth/sso", +            				"type": "object", +            				"title": "SSO Configuration", +            				"description": "Single Sign-On authentication", +            				"options": { +    										"collapsed": true +    								}, +            				"properties": { +            						"servicename" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/sso/idpname", +            								"type": "string", +            								"title": "Service name" +            						}, +                        "target" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/sso/target", +            								"type": "string", +            								"title": "Service Target" +            						}, +            						"authblock.text" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/auth/sso/authblocktext", +            								"type": "string", +            								"format": "textarea", +            								"title": "AuthBlock Text" +            						} +                    } +            		} +            } +        }, +        "protocols": { +            "id": "http://www.egiz.gv.at/dynUI/general/protocols", +            "type": "object", +            "title": "Protocols", +            "description": "Authentication protocol configuration", +            "options": { +    						"collapsed": true +    				}, +            "properties": { +            		"saml1": { +            				"id": "http://www.egiz.gv.at/dynUI/general/protocols/saml1", +            				"type": "object", +            				"title": "SAML1 Configuration", +            				"description": "SAML1 authentication protocol", +            				"options": { +    										"collapsed": true +    								}, +            				"properties": { +            						"enabled" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/protocols/saml1/enabled", +            								"type": "boolean", +                            "format" : "checkbox", +            								"title": "Enabled" +            						}, +            						"legacy" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/protocols/saml1/legacy", +            								"type": "boolean", +                            "format" : "checkbox", +            								"title": "Legacy mode enabled" +            						}, +            						"sourceID" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/protocols/saml1/sourceid", +            								"type": "string", +            								"title": "SourceID" +            						} +                    } +            		}, +                "pvp2x": { +            				"id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2x", +            				"type": "object", +            				"title": "PVP Configuration", +            				"description": "PVP 2.x authentication protocol", +            				"options": { +    										"collapsed": true +    								}, +            				"properties": { +            						"enabled" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2x/enabled", +            								"type": "boolean", +                            "format" : "checkbox", +            								"title": "Enabled" +            						}, +            						"legacy" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2/legacyx", +            								"type": "boolean", +                            "format" : "checkbox", +            								"title": "Legacy mode enabled" +            						}, +            						"metadata" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2x/metadata", +            								"type": "object", +            								"title": "Metadata", +                            "description": "PVP 2.x Metadata configuration", +                            "options": { +    														"collapsed": true +    												}, +            				        "properties": { +            						        "servicename" : { +            								        "id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2x/metadata/servicename", +            								        "type": "string", +            								        "title": "Service Name" +            						        }, +                                "org.name.short" : { +            								        "id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2x/metadata/org/name/short", +            								        "type": "string", +            								        "title": "Organisation - Short name" +            						        }, +                                "org.name.full" : { +            								        "id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2x/metadata/org/name/full", +            								        "type": "string", +            								        "title": "Organisation - Full name" +            						        }, +                                "org.url" : { +            								        "id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2x/metadata/org/url", +            								        "type": "string", +            								        "format": "url", +            								        "title": "Organisation - URL" +            						        }, +                                "contact.givenname" : { +            								        "id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2x/metadata/contact/givenname", +            								        "type": "string", +            								        "title": "Contact - Givenname" +            						        }, +                                "contact.familyname" : { +            								        "id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2x/metadata/contact/familyname", +            								        "type": "string", +            								        "title": "Contact - Familyname" +            						        }, +                                "contact.company" : { +            								        "id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2x/metadata/contact/company", +            								        "type": "string", +            								        "title": "Contact - Company" +            						        }, +                                "contact.mail" : { +            								        "id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2x/metadata/contact/mail", +            								        "type": "string", +            								        "format": "email", +            								        "title": "Contact - Mail" +            						        }, +                                "contact.phone" : { +            								        "id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2x/metadata/contact/phone", +            								        "type": "string", +            								        "format": "tel", +            								        "title": "Contact - phone" +            						        }, +                                "contact.type" : { +            								        "id": "http://www.egiz.gv.at/dynUI/general/protocols/pvp2x/metadata/contact/type", +            								        "type": "string", +            								        "title": "Contact - Type", +                                    "enum": [ +                                      "technical", +                                      "support", +                                      "administrative", +                                      "billing", +                                      "other" +                                    ] +            						        }            						       +                            } +            						} +                    } +            		}, +                "openID": { +            				"id": "http://www.egiz.gv.at/dynUI/general/protocols/openid", +            				"type": "object", +            				"title": "OpenID Connect Configuration", +            				"description": "OpenID Connect authentication protocol", +            				"options": { +    										"collapsed": true +    								}, +            				"properties": { +            						"enabled" : { +            								"id": "http://www.egiz.gv.at/dynUI/general/protocols/openid/enabled", +            								"type": "boolean", +                            "format" : "checkbox", +            								"title": "Enabled" +            						} +                    } +            		} +            } +        }, +        "auth.stork": { +            "id": "http://www.egiz.gv.at/dynUI/general/auth/stork", +            "type": "object", +            "title": "STORK", +            "description": "STORK cross boarder eID", +            "options": { +    						"collapsed": true +    				}, +            "properties": { +            		"qaa": { +            				"id": "http://www.egiz.gv.at/dynUI/general/auth/stork/qaa", +            				"type": "integer", +            				"title": "Minimal QAA level" +    						}, +                "cpeps" : { +                     "type": "array", +                      "title": "C-PEPS services", +                      "format": "table", +                      "options": { +    											"collapsed": true +    									}, +                      "items": { +                          "type": "object", +                          "properties": { +                              "countrycode": { +                                  "type": "string", +                                  "title": "CountryCode" +                              }, +                              "url": { +                                  "type": "string", +                                  "format": "url", +                                  "title": "URL" +                              }, +                              "support.xmldsig": { +                                  "type": "boolean", +                                  "format": "checkbox", +                                  "title": "XMLDsig supported" +                              } +                          } +                      } +                }, +                "attributes" : { +                     "type": "array", +                      "title": "STORK attributes", +                      "format": "table", +                      "options": { +    											"collapsed": true +    									}, +                      "items": { +                          "type": "object", +                          "properties": { +                              "friendlyname": { +                                  "type": "string", +                                  "title": "Attribute name" +                              }, +                              "mandatory": { +                                  "type": "boolean", +                                  "format": "checkbox", +                                  "title": "Mandatory" +                              } +                          } +                      } +                } +            } +        }                                            +    }, +    "required": ["publicURLPrefix"] +} diff --git a/id/moa-id-webgui/src/main/resources/gui/types/oa.json b/id/moa-id-webgui/src/main/resources/gui/types/oa.json new file mode 100644 index 000000000..eee0e97aa --- /dev/null +++ b/id/moa-id-webgui/src/main/resources/gui/types/oa.json @@ -0,0 +1,148 @@ +{ +    "$schema": "http://json-schema.org/draft-04/schema#", +    "id": "http://www.egiz.gv.at/dynUI/OA", +    "typeName": "oa", +    "type": "object", +    "title": "Online Application Configuration", +    "format": "tabs", +    "properties": { +        "isActive" : { +            "id": "http://www.egiz.gv.at/dynUI/OA/isactive", +            "type": "boolean", +            "format" : "checkbox", +            "title": "is Active" +        }, +        "uniqueID": { +            "id": "http://www.egiz.gv.at/dynUI/OA/uniqueId", +            "type": "string", +            "format": "url", +            "title": "Unique Identifier (PublicURLPrefix)" +        }, +        "friendlyName": { +            "id": "http://www.egiz.gv.at/dynUI/OA/friendlyname", +            "type": "string", +            "title": "Friendlyname" +        }, +        "businessservice" : { +            "id": "http://www.egiz.gv.at/dynUI/OA/type", +            "type": "boolean", +            "format" : "checkbox", +            "title": "Private Sector application" +        }, +        "target": { +            "id": "http://www.egiz.gv.at/dynUI/OA/target", +            "type": "object", +            "title": "Target definition", +            "description": "bPK or wbPK target definitions", +            "options": { +    						"collapsed": true +    				}, +            "properties": { +                "public": { +                    "id": "http://www.egiz.gv.at/dynUI/OA/target/public", +                    "type": "object", +                    "title": "Public Sector definition", +                    "description": "bPK target definitions", +                    "options": { +    						        "collapsed": true +    				        }, +                    "properties": { +            	           "target" : { +            		              "id": "http://www.egiz.gv.at/dynUI/OA/target/public/target", +            		              "type": "string", +            		              "title": "Target", +                              "enum": [ +                                      "AR", +                                      "AS", +                                      "BF", +                                      "BW", +                                      "EA", +                                      "EF", +                                      "GH", +                                      "GS", +                                      "JR", +                                      "KL", +                                      "KU", +                                      "LF", +                                      "LV", +                                      "RT", +                                      "SA", +                                      "SF", +                                      "SO", +                                      "SV", +                                      "UW", +                                      "VT", +                                      "VV", +                                      "WT", +                                      "ZP", +                                      "BR", +                                      "HR", +                                      "KI", +                                      "OI", +                                      "PV", +                                      "RD", +                                      "VS", +                                      "ZU" +                                      ] +            	           }, +                         "use.sub" : { +                              "id": "http://www.egiz.gv.at/dynUI/OA/target/public/usesubtarget", +                              "type": "boolean", +                              "format" : "checkbox", +                              "title": "Use sub-target" +                         }, +            	           "target.sub" : { +            		              "id": "http://www.egiz.gv.at/dynUI/OA/target/public/subtarget", +            		              "type": "string", +            		              "title": "Sub-Target" +            	           }, +                         "use.own" : { +                              "id": "http://www.egiz.gv.at/dynUI/OA/target/public/useowntarget", +                              "type": "boolean", +                              "format" : "checkbox", +                              "title": "Use own-target" +                         }, +                         "own.target" : { +            		              "id": "http://www.egiz.gv.at/dynUI/OA/target/public/owntarget", +            		              "type": "string", +            		              "title": "Own target" +            	           }, +                         "own.name" : { +            		              "id": "http://www.egiz.gv.at/dynUI/OA/target/public/owntarget/friendlyname", +            		              "type": "string", +            		              "title": "Own target - friendlyname" +            	           } +                    } +                }, +                "private": { +                    "id": "http://www.egiz.gv.at/dynUI/OA/target/private", +                    "type": "object", +                    "title": "Private Sector definition", +                    "description": "wbPK target definitions", +                    "options": { +    						        "collapsed": true +    				        }, +                    "properties": { +            	           "type" : { +            		              "id": "http://www.egiz.gv.at/dynUI/OA/target/private/type", +            		              "type": "string", +            		              "title": "Sector Type", +                              "enum": [ +                                      "FN", +                                      "ZVR", +                                      "ERSB", +                                      "STORK" +                                      ] +            	           }, +            	           "value" : { +            		              "id": "http://www.egiz.gv.at/dynUI/OA/target/private/value", +            		              "type": "string", +            		              "title": "Identifier" +            	           }, +                    } +                } +            } +        } +    }, +    "required": ["uniqueID", "friendlyName"] +} diff --git a/id/moa-id-webgui/src/main/resources/moaid.webgui.beans.xml b/id/moa-id-webgui/src/main/resources/moaid.webgui.beans.xml new file mode 100644 index 000000000..3d1528fdf --- /dev/null +++ b/id/moa-id-webgui/src/main/resources/moaid.webgui.beans.xml @@ -0,0 +1,22 @@ +<?xml version="1.0" encoding="UTF-8"?> +<beans xmlns="http://www.springframework.org/schema/beans" +	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" +	xmlns:context="http://www.springframework.org/schema/context" +	xmlns:tx="http://www.springframework.org/schema/tx" +	xmlns:aop="http://www.springframework.org/schema/aop" +	xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.1.xsd +		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd +		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd +		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd"> + + +	<bean id="moaidconfigurationmodul" class="at.gv.egovernment.moa.id.config.webgui.MOAIDConfigurationModul"> +		<property name="databaseConfiguration" ref="configPropertyDao"/> +	</bean> + +	<bean id="moaidConfigurationValidiation" class="at.gv.egovernment.moa.id.config.webgui.validation.MOAIDConfigurationValidator"> +		<property name="databaseConfiguration" ref="configPropertyDao"/> +	</bean> +	 +		 +</beans>
\ No newline at end of file diff --git a/id/moa-id-webgui/src/test/java/META-INF/MANIFEST.MF b/id/moa-id-webgui/src/test/java/META-INF/MANIFEST.MF new file mode 100644 index 000000000..254272e1c --- /dev/null +++ b/id/moa-id-webgui/src/test/java/META-INF/MANIFEST.MF @@ -0,0 +1,3 @@ +Manifest-Version: 1.0 +Class-Path:  + diff --git a/id/server/moa-id-commons/pom.xml b/id/server/moa-id-commons/pom.xml index c04ea13fa..591998185 100644 --- a/id/server/moa-id-commons/pom.xml +++ b/id/server/moa-id-commons/pom.xml @@ -53,15 +53,15 @@      		<dependency>  	    		<groupId>at.gv.egiz.components</groupId>  	    		<artifactId>egiz-configuration-api</artifactId> -	    		<version>0.1</version> +	    		<version>0.2</version>  	    		<classifier>sources</classifier>      		</dependency>      		<dependency>      			<groupId>at.gv.egiz.components</groupId>      			<artifactId>egiz-configuration-file</artifactId> -    			<version>0.1</version> +    			<version>0.2</version>      			<classifier>sources</classifier> -    		</dependency> +    		</dependency>                  <dependency>              <groupId>org.hibernate</groupId> diff --git a/id/server/moa-id-commons/src/main/java/at/gv/egiz/components/configuration/api/AbstractConfigurationImpl.java b/id/server/moa-id-commons/src/main/java/at/gv/egiz/components/configuration/api/AbstractConfigurationImpl.java index d5ea2342a..e2db54609 100644 --- a/id/server/moa-id-commons/src/main/java/at/gv/egiz/components/configuration/api/AbstractConfigurationImpl.java +++ b/id/server/moa-id-commons/src/main/java/at/gv/egiz/components/configuration/api/AbstractConfigurationImpl.java @@ -526,6 +526,12 @@ public abstract class AbstractConfigurationImpl implements Configuration {  	}  	/* (non-Javadoc) +	 * @see at.gv.egiz.components.configuration.api.Configuration#deleteIds(java.lang.String) +	 */ +	@Override +	abstract public void deleteIds(String idSearch) throws ConfigurationException; +	 +	/* (non-Javadoc)  	 * @see at.gv.egiz.components.configuration.api.Configuration#synchronize()  	 */  	@Override diff --git a/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/config/ConfigurationMigrationUtils.java b/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/config/ConfigurationMigrationUtils.java index 974646ef0..694ff0720 100644 --- a/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/config/ConfigurationMigrationUtils.java +++ b/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/config/ConfigurationMigrationUtils.java @@ -113,6 +113,9 @@ public class ConfigurationMigrationUtils {  	 * @return MOA-ID 3.x OnlineApplication configuration without prefix but never Null   	 */  	public static Map<String, String> convertHyberJaxBOnlineApplicationToKeyValue(OnlineApplication oa) { +		//TODO: add C-PEPS countries and STORK attributes from general config!!!! +		//TODO: add correct list identifiers for metadata handling +		  		Map<String, String> result = new HashMap<String, String>();  		if (oa != null) {  			//convert oaID and friendlyname diff --git a/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/config/MOAIDConfigurationConstants.java b/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/config/MOAIDConfigurationConstants.java index 78eec24ee..34e3f3c7e 100644 --- a/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/config/MOAIDConfigurationConstants.java +++ b/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/config/MOAIDConfigurationConstants.java @@ -1,7 +1,9 @@  package at.gv.egovernment.moa.id.commons.config; +import java.util.ArrayList;  import java.util.Collections;  import java.util.Hashtable; +import java.util.List;  import java.util.Map;  /** @@ -26,14 +28,24 @@ public final class MOAIDConfigurationConstants {      public static final Map<String, String> BUSINESSSERVICENAMES; +    public static final List<String> ALLOWED_WBPK_PREFIXES; +      	static {  		Hashtable<String, String> tmp = new Hashtable<String, String>();  		tmp.put(IDENIFICATIONTYPE_FN, "Firmenbuchnummer");  		tmp.put(IDENIFICATIONTYPE_ZVR, "Vereinsnummer");  		tmp.put(IDENIFICATIONTYPE_ERSB, "ERsB Kennzahl");          tmp.put(IDENIFICATIONTYPE_STORK, "STORK"); -          BUSINESSSERVICENAMES = Collections.unmodifiableMap(tmp); +         +        List<String> awbpk = new ArrayList<String>(); +        awbpk.add(IDENIFICATIONTYPE_FN); +        awbpk.add(IDENIFICATIONTYPE_ERSB); +        awbpk.add(IDENIFICATIONTYPE_ZVR); +        awbpk.add(PREFIX_WPBK + IDENIFICATIONTYPE_FN); +        awbpk.add(PREFIX_WPBK + IDENIFICATIONTYPE_ERSB); +        awbpk.add(PREFIX_WPBK + IDENIFICATIONTYPE_ZVR);         +        ALLOWED_WBPK_PREFIXES = Collections.unmodifiableList(awbpk);  	} @@ -206,9 +218,10 @@ public final class MOAIDConfigurationConstants {  	public static final String GENERAL_DEFAULTS_TEMPLATES_ONLINE = GENERAL_DEFAULTS_TEMPLATES + ".onlineBKU";  	private static final String GENERAL_AUTH = PREFIX_MOAID_GENERAL + ".auth"; -	public static final String GENERAL_AUTH_CERTSTORE_URL = GENERAL_AUTH + ".certstore.url"; -	public static final String GENERAL_AUTH_TRUSTSTORE_URL = GENERAL_AUTH + ".truststore.url"; -	public static final String GENERAL_AUTH_REVOCATIONCHECKING = GENERAL_AUTH + ".revocationchecking"; +	private static final String GENERAL_AUTH_CERTIFICATE = GENERAL_AUTH + ".certificate"; +	public static final String GENERAL_AUTH_CERTSTORE_URL = GENERAL_AUTH_CERTIFICATE + ".certstore.url"; +	public static final String GENERAL_AUTH_TRUSTSTORE_URL = GENERAL_AUTH_CERTIFICATE + ".truststore.url"; +	public static final String GENERAL_AUTH_REVOCATIONCHECKING = GENERAL_AUTH_CERTIFICATE + ".revocationchecking";  	public static final String GENERAL_AUTH_TIMEOUTS_TRANSACTION = GENERAL_AUTH + ".timeouts.transaction";   //Anmeldedaten  	public static final String GENERAL_AUTH_TIMEOUS_SSO_CREATE = GENERAL_AUTH + ".timeouts.sso.create"; @@ -256,8 +269,8 @@ public final class MOAIDConfigurationConstants {  	public static final String GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_COMPANY = GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT + ".company";  	public static final String GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT_TYPE = GENERAL_PROTOCOLS_PVP2X_METADATA_CONTACT + ".type"; -	public static final String GENERAL_AUTH_AUTHBLOCK_TRANSFORMATION_NAME = GENERAL_AUTH + ".authblock.transformation.name"; -	public static final String GENERAL_AUTH_AUTHBLOCK_TRANSFORMATION_BASE64 = GENERAL_AUTH + ".authblock.transformation.base64"; +	public static final String GENERAL_AUTH_AUTHBLOCK_TRANSFORMATION_NAME = GENERAL_AUTH + ".authblock.transformation.preview"; +	public static final String GENERAL_AUTH_AUTHBLOCK_TRANSFORMATION_BASE64 = GENERAL_AUTH + ".authblock.transformation.data";  	public static final String GENERAL_AUTH_STORK = GENERAL_AUTH + "." + STORK;  	public static final String GENERAL_AUTH_STORK_QAA = GENERAL_AUTH_STORK + ".qaa"; diff --git a/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/db/NewConfigurationDBRead.java b/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/db/NewConfigurationDBRead.java index 66143efad..8f6100f84 100644 --- a/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/db/NewConfigurationDBRead.java +++ b/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/db/NewConfigurationDBRead.java @@ -1,53 +1,69 @@ -//package at.gv.egovernment.moa.id.commons.db; -// -//import java.util.ArrayList; -//import java.util.Collections; -//import java.util.Date; -//import java.util.List; -// -//import org.springframework.beans.factory.annotation.Autowired; -// -//import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; -//import at.gv.egovernment.moa.id.commons.config.persistence.MOAIDConfiguration; -//import at.gv.egovernment.moa.id.commons.db.dao.config.AuthComponentGeneral; -//import at.gv.egovernment.moa.id.commons.db.dao.config.ChainingModes; -//import at.gv.egovernment.moa.id.commons.db.dao.config.DefaultBKUs; -//import at.gv.egovernment.moa.id.commons.db.dao.config.GenericConfiguration; -//import at.gv.egovernment.moa.id.commons.db.dao.config.OnlineApplication; -//import at.gv.egovernment.moa.id.commons.db.dao.config.SLRequestTemplates; -//import at.gv.egovernment.moa.id.commons.db.dao.config.UserDatabase; -//import at.gv.egovernment.moa.logging.Logger; -// -///** -// *  -// * -// */ -//public class NewConfigurationDBRead { -// -//	private static MOAIDConfiguration conf; -// -//	@Autowired(required = true) -//	public void setConfiguration(MOAIDConfiguration conf) { -//		// https://jira.spring.io/browse/SPR-3845 -//		NewConfigurationDBRead.conf = conf; -//	} -// -//	@SuppressWarnings("unchecked") -//	public static <T extends Iterable<?>> T nullGuard(T item) { -//		if (item == null) { -//			return (T) Collections.emptyList(); -//		} else { -//			return item; -//		} -//	} -// -//	/** -//	 *  -//	 * @return -//	 */ -//	public static List<UserDatabase> getAllUsers() { -//		Logger.trace("Get All Users from database."); -// +package at.gv.egovernment.moa.id.commons.db; + +import java.util.ArrayList; +import java.util.Collections; +import java.util.Date; +import java.util.List; +import java.util.Map; + +import org.springframework.beans.factory.annotation.Autowired; + +import at.gv.egiz.components.configuration.api.ConfigurationException; +import at.gv.egovernment.moa.id.commons.config.MOAIDConfigurationConstants; +import at.gv.egovernment.moa.id.commons.config.persistence.MOAIDConfiguration; +import at.gv.egovernment.moa.id.commons.db.dao.config.AuthComponentGeneral; +import at.gv.egovernment.moa.id.commons.db.dao.config.ChainingModes; +import at.gv.egovernment.moa.id.commons.db.dao.config.DefaultBKUs; +import at.gv.egovernment.moa.id.commons.db.dao.config.GenericConfiguration; +import at.gv.egovernment.moa.id.commons.db.dao.config.OnlineApplication; + +import at.gv.egovernment.moa.id.commons.db.dao.config.UserDatabase; +import at.gv.egovernment.moa.logging.Logger; + +/** + *  + * + */ +public class NewConfigurationDBRead { + +	private static MOAIDConfiguration conf; + +	@Autowired(required = true) +	public void setConfiguration(MOAIDConfiguration conf) { +		// https://jira.spring.io/browse/SPR-3845 +		NewConfigurationDBRead.conf = conf; +	} + +	@SuppressWarnings("unchecked") +	public static <T extends Iterable<?>> T nullGuard(T item) { +		if (item == null) { +			return (T) Collections.emptyList(); +		} else { +			return item; +		} +		 +	} + +	public static Map<String, String> getOnlineApplicationKeyValueWithId(String id) { +		try { +			return conf.getOnlineApplication(id); +			 +		} catch (ConfigurationException e) { +			Logger.warn("OnlineApplication with Id: " + id + " not found.", e); +			return null; +			 +		} +	} +	 +	 +	 +	/** +	 *  +	 * @return +	 */ +	public static List<UserDatabase> getAllUsers() { +		Logger.trace("Get All Users from database."); +  //		// select userdatabase from UserDatabase userdatabase  //		List<UserDatabase> result = conf.getList("getAllUsers", UserDatabase.class);  //		if (result.size() == 0) { @@ -56,46 +72,52 @@  //		}  //  //		return result; -//	} -// -//	/** -//	 *  -//	 * @return -//	 */ -//	public static List<OnlineApplication> getAllOnlineApplications() { -//		Logger.trace("Get All OnlineApplications from database."); -// -//		// select onlineapplication from OnlineApplication onlineapplication +		 +		//TODO!!! +		return null; +	} + +	/** +	 *  +	 * @return +	 */ +	public static List<OnlineApplication> getAllOnlineApplications() { +		Logger.trace("Get All OnlineApplications from database."); + +		// select onlineapplication from OnlineApplication onlineapplication  //		return conf.getList(MOAIDConfigurationConstants.ONLINE_APPLICATIONS_KEY, OnlineApplication.class); -// -//	} -// -//	/** -//	 *  -//	 * @return -//	 */ -//	public static List<OnlineApplication> getAllNewOnlineApplications() { -//		Logger.trace("Get All New OnlineApplications from database."); -// -//		// select onlineapplication from OnlineApplication onlineapplication -//		// where onlineapplication.isActive = '0' and onlineapplication.isAdminRequired = '1' -//		List<OnlineApplication> result = new ArrayList<OnlineApplication>(); -//		List<OnlineApplication> allOAs = getAllOnlineApplications(); -// -//		for (OnlineApplication oa : nullGuard(allOAs)) { -//			if (!oa.isIsActive() && oa.isIsAdminRequired()) { -//				result.add(oa); -//			} -//		} -// -//		if (result.size() == 0) { -//			Logger.trace("No entries found."); -//			return null; -//		} -// -//		return result; -//	} -// +		 +		//TODO!!! +		return null; + +	} + +	/** +	 *  +	 * @return +	 */ +	public static List<OnlineApplication> getAllNewOnlineApplications() { +		Logger.trace("Get All New OnlineApplications from database."); + +		// select onlineapplication from OnlineApplication onlineapplication +		// where onlineapplication.isActive = '0' and onlineapplication.isAdminRequired = '1' +		List<OnlineApplication> result = new ArrayList<OnlineApplication>(); +		List<OnlineApplication> allOAs = getAllOnlineApplications(); + +		for (OnlineApplication oa : nullGuard(allOAs)) { +			if (!oa.isIsActive() && oa.isIsAdminRequired()) { +				result.add(oa); +			} +		} + +		if (result.size() == 0) { +			Logger.trace("No entries found."); +			return null; +		} + +		return result; +	} +  //	/**  //	 *   //	 * @return @@ -138,291 +160,291 @@  //  //		return result;  //	} -// -//	/** -//	 *  -//	 * @return -//	 */ -//	public static List<OnlineApplication> getAllActiveOnlineApplications() { -//		Logger.trace("Get All New OnlineApplications from database."); -// -//		// select onlineapplication from OnlineApplication onlineapplication -//		// where onlineapplication.isActive = '1' -//		List<OnlineApplication> result = new ArrayList<OnlineApplication>(); -//		List<OnlineApplication> allOAs = getAllOnlineApplications(); -// -//		for (OnlineApplication oa : nullGuard(allOAs)) { -//			if (oa.isIsActive()) { -//				result.add(oa); -//			} -//		} -// -//		if (result.size() == 0) { -//			Logger.trace("No entries found."); -//			return null; -//		} -// -//		return result; -//	} -// -//	/** -//	 *  -//	 * @param id -//	 * @return -//	 */ -//	public static OnlineApplication getActiveOnlineApplication(String id) { -//		Logger.trace("Getting Active OnlineApplication with ID " + id + " from database."); -// -//		// select onlineapplication from OnlineApplication onlineapplication -//		// where onlineapplication.publicURLPrefix = -//		// SUBSTRING(:id, 1, LENGTH(onlineapplication.publicURLPrefix)) and  onlineapplication.isActive = '1' -//		OnlineApplication result = null; -//		List<OnlineApplication> allActiveOAs = getAllActiveOnlineApplications(); -// -//		for (OnlineApplication oa : nullGuard(allActiveOAs)) { -//			String publicUrlPrefix = oa.getPublicURLPrefix(); -//			if (publicUrlPrefix != null && publicUrlPrefix.length() <= id.length()) { -//				if ((id.substring(1, publicUrlPrefix.length()).equals(publicUrlPrefix))) { -//					if (result != null) { -//						Logger.warn("OAIdentifier match to more then one DB-entry!"); -//						return null; -//					} else { -//						result = oa; -//					} -//				} -//			} -//		} -// -//		return result; -//	} -// -//	/** -//	 *  -//	 * @param dbid -//	 * @return -//	 */ -//	public static OnlineApplication getOnlineApplication(long dbid) { -//		Logger.trace("Getting OnlineApplication with DBID " + dbid + " from database."); -// -//		// select onlineapplication from OnlineApplication onlineapplication where onlineapplication.hjid = :id -//		OnlineApplication result = null; -//		List<OnlineApplication> allOAs = getAllOnlineApplications(); -// -//		for (OnlineApplication oa : nullGuard(allOAs)) { -//			if (oa.getHjid() == dbid) { -//				result = oa; -//				break; -//			} -//		} -// -//		return result; -//	} -// -//	/** -//	 *  -//	 * @param id -//	 * @return -//	 */ -//	public static OnlineApplication getOnlineApplication(String id) { -//		Logger.trace("Getting OnlineApplication with ID " + id + " from database."); -// -//		// select onlineapplication from OnlineApplication onlineapplication -//		// where onlineapplication.publicURLPrefix = SUBSTRING(:id, 1, LENGTH(onlineapplication.publicURLPrefix)) -//		OnlineApplication result = null; -//		List<OnlineApplication> allOAs = getAllOnlineApplications(); -// -//		for (OnlineApplication oa : nullGuard(allOAs)) { -//			String publicUrlPrefix = oa.getPublicURLPrefix(); -//			if (publicUrlPrefix != null && publicUrlPrefix.length() <= id.length()) { -//				if (id.substring(1, publicUrlPrefix.length()).equals(publicUrlPrefix)) { -//					if (result != null) { -//						Logger.warn("OAIdentifier match to more then one DB-entry!"); -//						return null; -//					} else { -//						result = oa; -//					} -//				} -//			} -//		} -// -//		return result; -//	} -// -//	/** -//	 *  -//	 * @param id -//	 * @return -//	 */ -//	public static List<OnlineApplication> searchOnlineApplications(String id) { -//		Logger.trace("Getting OnlineApplication with ID " + id + " from database."); -// -//		// select onlineapplication from OnlineApplication onlineapplication -//		// where onlineapplication.friendlyName like :id -//		List<OnlineApplication> result = new ArrayList<OnlineApplication>(); -//		List<OnlineApplication> allOAs = getAllOnlineApplications(); -// -//		for (OnlineApplication oa : nullGuard(allOAs)) { -//			if (id.equals(oa.getFriendlyName())) { -//				result.add(oa); -//			} -//		} -// -//		if (result.size() == 0) { -//			Logger.trace("No entries found."); -//			return null; -//		} -//		 -//		return result; -//	} -// -//	/** -//	 *  -//	 * @return -//	 */ -//	public static List<UserDatabase> getAllOpenUsersRequests() { -//		Logger.trace("Get all new Users from Database"); -// -//		// select userdatabase from UserDatabase userdatabase -//		// where userdatabase.userRequestTokken is not null -//		// and userdatabase.isAdminRequest = '1' and userdatabase.isMailAddressVerified = '0' -//		List<UserDatabase> result = new ArrayList<UserDatabase>(); -//		List<UserDatabase> allUsers = getAllUsers(); -// -//		for (UserDatabase user : nullGuard(allUsers)) { -//			// TODO check result of query "... userdatabase.userRequestTokken is not null" if Tokken is null -> (null, "NULL", "", ... ?) -//			if ((user.getUserRequestTokken() != null && !user.getUserRequestTokken().isEmpty() && !user.getUserRequestTokken().equals("NULL")) -//					&& (user.isIsAdminRequest()) && (!user.isIsMailAddressVerified())) { -//				result.add(user); -//			} -//		} -// -//		if (result.size() == 0) { -//			Logger.trace("No entries found."); -//			return null; -//		} -// -//		return result; -//	} -// -//	/** -//	 *  -//	 * @param tokken -//	 * @return -//	 */ -//	public static UserDatabase getNewUserWithTokken(String tokken) { -//		Logger.trace("Getting Userinformation with Tokken " + tokken + " from database."); -// -//		// select userdatabase from UserDatabase userdatabase where userdatabase.userRequestTokken = :tokken -//		UserDatabase result = null; -//		List<UserDatabase> allUsers = getAllUsers(); -// -//		for (UserDatabase user : nullGuard(allUsers)) { -//			if (user.getUserRequestTokken().equals(tokken)) { -//				result = user; -//				break; -//			} -//		} -// -//		return result; -//	} -// -//	/** -//	 *  -//	 * @param id -//	 * @return -//	 */ -//	public static UserDatabase getUsersWithOADBID(long id) { -//		Logger.trace("Getting Userinformation with OADBID " + id + " from database."); -// -//		// select userdatabase from UserDatabase userdatabase -//		// inner join userdatabase.onlineApplication oa where oa.hjid = :id -//		UserDatabase result = null; -//		List<UserDatabase> allUsers = getAllUsers(); -// -//		boolean quit = false; -//		for (UserDatabase user : nullGuard(allUsers)) { -// -//			for (OnlineApplication oa : user.getOnlineApplication()) { -// -//				if (oa.getHjid() == id) { -//					result = user; -//					quit = true; -//					break; -//				} -//			} -// -//			if (quit) { -//				break; -//			} -//		} -// -//		return result; -//	} -// -//	/** -//	 *  -//	 * @param id -//	 * @return -//	 */ -//	public static UserDatabase getUserWithID(long id) { -//		Logger.trace("Getting Userinformation with ID " + id + " from database."); -// -//		// select userdatabase from UserDatabase userdatabase where userdatabase.hjid = :id -//		UserDatabase result = null; -//		List<UserDatabase> allUsers = getAllUsers(); -// -//		for (UserDatabase user : nullGuard(allUsers)) { -//			if (user.getHjid() == id) { -//				result = user; -//				break; -//			} -//		} -// -//		return result; -//	} -// -//	/** -//	 *  -//	 * @param username -//	 * @return -//	 */ -//	public static UserDatabase getUserWithUserName(String username) { -//		Logger.trace("Getting Userinformation with ID " + username + " from database."); -// -//		// select userdatabase from UserDatabase userdatabase where userdatabase.username = :username -//		UserDatabase result = null; -//		List<UserDatabase> allUsers = getAllUsers(); -// -//		for (UserDatabase user : nullGuard(allUsers)) { -//			if (user.getUsername().equals(username)) { -//				result = user; -//				break; -//			} -//		} -// -//		return result; -//	} -// -//	/** -//	 *  -//	 * @param bpkwbpk -//	 * @return -//	 */ -//	public static UserDatabase getUserWithUserBPKWBPK(String bpkwbpk) { -//		Logger.trace("Getting Userinformation with ID " + bpkwbpk + " from database."); -// -//		// select userdatabase from UserDatabase userdatabase where userdatabase.bpk = :bpk -//		UserDatabase result = null; -//		List<UserDatabase> allUsers = getAllUsers(); -// -//		for (UserDatabase user : nullGuard(allUsers)) { -//			if (user.getBpk().equals(bpkwbpk)) { -//				result = user; -//				break; -//			} -//		} -// -//		return result; -//	} -// -//} + +	/** +	 *  +	 * @return +	 */ +	public static List<OnlineApplication> getAllActiveOnlineApplications() { +		Logger.trace("Get All New OnlineApplications from database."); + +		// select onlineapplication from OnlineApplication onlineapplication +		// where onlineapplication.isActive = '1' +		List<OnlineApplication> result = new ArrayList<OnlineApplication>(); +		List<OnlineApplication> allOAs = getAllOnlineApplications(); + +		for (OnlineApplication oa : nullGuard(allOAs)) { +			if (oa.isIsActive()) { +				result.add(oa); +			} +		} + +		if (result.size() == 0) { +			Logger.trace("No entries found."); +			return null; +		} + +		return result; +	} + +	/** +	 *  +	 * @param id +	 * @return +	 */ +	public static OnlineApplication getActiveOnlineApplication(String id) { +		Logger.trace("Getting Active OnlineApplication with ID " + id + " from database."); + +		// select onlineapplication from OnlineApplication onlineapplication +		// where onlineapplication.publicURLPrefix = +		// SUBSTRING(:id, 1, LENGTH(onlineapplication.publicURLPrefix)) and  onlineapplication.isActive = '1' +		OnlineApplication result = null; +		List<OnlineApplication> allActiveOAs = getAllActiveOnlineApplications(); + +		for (OnlineApplication oa : nullGuard(allActiveOAs)) { +			String publicUrlPrefix = oa.getPublicURLPrefix(); +			if (publicUrlPrefix != null && publicUrlPrefix.length() <= id.length()) { +				if ((id.substring(1, publicUrlPrefix.length()).equals(publicUrlPrefix))) { +					if (result != null) { +						Logger.warn("OAIdentifier match to more then one DB-entry!"); +						return null; +					} else { +						result = oa; +					} +				} +			} +		} + +		return result; +	} + +	/** +	 *  +	 * @param dbid +	 * @return +	 */ +	public static OnlineApplication getOnlineApplication(long dbid) { +		Logger.trace("Getting OnlineApplication with DBID " + dbid + " from database."); + +		// select onlineapplication from OnlineApplication onlineapplication where onlineapplication.hjid = :id +		OnlineApplication result = null; +		List<OnlineApplication> allOAs = getAllOnlineApplications(); + +		for (OnlineApplication oa : nullGuard(allOAs)) { +			if (oa.getHjid() == dbid) { +				result = oa; +				break; +			} +		} + +		return result; +	} + +	/** +	 *  +	 * @param id +	 * @return +	 */ +	public static OnlineApplication getOnlineApplication(String id) { +		Logger.trace("Getting OnlineApplication with ID " + id + " from database."); + +		// select onlineapplication from OnlineApplication onlineapplication +		// where onlineapplication.publicURLPrefix = SUBSTRING(:id, 1, LENGTH(onlineapplication.publicURLPrefix)) +		OnlineApplication result = null; +		List<OnlineApplication> allOAs = getAllOnlineApplications(); + +		for (OnlineApplication oa : nullGuard(allOAs)) { +			String publicUrlPrefix = oa.getPublicURLPrefix(); +			if (publicUrlPrefix != null && publicUrlPrefix.length() <= id.length()) { +				if (id.substring(1, publicUrlPrefix.length()).equals(publicUrlPrefix)) { +					if (result != null) { +						Logger.warn("OAIdentifier match to more then one DB-entry!"); +						return null; +					} else { +						result = oa; +					} +				} +			} +		} + +		return result; +	} + +	/** +	 *  +	 * @param id +	 * @return +	 */ +	public static List<OnlineApplication> searchOnlineApplications(String id) { +		Logger.trace("Getting OnlineApplication with ID " + id + " from database."); + +		// select onlineapplication from OnlineApplication onlineapplication +		// where onlineapplication.friendlyName like :id +		List<OnlineApplication> result = new ArrayList<OnlineApplication>(); +		List<OnlineApplication> allOAs = getAllOnlineApplications(); + +		for (OnlineApplication oa : nullGuard(allOAs)) { +			if (id.equals(oa.getFriendlyName())) { +				result.add(oa); +			} +		} + +		if (result.size() == 0) { +			Logger.trace("No entries found."); +			return null; +		} +		 +		return result; +	} + +	/** +	 *  +	 * @return +	 */ +	public static List<UserDatabase> getAllOpenUsersRequests() { +		Logger.trace("Get all new Users from Database"); + +		// select userdatabase from UserDatabase userdatabase +		// where userdatabase.userRequestTokken is not null +		// and userdatabase.isAdminRequest = '1' and userdatabase.isMailAddressVerified = '0' +		List<UserDatabase> result = new ArrayList<UserDatabase>(); +		List<UserDatabase> allUsers = getAllUsers(); + +		for (UserDatabase user : nullGuard(allUsers)) { +			// TODO check result of query "... userdatabase.userRequestTokken is not null" if Tokken is null -> (null, "NULL", "", ... ?) +			if ((user.getUserRequestTokken() != null && !user.getUserRequestTokken().isEmpty() && !user.getUserRequestTokken().equals("NULL")) +					&& (user.isIsAdminRequest()) && (!user.isIsMailAddressVerified())) { +				result.add(user); +			} +		} + +		if (result.size() == 0) { +			Logger.trace("No entries found."); +			return null; +		} + +		return result; +	} + +	/** +	 *  +	 * @param tokken +	 * @return +	 */ +	public static UserDatabase getNewUserWithTokken(String tokken) { +		Logger.trace("Getting Userinformation with Tokken " + tokken + " from database."); + +		// select userdatabase from UserDatabase userdatabase where userdatabase.userRequestTokken = :tokken +		UserDatabase result = null; +		List<UserDatabase> allUsers = getAllUsers(); + +		for (UserDatabase user : nullGuard(allUsers)) { +			if (user.getUserRequestTokken().equals(tokken)) { +				result = user; +				break; +			} +		} + +		return result; +	} + +	/** +	 *  +	 * @param id +	 * @return +	 */ +	public static UserDatabase getUsersWithOADBID(long id) { +		Logger.trace("Getting Userinformation with OADBID " + id + " from database."); + +		// select userdatabase from UserDatabase userdatabase +		// inner join userdatabase.onlineApplication oa where oa.hjid = :id +		UserDatabase result = null; +		List<UserDatabase> allUsers = getAllUsers(); + +		boolean quit = false; +		for (UserDatabase user : nullGuard(allUsers)) { + +			for (OnlineApplication oa : user.getOnlineApplication()) { + +				if (oa.getHjid() == id) { +					result = user; +					quit = true; +					break; +				} +			} + +			if (quit) { +				break; +			} +		} + +		return result; +	} + +	/** +	 *  +	 * @param id +	 * @return +	 */ +	public static UserDatabase getUserWithID(long id) { +		Logger.trace("Getting Userinformation with ID " + id + " from database."); + +		// select userdatabase from UserDatabase userdatabase where userdatabase.hjid = :id +		UserDatabase result = null; +		List<UserDatabase> allUsers = getAllUsers(); + +		for (UserDatabase user : nullGuard(allUsers)) { +			if (user.getHjid() == id) { +				result = user; +				break; +			} +		} + +		return result; +	} + +	/** +	 *  +	 * @param username +	 * @return +	 */ +	public static UserDatabase getUserWithUserName(String username) { +		Logger.trace("Getting Userinformation with ID " + username + " from database."); + +		// select userdatabase from UserDatabase userdatabase where userdatabase.username = :username +		UserDatabase result = null; +		List<UserDatabase> allUsers = getAllUsers(); + +		for (UserDatabase user : nullGuard(allUsers)) { +			if (user.getUsername().equals(username)) { +				result = user; +				break; +			} +		} + +		return result; +	} + +	/** +	 *  +	 * @param bpkwbpk +	 * @return +	 */ +	public static UserDatabase getUserWithUserBPKWBPK(String bpkwbpk) { +		Logger.trace("Getting Userinformation with ID " + bpkwbpk + " from database."); + +		// select userdatabase from UserDatabase userdatabase where userdatabase.bpk = :bpk +		UserDatabase result = null; +		List<UserDatabase> allUsers = getAllUsers(); + +		for (UserDatabase user : nullGuard(allUsers)) { +			if (user.getBpk().equals(bpkwbpk)) { +				result = user; +				break; +			} +		} + +		return result; +	} + +} diff --git a/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/db/dao/config/DatabaseConfigPropertyImpl.java b/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/db/dao/config/DatabaseConfigPropertyImpl.java index 8e845478b..00c191228 100644 --- a/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/db/dao/config/DatabaseConfigPropertyImpl.java +++ b/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/db/dao/config/DatabaseConfigPropertyImpl.java @@ -100,7 +100,10 @@ public class DatabaseConfigPropertyImpl extends AbstractConfigurationImpl {  	protected void deleteKey(String key) {  		log.debug("Deleting entry with key '{}'.", key); -		em.remove(em.find(ConfigProperty.class, key)); +		ConfigProperty el = em.find(ConfigProperty.class, key); +		if (el != null) +			em.remove(el); +			  	}  	/* (non-Javadoc) @@ -117,7 +120,10 @@ public class DatabaseConfigPropertyImpl extends AbstractConfigurationImpl {  		TypedQuery<String> query = em.createQuery("select key from ConfigProperty dbconfig where dbconfig.key like :key", String.class);  		query.setParameter("key", searchString.replace("*", "%"));  		List<String> result = query.getResultList(); -		return result.toArray(new String[result.size()]); +		if (result == null) +			return null; +		else +			return result.toArray(new String[result.size()]);  	}  	/* (non-Javadoc) @@ -166,7 +172,17 @@ public class DatabaseConfigPropertyImpl extends AbstractConfigurationImpl {  		return result;  	} -	 +	/* (non-Javadoc) +	 * @see at.gv.egiz.components.configuration.api.AbstractConfigurationImpl#deleteIds(java.lang.String) +	 */ +	@Override +	public void deleteIds(String idSearch) throws ConfigurationException { +		String[] keyList = findConfigurationId(idSearch); +		for (String el : keyList) { +			deleteKey(el); +			 +		} +	}  //	@Override  //	public String getPropertyValue(String key) { diff --git a/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/utils/KeyValueUtils.java b/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/utils/KeyValueUtils.java index 626db2167..0e4616825 100644 --- a/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/utils/KeyValueUtils.java +++ b/id/server/moa-id-commons/src/main/java/at/gv/egovernment/moa/id/commons/utils/KeyValueUtils.java @@ -22,23 +22,35 @@   */  package at.gv.egovernment.moa.id.commons.utils; +import java.util.ArrayList; +import java.util.Collections; +import java.util.HashMap; +import java.util.Iterator; +import java.util.List; +import java.util.Map; +import java.util.Map.Entry; + +import at.gv.egovernment.moa.util.MiscUtil; +  /**   * @author tlenz   *   */  public class KeyValueUtils { +	public static final String KEY_DELIMITER = "."; +	  	/**  	 * Extract the first child of an input key after a the prefix  	 *  -	 * @param key: Full input key  -	 * @param prefix: Prefix  +	 * @param key Full input key  +	 * @param prefix Prefix   	 * @return Child key {String} if it exists or null  	 */  	public static String getFirstChildAfterPrefix(String key, String prefix) {		  		String idAfterPrefix = removePrefixFromKey(key, prefix);  		if (idAfterPrefix != null) { -			int index = idAfterPrefix.indexOf("."); +			int index = idAfterPrefix.indexOf(KEY_DELIMITER);  			if (index > 0) {  				String adding = idAfterPrefix.substring(0, index);  				if (!(adding.isEmpty())) { @@ -57,14 +69,14 @@ public class KeyValueUtils {  	/**  	 * Extract the prefix from an input key  	 *  -	 * @param key: Full input key -	 * @param suffix: Suffix of this key +	 * @param key Full input key +	 * @param suffix Suffix of this key  	 * @return Prefix {String} of the key or null if input key does not ends with postfix string   	 */  	public static String getPrefixFromKey(String key, String suffix) {  		if (key != null && key.endsWith(suffix)) {  			String idPreforeSuffix = key.substring(0, key.length()-suffix.length());			 -			if (idPreforeSuffix.endsWith(".")) +			if (idPreforeSuffix.endsWith(KEY_DELIMITER))  				return idPreforeSuffix.substring(0, idPreforeSuffix.length()-1);  			else  				return idPreforeSuffix; @@ -76,8 +88,8 @@ public class KeyValueUtils {  	/**  	 * Remove a prefix string from a key  	 *  -	 * @param key: Full input key -	 * @param prefix: Prefix, which should be removed +	 * @param key Full input key +	 * @param prefix Prefix, which should be removed  	 * @return The suffix of the input key or null if the input does not starts with the prefix  	 */  	public static String removePrefixFromKey(String key, String prefix) { @@ -86,7 +98,7 @@ public class KeyValueUtils {  		if (key!=null && key.startsWith(prefix)) {  			String afterPrefix = key.substring(prefix.length());  -			int index = afterPrefix.indexOf("."); +			int index = afterPrefix.indexOf(KEY_DELIMITER);  			if (index == 0) {  				afterPrefix = afterPrefix.substring(1); @@ -98,4 +110,108 @@ public class KeyValueUtils {  		return null;  	} +	/** +	 * Remove a prefix string from all keys in {Map<String, String>} of key/value pairs +	 *  +	 * @param keys Input data of key/value pairs +	 * @param prefix Prefix which should be removed +	 * @return {Map<String, String>} of key/value pairs without prefix in key, but never null +	 */ +	public static Map<String, String> removePrefixFromKeys(Map<String, String> keys, String prefix) { +		Map<String, String> result = new HashMap<String, String>(); +		Iterator<Entry<String, String>> interator = keys.entrySet().iterator(); +		while(interator.hasNext()) { +			Entry<String, String> el = interator.next(); +			String newKey = removePrefixFromKey(el.getKey(), prefix);  +			if (MiscUtil.isNotEmpty(newKey)) { +				result.put(newKey, el.getValue()); +			}			 +		} +		 +		return result; +	} + +	/** +	 * Get a subset of key/value pairs which starts with a prefix string +	 * The Prefix is removed from the key +	 *  +	 * @param keys Input data of key/value pairs +	 * @param prefix Prefix string +	 * @return {Map<String, String>} of key/value pairs without prefix in key, but never null +	 */ +	public static Map<String, String> getSubSetWithPrefix(Map<String, String> keys, String prefix) { +		return removePrefixFromKeys(keys, prefix); +	} +	 +	 +	/** +	 * Add a prefix to key/value pairs to make the key absolute according to key namespace convention +	 *  +	 * @param input Input key/value pairs which should be updated +	 * @param prefix Key prefix, which should be added if the key is not absolute +	 * @param absolutIdentifier Key identifier, which indicates an absolute key +	 * @return {Map<String, String>} of key/value pairs in which all keys are absolute but never null +	 */ +	public static Map<String, String> makeKeysAbsolut(Map<String, String> input, String prefix, String absolutIdentifier) { +		Map<String, String> result = new HashMap<String, String>(); +		Iterator<Entry<String, String>> interator = input.entrySet().iterator(); +		while(interator.hasNext()) { +			Entry<String, String> el = interator.next(); +			if (!el.getKey().startsWith(absolutIdentifier)) { +				//key is not absolute -> add prefix +				result.put(prefix  +						+ KEY_DELIMITER +						+ el.getKey(),  +						el.getValue()); +								 +			} else { +				//key is absolute +				result.put(el.getKey(), el.getValue()); +			} +		} +		return result; +	} +	 +	/** +	 * Get the parent key string from an input key +	 *  +	 * @param key input key +	 * @return parent key or the empty String if no parent exists +	 */ +	public static String getParentKey(String key) { +		if (MiscUtil.isNotEmpty(key)) { +			int index = key.lastIndexOf(KEY_DELIMITER); +			if (index > 0) { +				return key.substring(0, index); +				 +			}			 +		} +		 +		return new String(); +	} + +	/** +	 * Find the highest free list counter +	 *  +	 * @param input Array of list keys +	 * @param listPrefix {String} prefix of the list +	 * @return {int} highest free list counter +	 */ +	public static int findNextFreeListCounter(String[] input, +			String listPrefix) { +		List<Integer> counters = new ArrayList<Integer>(); +		if (input == null || input.length == 0) +			return 0; +		 +		else { +			for (String key : input) { +				String listIndex = getFirstChildAfterPrefix(key, listPrefix); +				counters.add(Integer.parseInt(listIndex)); +			 +			}		 +			Collections.sort(counters);		 +			return counters.get(counters.size()-1) + 1; +		} +	} +	  } | 
