1 /** 2 * Copyright 2004-2013 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.kpme.core.department.service; 17 18 import java.util.List; 19 20 import org.joda.time.LocalDate; 21 import org.kuali.kpme.core.department.Department; 22 import org.springframework.cache.annotation.Cacheable; 23 24 public interface DepartmentService { 25 26 /** 27 * Fetch department by id 28 * @param hrDeptId 29 * @return 30 */ 31 @Cacheable(value=Department.CACHE_NAME, key="'hrDeptId=' + #p0") 32 Department getDepartment(String hrDeptId); 33 34 List<Department> getDepartments(String userPrincipalId, String department, String location, String descr, String active, String showHistory); 35 36 /** 37 * get count of department with given department 38 * @param department 39 * @return int 40 */ 41 int getDepartmentCount(String department); 42 43 /** 44 * Get Department as of a particular date passed in 45 * @param department 46 * @param asOfDate 47 * @return 48 */ 49 @Cacheable(value=Department.CACHE_NAME, key="'department=' + #p0 + '|' + 'asOfDate=' + #p1") 50 Department getDepartment(String department, LocalDate asOfDate); 51 52 /** 53 * Fetches a list of Department objects as of the specified date all of which 54 * belong to the indicated location. 55 * 56 * @param location The search criteria 57 * @param asOfDate Effective date 58 * @return A List<Department> object. 59 */ 60 @Cacheable(value=Department.CACHE_NAME, key="'chart=' + #p0 + '|' + 'asOfDate=' + #p1") 61 List<Department> getDepartments(String location, LocalDate asOfDate); 62 63 /** 64 * get count of department with given department 65 * @param department 66 * @return int 67 */ 68 List<Department> getDepartments(String department); 69 70 }