servant/servant-client
Sönke Hahn e5974ec94d add ComprehensiveAPI to test whether we're missing instances
Some of the combinators are commented atm, because we *are* missing combinators.
2016-01-18 12:28:29 +01:00
..
include less OverlappingInstances noise 2016-01-04 13:09:11 -05:00
src/Servant Review fixes 2016-01-08 18:03:28 +01:00
test add ComprehensiveAPI to test whether we're missing instances 2016-01-18 12:28:29 +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