1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package edu.internet2.middleware.shibboleth.common.config.security.saml;
18
19 import javax.xml.namespace.QName;
20
21 import org.opensaml.common.binding.security.IssueInstantRule;
22 import org.opensaml.xml.util.XMLHelper;
23 import org.springframework.beans.factory.support.BeanDefinitionBuilder;
24 import org.springframework.beans.factory.xml.AbstractSingleBeanDefinitionParser;
25 import org.w3c.dom.Element;
26
27 import edu.internet2.middleware.shibboleth.common.config.SpringConfigurationUtils;
28
29
30
31
32 public class IssueInstantRuleBeanDefinitionParser extends AbstractSingleBeanDefinitionParser {
33
34
35 public static final QName SCHEMA_TYPE = new QName(SAMLSecurityNamespaceHandler.NAMESPACE, "IssueInstant");
36
37
38 protected Class getBeanClass(Element element) {
39 return IssueInstantRule.class;
40 }
41
42
43 protected boolean shouldGenerateId() {
44 return true;
45 }
46
47
48 protected void doParse(Element element, BeanDefinitionBuilder builder) {
49 long skew = 300;
50 if (element.hasAttributeNS(null, "clockSkew")) {
51 skew = SpringConfigurationUtils.parseDurationToMillis("'clockSkew' on security rule of type "
52 + XMLHelper.getXSIType(element), element.getAttributeNS(null, "clockSkew"), 1000) / 1000;
53 }
54 builder.addConstructorArgValue(skew);
55
56 long expirationThreshold = 60;
57 if (element.hasAttributeNS(null, "expirationThreshold")) {
58 expirationThreshold = SpringConfigurationUtils.parseDurationToMillis(
59 "'expirationThreshold' on security rule of type " + XMLHelper.getXSIType(element), element
60 .getAttributeNS(null, "expirationThreshold"), 1000) / 1000;
61 }
62 builder.addConstructorArgValue(expirationThreshold);
63
64 if (element.hasAttributeNS(null, "required")) {
65 builder.addPropertyValue("requiredRule", XMLHelper.getAttributeValueAsBoolean(element.getAttributeNodeNS(
66 null, "required")));
67 } else {
68 builder.addPropertyValue("requiredRule", true);
69 }
70 }
71 }