2022-02-08 09:37:28 +01:00
|
|
|
package domain
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
2022-04-27 01:01:45 +02:00
|
|
|
"github.com/zitadel/zitadel/internal/errors"
|
2022-02-08 09:37:28 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
//most of us won't survive until 12-31-9999 23:59:59, maybe ZITADEL does
|
|
|
|
defaultExpDate = time.Date(9999, time.December, 31, 23, 59, 59, 0, time.UTC)
|
|
|
|
)
|
|
|
|
|
|
|
|
type expiration interface {
|
2022-10-24 16:04:52 +02:00
|
|
|
GetExpirationDate() time.Time
|
|
|
|
SetExpirationDate(time.Time)
|
2022-02-08 09:37:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func EnsureValidExpirationDate(key expiration) error {
|
2022-10-24 16:04:52 +02:00
|
|
|
date, err := ValidateExpirationDate(key.GetExpirationDate())
|
2022-02-08 09:37:28 +01:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2022-10-24 16:04:52 +02:00
|
|
|
key.SetExpirationDate(date)
|
2022-02-08 09:37:28 +01:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func ValidateExpirationDate(date time.Time) (time.Time, error) {
|
|
|
|
if date.IsZero() {
|
|
|
|
return defaultExpDate, nil
|
|
|
|
}
|
|
|
|
if date.Before(time.Now()) {
|
|
|
|
return time.Time{}, errors.ThrowInvalidArgument(nil, "DOMAIN-dv3t5", "Errors.AuthNKey.ExpireBeforeNow")
|
|
|
|
}
|
|
|
|
return date, nil
|
|
|
|
}
|