2019-05-22 23:16:55 +02:00
|
|
|
package storage
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2022-06-30 17:17:07 +02:00
|
|
|
func dateToString(date uint64) string {
|
|
|
|
if date == 0 {
|
|
|
|
return "1970-01-01"
|
|
|
|
}
|
|
|
|
t := time.Unix(int64(date*24*3600), 0).UTC()
|
|
|
|
return t.Format("2006-01-02")
|
|
|
|
}
|
|
|
|
|
2019-05-22 23:16:55 +02:00
|
|
|
// timestampToTime returns time representation of the given timestamp.
|
|
|
|
//
|
|
|
|
// The returned time is in UTC timezone.
|
|
|
|
func timestampToTime(timestamp int64) time.Time {
|
|
|
|
return time.Unix(timestamp/1e3, (timestamp%1e3)*1e6).UTC()
|
|
|
|
}
|
|
|
|
|
|
|
|
// timestampFromTime returns timestamp value for the given time.
|
|
|
|
func timestampFromTime(t time.Time) int64 {
|
|
|
|
// There is no need in converting t to UTC, since UnixNano must
|
|
|
|
// return the same value for any timezone.
|
|
|
|
return t.UnixNano() / 1e6
|
|
|
|
}
|
|
|
|
|
|
|
|
// TimeRange is time range.
|
|
|
|
type TimeRange struct {
|
|
|
|
MinTimestamp int64
|
|
|
|
MaxTimestamp int64
|
|
|
|
}
|
|
|
|
|
|
|
|
func (tr *TimeRange) String() string {
|
2022-06-27 12:32:47 +02:00
|
|
|
start := TimestampToHumanReadableFormat(tr.MinTimestamp)
|
|
|
|
end := TimestampToHumanReadableFormat(tr.MaxTimestamp)
|
|
|
|
return fmt.Sprintf("[%s..%s]", start, end)
|
|
|
|
}
|
|
|
|
|
|
|
|
// TimestampToHumanReadableFormat converts the given timestamp to human-readable format.
|
|
|
|
func TimestampToHumanReadableFormat(timestamp int64) string {
|
|
|
|
t := timestampToTime(timestamp).UTC()
|
|
|
|
return t.Format("2006-01-02T15:04:05.999Z")
|
2019-05-22 23:16:55 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// timestampToPartitionName returns partition name for the given timestamp.
|
|
|
|
func timestampToPartitionName(timestamp int64) string {
|
|
|
|
t := timestampToTime(timestamp)
|
|
|
|
return t.Format("2006_01")
|
|
|
|
}
|
|
|
|
|
|
|
|
// fromPartitionName initializes tr from the given parition name.
|
|
|
|
func (tr *TimeRange) fromPartitionName(name string) error {
|
|
|
|
t, err := time.Parse("2006_01", name)
|
|
|
|
if err != nil {
|
2020-06-30 21:58:18 +02:00
|
|
|
return fmt.Errorf("cannot parse partition name %q: %w", name, err)
|
2019-05-22 23:16:55 +02:00
|
|
|
}
|
|
|
|
tr.fromPartitionTime(t)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// fromPartitionTimestamp initializes tr from the given partition timestamp.
|
|
|
|
func (tr *TimeRange) fromPartitionTimestamp(timestamp int64) {
|
|
|
|
t := timestampToTime(timestamp)
|
|
|
|
tr.fromPartitionTime(t)
|
|
|
|
}
|
|
|
|
|
|
|
|
// fromPartitionTime initializes tr from the given partition time t.
|
|
|
|
func (tr *TimeRange) fromPartitionTime(t time.Time) {
|
|
|
|
y, m, _ := t.UTC().Date()
|
|
|
|
minTime := time.Date(y, m, 1, 0, 0, 0, 0, time.UTC)
|
|
|
|
maxTime := time.Date(y, m+1, 1, 0, 0, 0, 0, time.UTC)
|
|
|
|
tr.MinTimestamp = minTime.Unix() * 1e3
|
|
|
|
tr.MaxTimestamp = maxTime.Unix()*1e3 - 1
|
|
|
|
}
|
|
|
|
|
|
|
|
const msecPerDay = 24 * 3600 * 1000
|
2019-06-09 18:06:53 +02:00
|
|
|
|
|
|
|
const msecPerHour = 3600 * 1000
|