Skip to content

Translate servant API to purescript code, with the help of purescript-bridge.

License

Notifications You must be signed in to change notification settings

shmish111/servant-purescript

 
 

Repository files navigation

Servant Purescript

Build Status

Generate typed PureScript query functions for your servant-api. Find an example, including the generated code in examples/central-counter.

Features

  • Typed serialization/deserialization, taken care of by Haskell's aeson and PureScript's argonaut. Generic encoding/decoding of both made compatible by purescript-argonaut-generic-codecs.
  • You can put common parameters like Auth tokens and the base URL in a reader monad, so you don't have to pass them explicitly. This is configurable in the code generator with readerParams in Settings.

Usage

Apart from the above basic usage example, the documentation is still lacking. For the purescript side make sure you have purescript-servant-support and purescript-argonaut-generic-codecs installed, otherwise the generated code will not compile.

Status

It works!

Documentation is yet to come, but there is a usage example in examples/central-counter which also uses servant-subscriber for counter live updates. Generated code is only partly tested, especially Query parameters are still completely untested.

For type translations purescript-bridge is used.

About

Translate servant API to purescript code, with the help of purescript-bridge.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Haskell 97.6%
  • Nix 2.1%
  • Shell 0.3%