This library lets you automatically derive Haskell functions that let you query each endpoint of a servant webservice.
Example
{-# LANGUAGE DataKinds #-}{-# LANGUAGE TypeOperators #-}import Data.Proxyimport Data.Textimport Servant.APIimport Servant.HttpStreamstypeBook = TexttypeMyApi = "books" :> Get '[JSON] [Book] -- GET /books
:<|> "books" :> ReqBody '[JSON] Book :> Post '[JSON] Book-- POST /booksmyApi :: ProxyMyApimyApi = Proxy-- 'client' allows you to produce operations to query an API from a client.postNewBook :: Book -> ClientMBookgetAllBooks :: ClientM [Book]
(getAllBooks :<|> postNewBook) = client myApi
-- the IOException happens already in withClientEnvIOmain' :: IO ()
main' = dolet burl = BaseUrlHttp"localhost"8081""
withClientEnvIO burl $ \env -> do
res <- runClientM getAllBooks env
case res ofLeft err -> putStrLn $ "Error: " ++ show err
Right books -> print books
main :: IO ()
main = return ()
Compatibility with newer dependencies and GHC versions
0.20
Compatibility with GHC series 9.2, 9.4, 9.6
0.18.4
Significant changes
servant-client / servant-client-core / servant-http-streams:
Fix erroneous behavior, where only 2XX status codes would be considered
successful, irrelevant of the status parameter specified by the verb
combinator. (#1469)
:<|> "capture-lenient" :> Capture' '[Lenient] "foo"Int :> GET
which will make the capture always succeed. Handlers will be of the
type Either String CapturedType, where Left err represents
the possible parse failure.
Other changes
servant-clientservant-client-coreservant-http-streams Fix Verb with headers checking content type differently #1200#1204
For Verbs with response Headers, the implementation didn’t check
for the content-type of the response. Now it does.
servant-clientservant-http-streamsHasClient instance for Stream with Headers#1170#1197
servant-client Redact the authorization header in Show and exceptions #1238