1 /** 2 * Copyright 2005-2016 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.service; 17 18 import org.kuali.rice.krad.bo.BusinessObject; 19 import org.kuali.rice.krad.bo.PersistableBusinessObject; 20 21 import java.util.Collection; 22 import java.util.List; 23 import java.util.Map; 24 25 /** 26 * Defines methods that a BusinessObjectService must provide 27 * 28 * @author Kuali Rice Team (rice.collab@kuali.org) 29 */ 30 public interface BusinessObjectService { 31 32 /** 33 * Saves the passed in object via the persistence layer. 34 * 35 * This will throw an IllegalArgumentException (runtime exception) if the object passed in is not a descendent of 36 * BusinessObject. 37 * 38 * @param bo A BusinessObject instance or descendent that you wish to be stored. 39 */ 40 public <T extends PersistableBusinessObject> T save(T bo); 41 42 /** 43 * Saves the businessObjects on the list via the persistence layer. 44 * 45 * This will throw an IllegalArgumentException (runtime exception) if any of the objects passed in is not a descendent of 46 * BusinessObject. 47 * 48 * @param businessObjects A List<PersistableBusinessObject> of objects to persist. 49 */ 50 public List<? extends PersistableBusinessObject> save(List<? extends PersistableBusinessObject> businessObjects); 51 52 /** 53 * Links up any contained objects, and then Saves the passed in object via the persistence layer. 54 * 55 * This will throw an IllegalArgumentException (runtime exception) if the object passed in is not a descendent of 56 * BusinessObject. 57 * 58 * @param bo A BusinessObject instance or descendent that you wish to be stored. 59 */ 60 public PersistableBusinessObject linkAndSave(PersistableBusinessObject bo); 61 62 /** 63 * Links up any contained objects, and Saves the businessObjects on the list via the persistence layer. 64 * 65 * This will throw an IllegalArgumentException (runtime exception) if any of the objects passed in is not a descendent of 66 * BusinessObject. 67 * 68 * @param businessObjects A List<BusinessObject> of objects to persist. 69 * 70 */ 71 public List<? extends PersistableBusinessObject> linkAndSave(List<? extends PersistableBusinessObject> businessObjects); 72 73 /** 74 * Retrieves an object instance identified by its primary key. For composite keys, use {@link #findByPrimaryKey(Class, Map)} 75 * 76 * @param clazz 77 * @param primaryKey 78 * @return 79 */ 80 public <T extends BusinessObject> T findBySinglePrimaryKey(Class<T> clazz, Object primaryKey); 81 82 /** 83 * Retrieves an object instance identified by its primary keys and values. This can be done by constructing a map where the key 84 * to the map entry is the primary key attribute and the value of the entry being the primary key value. For composite keys, 85 * pass in each primaryKey attribute and its value as a map entry. 86 * 87 * @param clazz 88 * @param primaryKeys 89 * @return 90 */ 91 public <T extends BusinessObject> T findByPrimaryKey(Class<T> clazz, Map<String, ?> primaryKeys); 92 93 /** 94 * Retrieves an object instance identified by the class of the given object and the object's primary key values. 95 * 96 * @param object 97 * @return 98 */ 99 public PersistableBusinessObject retrieve(PersistableBusinessObject object); 100 101 /** 102 * Retrieves a collection of business objects populated with data, such that each record in the database populates a new object 103 * instance. This will only retrieve business objects by class type. 104 * 105 * @param clazz 106 * @return 107 */ 108 public <T extends BusinessObject> Collection<T> findAll(Class<T> clazz); 109 110 /** 111 * Retrieves a collection of business objects populated with data, such that each record in the database populates a new object 112 * instance. This will only retrieve business objects by class type. 113 * 114 * @param clazz 115 * @return 116 */ 117 public <T extends BusinessObject> Collection<T> findAllOrderBy( Class<T> clazz, String sortField, boolean sortAscending ); 118 119 /** 120 * This method retrieves a collection of business objects populated with data, such that each record in the database populates a 121 * new object instance. This will retrieve business objects by class type and also by criteria passed in as key-value pairs, 122 * specifically attribute name and its expected value. 123 * 124 * @param clazz 125 * @param fieldValues 126 * @return 127 */ 128 public <T extends BusinessObject> Collection<T> findMatching(Class<T> clazz, Map<String, ?> fieldValues); 129 130 /** 131 * Finds all entities matching the passed in Rice JPA criteria 132 * 133 * @param <T> the type of the entity that will be returned 134 * @param criteria the criteria to form the query with 135 * @return a Collection (most likely a List) of all matching entities 136 */ 137 //public abstract <T extends BusinessObject> Collection<T> findMatching(Criteria criteria); 138 139 /** 140 * This method retrieves a count of the business objects populated with data which match the criteria in the given Map. 141 * 142 * @param clazz 143 * @param fieldValues 144 * @return number of businessObjects of the given class whose fields match the values in the given expected-value Map 145 */ 146 public int countMatching(Class clazz, Map<String, ?> fieldValues); 147 148 /** 149 * This method retrieves a count of the business objects populated with data which match both the positive criteria 150 * and the negative criteria in the given Map. 151 * 152 * @param clazz 153 * @param positiveFieldValues 154 * @param negativeFieldValues 155 * @return number of businessObjects of the given class whose fields match the values in the given expected-value Maps 156 */ 157 public int countMatching(Class clazz, Map<String, ?> positiveFieldValues, Map<String, ?> negativeFieldValues); 158 159 /** 160 * This method retrieves a collection of business objects populated with data, such that each record in the database populates a 161 * new object instance. This will retrieve business objects by class type and also by criteria passed in as key-value pairs, 162 * specifically attribute name and its expected value. Performs an order by on sort field. 163 * 164 * @param clazz 165 * @param fieldValues 166 * @return 167 */ 168 public <T extends BusinessObject> Collection<T> findMatchingOrderBy(Class<T> clazz, Map<String, ?> fieldValues, String sortField, boolean sortAscending); 169 170 /** 171 * Deletes a business object from the database. 172 * 173 * @param bo 174 */ 175 public void delete(PersistableBusinessObject bo); 176 177 /** 178 * Deletes each business object in the given List. 179 * 180 * @param boList 181 */ 182 public void delete(List<? extends PersistableBusinessObject> boList); 183 184 /** 185 * Deletes the object(s) matching the given field values 186 * 187 * @param clazz 188 * @param fieldValues 189 */ 190 public void deleteMatching(Class clazz, Map<String, ?> fieldValues); 191 192 /** 193 * 194 * This method attempts to retrieve the reference from a BO if it exists. 195 * 196 * @param bo - populated BusinessObject instance that includes the referenceName property 197 * @param referenceName - name of the member/property to load 198 * @return A populated object from the DB, if it exists 199 * 200 */ 201 public BusinessObject getReferenceIfExists(BusinessObject bo, String referenceName); 202 203 /** 204 * 205 * Updates all KualiUser or Person objects contained within this BO, based on the UserID as the authoritative key. The 206 * appropriate foreign-key field in the BO itself is also updated. 207 * 208 * This allows UserIDs to be entered on forms, and the back-end will link up correctly based on this non-key field. 209 * 210 * @param bo The populated BO (or descendent) instance to be linked & updated 211 * 212 */ 213 public void linkUserFields(PersistableBusinessObject bo); 214 215 /** 216 * 217 * Updates all KualiUser or Person objects contained within this BO, based on the UserID as the authoritative key. The 218 * appropriate foreign-key field in the BO itself is also updated. 219 * 220 * This allows UserIDs to be entered on forms, and the back-end will link up correctly based on this non-key field. 221 * 222 * @param bos A List of populated BusinessObject (or descendent) instances to be linked & updated. 223 */ 224 public void linkUserFields(List<PersistableBusinessObject> bos); 225 226 /** 227 * Merges the given business object, but tells the ORM that the object is to be treated as Read Only, 228 * and even if it has changes, it will not be persisted to the database 229 * 230 * @param bo the business object to managed 231 * @return the managed copied of the business object 232 */ 233 public PersistableBusinessObject manageReadOnly(PersistableBusinessObject bo); 234 235 } 236