View Javadoc
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.core.api.criteria;
17  
18  import org.kuali.rice.core.api.CoreConstants;
19  import org.w3c.dom.Element;
20  
21  import javax.xml.bind.annotation.XmlAccessType;
22  import javax.xml.bind.annotation.XmlAccessorType;
23  import javax.xml.bind.annotation.XmlAnyElement;
24  import javax.xml.bind.annotation.XmlAttribute;
25  import javax.xml.bind.annotation.XmlElement;
26  import javax.xml.bind.annotation.XmlElements;
27  import javax.xml.bind.annotation.XmlRootElement;
28  import javax.xml.bind.annotation.XmlType;
29  import java.util.Collection;
30  
31  /**
32   * An immutable predicate which represents an "equal" statement which is
33   * evaluated the {@link CriteriaValue} of this predicate.
34   *
35   * @see PredicateFactory for a convenient way to construct this class.
36   * 
37   * @author Kuali Rice Team (rice.collab@kuali.org)
38   * 
39   */
40  @XmlRootElement(name = EqualPredicate.Constants.ROOT_ELEMENT_NAME)
41  @XmlAccessorType(XmlAccessType.NONE)
42  @XmlType(name = EqualPredicate.Constants.TYPE_NAME, propOrder = {
43      CriteriaSupportUtils.PropertyConstants.VALUE,
44      CoreConstants.CommonElements.FUTURE_ELEMENTS
45  })
46  public final class EqualPredicate extends AbstractPredicate implements SingleValuedPredicate {
47  	
48  	private static final long serialVersionUID = 7159459561133496549L;
49  	
50  	@XmlAttribute(name = CriteriaSupportUtils.PropertyConstants.PROPERTY_PATH)
51  	private final String propertyPath;
52  
53      @XmlElements(value = {
54              @XmlElement(name = CriteriaStringValue.Constants.ROOT_ELEMENT_NAME, type = CriteriaStringValue.class, required = true),
55              @XmlElement(name = CriteriaPropertyPathValue.Constants.ROOT_ELEMENT_NAME, type = CriteriaPropertyPathValue.class, required = true),
56      		@XmlElement(name = CriteriaDateTimeValue.Constants.ROOT_ELEMENT_NAME, type = CriteriaDateTimeValue.class, required = true),
57      		@XmlElement(name = CriteriaDecimalValue.Constants.ROOT_ELEMENT_NAME, type = CriteriaDecimalValue.class, required = true),
58              @XmlElement(name = CriteriaKualiDecimalValue.Constants.ROOT_ELEMENT_NAME, type = CriteriaKualiDecimalValue.class, required = true),
59              @XmlElement(name = CriteriaKualiPercentValue.Constants.ROOT_ELEMENT_NAME, type = CriteriaKualiPercentValue.class, required = true),
60              @XmlElement(name = CriteriaKualiIntegerValue.Constants.ROOT_ELEMENT_NAME, type = CriteriaKualiIntegerValue.class, required = true),
61      		@XmlElement(name = CriteriaIntegerValue.Constants.ROOT_ELEMENT_NAME, type = CriteriaIntegerValue.class, required = true),
62              @XmlElement(name = CriteriaBooleanValue.Constants.ROOT_ELEMENT_NAME, type = CriteriaBooleanValue.class, required = true)
63      })
64  	private final CriteriaValue<?> value;
65  
66      @SuppressWarnings("unused")
67      @XmlAnyElement
68      private final Collection<Element> _futureElements = null;
69  	
70      /**
71       * Should only be invoked by JAXB.
72       */
73      @SuppressWarnings("unused")
74      private EqualPredicate() {
75          this.propertyPath = null;
76          this.value = null;
77      }
78      
79      /**
80  	 * Constructs an EqualPredicate for the given path and value.  EqualPredicate supports the following {@link CriteriaValue}:
81  	 * 
82  	 * <ul>
83  	 *   <li>{@link CriteriaStringValue}</li>
84  	 *   <li>{@link CriteriaDateTimeValue}</li>
85  	 *   <li>{@link CriteriaDecimalValue}</li>
86  	 *   <li>{@link CriteriaIntegerValue}</li>
87       *   <li>{@link CriteriaKualiDecimalValue}</li>
88       *   <li>{@link CriteriaKualiPercentValue}</li>
89  	 * </ul>
90  	 * 
91  	 * @param propertyPath the property path for the predicate, must not be null or blank
92  	 * @param value the value to evaluation the path against, must not be null.
93  	 * 
94  	 * @throws IllegalArgumentException if the propertyPath is null or blank
95  	 * @throws IllegalArgumentException if the value is null
96  	 * @throws IllegalArgumentException if this predicate does not support the given type of {@link CriteriaValue}
97  	 */
98      EqualPredicate(String propertyPath, CriteriaValue<?> value) {
99      	CriteriaSupportUtils.validateValuedConstruction(getClass(), propertyPath, value);
100 		this.propertyPath = propertyPath;
101 		this.value = value;
102     }
103         
104     @Override
105     public String getPropertyPath() {
106     	return propertyPath;
107     }
108     
109 	@Override
110 	public CriteriaValue<?> getValue() {
111 		return value;
112 	}
113     
114 	/**
115      * Defines some internal constants used on this class.
116      */
117     static class Constants {
118         final static String ROOT_ELEMENT_NAME = "equal";
119         final static String TYPE_NAME = "EqualType";
120     }
121 
122     @Override
123     public String toString() {
124         return CriteriaSupportUtils.toString(this);
125     }
126 }