
org.italiangrid.voms.util.TimeUtils Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of voms-api-java Show documentation
Show all versions of voms-api-java Show documentation
Java APIs to validate and request VOMS attribute certificates
The newest version!
/**
* Copyright (c) Istituto Nazionale di Fisica Nucleare, 2006-2014.
*
* 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 org.italiangrid.voms.util;
import static java.util.Objects.isNull;
import java.time.LocalDateTime;
import java.time.ZoneOffset;
import java.time.format.DateTimeFormatter;
import java.time.format.ResolverStyle;
import java.util.Calendar;
import java.util.Date;
/**
* Time utilities.
*
* @author cecco
*
*/
public class TimeUtils {
public static final DateTimeFormatter DATE_FORMATTER =
DateTimeFormatter.ISO_DATE_TIME.withResolverStyle(ResolverStyle.LENIENT);
private TimeUtils() {
}
/**
* Checks that a date falls in the interval allowing for a certain clock skew expressed in
* minutes. The interval defined by (startDate, endDate) is modified to be (startDate -
* skewInMinutes, endDate + skewInMinutes).
*
* @param timeToCheck the time to be checked
* @param startDate the start date of the time range
* @param endDate the end date of the time range
* @param skewInMinutes the clock skew in minutes to take into account
*
* @throws IllegalArgumentException if passed an illegal time range
* @return true
, if the time is in the given range, false
otherwise
*/
public static boolean checkTimeInRangeWithSkew(Date timeToCheck, Date startDate, Date endDate,
int skewInMinutes) {
if (startDate.after(endDate) || startDate.equals(endDate)) {
String msg = String.format(
"Illegal time interval: start date must be before end date. [start date: %s, end date: %s]",
startDate, endDate);
throw new IllegalArgumentException(msg);
}
Calendar cal = Calendar.getInstance();
cal.setTime(startDate);
cal.add(Calendar.MINUTE, -skewInMinutes);
Date skewedStartDate = cal.getTime();
cal.clear();
cal.setTime(endDate);
cal.add(Calendar.MINUTE, skewInMinutes);
Date skewedEndDate = cal.getTime();
return skewedEndDate.after(timeToCheck) && skewedStartDate.before(timeToCheck);
}
/**
* Parses a date from string
*
* @param date the date string representation;
* @return the parsed date
* @throws NullPointerException if date is null
* @throws java.time.format.DateTimeParseException if the date is in the wrong format
*/
public static Date parseDate(String date) {
if (isNull(date)) {
throw new NullPointerException("Cannot parse a null date");
}
LocalDateTime dateTime = LocalDateTime.parse(date, DATE_FORMATTER);
return Date.from(dateTime.atZone(ZoneOffset.UTC).toInstant());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy