@hackage nero0.1

Lens-based HTTP toolkit

Nero

An experimental Haskell toolkit for Lens-based web application development.

⚠️ The following is for now a declaration of intentions only. Expect wild changes in the API in the near future.

  • Not a framework: it could be considered an anti-framework, micro-framework, or just a "library", in the sense that it provides a set of utilities to build custom web applications instead of being a framework that creates web applications from user provided code.

  • Pay for what you eat: instead of coming with everything and the kitchen sink, it provides the bare minimum to write applications without almost any implicit behavior. At the same time, it offers diverse paths to grow with you as applications become more complex.

  • Unopinonated: there is no preferred routing method, HTML templating library, session management, web server or database adapter. It comes with some defaults to alleviate the paradox of choice, but most components are expected to be easily swapped in and out with plain 3rd party Haskell libraries writing thin adapters if at all needed.

  • Power of Haskell and Lens: the Lens-based API enables styles familiar to imperative programmers [Lens] while being purely functional under the hood. Haskell veterans can take advantage of the powerful lens combinators.

Example

import Nero

app :: Request -> Maybe Response
app = request ^? _GET . match ("/hello/" <> text) <&> \name ->
    ok $ "<h1>Hello " <> name <> "</h1>"

Check more examples with its corresponding tests in the examples directory.