View Javadoc

1   /*
2    * Licensed to the University Corporation for Advanced Internet Development, 
3    * Inc. (UCAID) under one or more contributor license agreements.  See the 
4    * NOTICE file distributed with this work for additional information regarding
5    * copyright ownership. The UCAID licenses this file to You under the Apache 
6    * License, Version 2.0 (the "License"); you may not use this file except in 
7    * compliance with the License.  You may obtain a copy of the License at
8    *
9    *    http://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the License for the specific language governing permissions and
15   * limitations under the License.
16   */
17  
18  package edu.internet2.middleware.shibboleth.common.config.relyingparty.saml;
19  
20  import javax.xml.namespace.QName;
21  
22  import org.opensaml.xml.util.XMLHelper;
23  import org.springframework.beans.factory.support.BeanDefinitionBuilder;
24  import org.springframework.beans.factory.xml.ParserContext;
25  import org.w3c.dom.Element;
26  
27  import edu.internet2.middleware.shibboleth.common.config.SpringConfigurationUtils;
28  import edu.internet2.middleware.shibboleth.common.relyingparty.provider.CryptoOperationRequirementLevel;
29  
30  /** Spring configuration parser for SAML 2 SSO profile configurations. */
31  public class SAML2SSOProfileConfigurationBeanDefinitionParser extends
32          AbstractSAML2ProfileConfigurationBeanDefinitionParser {
33  
34      /** Schema type name. */
35      public static final QName TYPE_NAME = new QName(SAMLRelyingPartyNamespaceHandler.NAMESPACE, "SAML2SSOProfile");
36  
37      /** {@inheritDoc} */
38      protected Class getBeanClass(Element element) {
39          return SAML2SSOProfileConfigurationFactoryBean.class;
40      }
41  
42      /** {@inheritDoc} */
43      protected void doParse(Element element, ParserContext parserContext, BeanDefinitionBuilder builder) {
44          super.doParse(element, parserContext, builder);
45  
46          if (element.hasAttributeNS(null, "includeAttributeStatement")) {
47              builder.addPropertyValue("includeAttributeStatement",
48                      XMLHelper.getAttributeValueAsBoolean(element.getAttributeNodeNS(null, "includeAttributeStatement")));
49          } else {
50              builder.addPropertyValue("includeAttributeStatement", true);
51          }
52  
53          if (element.hasAttributeNS(null, "maximumSPSessionLifetime")) {
54              long lifetime = SpringConfigurationUtils.parseDurationToMillis(
55                      "'maximumSPSessionLifetime' on profile configuration of type " + XMLHelper.getXSIType(element),
56                      element.getAttributeNS(null, "maximumSPSessionLifetime"), 0);
57              builder.addPropertyValue("maximumSPSessionLifetime", lifetime);
58          }
59      }
60  
61      /** {@inheritDoc} */
62      protected CryptoOperationRequirementLevel getSignAssertionsDefault() {
63          return CryptoOperationRequirementLevel.always;
64      }
65  
66      /** {@inheritDoc} */
67      protected CryptoOperationRequirementLevel getSignResponsesDefault() {
68          return CryptoOperationRequirementLevel.never;
69      }
70  }