{-# LANGUAGE OverloadedStrings #-}
module Network.AWS.Data.JSON
    (
    
      FromJSON (..)
    , parseJSONText
    , eitherDecode
    , eitherDecode'
    
    , withObject
    , (.:)
    , (.:?)
    , (.!=)
    
    , eitherParseJSON
    , (.:>)
    , (.?>)
    
    , ToJSON   (..)
    , toJSONText
    , Value    (Object)
    , object
    , (.=)
    ) where
import           Data.Aeson            (eitherDecode, eitherDecode')
import           Data.Aeson.Types
import qualified Data.HashMap.Strict   as Map
import           Network.AWS.Data.Text
parseJSONText :: FromText a => String -> Value -> Parser a
parseJSONText n = withText n (either fail return . fromText)
toJSONText :: ToText a => a -> Value
toJSONText = String . toText
eitherParseJSON :: FromJSON a => Object -> Either String a
eitherParseJSON = parseEither parseJSON . Object
(.:>) :: FromJSON a => Object -> Text -> Either String a
(.:>) o k =
    case Map.lookup k o of
        Nothing -> Left $ "key " ++ show k ++ " not present"
        Just v  -> parseEither parseJSON v
(.?>) :: FromJSON a => Object -> Text -> Either String (Maybe a)
(.?>) o k =
    case Map.lookup k o of
        Nothing -> Right Nothing
        Just v  -> parseEither parseJSON v