{-# LANGUAGE DeriveDataTypeable #-} {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE OverloadedStrings #-} {-# OPTIONS_GHC -fno-warn-missing-fields #-} {-# OPTIONS_GHC -fno-warn-missing-signatures #-} {-# OPTIONS_GHC -fno-warn-name-shadowing #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} ----------------------------------------------------------------- -- Autogenerated by Thrift Compiler (0.10.0) -- -- -- -- DO NOT EDIT UNLESS YOU ARE SURE YOU KNOW WHAT YOU ARE DOING -- ----------------------------------------------------------------- module SearchService where import Prelude (($), (.), (>>=), (==), (++)) import qualified Prelude as P import qualified Control.Exception as X import qualified Control.Monad as M ( liftM, ap, when ) import Data.Functor ( (<$>) ) import qualified Data.ByteString.Lazy as LBS import qualified Data.Hashable as H import qualified Data.Int as I import qualified Data.Maybe as M (catMaybes) import qualified Data.Text.Lazy.Encoding as E ( decodeUtf8, encodeUtf8 ) import qualified Data.Text.Lazy as LT import qualified GHC.Generics as G (Generic) import qualified Data.Typeable as TY ( Typeable ) import qualified Data.HashMap.Strict as Map import qualified Data.HashSet as Set import qualified Data.Vector as Vector import qualified Test.QuickCheck.Arbitrary as QC ( Arbitrary(..) ) import qualified Test.QuickCheck as QC ( elements ) import qualified Thrift as T import qualified Thrift.Types as T import qualified Thrift.Arbitraries as T import qualified Communication_Types import qualified Services_Types import qualified Structure_Types import qualified Uuid_Types import qualified Metadata_Types import qualified Entities_Types import qualified Service import Search_Types import qualified SearchService_Iface as Iface -- HELPER FUNCTIONS AND STRUCTURES -- data Search_args = Search_args { search_args_query :: SearchQuery } deriving (P.Show,P.Eq,G.Generic,TY.Typeable) instance H.Hashable Search_args where hashWithSalt salt record = salt `H.hashWithSalt` search_args_query record instance QC.Arbitrary Search_args where arbitrary = M.liftM Search_args (QC.arbitrary) shrink obj | obj == default_Search_args = [] | P.otherwise = M.catMaybes [ if obj == default_Search_args{search_args_query = search_args_query obj} then P.Nothing else P.Just $ default_Search_args{search_args_query = search_args_query obj} ] from_Search_args :: Search_args -> T.ThriftVal from_Search_args record = T.TStruct $ Map.fromList $ M.catMaybes [ (\_v64 -> P.Just (1, ("query",from_SearchQuery _v64))) $ search_args_query record ] write_Search_args :: (T.Protocol p, T.Transport t) => p t -> Search_args -> P.IO () write_Search_args oprot record = T.writeVal oprot $ from_Search_args record encode_Search_args :: (T.Protocol p, T.Transport t) => p t -> Search_args -> LBS.ByteString encode_Search_args oprot record = T.serializeVal oprot $ from_Search_args record to_Search_args :: T.ThriftVal -> Search_args to_Search_args (T.TStruct fields) = Search_args{ search_args_query = P.maybe (search_args_query default_Search_args) (\(_,_val66) -> (case _val66 of {T.TStruct _val67 -> (to_SearchQuery (T.TStruct _val67)); _ -> P.error "wrong type"})) (Map.lookup (1) fields) } to_Search_args _ = P.error "not a struct" read_Search_args :: (T.Transport t, T.Protocol p) => p t -> P.IO Search_args read_Search_args iprot = to_Search_args <$> T.readVal iprot (T.T_STRUCT typemap_Search_args) decode_Search_args :: (T.Protocol p, T.Transport t) => p t -> LBS.ByteString -> Search_args decode_Search_args iprot bs = to_Search_args $ T.deserializeVal iprot (T.T_STRUCT typemap_Search_args) bs typemap_Search_args :: T.TypeMap typemap_Search_args = Map.fromList [(1,("query",(T.T_STRUCT typemap_SearchQuery)))] default_Search_args :: Search_args default_Search_args = Search_args{ search_args_query = default_SearchQuery} data Search_result = Search_result { search_result_success :: SearchResult , search_result_ex :: P.Maybe Services_Types.ServicesException } deriving (P.Show,P.Eq,G.Generic,TY.Typeable) instance H.Hashable Search_result where hashWithSalt salt record = salt `H.hashWithSalt` search_result_success record `H.hashWithSalt` search_result_ex record instance QC.Arbitrary Search_result where arbitrary = M.liftM Search_result (QC.arbitrary) `M.ap`(M.liftM P.Just QC.arbitrary) shrink obj | obj == default_Search_result = [] | P.otherwise = M.catMaybes [ if obj == default_Search_result{search_result_success = search_result_success obj} then P.Nothing else P.Just $ default_Search_result{search_result_success = search_result_success obj} , if obj == default_Search_result{search_result_ex = search_result_ex obj} then P.Nothing else P.Just $ default_Search_result{search_result_ex = search_result_ex obj} ] from_Search_result :: Search_result -> T.ThriftVal from_Search_result record = T.TStruct $ Map.fromList (let exns = M.catMaybes [ (\_v70 -> (1, ("ex",Services_Types.from_ServicesException _v70))) <$> search_result_ex record] in if P.not (P.null exns) then exns else M.catMaybes [ (\_v70 -> P.Just (0, ("success",from_SearchResult _v70))) $ search_result_success record , (\_v70 -> (1, ("ex",Services_Types.from_ServicesException _v70))) <$> search_result_ex record ] ) write_Search_result :: (T.Protocol p, T.Transport t) => p t -> Search_result -> P.IO () write_Search_result oprot record = T.writeVal oprot $ from_Search_result record encode_Search_result :: (T.Protocol p, T.Transport t) => p t -> Search_result -> LBS.ByteString encode_Search_result oprot record = T.serializeVal oprot $ from_Search_result record to_Search_result :: T.ThriftVal -> Search_result to_Search_result (T.TStruct fields) = Search_result{ search_result_success = P.maybe (search_result_success default_Search_result) (\(_,_val72) -> (case _val72 of {T.TStruct _val73 -> (to_SearchResult (T.TStruct _val73)); _ -> P.error "wrong type"})) (Map.lookup (0) fields), search_result_ex = P.maybe (P.Nothing) (\(_,_val72) -> P.Just (case _val72 of {T.TStruct _val74 -> (Services_Types.to_ServicesException (T.TStruct _val74)); _ -> P.error "wrong type"})) (Map.lookup (1) fields) } to_Search_result _ = P.error "not a struct" read_Search_result :: (T.Transport t, T.Protocol p) => p t -> P.IO Search_result read_Search_result iprot = to_Search_result <$> T.readVal iprot (T.T_STRUCT typemap_Search_result) decode_Search_result :: (T.Protocol p, T.Transport t) => p t -> LBS.ByteString -> Search_result decode_Search_result iprot bs = to_Search_result $ T.deserializeVal iprot (T.T_STRUCT typemap_Search_result) bs typemap_Search_result :: T.TypeMap typemap_Search_result = Map.fromList [(0,("success",(T.T_STRUCT typemap_SearchResult))),(1,("ex",(T.T_STRUCT Services_Types.typemap_ServicesException)))] default_Search_result :: Search_result default_Search_result = Search_result{ search_result_success = default_SearchResult, search_result_ex = P.Nothing} data GetCapabilities_args = GetCapabilities_args deriving (P.Show,P.Eq,G.Generic,TY.Typeable) instance H.Hashable GetCapabilities_args where hashWithSalt salt record = salt instance QC.Arbitrary GetCapabilities_args where arbitrary = QC.elements [GetCapabilities_args] from_GetCapabilities_args :: GetCapabilities_args -> T.ThriftVal from_GetCapabilities_args record = T.TStruct $ Map.fromList $ M.catMaybes [] write_GetCapabilities_args :: (T.Protocol p, T.Transport t) => p t -> GetCapabilities_args -> P.IO () write_GetCapabilities_args oprot record = T.writeVal oprot $ from_GetCapabilities_args record encode_GetCapabilities_args :: (T.Protocol p, T.Transport t) => p t -> GetCapabilities_args -> LBS.ByteString encode_GetCapabilities_args oprot record = T.serializeVal oprot $ from_GetCapabilities_args record to_GetCapabilities_args :: T.ThriftVal -> GetCapabilities_args to_GetCapabilities_args (T.TStruct fields) = GetCapabilities_args{ } to_GetCapabilities_args _ = P.error "not a struct" read_GetCapabilities_args :: (T.Transport t, T.Protocol p) => p t -> P.IO GetCapabilities_args read_GetCapabilities_args iprot = to_GetCapabilities_args <$> T.readVal iprot (T.T_STRUCT typemap_GetCapabilities_args) decode_GetCapabilities_args :: (T.Protocol p, T.Transport t) => p t -> LBS.ByteString -> GetCapabilities_args decode_GetCapabilities_args iprot bs = to_GetCapabilities_args $ T.deserializeVal iprot (T.T_STRUCT typemap_GetCapabilities_args) bs typemap_GetCapabilities_args :: T.TypeMap typemap_GetCapabilities_args = Map.fromList [] default_GetCapabilities_args :: GetCapabilities_args default_GetCapabilities_args = GetCapabilities_args{ } data GetCapabilities_result = GetCapabilities_result { getCapabilities_result_success :: (Vector.Vector SearchCapability) , getCapabilities_result_ex :: P.Maybe Services_Types.ServicesException } deriving (P.Show,P.Eq,G.Generic,TY.Typeable) instance H.Hashable GetCapabilities_result where hashWithSalt salt record = salt `H.hashWithSalt` getCapabilities_result_success record `H.hashWithSalt` getCapabilities_result_ex record instance QC.Arbitrary GetCapabilities_result where arbitrary = M.liftM GetCapabilities_result (QC.arbitrary) `M.ap`(M.liftM P.Just QC.arbitrary) shrink obj | obj == default_GetCapabilities_result = [] | P.otherwise = M.catMaybes [ if obj == default_GetCapabilities_result{getCapabilities_result_success = getCapabilities_result_success obj} then P.Nothing else P.Just $ default_GetCapabilities_result{getCapabilities_result_success = getCapabilities_result_success obj} , if obj == default_GetCapabilities_result{getCapabilities_result_ex = getCapabilities_result_ex obj} then P.Nothing else P.Just $ default_GetCapabilities_result{getCapabilities_result_ex = getCapabilities_result_ex obj} ] from_GetCapabilities_result :: GetCapabilities_result -> T.ThriftVal from_GetCapabilities_result record = T.TStruct $ Map.fromList (let exns = M.catMaybes [ (\_v82 -> (1, ("ex",Services_Types.from_ServicesException _v82))) <$> getCapabilities_result_ex record] in if P.not (P.null exns) then exns else M.catMaybes [ (\_v82 -> P.Just (0, ("success",T.TList (T.T_STRUCT typemap_SearchCapability) $ P.map (\_v84 -> from_SearchCapability _v84) $ Vector.toList _v82))) $ getCapabilities_result_success record , (\_v82 -> (1, ("ex",Services_Types.from_ServicesException _v82))) <$> getCapabilities_result_ex record ] ) write_GetCapabilities_result :: (T.Protocol p, T.Transport t) => p t -> GetCapabilities_result -> P.IO () write_GetCapabilities_result oprot record = T.writeVal oprot $ from_GetCapabilities_result record encode_GetCapabilities_result :: (T.Protocol p, T.Transport t) => p t -> GetCapabilities_result -> LBS.ByteString encode_GetCapabilities_result oprot record = T.serializeVal oprot $ from_GetCapabilities_result record to_GetCapabilities_result :: T.ThriftVal -> GetCapabilities_result to_GetCapabilities_result (T.TStruct fields) = GetCapabilities_result{ getCapabilities_result_success = P.maybe (getCapabilities_result_success default_GetCapabilities_result) (\(_,_val86) -> (case _val86 of {T.TList _ _val87 -> (Vector.fromList $ P.map (\_v88 -> (case _v88 of {T.TStruct _val89 -> (to_SearchCapability (T.TStruct _val89)); _ -> P.error "wrong type"})) _val87); _ -> P.error "wrong type"})) (Map.lookup (0) fields), getCapabilities_result_ex = P.maybe (P.Nothing) (\(_,_val86) -> P.Just (case _val86 of {T.TStruct _val90 -> (Services_Types.to_ServicesException (T.TStruct _val90)); _ -> P.error "wrong type"})) (Map.lookup (1) fields) } to_GetCapabilities_result _ = P.error "not a struct" read_GetCapabilities_result :: (T.Transport t, T.Protocol p) => p t -> P.IO GetCapabilities_result read_GetCapabilities_result iprot = to_GetCapabilities_result <$> T.readVal iprot (T.T_STRUCT typemap_GetCapabilities_result) decode_GetCapabilities_result :: (T.Protocol p, T.Transport t) => p t -> LBS.ByteString -> GetCapabilities_result decode_GetCapabilities_result iprot bs = to_GetCapabilities_result $ T.deserializeVal iprot (T.T_STRUCT typemap_GetCapabilities_result) bs typemap_GetCapabilities_result :: T.TypeMap typemap_GetCapabilities_result = Map.fromList [(0,("success",(T.T_LIST (T.T_STRUCT typemap_SearchCapability)))),(1,("ex",(T.T_STRUCT Services_Types.typemap_ServicesException)))] default_GetCapabilities_result :: GetCapabilities_result default_GetCapabilities_result = GetCapabilities_result{ getCapabilities_result_success = Vector.empty, getCapabilities_result_ex = P.Nothing} data GetCorpora_args = GetCorpora_args deriving (P.Show,P.Eq,G.Generic,TY.Typeable) instance H.Hashable GetCorpora_args where hashWithSalt salt record = salt instance QC.Arbitrary GetCorpora_args where arbitrary = QC.elements [GetCorpora_args] from_GetCorpora_args :: GetCorpora_args -> T.ThriftVal from_GetCorpora_args record = T.TStruct $ Map.fromList $ M.catMaybes [] write_GetCorpora_args :: (T.Protocol p, T.Transport t) => p t -> GetCorpora_args -> P.IO () write_GetCorpora_args oprot record = T.writeVal oprot $ from_GetCorpora_args record encode_GetCorpora_args :: (T.Protocol p, T.Transport t) => p t -> GetCorpora_args -> LBS.ByteString encode_GetCorpora_args oprot record = T.serializeVal oprot $ from_GetCorpora_args record to_GetCorpora_args :: T.ThriftVal -> GetCorpora_args to_GetCorpora_args (T.TStruct fields) = GetCorpora_args{ } to_GetCorpora_args _ = P.error "not a struct" read_GetCorpora_args :: (T.Transport t, T.Protocol p) => p t -> P.IO GetCorpora_args read_GetCorpora_args iprot = to_GetCorpora_args <$> T.readVal iprot (T.T_STRUCT typemap_GetCorpora_args) decode_GetCorpora_args :: (T.Protocol p, T.Transport t) => p t -> LBS.ByteString -> GetCorpora_args decode_GetCorpora_args iprot bs = to_GetCorpora_args $ T.deserializeVal iprot (T.T_STRUCT typemap_GetCorpora_args) bs typemap_GetCorpora_args :: T.TypeMap typemap_GetCorpora_args = Map.fromList [] default_GetCorpora_args :: GetCorpora_args default_GetCorpora_args = GetCorpora_args{ } data GetCorpora_result = GetCorpora_result { getCorpora_result_success :: (Vector.Vector LT.Text) , getCorpora_result_ex :: P.Maybe Services_Types.ServicesException } deriving (P.Show,P.Eq,G.Generic,TY.Typeable) instance H.Hashable GetCorpora_result where hashWithSalt salt record = salt `H.hashWithSalt` getCorpora_result_success record `H.hashWithSalt` getCorpora_result_ex record instance QC.Arbitrary GetCorpora_result where arbitrary = M.liftM GetCorpora_result (QC.arbitrary) `M.ap`(M.liftM P.Just QC.arbitrary) shrink obj | obj == default_GetCorpora_result = [] | P.otherwise = M.catMaybes [ if obj == default_GetCorpora_result{getCorpora_result_success = getCorpora_result_success obj} then P.Nothing else P.Just $ default_GetCorpora_result{getCorpora_result_success = getCorpora_result_success obj} , if obj == default_GetCorpora_result{getCorpora_result_ex = getCorpora_result_ex obj} then P.Nothing else P.Just $ default_GetCorpora_result{getCorpora_result_ex = getCorpora_result_ex obj} ] from_GetCorpora_result :: GetCorpora_result -> T.ThriftVal from_GetCorpora_result record = T.TStruct $ Map.fromList (let exns = M.catMaybes [ (\_v98 -> (1, ("ex",Services_Types.from_ServicesException _v98))) <$> getCorpora_result_ex record] in if P.not (P.null exns) then exns else M.catMaybes [ (\_v98 -> P.Just (0, ("success",T.TList T.T_STRING $ P.map (\_v100 -> T.TString $ E.encodeUtf8 _v100) $ Vector.toList _v98))) $ getCorpora_result_success record , (\_v98 -> (1, ("ex",Services_Types.from_ServicesException _v98))) <$> getCorpora_result_ex record ] ) write_GetCorpora_result :: (T.Protocol p, T.Transport t) => p t -> GetCorpora_result -> P.IO () write_GetCorpora_result oprot record = T.writeVal oprot $ from_GetCorpora_result record encode_GetCorpora_result :: (T.Protocol p, T.Transport t) => p t -> GetCorpora_result -> LBS.ByteString encode_GetCorpora_result oprot record = T.serializeVal oprot $ from_GetCorpora_result record to_GetCorpora_result :: T.ThriftVal -> GetCorpora_result to_GetCorpora_result (T.TStruct fields) = GetCorpora_result{ getCorpora_result_success = P.maybe (getCorpora_result_success default_GetCorpora_result) (\(_,_val102) -> (case _val102 of {T.TList _ _val103 -> (Vector.fromList $ P.map (\_v104 -> (case _v104 of {T.TString _val105 -> E.decodeUtf8 _val105; _ -> P.error "wrong type"})) _val103); _ -> P.error "wrong type"})) (Map.lookup (0) fields), getCorpora_result_ex = P.maybe (P.Nothing) (\(_,_val102) -> P.Just (case _val102 of {T.TStruct _val106 -> (Services_Types.to_ServicesException (T.TStruct _val106)); _ -> P.error "wrong type"})) (Map.lookup (1) fields) } to_GetCorpora_result _ = P.error "not a struct" read_GetCorpora_result :: (T.Transport t, T.Protocol p) => p t -> P.IO GetCorpora_result read_GetCorpora_result iprot = to_GetCorpora_result <$> T.readVal iprot (T.T_STRUCT typemap_GetCorpora_result) decode_GetCorpora_result :: (T.Protocol p, T.Transport t) => p t -> LBS.ByteString -> GetCorpora_result decode_GetCorpora_result iprot bs = to_GetCorpora_result $ T.deserializeVal iprot (T.T_STRUCT typemap_GetCorpora_result) bs typemap_GetCorpora_result :: T.TypeMap typemap_GetCorpora_result = Map.fromList [(0,("success",(T.T_LIST T.T_STRING))),(1,("ex",(T.T_STRUCT Services_Types.typemap_ServicesException)))] default_GetCorpora_result :: GetCorpora_result default_GetCorpora_result = GetCorpora_result{ getCorpora_result_success = Vector.empty, getCorpora_result_ex = P.Nothing} process_search (seqid, iprot, oprot, handler) = do args <- read_Search_args iprot (X.catch (X.catch (do val <- Iface.search handler (search_args_query args) let res = default_Search_result{search_result_success = val} T.writeMessageBegin oprot ("search", T.M_REPLY, seqid) write_Search_result oprot res T.writeMessageEnd oprot T.tFlush (T.getTransport oprot)) (\e -> do let res = default_Search_result{search_result_ex = P.Just e} T.writeMessageBegin oprot ("search", T.M_REPLY, seqid) write_Search_result oprot res T.writeMessageEnd oprot T.tFlush (T.getTransport oprot))) ((\_ -> do T.writeMessageBegin oprot ("search", T.M_EXCEPTION, seqid) T.writeAppExn oprot (T.AppExn T.AE_UNKNOWN "") T.writeMessageEnd oprot T.tFlush (T.getTransport oprot)) :: X.SomeException -> P.IO ())) process_getCapabilities (seqid, iprot, oprot, handler) = do args <- read_GetCapabilities_args iprot (X.catch (X.catch (do val <- Iface.getCapabilities handler let res = default_GetCapabilities_result{getCapabilities_result_success = val} T.writeMessageBegin oprot ("getCapabilities", T.M_REPLY, seqid) write_GetCapabilities_result oprot res T.writeMessageEnd oprot T.tFlush (T.getTransport oprot)) (\e -> do let res = default_GetCapabilities_result{getCapabilities_result_ex = P.Just e} T.writeMessageBegin oprot ("getCapabilities", T.M_REPLY, seqid) write_GetCapabilities_result oprot res T.writeMessageEnd oprot T.tFlush (T.getTransport oprot))) ((\_ -> do T.writeMessageBegin oprot ("getCapabilities", T.M_EXCEPTION, seqid) T.writeAppExn oprot (T.AppExn T.AE_UNKNOWN "") T.writeMessageEnd oprot T.tFlush (T.getTransport oprot)) :: X.SomeException -> P.IO ())) process_getCorpora (seqid, iprot, oprot, handler) = do args <- read_GetCorpora_args iprot (X.catch (X.catch (do val <- Iface.getCorpora handler let res = default_GetCorpora_result{getCorpora_result_success = val} T.writeMessageBegin oprot ("getCorpora", T.M_REPLY, seqid) write_GetCorpora_result oprot res T.writeMessageEnd oprot T.tFlush (T.getTransport oprot)) (\e -> do let res = default_GetCorpora_result{getCorpora_result_ex = P.Just e} T.writeMessageBegin oprot ("getCorpora", T.M_REPLY, seqid) write_GetCorpora_result oprot res T.writeMessageEnd oprot T.tFlush (T.getTransport oprot))) ((\_ -> do T.writeMessageBegin oprot ("getCorpora", T.M_EXCEPTION, seqid) T.writeAppExn oprot (T.AppExn T.AE_UNKNOWN "") T.writeMessageEnd oprot T.tFlush (T.getTransport oprot)) :: X.SomeException -> P.IO ())) proc_ handler (iprot,oprot) (name,typ,seqid) = case name of "search" -> process_search (seqid,iprot,oprot,handler) "getCapabilities" -> process_getCapabilities (seqid,iprot,oprot,handler) "getCorpora" -> process_getCorpora (seqid,iprot,oprot,handler) _ -> Service.proc_ handler (iprot,oprot) (name,typ,seqid) process handler (iprot, oprot) = do (name, typ, seqid) <- T.readMessageBegin iprot proc_ handler (iprot,oprot) (name,typ,seqid) T.readMessageEnd iprot P.return P.True