module Network.SOAP.Transport.Mock
(
initTransport
, Handler, Handlers
, handler
, runQuery
) where
import Network.SOAP.Transport
import Text.XML
import Text.XML.Writer
import Data.ByteString.Lazy.Char8 as LBS
type Handler = Document -> IO LBS.ByteString
type Handlers = [(String, Handler)]
initTransport :: Handlers -> IO Transport
initTransport handlers = return $ runQuery handlers
runQuery :: [(String, Handler)] -> Transport
runQuery handlers soapAction doc = do
case lookup soapAction handlers of
Nothing -> error $ "No handler for action " ++ soapAction
Just handler -> handler doc
handler :: (ToXML a) => (Document -> IO a) -> Handler
handler h doc = do
result <- h doc
return . renderLBS def
. document "Envelope"
. element "Body"
. toXML
$ result