1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package edu.internet2.middleware.shibboleth.idp.config.profile.saml2;
18
19 import javax.xml.namespace.QName;
20
21 import org.opensaml.saml2.core.AuthnContext;
22 import org.opensaml.xml.util.DatatypeHelper;
23 import org.springframework.beans.factory.support.BeanDefinitionBuilder;
24 import org.w3c.dom.Element;
25
26 import edu.internet2.middleware.shibboleth.idp.config.profile.ProfileHandlerNamespaceHandler;
27 import edu.internet2.middleware.shibboleth.idp.config.profile.saml2.AbstractSAML2ProfileHandlerBeanDefinitionParser;
28 import edu.internet2.middleware.shibboleth.idp.profile.saml2.SAML2ECPProfileHandler;
29
30
31
32
33 public class SAML2ECPProfileHandlerBeanDefinitionParser
34 extends AbstractSAML2ProfileHandlerBeanDefinitionParser {
35
36
37 public static final QName SCHEMA_TYPE = new QName(ProfileHandlerNamespaceHandler.NAMESPACE, "SAML2ECP");
38
39
40 protected Class getBeanClass(Element arg0) {
41 return SAML2ECPProfileHandler.class;
42 }
43
44
45 protected void doParse(Element config, BeanDefinitionBuilder builder) {
46 super.doParse(config, builder);
47
48 builder.setInitMethodName("initialize");
49
50 if (config.hasAttributeNS(null, "authnContextClassRef")) {
51 builder.addPropertyValue("authnContextClassRef", DatatypeHelper.safeTrimOrNullString(config.getAttributeNS(null,
52 "authnContextClassRef")));
53 } else {
54 builder.addPropertyValue("authnContextClassRef", AuthnContext.PPT_AUTHN_CTX);
55 }
56 }
57 }