View Javadoc

1   /*
2    * Copyright [2007] [University Corporation for Advanced Internet Development, Inc.]
3    *
4    * Licensed under the Apache License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    *
8    * http://www.apache.org/licenses/LICENSE-2.0
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS,
12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   * See the License for the specific language governing permissions and
14   * limitations under the License.
15   */
16  
17  package edu.internet2.middleware.shibboleth.common.config.security;
18  
19  import org.springframework.beans.factory.xml.BeanDefinitionParser;
20  
21  import edu.internet2.middleware.shibboleth.common.config.BaseSpringNamespaceHandler;
22  
23  /**
24   * Spring namespace handler for Shibboleth security objects.
25   */
26  public class SecurityNamespaceHandler extends BaseSpringNamespaceHandler {
27  
28      /** Security configuration namespace. */
29      public static final String NAMESPACE = "urn:mace:shibboleth:2.0:security";
30  
31      /** {@inheritDoc} */
32      public void init() {
33          registerBeanDefinitionParser(FilesystemX509CredentialBeanDefinitionParser.SCHEMA_TYPE,
34                  new FilesystemX509CredentialBeanDefinitionParser());
35  
36          registerBeanDefinitionParser(InlineX509CredentialBeanDefinitionParser.SCHEMA_TYPE,
37                  new InlineX509CredentialBeanDefinitionParser());
38  
39          registerBeanDefinitionParser(FilesystemBasicCredentialBeanDefinitionParser.SCHEMA_TYPE,
40                  new FilesystemBasicCredentialBeanDefinitionParser());
41  
42          registerBeanDefinitionParser(InlineBasicCredentialBeanDefinitionParser.SCHEMA_TYPE,
43                  new InlineBasicCredentialBeanDefinitionParser());
44  
45          registerBeanDefinitionParser(FilesystemPKIXValidationInformationBeanDefinitionParser.SCHEMA_TYPE,
46                  new FilesystemPKIXValidationInformationBeanDefinitionParser());
47  
48          registerBeanDefinitionParser(InlinePKIXValidationInformationBeanDefinitionParser.SCHEMA_TYPE,
49                  new InlinePKIXValidationInformationBeanDefinitionParser());
50          
51          BeanDefinitionParser pkixOptionsParser = new PKIXValidationOptionsBeanDefinitionParser();
52          registerBeanDefinitionParser(PKIXValidationOptionsBeanDefinitionParser.ELEMENT_NAME, pkixOptionsParser);
53          registerBeanDefinitionParser(PKIXValidationOptionsBeanDefinitionParser.SCHEMA_TYPE, pkixOptionsParser);
54          
55          registerBeanDefinitionParser(CertPathPKIXValidationOptionsBeanDefinitionParser.SCHEMA_TYPE,
56                  new CertPathPKIXValidationOptionsBeanDefinitionParser());
57  
58          BeanDefinitionParser parser = new ShibbolethSecurityPolicyBeanDefinitionParser();
59          registerBeanDefinitionParser(ShibbolethSecurityPolicyBeanDefinitionParser.ELEMENT_NAME, parser);
60          registerBeanDefinitionParser(ShibbolethSecurityPolicyBeanDefinitionParser.SCHEMA_TYPE, parser);
61  
62          registerBeanDefinitionParser(ChainingTrustEngineBeanDefinitionParser.SCHEMA_TYPE,
63                  new ChainingTrustEngineBeanDefinitionParser());
64  
65          registerBeanDefinitionParser(ChainingSignatureTrustEngineBeanDefinitionParser.SCHEMA_TYPE,
66                  new ChainingSignatureTrustEngineBeanDefinitionParser());
67  
68          registerBeanDefinitionParser(MetadataExplicitKeyTrustEngineBeanDefinitionParser.SCHEMA_TYPE,
69                  new MetadataExplicitKeyTrustEngineBeanDefinitionParser());
70  
71          registerBeanDefinitionParser(MetadataPKIXX509CredentialTrustEngineBeanDefinitionParser.SCHEMA_TYPE,
72                  new MetadataPKIXX509CredentialTrustEngineBeanDefinitionParser());
73  
74          registerBeanDefinitionParser(MetadataExplicitKeySignatureTrustEngineBeanDefinitionParser.SCHEMA_TYPE,
75                  new MetadataExplicitKeySignatureTrustEngineBeanDefinitionParser());
76  
77          registerBeanDefinitionParser(MetadataPKIXSignatureTrustEngineBeanDefinitionParser.SCHEMA_TYPE,
78                  new MetadataPKIXSignatureTrustEngineBeanDefinitionParser());
79  
80          registerBeanDefinitionParser(StaticExplicitKeyTrustEngineBeanDefinitionParser.SCHEMA_TYPE,
81                  new StaticExplicitKeyTrustEngineBeanDefinitionParser());
82  
83          registerBeanDefinitionParser(StaticExplicitKeySignatureTrustEngineBeanDefinitionParser.SCHEMA_TYPE,
84                  new StaticExplicitKeySignatureTrustEngineBeanDefinitionParser());
85  
86          registerBeanDefinitionParser(StaticPKIXX509CredentialTrustEngineBeanDefinitionParser.SCHEMA_TYPE,
87                  new StaticPKIXX509CredentialTrustEngineBeanDefinitionParser());
88  
89          registerBeanDefinitionParser(StaticPKIXSignatureTrustEngineBeanDefinitionParser.SCHEMA_TYPE,
90                  new StaticPKIXSignatureTrustEngineBeanDefinitionParser());
91  
92          registerBeanDefinitionParser(ClientCertAuthRuleBeanDefinitionParser.SCHEMA_TYPE,
93                  new ClientCertAuthRuleBeanDefinitionParser());
94  
95          registerBeanDefinitionParser(MandatoryMessageAuthenticationRuleBeanDefinitionParser.SCHEMA_TYPE,
96                  new MandatoryMessageAuthenticationRuleBeanDefinitionParser());
97      }
98  
99  }