
org.hawkular.metrics.tasks.DateTimeService Maven / Gradle / Ivy
The newest version!
/*
* Copyright 2014-2015 Red Hat, Inc. and/or its affiliates
* and other contributors as indicated by the @author tags.
*
* 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.hawkular.metrics.tasks;
import static org.joda.time.DateTime.now;
import org.joda.time.DateTime;
import org.joda.time.DateTimeZone;
import org.joda.time.Days;
import org.joda.time.Duration;
import org.joda.time.Hours;
import org.joda.time.Period;
/**
* @author jsanda
*/
public class DateTimeService {
static {
// Force the timezone to UTC to avoid any problems due to transitions from DST to non-DST
DateTimeZone.setDefault(DateTimeZone.UTC);
}
/**
* @return A DateTime object rounded down to the start of the current hour. For example, if the current time is
* 17:21:09, then 17:00:00 is returned.
*/
public DateTime currentHour() {
return getTimeSlice(now(), Hours.ONE.toStandardDuration());
}
/**
* The 24 hour time slices are fix - 00:00 to 24:00. This method determines the 24 hour time slice based on
* {@link #currentHour()} and returns the start of the time slice.
*
* @return A DateTime object rounded down to the start of the current 24 hour time slice.
*/
public DateTime current24HourTimeSlice() {
return get24HourTimeSlice(currentHour());
}
/**
* This method determines the 24 hour time slice for the specified time and returns the start of that time slice.
*
* @param time The DateTime to be rounded down
* @return A DateTime rounded down to the start of the 24 hour time slice in which the time parameter falls.
* @see #current24HourTimeSlice()
*/
public DateTime get24HourTimeSlice(DateTime time) {
return getTimeSlice(time, Days.ONE.toStandardDuration());
}
public DateTime getTimeSlice(DateTime dt, Duration duration) {
Period p = duration.toPeriod();
if (p.getYears() != 0) {
return dt.yearOfEra().roundFloorCopy().minusYears(dt.getYearOfEra() % p.getYears());
} else if (p.getMonths() != 0) {
return dt.monthOfYear().roundFloorCopy().minusMonths((dt.getMonthOfYear() - 1) % p.getMonths());
} else if (p.getWeeks() != 0) {
return dt.weekOfWeekyear().roundFloorCopy().minusWeeks((dt.getWeekOfWeekyear() - 1) % p.getWeeks());
} else if (p.getDays() != 0) {
return dt.dayOfMonth().roundFloorCopy().minusDays((dt.getDayOfMonth() - 1) % p.getDays());
} else if (p.getHours() != 0) {
return dt.hourOfDay().roundFloorCopy().minusHours(dt.getHourOfDay() % p.getHours());
} else if (p.getMinutes() != 0) {
return dt.minuteOfHour().roundFloorCopy().minusMinutes(dt.getMinuteOfHour() % p.getMinutes());
} else if (p.getSeconds() != 0) {
return dt.secondOfMinute().roundFloorCopy().minusSeconds(dt.getSecondOfMinute() % p.getSeconds());
}
return dt.millisOfSecond().roundCeilingCopy().minusMillis(dt.getMillisOfSecond() % p.getMillis());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy