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; 17 18 import org.kuali.rice.krad.datadictionary.exception.AttributeValidationException; 19 import org.kuali.rice.krad.datadictionary.validation.capability.Constrainable; 20 21 import java.util.List; 22 23 /** 24 * An interface to define classes that encapsulate access to both dictionary metadata and object field values, for example, by reflection 25 * and introspection, for the purpose of performing validation against constraints defined in the DictionaryValidationService implementation. 26 * 27 * Practically speaking, this interface should only need to be implemented by a small number of classes. The two major use cases are for 28 * (1) a dictionary object with members 29 * (2) a specific member of a dictionary object 30 * 31 * In the first case, implementing classes should provide access to all underlying members of the object via reflection or some other mechanism. 32 * In the second case, implementing classes only need to provide access to the value associated with that specific member, and constraints 33 * requiring access to additional members will be skipped. 34 * 35 * @author Kuali Rice Team (rice.collab@kuali.org) 36 * @since 1.1 37 */ 38 public interface AttributeValueReader { 39 40 /** 41 * This method is an accessor for the attribute name that is currently being processed by the DictionaryValidationService implementation. 42 * 43 * @return the current attribute name being processed 44 */ 45 public String getAttributeName(); 46 47 /** 48 * This method provides access to the constrainable attribute definition of a specific attribute name. If the value of the metadata 49 * associated with the object field does not implement constrainable, or if no metadata is associated with this object field, 50 * then null should be returned. 51 * 52 * @param attributeName - the name of the attribute/field whose metadata is being requested 53 * @return dictionary metadata object implementing some constrainable capability 54 */ 55 public Constrainable getDefinition(String attributeName); 56 57 /** 58 * This method returns a list of all constrainable dictionary metadata definitions for attributes or fields encapsulated by this object. 59 * 60 * @return a list of constrainable definitions 61 */ 62 public List<Constrainable> getDefinitions(); 63 64 /** 65 * The dictionary metadata associated with an object (its "entry" in the dictionary) can also be constrainable, in which case the object 66 * value itself can be validated against one or more constraints. If the specific entry for the dictionary object encapsulated by this 67 * reader is not constrainable, or if no entry exists for this dictionary object, or no dictionary object is being encapsulted, then 68 * null should be returned. 69 * 70 * @return the constrainable dictionary entry metadata for this object, or null 71 */ 72 public Constrainable getEntry(); 73 74 /** 75 * An entry name should be returned for the purposes of correcting looking up errors, which are generally found by entry name + 76 * attribute name + error key. 77 * 78 * @return the name that the data dictionary uses to store metadata about this object (not its attributes) 79 */ 80 public String getEntryName(); 81 82 /** 83 * This method looks up a label for a specific attribute name. 84 * 85 * @param attributeName 86 * @return some descriptive label that can be exposed to the end user for error messages 87 */ 88 public String getLabel(String attributeName); 89 90 /** 91 * The underlying object itself (not the field/attribute value, but the object). 92 * 93 * @return the object that is being encapsulated by this reader, or null if no object is being encapsulated. 94 */ 95 public Object getObject(); 96 97 /** 98 * The path is a string representation of specifically which attribute (at some depth) is being accessed, for example, on a 99 * person object there might be the following field path: 100 * 101 * joe.home.mailingAddress.state 102 * 103 * @return the string representation of the attribute identifier currently being processed 104 */ 105 public String getPath(); 106 107 /** 108 * The type of the attribute specified. A Java class. 109 * 110 * @param attributeName 111 * @return the type of the attribute referenced by the passed name, or null if no attribute exists of that name 112 */ 113 public Class<?> getType(String attributeName); 114 115 /** 116 * Indicates whether the configured attribute name is readable for the object 117 * 118 * @return boolean if attribute is readable, false if not 119 */ 120 public boolean isReadable(); 121 122 /** 123 * A convenience method for looking up the attribute value that is currently being processed. 124 * 125 * @param <X> 126 * @return 127 * @throws AttributeValidationException 128 */ 129 public <X> X getValue() throws AttributeValidationException; 130 131 /** 132 * A method for looking up any attribute value by name for the object being processed. 133 * 134 * @param <X> 135 * @param attributeName 136 * @return 137 * @throws AttributeValidationException 138 */ 139 public <X> X getValue(String attributeName) throws AttributeValidationException; 140 141 /** 142 * A method to enable legacy processing of string representations of attribute values like a date range in the format 143 * 12/03/2001..1/29/2009 144 * 145 * @param attributeName 146 * @return the list of token strings for the attribute value of the named attribute 147 * @throws AttributeValidationException 148 */ 149 public List<String> getCleanSearchableValues(String attributeName) throws AttributeValidationException; 150 151 /** 152 * Setter for the current attribute that is being processed. 153 * 154 * @param attributeName 155 */ 156 public void setAttributeName(String attributeName); 157 158 public AttributeValueReader clone(); 159 160 } 161