1 /*
2 * Copyright (c) 2002-2021, City of 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.stock.utils;
35
36 import java.sql.Timestamp;
37 import java.util.Calendar;
38 import java.util.Date;
39
40 import org.apache.commons.beanutils.ConversionException;
41 import org.apache.commons.beanutils.Converter;
42
43 /**
44 * Convertisseu de {@link Timestamp}
45 *
46 */
47 public class MapConverter implements Converter
48 {
49 /**
50 * Méthode permettant de convertir une date d'un type à l'autre
51 *
52 * @param type
53 * Type de la date passée en paramètre Les types suivants peuvent être précisés : - {@link String} - {@link Timestamp} - {@link Date} -
54 * {@link Calendar}
55 * @param value
56 * date à convertir en {@link Timestamp}
57 * @return une date de type {@link Timestamp} ou null en cas d'erreur
58 */
59 public Object convert( Class type, Object value ) throws ConversionException
60 {
61 if ( value != null )
62 {
63 // Support Calendar and Timestamp conversion
64 if ( value instanceof String )
65 {
66 if ( !( (String) value ).trim( ).equals( "" ) )
67 {
68 Timestamp date = DateUtils.getDate( (String) value, true );
69
70 if ( date == null )
71 {
72 TimestampValidationidation.html#TimestampValidation">TimestampValidation timestampValidation = new TimestampValidation( (String) value );
73 timestampValidation.setIdTypeError( TimestampValidation.ERROR_DATE_FORMAT );
74
75 return timestampValidation;
76 }
77
78 return date;
79 }
80 }
81
82 if ( value instanceof Timestamp )
83 {
84 return value;
85 }
86 else
87 if ( value instanceof Date )
88 {
89 return new Timestamp( ( (Date) value ).getTime( ) );
90 }
91 else
92 if ( value instanceof Calendar )
93 {
94 return new Timestamp( ( (Calendar) value ).getTime( ).getTime( ) );
95 }
96 }
97
98 return null;
99 }
100 }