-
Notifications
You must be signed in to change notification settings - Fork 26
/
Copy pathLog.hs
49 lines (37 loc) · 1.73 KB
/
Log.hs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
-- | Logging action for the project. Currently just logs the output to terminal.
module Lib.Effects.Log
( mainLogAction
, runAppAsHandler
, runAppLogIO
, runAppLogIO_
) where
import Colog (LogAction, Message, Msg (..), Severity, filterBySeverity, richMessageAction)
import Control.Monad.Except (liftEither)
import Servant.Server (Handler)
import Lib.App (App, AppEnv, AppError, runAppAsIO, toHttpError)
-- | Maing log action for the application. Prints message with some metadata to @stdout@.
mainLogAction :: MonadIO m => Severity -> LogAction m Message
mainLogAction severity =
filterBySeverity severity msgSeverity richMessageAction
----------------------------------------------------------------------------
-- Application runners with runners
----------------------------------------------------------------------------
-- | Runs application as servant 'Handler'.
runAppAsHandler :: AppEnv -> App a -> Handler a
runAppAsHandler env app = do
res <- liftIO $ runAppLogIO env app
liftEither $ first toHttpError res
-- | Runs application like 'runAppAsIO' but also logs error.
runAppLogIO :: AppEnv -> App a -> IO (Either AppError a)
runAppLogIO env app = do
appRes <- runAppAsIO env app
logRes <- whenLeft (Right ()) appRes (logMPErrorIO env)
pure $ appRes <* logRes
-- | Like 'runAppAsIO' but discards result.
runAppLogIO_ :: AppEnv -> App a -> IO ()
runAppLogIO_ env app = void $ runAppLogIO env app
----------------------------------------------------------------------------
-- Internal utilities
----------------------------------------------------------------------------
logMPErrorIO :: AppEnv -> AppError -> IO (Either AppError ())
logMPErrorIO env err = runAppAsIO env $ log E $ show err