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 }