servant/servant-client
2016-10-17 11:52:40 -04:00
..
include less OverlappingInstances noise 2016-01-04 13:09:11 -05:00
src/Servant servant-client: use base-compat in order to use less CPP 2016-10-17 11:52:40 -04:00
test servant-client: use base-compat in order to use less CPP 2016-10-17 11:52:40 -04:00
CHANGELOG.md tweake changelogs for the upcoming release 2016-09-17 11:46:26 -04:00
docs.sh prepare merge 2015-04-20 11:15:58 +02:00
LICENSE Change copyright to servant contributors 2016-01-20 16:58:29 +01:00
README.md Remove host param from servant-client README. 2016-05-25 17:38:25 +02:00
servant-client.cabal servant-client: use base-compat in order to use less CPP 2016-10-17 11:52:40 -04:00
Setup.hs stylish haskell changes 2015-08-18 00:07:12 +02:00
tinc.yaml Use tinc on travis 2015-11-05 09:32:13 +08:00

servant-client

servant

This library lets you automatically derive Haskell functions that let you query each endpoint of a servant webservice.

Example

type MyApi = "books" :> Get '[JSON] [Book] -- GET /books
        :<|> "books" :> ReqBody Book :> Post '[JSON] Book -- POST /books

myApi :: Proxy MyApi
myApi = Proxy

getAllBooks :: Manager -> BaseUrl -> ExceptT String IO [Book]
postNewBook :: Book -> Manager -> BaseUrl -> ExceptT String IO Book
-- 'client' allows you to produce operations to query an API from a client.
(getAllBooks :<|> postNewBook) = client myApi