module HNormalise.Json where
import Control.Monad
import Data.Aeson
import qualified Data.HashMap.Lazy as M
import Data.Monoid
import HNormalise.Internal
instance FromJSON Rsyslog where
parseJSON = withObject "Rsyslog" $ \v ->
Rsyslog <$>
(v .: "msg") <*>
(v .: "timereported") <*>
(v .: "hostname") <*>
(v .: "syslogtag") <*>
(v .: "inputname") <*>
(v .: "fromhost") <*>
(v .: "fromhost-ip") <*>
(v .: "pri") <*>
(v .: "version") <*>
(v .: "syslogfacility") <*>
(v .: "syslogseverity") <*>
(v .: "timegenerated") <*>
(v .: "programname") <*>
(v .: "protocol-version") <*>
(v .: "app-name") <*>
(v .: "procid")
instance ToJSON Rsyslog where
toEncoding = genericToEncoding defaultOptions
toJSON = genericToJSON defaultOptions
instance ToJSON NormalisedRsyslog where
toEncoding (NRsyslog r n k fs) =
case fs of
Nothing -> pairs
( "message" .= msg r
<> "syslog_abspri" .= pri r
<> "syslog_version" .= version r
<> "program" .= app_name r
<> "@source_host" .= hostname r
<> k .= n
)
Just fs' -> case toJSON r of
Object syslog -> pairs $ foldl (\v (key, fieldname) -> v <> key .= (M.lookupDefault Null fieldname syslog)) (k .= n) fs'
_ -> pairs (k .= n)