module Data.Validity.Time.Clock where
import Data.Validity
import Data.Time.Clock
import Data.Validity.Time.Calendar ()
instance Validity UniversalTime where
isValid (ModJulianDate i) = isValid i
validate = validateByCheckingName "UniversalTime"
instance Validity DiffTime where
isValid = triviallyValid
validate = validateByCheckingName "DiffTime"
instance Validity UTCTime where
isValid UTCTime {..} =
and
[ isValid utctDay
, isValid utctDayTime
, utctDayTime >= 0
, utctDayTime < 86401
]
validate UTCTime {..} =
mconcat
[ utctDay <?!> "utctDay"
, utctDayTime <?!> "utctDayTime"
, utctDayTime >= 0 <?@> "The day time is positive."
, utctDayTime < 86401 <?@> "The day time is strictly less than 86401."
]
instance Validity NominalDiffTime
where
isValid = isValid . (round :: NominalDiffTime -> Integer)
validate = validateByCheckingName "NominalDiffTime"