1
2
3
4
5
6 package fr.ifremer.quadrige3.core.dao.system;
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28 import fr.ifremer.quadrige3.core.dao.PrincipalStore;
29 import fr.ifremer.quadrige3.core.dao.PropertySearch;
30 import fr.ifremer.quadrige3.core.dao.Search;
31 import fr.ifremer.quadrige3.core.dao.technical.hibernate.HibernateDaoSupport;
32 import java.security.Principal;
33 import java.sql.Timestamp;
34 import java.util.Collection;
35 import java.util.LinkedHashSet;
36 import java.util.List;
37 import java.util.Set;
38 import javax.annotation.Resource;
39 import org.andromda.spring.PaginationResult;
40 import org.apache.commons.collections.CollectionUtils;
41 import org.apache.commons.collections.Transformer;
42 import org.hibernate.Criteria;
43 import org.hibernate.HibernateException;
44 import org.hibernate.Query;
45 import org.hibernate.ScrollableResults;
46
47
48
49
50
51
52
53
54
55 public abstract class LocationDaoBase
56 extends HibernateDaoSupport
57 implements LocationDao
58 {
59
60
61
62 @Override
63 public Object get(final int transform, final Integer locId)
64 {
65 if (locId == null)
66 {
67 throw new IllegalArgumentException(
68 "Location.get - 'locId' can not be null");
69 }
70 final Location entity = get(LocationImpl.class, locId);
71 return transformEntity(transform, entity);
72 }
73
74
75
76 @Override
77 public Location get(Integer locId)
78 {
79 return (Location)this.get(TRANSFORM_NONE, locId);
80 }
81
82
83
84
85 @Override
86 public Object load(final int transform, final Integer locId)
87 {
88 if (locId == null)
89 {
90 throw new IllegalArgumentException(
91 "Location.load - 'locId' can not be null");
92 }
93 final Location entity = get(LocationImpl.class, locId);
94 return transformEntity(transform, entity);
95 }
96
97
98
99
100 @Override
101 public Location load(Integer locId)
102 {
103 return (Location)this.load(TRANSFORM_NONE, locId);
104 }
105
106
107
108
109 @Override
110 @SuppressWarnings({"unchecked"})
111 public Collection<Location> loadAll()
112 {
113 return (Collection<Location>) this.loadAll(LocationDao.TRANSFORM_NONE);
114 }
115
116
117
118
119 @Override
120 public Collection<?> loadAll(final int transform)
121 {
122 return this.loadAll(transform, -1, -1);
123 }
124
125
126
127
128 @Override
129 public Collection<?> loadAll(final int pageNumber, final int pageSize)
130 {
131 return this.loadAll(LocationDao.TRANSFORM_NONE, pageNumber, pageSize);
132 }
133
134
135
136
137 @Override
138 public Collection<?> loadAll(final int transform, final int pageNumber, final int pageSize)
139 {
140 try
141 {
142 final Criteria criteria = this.getSession().createCriteria(LocationImpl.class);
143 if (pageNumber > 0 && pageSize > 0)
144 {
145 criteria.setFirstResult(this.calculateFirstResult(pageNumber, pageSize));
146 criteria.setMaxResults(pageSize);
147 }
148 final Collection<?> results = criteria.list();
149 this.transformEntities(transform, results);
150 return results;
151 }
152 catch (HibernateException ex)
153 {
154 throw ex;
155 }
156 }
157
158
159
160
161
162
163
164 protected int calculateFirstResult(int pageNumber, int pageSize)
165 {
166 int firstResult = 0;
167 if (pageNumber > 0)
168 {
169 firstResult = (pageNumber - 1) * pageSize;
170 }
171 return firstResult;
172 }
173
174
175
176
177 @Override
178 public Location create(Location location)
179 {
180 return (Location)this.create(LocationDao.TRANSFORM_NONE, location);
181 }
182
183
184
185
186 @Override
187 public Object create(final int transform, final Location location)
188 {
189 if (location == null)
190 {
191 throw new IllegalArgumentException(
192 "Location.create - 'location' can not be null");
193 }
194 this.getSessionFactory().getCurrentSession().save(location);
195 return this.transformEntity(transform, location);
196 }
197
198
199
200
201 @Override
202 @SuppressWarnings({"unchecked"})
203 public Collection<Location> create(final Collection<Location> entities)
204 {
205 return (Collection<Location>) create(LocationDao.TRANSFORM_NONE, entities);
206 }
207
208
209
210
211 @Override
212 public Collection<?> create(final int transform, final Collection<Location> entities)
213 {
214 if (entities == null)
215 {
216 throw new IllegalArgumentException(
217 "Location.create - 'entities' can not be null");
218 }
219 for (Location entity : entities)
220 {
221 create(transform, entity);
222 }
223 return entities;
224 }
225
226
227
228
229 @Override
230 public Location create(
231 String locLb,
232 String locNm,
233 String locDc,
234 Timestamp updateDt)
235 {
236 return (Location)this.create(LocationDao.TRANSFORM_NONE, locLb, locNm, locDc, updateDt);
237 }
238
239
240
241
242 @Override
243 public Object create(
244 final int transform,
245 String locLb,
246 String locNm,
247 String locDc,
248 Timestamp updateDt)
249 {
250 Location entity = new LocationImpl();
251 entity.setLocLb(locLb);
252 entity.setLocNm(locNm);
253 entity.setLocDc(locDc);
254 entity.setUpdateDt(updateDt);
255 return this.create(transform, entity);
256 }
257
258
259
260
261 @Override
262 public void update(Location location)
263 {
264 if (location == null)
265 {
266 throw new IllegalArgumentException(
267 "Location.update - 'location' can not be null");
268 }
269 this.getSessionFactory().getCurrentSession().update(location);
270 }
271
272
273
274
275 @Override
276 public void update(final Collection<Location> entities)
277 {
278 if (entities == null)
279 {
280 throw new IllegalArgumentException(
281 "Location.update - 'entities' can not be null");
282 }
283 for (Location entity : entities)
284 {
285 update(entity);
286 }
287 }
288
289
290
291
292 @Override
293 public void remove(Location location)
294 {
295 if (location == null)
296 {
297 throw new IllegalArgumentException(
298 "Location.remove - 'location' can not be null");
299 }
300 this.getSessionFactory().getCurrentSession().delete(location);
301 }
302
303
304
305
306 @Override
307 public void remove(Integer locId)
308 {
309 if (locId == null)
310 {
311 throw new IllegalArgumentException(
312 "Location.remove - 'locId' can not be null");
313 }
314 Location entity = this.get(locId);
315 if (entity != null)
316 {
317 this.remove(entity);
318 }
319 }
320
321
322
323
324 @Override
325 public void remove(Collection<Location> entities)
326 {
327 if (entities == null)
328 {
329 throw new IllegalArgumentException(
330 "Location.remove - 'entities' can not be null");
331 }
332 deleteAll(entities);
333 }
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348 public Object transformEntity(final int transform, final Location entity)
349 {
350 Object target = null;
351 if (entity != null)
352 {
353 switch (transform)
354 {
355 case LocationDao.TRANSFORM_NONE :
356 default:
357 target = entity;
358 }
359 }
360 return target;
361 }
362
363
364
365
366 @Override
367 public void transformEntities(final int transform, final Collection<?> entities)
368 {
369 switch (transform)
370 {
371 case LocationDao.TRANSFORM_NONE :
372 default:
373
374 }
375 }
376
377
378
379
380 public void toEntities(final Collection<?> results)
381 {
382 if (results != null)
383 {
384 CollectionUtils.transform(results, this.ENTITYTRANSFORMER);
385 }
386 }
387
388
389
390
391
392
393 private Transformer ENTITYTRANSFORMER =
394 new Transformer()
395 {
396 public Object transform(Object input)
397 {
398 Object result = null;
399 if (input instanceof Object[])
400 {
401 result = toEntity((Object[])input);
402 }
403 else if (input instanceof Location)
404 {
405 result = input;
406 }
407 return result;
408 }
409 };
410
411
412
413
414
415 protected Location toEntity(Object[] row)
416 {
417 Location target = null;
418 if (row != null)
419 {
420 final int numberOfObjects = row.length;
421 for (int ctr = 0; ctr < numberOfObjects; ctr++)
422 {
423 final Object object = row[ctr];
424 if (object instanceof Location)
425 {
426 target = (Location)object;
427 break;
428 }
429 }
430 }
431 return target;
432 }
433
434
435
436
437
438
439
440 protected Principal getPrincipal()
441 {
442 return PrincipalStore.get();
443 }
444
445
446
447
448 @Override
449 @SuppressWarnings({ "unchecked" })
450 public PaginationResult search(final int transform, final int pageNumber, final int pageSize, final Search search)
451 {
452 try
453 {
454 search.setPageNumber(pageNumber);
455 search.setPageSize(pageSize);
456 final PropertySearch propertySearch = new PropertySearch(
457 this.getSession(), LocationImpl.class, search);
458 final List results = propertySearch.executeAsList();
459 this.transformEntities(transform, results);
460 return new PaginationResult(results.toArray(new Object[results.size()]), propertySearch.getTotalCount());
461 }
462 catch (HibernateException ex)
463 {
464 throw ex;
465 }
466 }
467
468
469
470
471 @Override
472 public PaginationResult search(final int pageNumber, final int pageSize, final Search search)
473 {
474 return this.search(LocationDao.TRANSFORM_NONE, pageNumber, pageSize, search);
475 }
476
477
478
479
480 @Override
481 public Set<?> search(final int transform, final Search search)
482 {
483 try
484 {
485 final PropertySearch propertySearch = new PropertySearch(
486 this.getSession(), LocationImpl.class, search);
487 final Set<?> results = propertySearch.executeAsSet();
488 this.transformEntities(transform, results);
489 return results;
490 }
491 catch (HibernateException ex)
492 {
493 throw ex;
494 }
495 }
496
497
498
499
500 @Override
501 @SuppressWarnings("unchecked")
502 public Set<Location> search(final Search search)
503 {
504 return (Set<Location>) this.search(LocationDao.TRANSFORM_NONE, search);
505 }
506
507
508
509
510
511
512
513
514
515 @SuppressWarnings({ "unchecked" })
516 protected PaginationResult getPaginationResult(
517 final Query queryObject,
518 final int transform, int pageNumber, int pageSize)
519 {
520 try
521 {
522 final ScrollableResults scrollableResults = queryObject.scroll();
523 scrollableResults.last();
524 int totalCount = scrollableResults.getRowNumber();
525 totalCount = totalCount >= 0 ? totalCount + 1 : 0;
526 if (pageNumber > 0 && pageSize > 0)
527 {
528 queryObject.setFirstResult(this.calculateFirstResult(pageNumber, pageSize));
529 queryObject.setMaxResults(pageSize);
530 }
531
532 Set results = new LinkedHashSet(queryObject.list());
533 transformEntities(transform, results);
534 return new PaginationResult(results.toArray(new Object[results.size()]), totalCount);
535 }
536 catch (HibernateException ex)
537 {
538 throw ex;
539 }
540 }
541
542
543 }