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.config.SpringConfigurationUtils;
28 import edu.internet2.middleware.shibboleth.common.relyingparty.provider.CryptoOperationRequirementLevel;
29
30
31 public class SAML2SSOProfileConfigurationBeanDefinitionParser extends
32 AbstractSAML2ProfileConfigurationBeanDefinitionParser {
33
34
35 public static final QName TYPE_NAME = new QName(SAMLRelyingPartyNamespaceHandler.NAMESPACE, "SAML2SSOProfile");
36
37
38 protected Class getBeanClass(Element element) {
39 return SAML2SSOProfileConfigurationFactoryBean.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", true);
51 }
52
53 if (element.hasAttributeNS(null, "maximumSPSessionLifetime")) {
54 long lifetime = SpringConfigurationUtils.parseDurationToMillis(
55 "'maximumSPSessionLifetime' on profile configuration of type " + XMLHelper.getXSIType(element),
56 element.getAttributeNS(null, "maximumSPSessionLifetime"), 0);
57 builder.addPropertyValue("maximumSPSessionLifetime", lifetime);
58 }
59 }
60
61
62 protected CryptoOperationRequirementLevel getSignAssertionsDefault() {
63 return CryptoOperationRequirementLevel.always;
64 }
65
66
67 protected CryptoOperationRequirementLevel getSignResponsesDefault() {
68 return CryptoOperationRequirementLevel.never;
69 }
70 }