View Javadoc
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 }