2015-04-14 04:36:12 +00:00
|
|
|
package timeutils
|
|
|
|
|
|
|
|
import (
|
|
|
|
"strconv"
|
2015-05-13 16:27:00 +00:00
|
|
|
"strings"
|
2015-04-14 04:36:12 +00:00
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2015-05-12 19:59:34 +00:00
|
|
|
// GetTimestamp tries to parse given string as golang duration,
|
|
|
|
// then RFC3339 time and finally as a Unix timestamp. If
|
|
|
|
// any of these were successful, it returns a Unix timestamp
|
|
|
|
// as string otherwise returns the given value back.
|
|
|
|
// In case of duration input, the returned timestamp is computed
|
|
|
|
// as the given reference time minus the amount of the duration.
|
|
|
|
func GetTimestamp(value string, reference time.Time) string {
|
|
|
|
if d, err := time.ParseDuration(value); value != "0" && err == nil {
|
|
|
|
return strconv.FormatInt(reference.Add(-d).Unix(), 10)
|
|
|
|
}
|
|
|
|
|
2015-05-13 16:27:00 +00:00
|
|
|
var format string
|
|
|
|
if strings.Contains(value, ".") {
|
|
|
|
format = time.RFC3339Nano
|
|
|
|
} else {
|
|
|
|
format = time.RFC3339
|
|
|
|
}
|
|
|
|
|
2015-04-14 04:36:12 +00:00
|
|
|
loc := time.FixedZone(time.Now().Zone())
|
|
|
|
if len(value) < len(format) {
|
|
|
|
format = format[:len(value)]
|
|
|
|
}
|
|
|
|
t, err := time.ParseInLocation(format, value, loc)
|
|
|
|
if err != nil {
|
|
|
|
return value
|
|
|
|
}
|
|
|
|
return strconv.FormatInt(t.Unix(), 10)
|
|
|
|
}
|