Skip to content

Commit

Permalink
Add jsontime nanosecond and string helpers
Browse files Browse the repository at this point in the history
  • Loading branch information
tulir committed Oct 13, 2023
1 parent 0b54c80 commit 1cfbf11
Show file tree
Hide file tree
Showing 3 changed files with 183 additions and 58 deletions.
59 changes: 59 additions & 0 deletions jsontime/helpers.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
// Copyright (c) 2023 Tulir Asokan
//
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.

package jsontime

import (
"time"
)

func UM(time time.Time) UnixMilli {
return UnixMilli{Time: time}
}

func UMInt(ts int64) UnixMilli {
return UM(time.UnixMilli(ts))
}

func UnixMilliNow() UnixMilli {
return UM(time.Now())
}

func UMicro(time time.Time) UnixMicro {
return UnixMicro{Time: time}
}

func UMicroInto(ts int64) UnixMicro {
return UMicro(time.UnixMicro(ts))
}

func UnixMicroNow() UnixMicro {
return UMicro(time.Now())
}

func UN(time time.Time) UnixNano {
return UnixNano{Time: time}
}

func UNInt(ts int64) UnixNano {
return UN(time.Unix(0, ts))
}

func UnixNanoNow() UnixNano {
return UN(time.Now())
}

func U(time time.Time) Unix {
return Unix{Time: time}
}

func UInt(ts int64) Unix {
return U(time.Unix(ts, 0))
}

func UnixNow() Unix {
return U(time.Now())
}
87 changes: 29 additions & 58 deletions jsontime/jsontime.go → jsontime/integer.go
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
// Copyright (c) 2022 Tulir Asokan
// Copyright (c) 2023 Tulir Asokan
//
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
Expand All @@ -11,16 +11,18 @@ import (
"time"
)

func UM(time time.Time) UnixMilli {
return UnixMilli{Time: time}
}

func UMInt(ts int64) UnixMilli {
return UM(time.UnixMilli(ts))
}

func UnixMilliNow() UnixMilli {
return UM(time.Now())
func parseTime(data []byte, unixConv func(int64) time.Time, into *time.Time) error {
var val int64
err := json.Unmarshal(data, &val)
if err != nil {
return nil
}
if val == 0 {
*into = time.Time{}
} else {
*into = unixConv(val)
}
return nil
}

type UnixMilli struct {
Expand All @@ -35,25 +37,7 @@ func (um UnixMilli) MarshalJSON() ([]byte, error) {
}

func (um *UnixMilli) UnmarshalJSON(data []byte) error {
var val int64
err := json.Unmarshal(data, &val)
if err != nil {
return err
}
if val == 0 {
um.Time = time.Time{}
} else {
um.Time = time.UnixMilli(val)
}
return nil
}

func UMicro(time time.Time) UnixMicro {
return UnixMicro{Time: time}
}

func UnixMicroNow() UnixMicro {
return UMicro(time.Now())
return parseTime(data, time.UnixMilli, &um.Time)
}

type UnixMicro struct {
Expand All @@ -68,29 +52,24 @@ func (um UnixMicro) MarshalJSON() ([]byte, error) {
}

func (um *UnixMicro) UnmarshalJSON(data []byte) error {
var val int64
err := json.Unmarshal(data, &val)
if err != nil {
return err
}
if val == 0 {
um.Time = time.Time{}
} else {
um.Time = time.UnixMicro(val)
}
return nil
return parseTime(data, time.UnixMicro, &um.Time)
}

func U(time time.Time) Unix {
return Unix{Time: time}
type UnixNano struct {
time.Time
}

func UInt(ts int64) Unix {
return U(time.Unix(ts, 0))
func (un UnixNano) MarshalJSON() ([]byte, error) {
if un.IsZero() {
return []byte{'0'}, nil
}
return json.Marshal(un.UnixNano())
}

func UnixNow() Unix {
return U(time.Now())
func (un *UnixNano) UnmarshalJSON(data []byte) error {
return parseTime(data, func(i int64) time.Time {
return time.Unix(0, i)
}, &un.Time)
}

type Unix struct {
Expand All @@ -105,15 +84,7 @@ func (u Unix) MarshalJSON() ([]byte, error) {
}

func (u *Unix) UnmarshalJSON(data []byte) error {
var val int64
err := json.Unmarshal(data, &val)
if err != nil {
return err
}
if val == 0 {
u.Time = time.Time{}
} else {
u.Time = time.Unix(val, 0)
}
return nil
return parseTime(data, func(i int64) time.Time {
return time.Unix(i, 0)
}, &u.Time)
}
95 changes: 95 additions & 0 deletions jsontime/string.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,95 @@
// Copyright (c) 2023 Tulir Asokan
//
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.

package jsontime

import (
"encoding/json"
"strconv"
"time"
)

func parseTimeString(data []byte, unixConv func(int64) time.Time, into *time.Time) error {
var strVal string
err := json.Unmarshal(data, &strVal)
if err != nil {
return nil
}
val, err := strconv.ParseInt(strVal, 10, 64)
if err != nil {
return err
}
if val == 0 {
*into = time.Time{}
} else {
*into = unixConv(val)
}
return nil
}

type UnixMilliString struct {
time.Time
}

func (um UnixMilliString) MarshalJSON() ([]byte, error) {
if um.IsZero() {
return []byte{'"', '0', '"'}, nil
}
return json.Marshal(strconv.FormatInt(um.UnixMilli(), 10))
}

func (um *UnixMilliString) UnmarshalJSON(data []byte) error {
return parseTimeString(data, time.UnixMilli, &um.Time)
}

type UnixMicroString struct {
time.Time
}

func (um UnixMicroString) MarshalJSON() ([]byte, error) {
if um.IsZero() {
return []byte{'"', '0', '"'}, nil
}
return json.Marshal(strconv.FormatInt(um.UnixMilli(), 10))
}

func (um *UnixMicroString) UnmarshalJSON(data []byte) error {
return parseTimeString(data, time.UnixMicro, &um.Time)
}

type UnixNanoString struct {
time.Time
}

func (um UnixNanoString) MarshalJSON() ([]byte, error) {
if um.IsZero() {
return []byte{'"', '0', '"'}, nil
}
return json.Marshal(um.UnixNano())
}

func (um *UnixNanoString) UnmarshalJSON(data []byte) error {
return parseTimeString(data, func(i int64) time.Time {
return time.Unix(0, i)
}, &um.Time)
}

type UnixString struct {
time.Time
}

func (u UnixString) MarshalJSON() ([]byte, error) {
if u.IsZero() {
return []byte{'"', '0', '"'}, nil
}
return json.Marshal(u.Unix())
}

func (u *UnixString) UnmarshalJSON(data []byte) error {
return parseTime(data, func(i int64) time.Time {
return time.Unix(i, 0)
}, &u.Time)
}

0 comments on commit 1cfbf11

Please sign in to comment.