com.phloc.datetime.xml.PDTXMLConverter Maven / Gradle / Ivy
/**
* Copyright (C) 2006-2014 phloc systems
* http://www.phloc.com
* office[at]phloc[dot]com
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.phloc.datetime.xml;
import java.util.Calendar;
import java.util.Date;
import java.util.GregorianCalendar;
import javax.annotation.CheckForSigned;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import javax.annotation.concurrent.Immutable;
import javax.xml.datatype.DatatypeConfigurationException;
import javax.xml.datatype.DatatypeConstants;
import javax.xml.datatype.DatatypeFactory;
import javax.xml.datatype.XMLGregorianCalendar;
import org.joda.time.DateTime;
import org.joda.time.LocalDate;
import org.joda.time.LocalDateTime;
import org.joda.time.LocalTime;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.phloc.commons.CGlobal;
import com.phloc.commons.annotations.PresentForCodeCoverage;
import com.phloc.commons.exceptions.InitializationException;
import com.phloc.datetime.PDTFactory;
/**
* Utility class for XML date/time data type handling.
*
* @author Philip Helger
*/
@Immutable
public final class PDTXMLConverter
{
private static final Logger s_aLogger = LoggerFactory.getLogger (PDTXMLConverter.class);
private static final DatatypeFactory s_aDTFactory;
static
{
try
{
// required for the Gregorian calendar
s_aDTFactory = DatatypeFactory.newInstance ();
}
catch (final DatatypeConfigurationException ex)
{
throw new InitializationException ("Failed to init DataTypeFactory", ex);
}
}
@PresentForCodeCoverage
@SuppressWarnings ("unused")
private static final PDTXMLConverter s_aInstance = new PDTXMLConverter ();
private PDTXMLConverter ()
{}
/**
* Get the timezone offset to UTC of the passed calendar in minutes to be used
* in {@link XMLGregorianCalendar}.
*
* @param aCalendar
* The calendar to use. May not be null
.
* @return 0 for no offset to UTC, the minutes otherwise. Usually in 60minutes
* steps :)
*/
public static int getTimezoneOffsetInMinutes (@Nonnull final Calendar aCalendar)
{
final int nOffsetInMillis = aCalendar.getTimeZone ().getOffset (aCalendar.getTimeInMillis ());
return nOffsetInMillis / (int) CGlobal.MILLISECONDS_PER_MINUTE;
}
/**
* Get the passed date as {@link GregorianCalendar}.
*
* @param aDate
* The source date. May be null
.
* @return Never null
.
*/
@Nonnull
public static GregorianCalendar getCalendar (@Nonnull final Date aDate)
{
final GregorianCalendar aCalendar = new GregorianCalendar ();
aCalendar.setTime (aDate);
return aCalendar;
}
/**
* Get the passed milli seconds as {@link GregorianCalendar}.
*
* @param nMillis
* Milli seconds since 1.1.1970
* @return Never null
.
*/
@Nonnull
public static GregorianCalendar getCalendar (final long nMillis)
{
final GregorianCalendar aCalendar = new GregorianCalendar ();
aCalendar.setTimeInMillis (nMillis);
return aCalendar;
}
/**
* @return A new XML calendar instance, with all fields uninitialized. Never
* null
.
*/
@Nonnull
public static XMLGregorianCalendar createNewCalendar ()
{
return s_aDTFactory.newXMLGregorianCalendar ();
}
/**
* Get the current date as {@link XMLGregorianCalendar}.
*
* @return Never null
.
*/
@Nonnull
public static XMLGregorianCalendar getXMLCalendarDateNow ()
{
return getXMLCalendarDate (PDTFactory.getCurrentLocalDate ());
}
/**
* Get the passed object as {@link XMLGregorianCalendar} date (without a
* time).
*
* @param aBase
* The source object. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static XMLGregorianCalendar getXMLCalendarDate (@Nullable final LocalDate aBase)
{
return aBase == null ? null : s_aDTFactory.newXMLGregorianCalendarDate (aBase.getYear (),
aBase.getMonthOfYear (),
aBase.getDayOfMonth (),
DatatypeConstants.FIELD_UNDEFINED);
}
/**
* Get the passed object as {@link XMLGregorianCalendar} date (without a
* time).
*
* @param aBase
* The source object. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static XMLGregorianCalendar getXMLCalendarDate (@Nullable final Date aBase)
{
return aBase == null ? null : getXMLCalendarDate (getCalendar (aBase));
}
/**
* Get the passed object as {@link XMLGregorianCalendar} date (without a
* time).
*
* @param aBase
* The source object. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static XMLGregorianCalendar getXMLCalendarDate (@Nullable final GregorianCalendar aBase)
{
return aBase == null ? null : s_aDTFactory.newXMLGregorianCalendarDate (aBase.get (Calendar.YEAR),
aBase.get (Calendar.MONTH),
aBase.get (Calendar.DAY_OF_MONTH),
getTimezoneOffsetInMinutes (aBase));
}
/**
* Get the passed object as {@link XMLGregorianCalendar} date (without a
* time).
*
* @param aBase
* The source object. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static XMLGregorianCalendar getXMLCalendarDate (@Nullable final XMLGregorianCalendar aBase)
{
return aBase == null ? null
: s_aDTFactory.newXMLGregorianCalendarDate (aBase.getYear (),
aBase.getMonth (),
aBase.getDay (),
aBase.getTimezone () == 0 ? DatatypeConstants.FIELD_UNDEFINED
: aBase.getTimezone ());
}
/**
*
* Create a Java representation of XML Schema builtin datatype
* date
or g*
.
*
*
* For example, an instance of gYear
can be created invoking this
* factory with month
and day
parameters set to
* {@link DatatypeConstants#FIELD_UNDEFINED}.
*
*
* A {@link DatatypeConstants#FIELD_UNDEFINED} value indicates that field is
* not set.
*
*
* @param nYear
* Year to be created.
* @param nMonth
* Month to be created.
* @param nDay
* Day to be created.
* @return XMLGregorianCalendar
created from parameter values.
* @see DatatypeConstants#FIELD_UNDEFINED
* @throws IllegalArgumentException
* If any individual parameter's value is outside the maximum value
* constraint for the field as determined by the Date/Time Data
* Mapping table in {@link XMLGregorianCalendar} or if the composite
* values constitute an invalid XMLGregorianCalendar
* instance as determined by {@link XMLGregorianCalendar#isValid()}.
*/
@Nonnull
public static XMLGregorianCalendar getXMLCalendarDate (final int nYear, final int nMonth, final int nDay)
{
return getXMLCalendarDate (nYear, nMonth, nDay, DatatypeConstants.FIELD_UNDEFINED);
}
/**
*
* Create a Java representation of XML Schema builtin datatype
* date
or g*
.
*
*
* For example, an instance of gYear
can be created invoking this
* factory with month
and day
parameters set to
* {@link DatatypeConstants#FIELD_UNDEFINED}.
*
*
* A {@link DatatypeConstants#FIELD_UNDEFINED} value indicates that field is
* not set.
*
*
* @param nYear
* Year to be created.
* @param nMonth
* Month to be created.
* @param nDay
* Day to be created.
* @param nTimezone
* Offset in minutes. {@link DatatypeConstants#FIELD_UNDEFINED}
* indicates optional field is not set.
* @return XMLGregorianCalendar
created from parameter values.
* @see DatatypeConstants#FIELD_UNDEFINED
* @throws IllegalArgumentException
* If any individual parameter's value is outside the maximum value
* constraint for the field as determined by the Date/Time Data
* Mapping table in {@link XMLGregorianCalendar} or if the composite
* values constitute an invalid XMLGregorianCalendar
* instance as determined by {@link XMLGregorianCalendar#isValid()}.
*/
@Nonnull
public static XMLGregorianCalendar getXMLCalendarDate (final int nYear,
final int nMonth,
final int nDay,
final int nTimezone)
{
return s_aDTFactory.newXMLGregorianCalendarDate (nYear, nMonth, nDay, nTimezone);
}
/**
* Get the current time as {@link XMLGregorianCalendar}.
*
* @return Never null
.
*/
@Nonnull
public static XMLGregorianCalendar getXMLCalendarTimeNow ()
{
return getXMLCalendarTime (PDTFactory.getCurrentLocalTime ());
}
/**
* Get the passed object as {@link XMLGregorianCalendar} time (without a
* date).
*
* @param aBase
* The source object. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static XMLGregorianCalendar getXMLCalendarTime (@Nullable final LocalTime aBase)
{
return aBase == null ? null : s_aDTFactory.newXMLGregorianCalendarTime (aBase.getHourOfDay (),
aBase.getMinuteOfHour (),
aBase.getSecondOfMinute (),
aBase.getMillisOfSecond (),
DatatypeConstants.FIELD_UNDEFINED);
}
/**
* Get the passed object as {@link XMLGregorianCalendar} time (without a
* date).
*
* @param aBase
* The source object. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static XMLGregorianCalendar getXMLCalendarTime (@Nullable final Date aBase)
{
return aBase == null ? null : getXMLCalendarTime (getCalendar (aBase));
}
/**
* Get the passed object as {@link XMLGregorianCalendar} time (without a
* date).
*
* @param aBase
* The source object. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static XMLGregorianCalendar getXMLCalendarTime (@Nullable final GregorianCalendar aBase)
{
return aBase == null ? null : s_aDTFactory.newXMLGregorianCalendarTime (aBase.get (Calendar.HOUR_OF_DAY),
aBase.get (Calendar.MINUTE),
aBase.get (Calendar.SECOND),
aBase.get (Calendar.MILLISECOND),
getTimezoneOffsetInMinutes (aBase));
}
/**
* Get the passed object as {@link XMLGregorianCalendar} time (without a
* date).
*
* @param aBase
* The source object. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static XMLGregorianCalendar getXMLCalendarTime (@Nullable final XMLGregorianCalendar aBase)
{
return aBase == null ? null : s_aDTFactory.newXMLGregorianCalendarTime (aBase.getHour (),
aBase.getMinute (),
aBase.getSecond (),
aBase.getMillisecond (),
aBase.getTimezone ());
}
/**
*
* Create a Java representation of XML Schema builtin datatype
* date
or g*
.
*
*
* For example, an instance of gYear
can be created invoking this
* factory with month
and day
parameters set to
* {@link DatatypeConstants#FIELD_UNDEFINED}.
*
*
* A {@link DatatypeConstants#FIELD_UNDEFINED} value indicates that field is
* not set.
*
*
* @param nHour
* Hour to be created.
* @param nMinute
* Minute to be created.
* @param nSecond
* Second to be created.
* @param nMilliSecond
* Milli second to be created.
* @return XMLGregorianCalendar
created from parameter values.
* @see DatatypeConstants#FIELD_UNDEFINED
* @throws IllegalArgumentException
* If any individual parameter's value is outside the maximum value
* constraint for the field as determined by the Date/Time Data
* Mapping table in {@link XMLGregorianCalendar} or if the composite
* values constitute an invalid XMLGregorianCalendar
* instance as determined by {@link XMLGregorianCalendar#isValid()}.
*/
@Nonnull
public static XMLGregorianCalendar getXMLCalendarTime (final int nHour,
final int nMinute,
final int nSecond,
final int nMilliSecond)
{
return getXMLCalendarTime (nHour, nMinute, nSecond, nMilliSecond, DatatypeConstants.FIELD_UNDEFINED);
}
/**
*
* Create a Java representation of XML Schema builtin datatype
* date
or g*
.
*
*
* For example, an instance of gYear
can be created invoking this
* factory with month
and day
parameters set to
* {@link DatatypeConstants#FIELD_UNDEFINED}.
*
*
* A {@link DatatypeConstants#FIELD_UNDEFINED} value indicates that field is
* not set.
*
*
* @param nHour
* Hour to be created.
* @param nMinute
* Minute to be created.
* @param nSecond
* Second to be created.
* @param nMilliSecond
* Milli second to be created.
* @param nTimezone
* Offset in minutes. {@link DatatypeConstants#FIELD_UNDEFINED}
* indicates optional field is not set.
* @return XMLGregorianCalendar
created from parameter values.
* @see DatatypeConstants#FIELD_UNDEFINED
* @throws IllegalArgumentException
* If any individual parameter's value is outside the maximum value
* constraint for the field as determined by the Date/Time Data
* Mapping table in {@link XMLGregorianCalendar} or if the composite
* values constitute an invalid XMLGregorianCalendar
* instance as determined by {@link XMLGregorianCalendar#isValid()}.
*/
@Nonnull
public static XMLGregorianCalendar getXMLCalendarTime (final int nHour,
final int nMinute,
final int nSecond,
final int nMilliSecond,
final int nTimezone)
{
return s_aDTFactory.newXMLGregorianCalendarTime (nHour, nMinute, nSecond, nMilliSecond, nTimezone);
}
/**
* Get the current date and time as {@link XMLGregorianCalendar} in the
* default time zone.
*
* @return Never null
.
*/
@Nonnull
public static XMLGregorianCalendar getXMLCalendarNow ()
{
return getXMLCalendar (PDTFactory.getCurrentDateTime ());
}
/**
* Get the current date and time as {@link XMLGregorianCalendar} in UTC.
*
* @return Never null
.
*/
@Nonnull
public static XMLGregorianCalendar getXMLCalendarNowUTC ()
{
return getXMLCalendar (PDTFactory.getCurrentDateTimeUTC ());
}
/**
* Get the passed object as {@link XMLGregorianCalendar} with date and time.
*
* @param aBase
* The source object. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static XMLGregorianCalendar getXMLCalendar (@Nullable final LocalDateTime aBase)
{
return aBase == null ? null : s_aDTFactory.newXMLGregorianCalendar (aBase.getYear (),
aBase.getMonthOfYear (),
aBase.getDayOfMonth (),
aBase.getHourOfDay (),
aBase.getMinuteOfHour (),
aBase.getSecondOfMinute (),
aBase.getMillisOfSecond (),
DatatypeConstants.FIELD_UNDEFINED);
}
/**
* Get the passed object as {@link XMLGregorianCalendar} with date and time.
*
* @param aBase
* The source object. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static XMLGregorianCalendar getXMLCalendar (@Nullable final DateTime aBase)
{
return aBase == null ? null : s_aDTFactory.newXMLGregorianCalendar (aBase.toGregorianCalendar ());
}
/**
* Get the passed {@link GregorianCalendar} as {@link XMLGregorianCalendar}.
*
* @param aCal
* Source calendar. May be null
.
* @return null
if the passed calendar is null
.
*/
@Nullable
public static XMLGregorianCalendar getXMLCalendar (@Nullable final GregorianCalendar aCal)
{
return aCal == null ? null : s_aDTFactory.newXMLGregorianCalendar (aCal);
}
/**
* Create a new {@link XMLGregorianCalendar} using separate objects for date
* and time.
*
* @param aDate
* Source date. May be null
.
* @param aTime
* Source time. May be null
.
* @return null
if the passed date and time are null
* .
*/
@Nullable
public static XMLGregorianCalendar getXMLCalendar (@Nullable final XMLGregorianCalendar aDate,
@Nullable final XMLGregorianCalendar aTime)
{
if (aDate == null && aTime == null)
return null;
if (aTime == null)
{
// Date only
return s_aDTFactory.newXMLGregorianCalendar (aDate.getYear (),
aDate.getMonth (),
aDate.getDay (),
0,
0,
0,
0,
aDate.getTimezone ());
}
if (aDate == null)
{
// Time only
return s_aDTFactory.newXMLGregorianCalendar (0,
0,
0,
aTime.getHour (),
aTime.getMinute (),
aTime.getSecond (),
aTime.getMillisecond (),
aTime.getTimezone ());
}
if (aDate.getTimezone () != aTime.getTimezone ())
s_aLogger.warn ("Date and time have different timezones: " +
aDate.getTimezone () +
" vs. " +
aTime.getTimezone ());
return s_aDTFactory.newXMLGregorianCalendar (aDate.getYear (),
aDate.getMonth (),
aDate.getDay (),
aTime.getHour (),
aTime.getMinute (),
aTime.getSecond (),
aTime.getMillisecond (),
aDate.getTimezone ());
}
/**
* Get the passed milli seconds as {@link XMLGregorianCalendar}.
*
* @param nMillis
* Milli seconds since 1.1.1970
* @return Never null
.
*/
@Nonnull
public static XMLGregorianCalendar getXMLCalendar (final long nMillis)
{
return s_aDTFactory.newXMLGregorianCalendar (getCalendar (nMillis));
}
/**
* Get the passed {@link Date} as {@link XMLGregorianCalendar}.
*
* @param aDate
* Source date. May be null
.
* @return null
if the passed date is null
.
*/
@Nullable
public static XMLGregorianCalendar getXMLCalendar (@Nullable final Date aDate)
{
return aDate == null ? null : s_aDTFactory.newXMLGregorianCalendar (getCalendar (aDate));
}
/**
* Convert the passed {@link XMLGregorianCalendar} to a
* {@link GregorianCalendar}.
*
* @param aCal
* Source calendar. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static GregorianCalendar getGregorianCalendar (@Nullable final XMLGregorianCalendar aCal)
{
return aCal == null ? null : aCal.toGregorianCalendar (aCal.getTimeZone (aCal.getTimezone ()), null, null);
}
/**
* Get the passed {@link XMLGregorianCalendar} as {@link LocalDate}.
*
* @param aCal
* The source {@link XMLGregorianCalendar}. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static LocalDate getLocalDate (@Nullable final XMLGregorianCalendar aCal)
{
return aCal == null ? null : PDTFactory.createLocalDate (getGregorianCalendar (aCal));
}
/**
* Get the passed {@link XMLGregorianCalendar} as {@link LocalTime}.
*
* @param aCal
* The source {@link XMLGregorianCalendar}. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static LocalTime getLocalTime (@Nullable final XMLGregorianCalendar aCal)
{
return aCal == null ? null : PDTFactory.createLocalTime (getGregorianCalendar (aCal));
}
/**
* Get the passed {@link XMLGregorianCalendar} as {@link LocalDateTime}.
*
* @param aCal
* The source {@link XMLGregorianCalendar}. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static LocalDateTime getLocalDateTime (@Nullable final XMLGregorianCalendar aCal)
{
return aCal == null ? null : PDTFactory.createLocalDateTime (getGregorianCalendar (aCal));
}
/**
* Get the passed {@link XMLGregorianCalendar} as {@link DateTime}.
*
* @param aCal
* The source {@link XMLGregorianCalendar}. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static DateTime getDateTime (@Nullable final XMLGregorianCalendar aCal)
{
return aCal == null ? null : PDTFactory.createDateTime (getGregorianCalendar (aCal));
}
/**
* Get the passed {@link XMLGregorianCalendar} as {@link Date}.
*
* @param aCal
* The source {@link XMLGregorianCalendar}. May be null
.
* @return null
if the parameter is null
.
*/
@Nullable
public static Date getDate (@Nullable final XMLGregorianCalendar aCal)
{
final GregorianCalendar aGregorianCalendar = getGregorianCalendar (aCal);
return aGregorianCalendar == null ? null : aGregorianCalendar.getTime ();
}
/**
* Get the passed {@link XMLGregorianCalendar} as milli seconds.
*
* @param aCal
* The source {@link XMLGregorianCalendar}. May be null
.
* @return {@link CGlobal#ILLEGAL_ULONG}
if the parameter is
* null
.
*/
@CheckForSigned
public static long getMillis (@Nullable final XMLGregorianCalendar aCal)
{
final GregorianCalendar aGregorianCalendar = getGregorianCalendar (aCal);
return aGregorianCalendar == null ? CGlobal.ILLEGAL_ULONG : aGregorianCalendar.getTimeInMillis ();
}
}