2017-12-10 23:37:04 -05:00
|
|
|
// Copyright 2017 The Gitea Authors. All rights reserved.
|
2022-11-27 13:20:29 -05:00
|
|
|
// SPDX-License-Identifier: MIT
|
2017-12-10 23:37:04 -05:00
|
|
|
|
2019-08-15 10:46:21 -04:00
|
|
|
package timeutil
|
2017-12-10 23:37:04 -05:00
|
|
|
|
2017-12-13 18:45:31 -05:00
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"code.gitea.io/gitea/modules/setting"
|
|
|
|
)
|
2017-12-10 23:37:04 -05:00
|
|
|
|
|
|
|
// TimeStamp defines a timestamp
|
|
|
|
type TimeStamp int64
|
|
|
|
|
2022-12-19 21:04:55 -05:00
|
|
|
var (
|
2023-12-28 05:09:57 -05:00
|
|
|
// mockNow is NOT concurrency-safe!!
|
|
|
|
mockNow time.Time
|
2022-12-19 21:04:55 -05:00
|
|
|
|
|
|
|
// Used for IsZero, to check if timestamp is the zero time instant.
|
|
|
|
timeZeroUnix = time.Time{}.Unix()
|
|
|
|
)
|
2021-10-18 16:12:26 -04:00
|
|
|
|
2023-12-28 05:09:57 -05:00
|
|
|
// MockSet sets the time to a mocked time.Time
|
2024-04-02 22:47:06 -04:00
|
|
|
func MockSet(now time.Time) func() {
|
2023-12-28 05:09:57 -05:00
|
|
|
mockNow = now
|
2024-04-02 22:47:06 -04:00
|
|
|
return MockUnset
|
2021-10-18 16:12:26 -04:00
|
|
|
}
|
|
|
|
|
2023-12-28 05:09:57 -05:00
|
|
|
// MockUnset will unset the mocked time.Time
|
|
|
|
func MockUnset() {
|
|
|
|
mockNow = time.Time{}
|
2021-10-18 16:12:26 -04:00
|
|
|
}
|
|
|
|
|
2017-12-10 23:37:04 -05:00
|
|
|
// TimeStampNow returns now int64
|
|
|
|
func TimeStampNow() TimeStamp {
|
2023-12-28 05:09:57 -05:00
|
|
|
if !mockNow.IsZero() {
|
|
|
|
return TimeStamp(mockNow.Unix())
|
2021-10-18 16:12:26 -04:00
|
|
|
}
|
2017-12-10 23:37:04 -05:00
|
|
|
return TimeStamp(time.Now().Unix())
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add adds seconds and return sum
|
|
|
|
func (ts TimeStamp) Add(seconds int64) TimeStamp {
|
|
|
|
return ts + TimeStamp(seconds)
|
|
|
|
}
|
|
|
|
|
|
|
|
// AddDuration adds time.Duration and return sum
|
|
|
|
func (ts TimeStamp) AddDuration(interval time.Duration) TimeStamp {
|
|
|
|
return ts + TimeStamp(interval/time.Second)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Year returns the time's year
|
|
|
|
func (ts TimeStamp) Year() int {
|
|
|
|
return ts.AsTime().Year()
|
|
|
|
}
|
|
|
|
|
|
|
|
// AsTime convert timestamp as time.Time in Local locale
|
|
|
|
func (ts TimeStamp) AsTime() (tm time.Time) {
|
2019-08-15 10:46:21 -04:00
|
|
|
return ts.AsTimeInLocation(setting.DefaultUILocation)
|
|
|
|
}
|
|
|
|
|
2022-08-25 12:05:21 -04:00
|
|
|
// AsLocalTime convert timestamp as time.Time in local location
|
|
|
|
func (ts TimeStamp) AsLocalTime() time.Time {
|
|
|
|
return time.Unix(int64(ts), 0)
|
|
|
|
}
|
|
|
|
|
2019-08-15 10:46:21 -04:00
|
|
|
// AsTimeInLocation convert timestamp as time.Time in Local locale
|
2023-04-10 19:01:20 -04:00
|
|
|
func (ts TimeStamp) AsTimeInLocation(loc *time.Location) time.Time {
|
|
|
|
return time.Unix(int64(ts), 0).In(loc)
|
2017-12-10 23:37:04 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// AsTimePtr convert timestamp as *time.Time in Local locale
|
|
|
|
func (ts TimeStamp) AsTimePtr() *time.Time {
|
2019-08-15 10:46:21 -04:00
|
|
|
return ts.AsTimePtrInLocation(setting.DefaultUILocation)
|
|
|
|
}
|
|
|
|
|
|
|
|
// AsTimePtrInLocation convert timestamp as *time.Time in customize location
|
|
|
|
func (ts TimeStamp) AsTimePtrInLocation(loc *time.Location) *time.Time {
|
|
|
|
tm := time.Unix(int64(ts), 0).In(loc)
|
2017-12-10 23:37:04 -05:00
|
|
|
return &tm
|
|
|
|
}
|
|
|
|
|
2019-08-15 10:46:21 -04:00
|
|
|
// Format formats timestamp as given format
|
2017-12-10 23:37:04 -05:00
|
|
|
func (ts TimeStamp) Format(f string) string {
|
2019-08-15 10:46:21 -04:00
|
|
|
return ts.FormatInLocation(f, setting.DefaultUILocation)
|
|
|
|
}
|
|
|
|
|
|
|
|
// FormatInLocation formats timestamp as given format with spiecific location
|
|
|
|
func (ts TimeStamp) FormatInLocation(f string, loc *time.Location) string {
|
|
|
|
return ts.AsTimeInLocation(loc).Format(f)
|
2017-12-10 23:37:04 -05:00
|
|
|
}
|
|
|
|
|
2023-12-28 05:09:57 -05:00
|
|
|
// FormatDate formats a date in YYYY-MM-DD
|
2020-06-05 18:51:10 -04:00
|
|
|
func (ts TimeStamp) FormatDate() string {
|
2023-12-28 05:09:57 -05:00
|
|
|
return ts.Format("2006-01-02")
|
2020-06-05 18:51:10 -04:00
|
|
|
}
|
|
|
|
|
2018-02-26 05:25:45 -05:00
|
|
|
// IsZero is zero time
|
|
|
|
func (ts TimeStamp) IsZero() bool {
|
2022-12-19 21:04:55 -05:00
|
|
|
return int64(ts) == 0 || int64(ts) == timeZeroUnix
|
2018-02-26 05:25:45 -05:00
|
|
|
}
|