| Safe Haskell | None | 
|---|---|
| Language | Haskell2010 | 
System.FastLogger
- data Logger
- timestampedLogEntry :: ByteString -> IO ByteString
- combinedLogEntry :: ByteString -> Maybe ByteString -> ByteString -> Int -> Word64 -> Maybe ByteString -> ByteString -> IO ByteString
- newLogger :: FilePath -> IO Logger
- newLoggerWithCustomErrorFunction :: (ByteString -> IO ()) -> FilePath -> IO Logger
- withLogger :: FilePath -> (Logger -> IO a) -> IO a
- withLoggerWithCustomErrorFunction :: (ByteString -> IO ()) -> FilePath -> (Logger -> IO a) -> IO a
- stopLogger :: Logger -> IO ()
- logMsg :: Logger -> ByteString -> IO ()
Documentation
timestampedLogEntry :: ByteString -> IO ByteString Source #
Prepares a log message with the time prepended.
Arguments
| :: ByteString | remote host | 
| -> Maybe ByteString | remote user | 
| -> ByteString | request line (up to you to ensure there are no quotes in here) | 
| -> Int | status code | 
| -> Word64 | num bytes sent | 
| -> Maybe ByteString | referer (up to you to ensure there are no quotes in here) | 
| -> ByteString | user agent (up to you to ensure there are no quotes in here) | 
| -> IO ByteString | 
Prepares a log message in "combined" format.
Creates a new logger, logging to the given file. If the file argument is "-", then log to stdout; if it's "stderr" then we log to stderr, otherwise we log to a regular file in append mode. The file is closed and re-opened every 15 minutes to facilitate external log rotation.
newLoggerWithCustomErrorFunction Source #
Arguments
| :: (ByteString -> IO ()) | logger uses this action to log any error messages of its own | 
| -> FilePath | log file to use | 
| -> IO Logger | 
Like newLogger, but uses a custom error action if the logger needs to
 print an error message of its own (for instance, if it can't open the
 output file.)
Creates a Logger and passes it into the given function, cleaning up with "stopLogger" afterwards.
withLoggerWithCustomErrorFunction Source #
Arguments
| :: (ByteString -> IO ()) | logger uses this action to log any error messages of its own | 
| -> FilePath | log file to use | 
| -> (Logger -> IO a) | |
| -> IO a | 
Creates a Logger with "newLoggerWithCustomErrorFunction" and passes it into the given function, cleaning up with "stopLogger" afterwards.
stopLogger :: Logger -> IO () Source #
Kills a logger thread, causing any unwritten contents to be flushed out to disk
logMsg :: Logger -> ByteString -> IO () Source #
Sends out a log message verbatim with a newline appended. Note:
 if you want a fancy log message you'll have to format it yourself
 (or use combinedLogEntry).