51 lines
963 B
Go
51 lines
963 B
Go
// Copyright (C) 2019 Storj Labs, Inc.
|
|
// See LICENSE for copying information.
|
|
|
|
package dbutil
|
|
|
|
import (
|
|
"database/sql/driver"
|
|
"time"
|
|
)
|
|
|
|
const (
|
|
sqliteTimeLayout = "2006-01-02 15:04:05-07:00"
|
|
)
|
|
|
|
// NullTime time helps convert nil to time.Time
|
|
type NullTime struct {
|
|
time.Time
|
|
Valid bool
|
|
}
|
|
|
|
// Scan implements the Scanner interface.
|
|
func (nt *NullTime) Scan(value interface{}) error {
|
|
// check if it's time.Time which is what postgres returns
|
|
// for lagged time values
|
|
if nt.Time, nt.Valid = value.(time.Time); nt.Valid {
|
|
return nil
|
|
}
|
|
|
|
// try to parse time from bytes which is what sqlite returns
|
|
date, ok := value.([]byte)
|
|
if !ok {
|
|
return nil
|
|
}
|
|
|
|
times, err := time.Parse(sqliteTimeLayout, string(date))
|
|
if err != nil {
|
|
return nil
|
|
}
|
|
|
|
nt.Time, nt.Valid = times, true
|
|
return nil
|
|
}
|
|
|
|
// Value implements the driver Valuer interface.
|
|
func (nt NullTime) Value() (driver.Value, error) {
|
|
if !nt.Valid {
|
|
return nil, nil
|
|
}
|
|
return nt.Time, nil
|
|
}
|