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