diff options
4 files changed, 77 insertions, 26 deletions
| diff --git a/id/server/data/deploy/conf/moa-id/stork/StorkSamlEngine_VIDP.xml b/id/server/data/deploy/conf/moa-id/stork/StorkSamlEngine_VIDP.xml index b45b69054..29973690e 100644 --- a/id/server/data/deploy/conf/moa-id/stork/StorkSamlEngine_VIDP.xml +++ b/id/server/data/deploy/conf/moa-id/stork/StorkSamlEngine_VIDP.xml @@ -121,4 +121,7 @@          <entry key="ECApplicationRole">http://www.stork.gov.eu/1.1/ECApplicationRole</entry>          <entry key="MSOrganization">http://www.stork.gov.eu/1.1/MSOrganization</entry> +        <entry key="citizenQAALevel">http://www.stork.gov.eu/1.0/citizenQAALevel</entry> + +  </properties> diff --git a/id/server/data/deploy/conf/moa-id/stork/StorkSamlEngine_incoming.xml b/id/server/data/deploy/conf/moa-id/stork/StorkSamlEngine_incoming.xml index 3370978b3..a817e29c0 100644 --- a/id/server/data/deploy/conf/moa-id/stork/StorkSamlEngine_incoming.xml +++ b/id/server/data/deploy/conf/moa-id/stork/StorkSamlEngine_incoming.xml @@ -94,5 +94,7 @@    <!-- ISA 1.18 attributes-->    <entry key="ECApplicationRole">http://www.stork.gov.eu/1.1/ECApplicationRole</entry>    <entry key="MSOrganization">http://www.stork.gov.eu/1.1/MSOrganization</entry> + +  <entry key="citizenQAALevel">http://www.stork.gov.eu/1.0/citizenQAALevel</entry>  </properties> diff --git a/id/server/data/deploy/conf/moa-id/stork/StorkSamlEngine_outgoing.xml b/id/server/data/deploy/conf/moa-id/stork/StorkSamlEngine_outgoing.xml index bdad5686b..b840b4fe5 100644 --- a/id/server/data/deploy/conf/moa-id/stork/StorkSamlEngine_outgoing.xml +++ b/id/server/data/deploy/conf/moa-id/stork/StorkSamlEngine_outgoing.xml @@ -124,5 +124,7 @@    <!-- ISA 1.18 attributes-->    <entry key="ECApplicationRole">http://www.stork.gov.eu/1.1/ECApplicationRole</entry>    <entry key="MSOrganization">http://www.stork.gov.eu/1.1/MSOrganization</entry> + +        <entry key="citizenQAALevel">http://www.stork.gov.eu/1.0/citizenQAALevel</entry> -</properties>
\ No newline at end of file +</properties> diff --git a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/stork2/MOAAttributeProvider.java b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/stork2/MOAAttributeProvider.java index 9a6206947..2c7e5b539 100644 --- a/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/stork2/MOAAttributeProvider.java +++ b/id/server/idserverlib/src/main/java/at/gv/egovernment/moa/id/protocols/stork2/MOAAttributeProvider.java @@ -26,21 +26,20 @@ import at.gv.egovernment.moa.id.auth.builder.BPKBuilder;  import at.gv.egovernment.moa.id.auth.exception.BuildException;  import at.gv.egovernment.moa.id.data.AuthenticationRole;  import at.gv.egovernment.moa.id.data.IAuthData; +import at.gv.egovernment.moa.id.protocols.pvp2x.PVPConstants;  import at.gv.egovernment.moa.id.util.PVPtoSTORKMapper;  import at.gv.egovernment.moa.logging.Logger;  import at.gv.egovernment.moa.util.MiscUtil;  import eu.stork.peps.auth.commons.PersonalAttribute;  import eu.stork.peps.auth.commons.PersonalAttributeList;  import eu.stork.peps.complex.attributes.eu.stork.names.tc.stork._1_0.assertion.AttributeStatusType; +import org.joda.time.Period; +  import java.lang.reflect.InvocationTargetException;  import java.lang.reflect.Method;  import java.text.DateFormat;  import java.text.SimpleDateFormat; -import java.util.ArrayList; -import java.util.Collections; -import java.util.HashMap; -import java.util.List; -import java.util.Map; +import java.util.*;  /**   * @author bsuzic @@ -55,6 +54,8 @@ public class MOAAttributeProvider {      private static final Map<String, String> storkAttributeFunctionMapping;      private final MOASTORKRequest moastorkRequest; +    // mappings for attribute population methods +    // based on mapping of moa authndata and executing functions to extract attributes      static {          Map<String, String> tempSimpleMap = new HashMap<String, String>();          tempSimpleMap.put("givenName", "getGivenName"); @@ -67,6 +68,9 @@ public class MOAAttributeProvider {          tempFunctionMap.put("ECApplicationRole","getECApplicationRole");          tempFunctionMap.put("dateOfBirth", "getFormatedDateOfBirth");          tempFunctionMap.put("MSOrganization", "getMSOrganization"); +        tempFunctionMap.put("age", "getAge"); +        tempFunctionMap.put("isAgeOver", "getIsAgeOver"); +        tempFunctionMap.put("citizenQAALevel", "getQAALevel");          storkAttributeFunctionMapping = Collections.unmodifiableMap(tempFunctionMap);      } @@ -79,6 +83,8 @@ public class MOAAttributeProvider {      public void populateAttribute(PersonalAttributeList attributeList, PersonalAttribute requestedAttribute ) {          String storkAttribute = requestedAttribute.getName(); + +        // TODO: check if authData gets populated with stork attributtes during previous steps; it seems it is not          if (null != authData && null != authData.getStorkAttributes() && authData.getStorkAttributes().containsKey(requestedAttribute.getName())) {              Logger.debug("Trying to get value for attribute directly from STORK2 response [" + storkAttribute + "]");              try { @@ -86,46 +92,78 @@ public class MOAAttributeProvider {                  attributeList.add((PersonalAttribute) tmp.clone());              } catch(Exception e) {                  Logger.error("Could not retrieve attribute from STORK2 response: " + storkAttribute); -                if(Logger.isDebugEnabled()) -                    e.printStackTrace(); +                Logger.debug(e);              }          } else if (storkAttributeSimpleMapping.containsKey(storkAttribute)) {              Logger.debug("Trying to get value for attribute using simple mapping [" + storkAttribute + "]");              try {                  Method method = authData.getClass().getDeclaredMethod(storkAttributeSimpleMapping.get(storkAttribute)); -                populateAttributeWithMethod(method, authData, attributeList, storkAttribute, requestedAttribute.isRequired()); +                populateAttributeWithMethod(method, authData, attributeList, storkAttribute, requestedAttribute);              } catch (NoSuchMethodException e) {                  Logger.error("Could not found MOA extraction method while getting attribute: " + storkAttribute); -                e.printStackTrace(); +                Logger.debug(e); +            } catch (NullPointerException e) { +                Logger.error("Error getting MOA extraction method while getting attribute: " + storkAttribute); +                Logger.debug(e);              }          } else if (storkAttributeFunctionMapping.containsKey(storkAttribute)) {              Logger.debug("Trying to get value for attribute using function mapping [" + storkAttribute + "]");              try { -                Method method = this.getClass().getDeclaredMethod(storkAttributeFunctionMapping.get(storkAttribute)); -                populateAttributeWithMethod(method, this, attributeList, storkAttribute, requestedAttribute.isRequired()); +                Method method = this.getClass().getDeclaredMethod(storkAttributeFunctionMapping.get(storkAttribute), PersonalAttribute.class); +                populateAttributeWithMethod(method, this, attributeList, storkAttribute, requestedAttribute);              } catch (NoSuchMethodException e) {                  Logger.error("Could not found MOA extraction method while getting attribute: " + storkAttribute); -                e.printStackTrace();              }          } else {              Logger.debug("MOA method for extraction of attribute " + storkAttribute + " not defined.");          }      } -    private String geteIdentifier() { +    private String getAge(PersonalAttribute personalAttribute) { +        if (authData.getDateOfBirth() != null) { +            Integer age = new Period(authData.getDateOfBirth().getTime(), Calendar.getInstance().getTime().getTime()).getYears(); +            return age >= 0 ? age.toString() : null; +        } +        return null; // WP4 D4.2, Table 12:age, description - considerations +    } + +    private String getIsAgeOver(PersonalAttribute personalAttribute) +    { +        try { +            if ((authData.getDateOfBirth() != null) && (personalAttribute.getValue() != null) && (personalAttribute.getValue().size() > 0)) { +                Integer ageOver = Integer.parseInt(personalAttribute.getValue().get(0)); +                Integer age = new Period(authData.getDateOfBirth().getTime(), Calendar.getInstance().getTime().getTime()).getYears(); +                return age >= ageOver ? ageOver.toString() : ""; +            } +        } catch (Exception ex) { +            Logger.error("Error encountered when determining isAgeOver"); +            Logger.debug(ex); +        } +        return null; +    } + +    public String getQAALevel(PersonalAttribute personalAttribute) { +        if (authData.getQAALevel().startsWith(PVPConstants.STORK_QAA_PREFIX)) +            return authData.getQAALevel().substring(PVPConstants.STORK_QAA_PREFIX.length()); +        else +            return null; +    } + + +    private String geteIdentifier(PersonalAttribute personalAttribute) {          Logger.debug("Using base urn for identification value: " + authData.getIdentificationType() + " and target country: " + moastorkRequest.getStorkAuthnRequest().getSpCountry());          try { -            return new BPKBuilder().buildStorkeIdentifier(authData.getIdentificationType(), authData.getIdentificationValue(),  -            			moastorkRequest.getStorkAuthnRequest().getSpCountry()); +            return new BPKBuilder().buildStorkeIdentifier(authData.getIdentificationType(), authData.getIdentificationValue(), +                    moastorkRequest.getStorkAuthnRequest().getSpCountry());          } catch (BuildException be) {              Logger.error("Stork eid could not be constructed; " + be.getMessage());              return null; // TODO error          }      } -    private List<String> getECApplicationRole() {    	 +    private List<String> getECApplicationRole(PersonalAttribute personalAttribute) {      	List<String> storkRoles = null;      	if (authData.getAuthenticationRoles() != null  @@ -137,29 +175,32 @@ public class MOAAttributeProvider {      			String storkRole = mapper.map(el);      			if (MiscUtil.isNotEmpty(storkRole))      				storkRoles.add(storkRole); -    			      		}    		      	}    	      	return storkRoles;      } -    private String getFormatedDateOfBirth() { +    private String getFormatedDateOfBirth(PersonalAttribute personalAttribute) {  		if (authData.getDateOfBirth() != null) {  			DateFormat fmt = new SimpleDateFormat("yyyyMMdd");      		return  fmt.format(authData.getDateOfBirth());  		}     		else     			return null; -    	      } -    private void populateAttributeWithMethod(Method method, Object object, PersonalAttributeList attributeList, String storkAttribute, Boolean isRequired) { +    private void populateAttributeWithMethod(Method method, Object object, PersonalAttributeList attributeList, String storkAttribute, PersonalAttribute requestedAttribute) {          try { -            Object attributeValue = method.invoke(object, new Class[]{});        // (Object[]) -             +            Object attributeValue; +            if (storkAttributeSimpleMapping.containsValue(method.getName())) { +                attributeValue = method.invoke(object, new Class[]{}); +            }  else { +                attributeValue = method.invoke(object, requestedAttribute); +            } +              PersonalAttribute newAttribute = new PersonalAttribute();              newAttribute.setName(storkAttribute); -            newAttribute.setIsRequired(isRequired); +            newAttribute.setIsRequired(requestedAttribute.isRequired());              if (attributeValue != null) {              	newAttribute.setStatus(AttributeStatusType.AVAILABLE.value()); @@ -192,10 +233,13 @@ public class MOAAttributeProvider {          } catch (InvocationTargetException e) {              Logger.error("Invocation target exception while getting attribute: " + storkAttribute); -            e.printStackTrace(); +            Logger.debug(e);          } catch (IllegalAccessException e) {              Logger.error("Illegal access exception while getting attribute: " + storkAttribute); -            e.printStackTrace(); +            Logger.debug(e); +        } catch (NullPointerException e) { +            Logger.error("Could not find method: " + storkAttribute); +            Logger.debug(e);          }      } | 
