View Javadoc
1   package fr.ifremer.quadrige3.core.dao.administration.user;
2   
3   /*-
4    * #%L
5    * Quadrige3 Core :: Quadrige3 Client Core
6    * $Id:$
7    * $HeadURL:$
8    * %%
9    * Copyright (C) 2017 Ifremer
10   * %%
11   * This program is free software: you can redistribute it and/or modify
12   * it under the terms of the GNU Affero General Public License as published by
13   * the Free Software Foundation, either version 3 of the License, or
14   * (at your option) any later version.
15   * 
16   * This program is distributed in the hope that it will be useful,
17   * but WITHOUT ANY WARRANTY; without even the implied warranty of
18   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19   * GNU General Public License for more details.
20   * 
21   * You should have received a copy of the GNU Affero General Public License
22   * along with this program.  If not, see <http://www.gnu.org/licenses/>.
23   * #L%
24   */
25  
26  import fr.ifremer.quadrige3.core.vo.administration.user.DepartmentVO;
27  
28  import java.util.Date;
29  import java.util.List;
30  import java.util.Properties;
31  
32  
33  /**
34   * <p>
35   * DepartmentJdbcDao interface.
36   * </p>
37   * 
38   */
39  public interface DepartmentJdbcDao {
40  
41  	/**
42  	 * Get full data on department (execute against the default datasource)
43  	 * 
44  	 * @param depId
45  	 *            a int.
46  	 * @return a {@link fr.ifremer.quadrige3.core.vo.administration.user.DepartmentVO} object.
47  	 */
48  	DepartmentVO getDepartmentById(int depId);
49  
50  	/**
51  	 * Get full data on department, using the given connection
52  	 * 
53  	 * @param connectionProperties
54  	 *            if null, the default datasource will be used (if exists)
55  	 * @param depId
56  	 *            a int.
57  	 * @return a {@link fr.ifremer.quadrige3.core.vo.administration.user.DepartmentVO} object.
58  	 */
59  	DepartmentVO getDepartmentById(Properties connectionProperties, int depId);
60  
61  	/**
62  	 * Get department by ids (execute against the default datasource)
63  	 * 
64  	 * @param ids
65  	 *            a {@link java.util.List} object.
66  	 * @return a {@link java.util.List} object.
67  	 */
68  	List<DepartmentVO> getDepartmentsByIds(List<Integer> ids);
69  
70  	/**
71  	 * Get department by ids, using the given connection
72  	 * 
73  	 * @param connectionProperties
74  	 *            if null, the default datasource will be used (if exists)
75  	 * @param ids
76  	 *            a {@link java.util.List} object.
77  	 * @return a {@link java.util.List} object.
78  	 */
79  	List<DepartmentVO> getDepartmentsByIds(Properties connectionProperties, List<Integer> ids);
80  
81  	List<Integer> getInheritedRecorderDepartmentIdsFrom(int departmentId, Date date);
82  
83  }