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