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.attribute.resolver.attributeDefinition;
19  
20  import edu.internet2.middleware.shibboleth.common.attribute.resolver.provider.attributeDefinition.RegexSplitAttributeDefinition;
21  
22  /** Factory bean for creating regular expression based splitting attribute definitions. */
23  public class RegexSplitAttributeDefinitionFactoryBean extends BaseAttributeDefinitionFactoryBean {
24  
25      /** Regular expression used to split values. */
26      private String regex;
27      
28      /** Whether the regular expression is case sensitive. */
29      private boolean caseSensitive;
30  
31      /** {@inheritDoc} */
32      public Class getObjectType() {
33          return RegexSplitAttributeDefinition.class;
34      }
35  
36      /**
37       * Gets the regular expression used to split values.
38       * 
39       * @return regular expression used to split values
40       */
41      public String getRegex() {
42          return regex;
43      }
44  
45      /**
46       * Sets the regular expression used to split values.
47       * 
48       * @param regularExpression regular expression used to split values
49       */
50      public void setRegex(String regularExpression) {
51          regex = regularExpression;
52      }
53      
54      /**
55       * Gets whether the regular expression is case sensitive.
56       * 
57       * @return whether the regular expression is case sensitive
58       */
59      public boolean isCaseSensitive() {
60          return caseSensitive;
61      }
62      
63      /**
64       * Sets whether the regular expression is case sensitive.
65       * 
66       * @param isSensitive whether the regular expression is case sensitive
67       */
68      public void setCaseSensitive(boolean isSensitive) {
69          caseSensitive = isSensitive;
70      }
71  
72      /** {@inheritDoc} */
73      protected Object createInstance() throws Exception {
74          RegexSplitAttributeDefinition definition = new RegexSplitAttributeDefinition(regex, caseSensitive);
75          populateAttributeDefinition(definition);
76  
77          return definition;
78      }
79  }