1 /*
2 * Copyright (c) 2002-2017, Mairie de Paris
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * 1. Redistributions of source code must retain the above copyright notice
10 * and the following disclaimer.
11 *
12 * 2. Redistributions in binary form must reproduce the above copyright notice
13 * and the following disclaimer in the documentation and/or other materials
14 * provided with the distribution.
15 *
16 * 3. Neither the name of 'Mairie de Paris' nor 'Lutece' nor the names of its
17 * contributors may be used to endorse or promote products derived from
18 * this software without specific prior written permission.
19 *
20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
24 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30 * POSSIBILITY OF SUCH DAMAGE.
31 *
32 * License 1.0
33 */
34 package fr.paris.lutece.plugins.transparency.business;
35
36 import fr.paris.lutece.portal.service.plugin.Plugin;
37 import fr.paris.lutece.portal.service.plugin.PluginService;
38 import fr.paris.lutece.portal.service.spring.SpringContextService;
39 import fr.paris.lutece.util.ReferenceList;
40
41 import java.util.List;
42
43 /**
44 * This class provides instances management methods (create, find, ...) for Appointment objects
45 */
46 public final class AppointmentHome
47 {
48 // Static variable pointed at the DAO instance
49 private static IAppointmentDAO _dao = SpringContextService.getBean( "transparency.appointmentDAO" );
50 private static Plugin _plugin = PluginService.getPlugin( "transparency" );
51
52 /**
53 * Private constructor - this class need not be instantiated
54 */
55 private AppointmentHome( )
56 {
57 }
58
59 /**
60 * Create an instance of the appointment class
61 *
62 * @param appointment
63 * The instance of the Appointment which contains the informations to store
64 * @return The instance of appointment which has been created with its primary key.
65 */
66 public static Appointment create( Appointment appointment )
67 {
68 _dao.insert( appointment, _plugin );
69
70 return appointment;
71 }
72
73 /**
74 * Update of the appointment which is specified in parameter
75 *
76 * @param appointment
77 * The instance of the Appointment which contains the data to store
78 * @return The instance of the appointment which has been updated
79 */
80 public static Appointment update( Appointment appointment )
81 {
82 _dao.store( appointment, _plugin );
83
84 return appointment;
85 }
86
87 /**
88 * Remove the appointment whose identifier is specified in parameter
89 *
90 * @param nKey
91 * The appointment Id
92 */
93 public static void remove( int nKey )
94 {
95 _dao.delete( nKey, _plugin );
96 }
97
98 /**
99 * Returns an instance of a appointment whose identifier is specified in parameter
100 *
101 * @param nKey
102 * The appointment primary key
103 * @return an instance of Appointment
104 */
105 public static Appointment findByPrimaryKey( int nKey )
106 {
107 return _dao.load( nKey, _plugin );
108 }
109
110 /**
111 * Returns an instance of a appointment whose identifier is specified in parameter
112 *
113 * @param nId
114 * @return an instance of Appointment
115 */
116 public static Appointment getFullAppointmentById( int nId )
117 {
118 Appointment appointment = _dao.load( nId, _plugin );
119
120 if ( appointment != null )
121 {
122 // get lobbies and elected officials
123 appointment.setLobbyList( LobbyHome.getLobbiesListByAppointment( appointment.getId( ) ) );
124 appointment.setElectedOfficialList( ElectedOfficialHome.getElectedOfficialsListByAppointment( appointment.getId( ) ) );
125
126 }
127
128 return appointment;
129 }
130
131 /**
132 * Load the data of all the appointment objects and returns them as a list
133 *
134 * @return the list which contains the data of all the appointment objects
135 */
136 public static List<Appointment> getAppointmentsList( )
137 {
138 return _dao.selectAppointmentsList( _plugin );
139 }
140
141 /**
142 * Load the data of all the appointment objects and returns them as a list
143 *
144 * @return the list which contains the data of all the appointment objects
145 */
146 public static List<Appointment> getFullAppointmentsList( )
147 {
148 return getFullAppointmentsList( null );
149 }
150
151 /**
152 * Load the data of all the filtred appointment objects and returns them as a list
153 *
154 * @param filter
155 * @return the list which contains the data of all the appointment objects
156 */
157 public static List<Appointment> getFullAppointmentsList( AppointmentFilter filter )
158 {
159 List<Appointment> list = _dao.selectAppointmentsList( filter, _plugin );
160 for ( Appointment appointment : list )
161 {
162 appointment.setElectedOfficialList( ElectedOfficialHome.getElectedOfficialsListByAppointment( appointment.getId( ) ) );
163 appointment.setLobbyList( LobbyHome.getLobbiesListByAppointment( appointment.getId( ) ) );
164 }
165 return list;
166 }
167
168 /**
169 * Load the id of all the appointment objects and returns them as a list
170 *
171 * @param filter
172 * @return the list which contains the id of all the appointment objects
173 */
174 public static List<Integer> getAppointmentIdsList( AppointmentFilter filter )
175 {
176 return _dao.selectAppointmentIdsList( filter, _plugin );
177 }
178
179 /**
180 * Load the data of all the appointment objects and returns them as a referenceList
181 *
182 * @return the referenceList which contains the data of all the appointment objects
183 */
184 public static ReferenceList getAppointmentsReferenceList( )
185 {
186 return _dao.selectAppointmentsReferenceList( _plugin );
187 }
188 }