Files
sqlite3/driver/time.go

32 lines
850 B
Go
Raw Permalink Normal View History

2023-02-17 10:40:43 +00:00
package driver
import (
"database/sql/driver"
"time"
)
// Convert a string in [time.RFC3339Nano] format into a [time.Time]
// if it roundtrips back to the same string.
// This way times can be persisted to, and recovered from, the database,
2023-02-22 17:51:30 +00:00
// but if a string is needed, [database/sql] will recover the same string.
2023-04-18 01:00:59 +01:00
func stringOrTime(text []byte) driver.Value {
// Weed out (some) values that can't possibly be
// [time.RFC3339Nano] timestamps.
2023-02-20 13:30:01 +00:00
if len(text) < len("2006-01-02T15:04:05Z") {
2023-04-18 01:00:59 +01:00
return string(text)
}
2023-02-20 13:30:01 +00:00
if len(text) > len(time.RFC3339Nano) {
2023-04-18 01:00:59 +01:00
return string(text)
}
2023-02-20 13:30:01 +00:00
if text[4] != '-' || text[10] != 'T' || text[16] != ':' {
2023-04-18 01:00:59 +01:00
return string(text)
}
// Slow path.
2023-04-18 01:00:59 +01:00
date, err := time.Parse(time.RFC3339Nano, string(text))
if err == nil && date.Format(time.RFC3339Nano) == string(text) {
2023-02-17 10:40:43 +00:00
return date
}
2023-04-18 01:00:59 +01:00
return string(text)
2023-02-17 10:40:43 +00:00
}