module Database.Cayley.Types where
import qualified Data.Aeson as A
import Control.Applicative
import Control.Monad
import qualified Data.Text as T
import Network.HTTP.Client (Manager)
data CayleyConfig = CayleyConfig
{ serverPort :: Int
, serverName :: String
, apiVersion :: String
, queryLang :: String
} deriving (Eq,Show)
defaultCayleyConfig = CayleyConfig
{ serverPort = 64210
, serverName = "localhost"
, apiVersion = "1"
, queryLang = "gremlin"
}
data CayleyConnection = CayleyConnection (CayleyConfig,Manager)
data Quad = Quad
{ subject :: T.Text
, predicate :: T.Text
, object :: T.Text
, label :: Maybe T.Text
} deriving (Eq,Show)
instance A.ToJSON Quad where
toJSON (Quad subject predicate object label) =
A.object [ "subject" A..= subject
, "predicate" A..= predicate
, "object" A..= object
, "label" A..= label
]
instance A.FromJSON Quad where
parseJSON (A.Object v) = Quad <$>
v A..: "subject" <*>
v A..: "predicate" <*>
v A..: "object" <*>
v A..: "label"
parseJSON _ = mzero