mirror of
https://github.com/ceph/ceph-csi.git
synced 2025-01-01 17:55:32 +00:00
1fcd1ed7c7
The CephFS Admin package has been made available with go-ceph v0.6. This will be used for provisioning and managing CephFS volumes. Signed-off-by: Niels de Vos <ndevos@redhat.com>
40 lines
876 B
Go
40 lines
876 B
Go
// +build !luminous,!mimic
|
|
|
|
package admin
|
|
|
|
import (
|
|
"encoding/json"
|
|
"time"
|
|
)
|
|
|
|
// golang's date parsing approach is rather bizarre
|
|
var cephTSLayout = "2006-01-02 15:04:05"
|
|
|
|
// TimeStamp abstracts some of the details about date+time stamps
|
|
// returned by ceph via JSON.
|
|
type TimeStamp struct {
|
|
time.Time
|
|
}
|
|
|
|
// String returns a string representing the date+time as presented
|
|
// by ceph.
|
|
func (ts TimeStamp) String() string {
|
|
return ts.Format(cephTSLayout)
|
|
}
|
|
|
|
// UnmarshalJSON implements the json Unmarshaler interface.
|
|
func (ts *TimeStamp) UnmarshalJSON(b []byte) error {
|
|
var raw string
|
|
if err := json.Unmarshal(b, &raw); err != nil {
|
|
return err
|
|
}
|
|
// AFAICT, ceph always returns the time in UTC so Parse, as opposed to
|
|
// ParseInLocation, is appropriate here.
|
|
t, err := time.Parse(cephTSLayout, raw)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
*ts = TimeStamp{t}
|
|
return nil
|
|
}
|