summaryrefslogtreecommitdiff
path: root/internal/id/ulid.go
diff options
context:
space:
mode:
Diffstat (limited to 'internal/id/ulid.go')
-rw-r--r--internal/id/ulid.go20
1 files changed, 14 insertions, 6 deletions
diff --git a/internal/id/ulid.go b/internal/id/ulid.go
index 8de4cc4cc..8c0b1e94c 100644
--- a/internal/id/ulid.go
+++ b/internal/id/ulid.go
@@ -22,7 +22,9 @@ import (
"math/big"
"time"
+ "codeberg.org/gruf/go-kv"
"github.com/oklog/ulid"
+ "github.com/superseriousbusiness/gotosocial/internal/log"
)
const (
@@ -45,13 +47,19 @@ func NewULID() string {
return ulid.String()
}
-// NewULIDFromTime returns a new ULID string using the given time, or an error if something goes wrong.
-func NewULIDFromTime(t time.Time) (string, error) {
- newUlid, err := ulid.New(ulid.Timestamp(t), rand.Reader)
- if err != nil {
- return "", err
+// NewULIDFromTime returns a new ULID string using
+// given time, or from current time on any error.
+func NewULIDFromTime(t time.Time) string {
+ ts := ulid.Timestamp(t)
+ if ts > ulid.MaxTime() {
+ log.WarnKVs(nil, kv.Fields{
+ {K: "caller", V: log.Caller(2)},
+ {K: "value", V: t},
+ {K: "msg", V: "invalid ulid time"},
+ }...)
+ ts = ulid.Now()
}
- return newUlid.String(), nil
+ return ulid.MustNew(ts, rand.Reader).String()
}
// NewRandomULID returns a new ULID string using a random time in an ~80 year range around the current datetime, or an error if something goes wrong.