mirror of
https://github.com/hasura/graphql-engine.git
synced 2024-12-17 04:24:35 +03:00
11a454c2d6
This commit applies ormolu to the whole Haskell code base by running `make format`. For in-flight branches, simply merging changes from `main` will result in merge conflicts. To avoid this, update your branch using the following instructions. Replace `<format-commit>` by the hash of *this* commit. $ git checkout my-feature-branch $ git merge <format-commit>^ # and resolve conflicts normally $ make format $ git commit -a -m "reformat with ormolu" $ git merge -s ours post-ormolu https://github.com/hasura/graphql-engine-mono/pull/2404 GitOrigin-RevId: 75049f5c12f430c615eafb4c6b8e83e371e01c8e
32 lines
858 B
Haskell
32 lines
858 B
Haskell
module Hasura.SQL.Time
|
|
( ZonedTimeOfDay (..),
|
|
)
|
|
where
|
|
|
|
import Data.Aeson.Types qualified as Aeson
|
|
import Data.Attoparsec.Text as A
|
|
import Data.Attoparsec.Time (timeOfDay, timeZone)
|
|
import Data.Time.LocalTime qualified as Local
|
|
import Hasura.Prelude
|
|
|
|
data ZonedTimeOfDay = ZonedTimeOfDay
|
|
{ ztodTime :: Local.TimeOfDay,
|
|
ztodZone :: Local.TimeZone
|
|
}
|
|
deriving (Show, Eq)
|
|
|
|
utc :: Local.TimeZone
|
|
utc = Local.TimeZone 0 False ""
|
|
|
|
zonedTimeOfDay :: Text -> Aeson.Parser ZonedTimeOfDay
|
|
zonedTimeOfDay t =
|
|
case A.parseOnly (p <* endOfInput) t of
|
|
Left err -> fail $ "could not parse timetz: " ++ err
|
|
Right r -> return r
|
|
where
|
|
p = ZonedTimeOfDay <$> timeOfDay <*> (fromMaybe utc <$> timeZone)
|
|
|
|
instance Aeson.FromJSON ZonedTimeOfDay where
|
|
parseJSON (Aeson.String t) = zonedTimeOfDay t
|
|
parseJSON _ = fail "Expecting a string for timetz"
|