servant/servant-client
2015-07-30 08:09:29 -06:00
..
src/Servant add HttpVersion, IsSecure, RemoteHost and Vault combinators with instances for all interpretations (all but the server ones being 'ignore that combinator') 2015-07-10 14:00:01 +02:00
test servant-client: Hide HttpException by wrapping it in SomeException 2015-06-12 21:19:26 +10:00
CHANGELOG.md add HttpVersion, IsSecure, RemoteHost and Vault combinators with instances for all interpretations (all but the server ones being 'ignore that combinator') 2015-07-10 14:00:01 +02:00
default.nix convenience scripts and nix updates 2015-07-30 08:09:29 -06: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 update examples in servant-client. fixes #75 2015-05-14 00:52:37 +02:00
servant-client.cabal Bump versions to 0.5 2015-07-27 22:26:49 +02:00
Setup.hs prepare merge 2015-04-20 11:15:58 +02:00
shell.nix convenience scripts and nix updates 2015-07-30 08:09:29 -06: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 :: EitherT String IO [Book]
postNewBook :: Book -> EitherT 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