{-# LANGUAGE OverloadedStrings #-}
module EasyLogger.Date
    ( FormattedTime
    , TimeFormat
    , newTimeCache
    , simpleTimeFormat
    , simpleTimeFormat'
    ) where
import           Control.AutoUpdate       (defaultUpdateSettings, mkAutoUpdate,
                                           updateAction)
import           Data.ByteString
import           Data.UnixTime            (formatUnixTime, fromEpochTime)
import           System.PosixCompat.Time  (epochTime)
import           System.PosixCompat.Types (EpochTime)
type FormattedTime = ByteString
type TimeFormat = ByteString
getTime :: IO EpochTime
getTime :: IO EpochTime
getTime = IO EpochTime
epochTime
formatDate :: TimeFormat -> EpochTime -> IO FormattedTime
formatDate :: TimeFormat -> EpochTime -> IO TimeFormat
formatDate TimeFormat
fmt = TimeFormat -> UnixTime -> IO TimeFormat
formatUnixTime TimeFormat
fmt (UnixTime -> IO TimeFormat)
-> (EpochTime -> UnixTime) -> EpochTime -> IO TimeFormat
forall b c a. (b -> c) -> (a -> b) -> a -> c
. EpochTime -> UnixTime
fromEpochTime
newTimeCache :: TimeFormat -> IO (IO FormattedTime)
newTimeCache :: TimeFormat -> IO (IO TimeFormat)
newTimeCache TimeFormat
fmt = UpdateSettings TimeFormat -> IO (IO TimeFormat)
forall a. UpdateSettings a -> IO (IO a)
mkAutoUpdate UpdateSettings ()
defaultUpdateSettings {updateAction :: IO TimeFormat
updateAction = IO EpochTime
getTime IO EpochTime -> (EpochTime -> IO TimeFormat) -> IO TimeFormat
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= TimeFormat -> EpochTime -> IO TimeFormat
formatDate TimeFormat
fmt}
simpleTimeFormat :: TimeFormat
simpleTimeFormat :: TimeFormat
simpleTimeFormat = TimeFormat
"%d/%b/%Y:%T %z"
simpleTimeFormat' :: TimeFormat
simpleTimeFormat' :: TimeFormat
simpleTimeFormat' = TimeFormat
"%d-%b-%Y %T"