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.security;
19
20 import javax.xml.namespace.QName;
21
22 import org.opensaml.xml.util.XMLHelper;
23 import org.slf4j.Logger;
24 import org.slf4j.LoggerFactory;
25 import org.springframework.beans.factory.support.AbstractBeanDefinition;
26 import org.springframework.beans.factory.support.BeanDefinitionBuilder;
27 import org.springframework.beans.factory.xml.AbstractSingleBeanDefinitionParser;
28 import org.springframework.beans.factory.xml.ParserContext;
29 import org.w3c.dom.Element;
30
31 import edu.internet2.middleware.shibboleth.common.config.SpringConfigurationUtils;
32
33
34
35
36 public class ShibbolethSecurityPolicyBeanDefinitionParser extends AbstractSingleBeanDefinitionParser {
37
38
39 public static final QName ELEMENT_NAME = new QName(SecurityNamespaceHandler.NAMESPACE, "SecurityPolicy");
40
41
42 public static final QName SCHEMA_TYPE = new QName(SecurityNamespaceHandler.NAMESPACE, "SecurityPolicyType");
43
44
45 private final Logger log = LoggerFactory.getLogger(ShibbolethSecurityPolicyBeanDefinitionParser.class);
46
47
48 protected Class getBeanClass(Element element) {
49 return ShibbolethSecurityPolicyFactoryBean.class;
50 }
51
52
53 protected String resolveId(Element element, AbstractBeanDefinition definition, ParserContext parserContext) {
54 return element.getAttributeNS(null, "id");
55 }
56
57
58 protected void doParse(Element element, ParserContext parserContext, BeanDefinitionBuilder builder) {
59 log.info("Parsing configuration for {} security policy with id: {}", XMLHelper.getXSIType(element)
60 .getLocalPart(), element.getAttributeNS(null, "id"));
61
62 String policyId = element.getAttributeNS(null, "id");
63 log.debug("Configuring security policy: {}", policyId);
64 builder.addPropertyValue("policyId", policyId);
65
66 builder.addPropertyValue("policyRules", SpringConfigurationUtils.parseInnerCustomElements(XMLHelper
67 .getChildElementsByTagNameNS(element, SecurityNamespaceHandler.NAMESPACE, "Rule"), parserContext));
68 }
69 }