1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package edu.internet2.middleware.shibboleth.common.config.relyingparty.saml;
18
19 import java.util.List;
20
21 import org.opensaml.xml.util.DatatypeHelper;
22 import org.opensaml.xml.util.LazyList;
23 import org.opensaml.xml.util.XMLHelper;
24 import org.springframework.beans.factory.support.BeanDefinitionBuilder;
25 import org.springframework.beans.factory.xml.ParserContext;
26 import org.w3c.dom.Element;
27
28 import edu.internet2.middleware.shibboleth.common.relyingparty.provider.CryptoOperationRequirementLevel;
29
30
31
32
33 public abstract class AbstractSAML2ProfileConfigurationBeanDefinitionParser extends
34 AbstractSAMLProfileConfigurationBeanDefinitionParser {
35
36
37 protected void doParse(Element element, ParserContext parserContext, BeanDefinitionBuilder builder) {
38 super.doParse(element, parserContext, builder);
39
40 List<Element> proxyAudiences = XMLHelper.getChildElementsByTagNameNS(element,
41 SAMLRelyingPartyNamespaceHandler.NAMESPACE, "ProxyAudience");
42 if (proxyAudiences != null && proxyAudiences.size() > 0) {
43 LazyList<String> audiences = new LazyList<String>();
44 for (Element proxyAudience : proxyAudiences) {
45 audiences.add(DatatypeHelper.safeTrimOrNullString(proxyAudience.getTextContent()));
46 }
47
48 builder.addPropertyValue("proxyAudiences", audiences);
49 }
50
51 builder.addPropertyReference("attributeAuthority", DatatypeHelper.safeTrimOrNullString(element.getAttributeNS(
52 null, "attributeAuthority")));
53
54 if (element.hasAttributeNS(null, "encryptNameIds")) {
55 builder.addPropertyValue("encryptNameIds", CryptoOperationRequirementLevel.valueOf(element.getAttributeNS(
56 null, "encryptNameIds")));
57 } else {
58 builder.addPropertyValue("encryptNameIds", CryptoOperationRequirementLevel.never);
59 }
60
61 if (element.hasAttributeNS(null, "encryptAssertions")) {
62 builder.addPropertyValue("encryptAssertions", CryptoOperationRequirementLevel.valueOf(element
63 .getAttributeNS(null, "encryptAssertions")));
64 } else {
65 builder.addPropertyValue("encryptAssertions", CryptoOperationRequirementLevel.conditional);
66 }
67
68 if (element.hasAttributeNS(null, "assertionProxyCount")) {
69 builder.addPropertyValue("assertionProxyCount", Integer.parseInt(DatatypeHelper
70 .safeTrimOrNullString(element.getAttributeNS(null, "assertionProxyCount"))));
71 } else {
72 builder.addPropertyValue("assertionProxyCount", 0);
73 }
74 }
75 }