servant/servant-client
Julian K. Arni 783a849c67 Make NoContent still take an arg.
For consistency with other combinators, and to make using headers
        easier.
2016-01-07 14:30:08 +01:00
..
include less OverlappingInstances noise 2016-01-04 13:09:11 -05:00
src/Servant Make NoContent still take an arg. 2016-01-07 14:30:08 +01:00
test Make NoContent still take an arg. 2016-01-07 14:30:08 +01:00
CHANGELOG.md Changelogs for matrix params 2015-10-13 21:46:52 +02:00
docs.sh prepare merge 2015-04-20 11:15:58 +02:00
LICENSE prepare merge 2015-04-20 11:15:58 +02:00
README.md Drop EitherT in favor of ExceptT 2015-09-12 15:11:24 +03:00
servant-client.cabal add include header files to extra-source-files 2016-01-04 23:05:05 -05: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 :: ExceptT String IO [Book]
postNewBook :: Book -> ExceptT String IO Book
-- 'client' allows you to produce operations to query an API from a client.
(getAllBooks :<|> postNewBook) = client myApi host
  where host = BaseUrl Http "localhost" 8080