1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18 package edu.internet2.middleware.shibboleth.common.config.relyingparty.saml;
19
20 import javax.xml.namespace.QName;
21
22 import org.opensaml.xml.util.XMLHelper;
23 import org.springframework.beans.factory.support.BeanDefinitionBuilder;
24 import org.springframework.beans.factory.xml.ParserContext;
25 import org.w3c.dom.Element;
26
27 import edu.internet2.middleware.shibboleth.common.relyingparty.provider.CryptoOperationRequirementLevel;
28
29
30
31
32 public class ShibbolethSSOProfileConfigurationBeanDefinitionParser extends
33 AbstractSAML1ProfileConfigurationBeanDefinitionParser {
34
35
36 public static final QName TYPE_NAME = new QName(SAMLRelyingPartyNamespaceHandler.NAMESPACE, "ShibbolethSSOProfile");
37
38
39 protected Class getBeanClass(Element element) {
40 return ShibbolethSSOProfileConfigurationFactoryBean.class;
41 }
42
43
44 protected void doParse(Element element, ParserContext parserContext, BeanDefinitionBuilder builder) {
45 super.doParse(element, parserContext, builder);
46
47 if (element.hasAttributeNS(null, "includeAttributeStatement")) {
48 builder.addPropertyValue("includeAttributeStatement",
49 XMLHelper.getAttributeValueAsBoolean(element.getAttributeNodeNS(null, "includeAttributeStatement")));
50 } else {
51 builder.addPropertyValue("includeAttributeStatement", false);
52 }
53 }
54
55
56 protected CryptoOperationRequirementLevel getSignAssertionsDefault() {
57 return CryptoOperationRequirementLevel.never;
58 }
59
60
61 protected CryptoOperationRequirementLevel getSignResponsesDefault() {
62 return CryptoOperationRequirementLevel.always;
63 }
64 }