-
Notifications
You must be signed in to change notification settings - Fork 7
oidcext:OIDCString
Default functionality of OIDCString encoder is to encode an IdPAttribute with simple string values as a JSON object with string value. If IdPAttribute has multiple string values they are catenated to a single string value with space as delimeter. There are several options to alter the behaviour.
Multiple values may be encoded also as JSON array instead of catenating all to single string. Options allow also presenting values as JSON integer or as JSON boolean. When presenting values as integer, nonparsable values are discarded. If output is set to be presented as JSON array all parsable values are placed to array, otherwise the first parsable value is treated as the result. When presenting values as boolean all strings matching 'true' (ignoring the case) are considered to be true, others false. If output is set to be presented as JSON array all boolean values are placed to array, otherwise the first value is treated as the result.
Options allow also wrapping the result to JSON Object (for instance to form address claim).
This xsi:type is defined by the org.geant.idpextension.oidc.attribute.encoder schema, which is located at https://github.com/CSCfi/shibboleth-idp-oidc-extension/blob/master/idp-oidc-extension-impl/src/main/resources/schema/idp-oidc-extension-attribute-encoder.xsd and used by the reference installation from classpath:/schema/idp-oidc-extension-attribute-encoder.xsd
- asBoolean, present value(s) as a JSON boolean. Default value is false.
- asInt, present value(s) as a JSON integer. Default value is false.
- asArray, set value(s) to JSON Array. Default value is false.
- asObject, wrap result to JSON object. Default value is false.
- fieldName, if result is wrapped to JSON object the field name for the value. Setting this attribute in such case is mandatory.
- stringDelimiter, delimiter used when catenating multiple values to single string. Default is " ".
Set affiliation value(s) to array instead of single string:
<AttributeEncoder xsi:type="oidcext:OIDCString" name="affiliation" asArray="true"/>
Convert the string value to integer:
<AttributeEncoder xsi:type="oidcext:OIDCString" name="age" asInt="true"/>
Wrap the result to JSON object:
<AttributeEncoder xsi:type="oidcext:OIDCString" asObject="true" fieldName="formatted" name="address"/>`
Resulting address claim might look like:
"address":{
"formatted":"Street Address P.O. Box 555 Finland"
}