{-# LANGUAGE GeneralizedNewtypeDeriving #-}
module Control.Monad.Logger.Extras where
import Control.Monad.Logger
import Data.ByteString.Unsafe (unsafeUseAsCStringLen)
import System.IO
import qualified System.Posix.Syslog as Posix
runLoggerLoggingT :: LoggingT m a -> Logger -> m a
runLoggerLoggingT f logger = f `runLoggingT` unLogger logger
type LogF = Loc -> LogSource -> LogLevel -> LogStr -> IO ()
newtype Logger = Logger { unLogger :: LogF }
deriving (Semigroup, Monoid)
logToStderr :: Logger
logToStderr = Logger $ defaultOutput stderr
logToStdout :: Logger
logToStdout = Logger $ defaultOutput stdout
logToNowhere :: Logger
logToNowhere = mempty
logToSyslog :: String -> Logger
logToSyslog tagstr = Logger $ \loc src lvl str -> do
let syslogPriority = case lvl of
LevelDebug -> Posix.Debug
LevelInfo -> Posix.Info
LevelWarn -> Posix.Warning
LevelError -> Posix.Error
LevelOther _ -> Posix.Info
out = defaultLogStr loc src lvl str
Posix.withSyslog tagstr [Posix.DelayedOpen] Posix.User $
unsafeUseAsCStringLen (fromLogStr out) $
Posix.syslog Nothing syslogPriority