{-# LANGUAGE OverloadedStrings #-}
module Database.CQL.IO.Protocol where
import Control.Exception (throw)
import Data.ByteString.Lazy (ByteString)
import Data.Maybe (fromMaybe)
import Data.Monoid ((<>))
import Database.CQL.Protocol
import Database.CQL.IO.Types
import qualified Data.Text.Lazy as LT
parse :: (Tuple a, Tuple b) => Compression -> (Header, ByteString) -> Response k a b
parse x (h, a) =
case unpack x h a of
Left e -> throw $ InternalError ("response body reading: " ++ e)
Right r -> r
serialise :: Tuple a => Version -> Compression -> Request k a b -> Int -> ByteString
serialise v f r i =
let c = case getOpCode r of
OcStartup -> noCompression
OcOptions -> noCompression
_ -> f
s = mkStreamId i
in either (throw $ InternalError "request creation") id (pack v c (isTracing r) s r)
where
isTracing :: Request k a b -> Bool
isTracing (RqQuery (Query _ p)) = fromMaybe False $ enableTracing p
isTracing (RqExecute (Execute _ p)) = fromMaybe False $ enableTracing p
isTracing _ = False
quoted :: LT.Text -> LT.Text
quoted s = "\"" <> LT.replace "\"" "\"\"" s <> "\""