View Javadoc
1   /*
2    *  Copyright 2010, 2011 Christopher Pheby
3    *
4    *  Licensed under the Apache License, Version 2.0 (the "License");
5    *  you may not use this file except in compliance with the License.
6    *  You may obtain a copy of the License at
7    *
8    *      http://www.apache.org/licenses/LICENSE-2.0
9    *
10   *  Unless required by applicable law or agreed to in writing, software
11   *  distributed under the License is distributed on an "AS IS" BASIS,
12   *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   *  See the License for the specific language governing permissions and
14   *  limitations under the License.
15   */
16  package org.jadira.usertype.dateandtime.joda;
17  
18  import org.jadira.usertype.dateandtime.joda.columnmapper.StringColumnDateTimeZoneWithOffsetMapper;
19  import org.jadira.usertype.dateandtime.joda.columnmapper.StringColumnLocalDateTimeMapper;
20  import org.jadira.usertype.dateandtime.joda.util.DateTimeZoneWithOffset;
21  import org.jadira.usertype.spi.shared.AbstractParameterizedTemporalMultiColumnUserType;
22  import org.jadira.usertype.spi.shared.ColumnMapper;
23  import org.jadira.usertype.spi.utils.reflection.ArrayUtils;
24  import org.joda.time.DateTime;
25  import org.joda.time.DateTimeZone;
26  import org.joda.time.LocalDateTime;
27  
28  /**
29   * Persist {@link org.joda.time.DateTime} via Hibernate. The offset will be stored in an extra column.
30   */
31  public class PersistentDateTimeAsString extends AbstractParameterizedTemporalMultiColumnUserType<DateTime> {
32  
33      private static final long serialVersionUID = 1364221029397346011L;
34  
35      private static final ColumnMapper<?, ?>[] COLUMN_MAPPERS = new ColumnMapper<?, ?>[] { new StringColumnLocalDateTimeMapper(), new StringColumnDateTimeZoneWithOffsetMapper() };
36  
37      private static final String[] PROPERTY_NAMES = new String[]{ "datetime", "offset" };
38  
39      @Override
40      protected ColumnMapper<?, ?>[] getColumnMappers() {
41          return COLUMN_MAPPERS;
42      }
43  
44      @Override
45      public String[] getPropertyNames() {
46          return ArrayUtils.copyOf(PROPERTY_NAMES);
47      }
48  
49      @Override
50      protected DateTime fromConvertedColumns(Object[] convertedColumns) {
51  
52          LocalDateTime datePart = (LocalDateTime) convertedColumns[0];
53          DateTimeZoneWithOffset offset = (DateTimeZoneWithOffset) convertedColumns[1];
54  
55          DateTime result;
56  
57          if (datePart == null) {
58              result = null;
59          } else {
60              result = datePart.toDateTime(offset.getStandardDateTimeZone());            
61          }
62          
63          // Handling DST rollover
64          if (result != null && offset.getOffsetDateTimeZone() != null &&
65          		offset.getStandardDateTimeZone().getOffset(result) > offset.getOffsetDateTimeZone().getOffset(result)) {
66          	return result.withLaterOffsetAtOverlap();
67          }
68  
69          return result;
70      }
71  
72      @Override
73      protected Object[] toConvertedColumns(DateTime value) {
74  
75          return new Object[] { value.toLocalDateTime(), new DateTimeZoneWithOffset(value.getZone(), value.getZone().isFixed() ? null : DateTimeZone.forOffsetMillis(value.getZone().getOffset(value))) };
76      }
77  }