servant/servant-client
Oleg Grenrus 50be3a263b Merge pull request #767 from fierce-katie/docs-combinators
Description and Summary combinators
2017-08-16 15:31:12 +03:00
..
include less OverlappingInstances noise 2016-01-04 13:09:11 -05:00
src/Servant Add instances for new combinators 2017-06-08 18:27:36 +03:00
test Rename EmptyAPIClient to EmptyClient 2017-05-16 16:00:15 +00:00
CHANGELOG.md Release 0.11 2017-05-24 08:02:56 +03: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 Fix cabal category 2017-07-25 10:46:57 +03: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