1 /**
2 * Copyright 2005-2015 The Kuali Foundation
3 *
4 * Licensed under the Educational Community 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.opensource.org/licenses/ecl2.php
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 package org.kuali.rice.krad.datadictionary.validation.constraint.resolver;
17
18 import org.kuali.rice.krad.datadictionary.validation.capability.ValidCharactersConstrainable;
19 import org.kuali.rice.krad.datadictionary.validation.constraint.Constraint;
20
21 import java.util.Collections;
22 import java.util.List;
23
24 /**
25 * An object that returns the valid characters constraint as a list for a definition implementing the capability {@link
26 * ValidCharactersConstrainable}.
27 *
28 * @param <T> constrainable type
29 * @author Kuali Rice Team (rice.collab@kuali.org)
30 */
31 public class ValidCharactersConstraintResolver<T extends ValidCharactersConstrainable> implements ConstraintResolver<T> {
32
33 @Override
34 public <C extends Constraint> List<C> resolve(T definition) {
35 @SuppressWarnings("unchecked") C caseConstraint = (C) definition.getValidCharactersConstraint();
36 return Collections.singletonList(caseConstraint);
37 }
38
39 }