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