Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/nmattia/wai-lambda

Haskell Webapps on AWS Lambda
https://github.com/nmattia/wai-lambda

aws aws-lambda haskell nix webapp

Last synced: 3 months ago
JSON representation

Haskell Webapps on AWS Lambda

Awesome Lists containing this project

README

        


wai-lambda

# WAI Lambda - Haskell Webapps on AWS Lambda

[![Hackage](https://img.shields.io/hackage/v/wai-lambda.svg)](https://hackage.haskell.org/package/wai-lambda)

This Haskell library turns any [wai] webapp ([spock], [servant], etc) into a
handler for AWS [Lambda][lambda] and [API Gateway][api-gateway] requests.

``` haskell
{-# LANGUAGE OverloadedStrings #-}
import Network.Wai
import Network.HTTP.Types
import Network.Wai.Handler.Lambda (run)

app :: Application
app _ respond = do
putStrLn "I've done some IO here"
respond $ responseLBS
status200
[("Content-Type", "text/plain")]
"Hello, Web!"

main :: IO ()
main = run app
```

This doesn't require any particular Lambda environment. By following the
instructions in the [build](#build) section the resulting `zip` file uploaded
to AWS Lambda is typically smaller than 1MB. For basic webapps the request
handling duration (as reported by AWS) is between 1 and 5 milliseconds.

* [**Install**](#install) with either Cabal, stack or Nix.
* [**Build for AWS**](#build) with Nix and fully static executables.
* [**Deploy to AWS**](#deploy) with Nix and Terraform.

## Install

### Cabal

Installing with Cabal:

``` shell
$ cabal install wai-lambda
```

### Stack

If you use stack and `wai-lambda` is not included in your snapshot, add it to
the `extra-deps`:

``` yaml
extra-deps:
- wai-lambda-0.1.0.0
```

or from GitHub:

``` yaml
packages:
- ...
- location:
git: https://github.com/deckgo/wai-lambda.git
commit:
extra-dep: true
```

### Nix

You do not have to do anything if you use cabal2nix and a Nix commit that
includes `wai-lambda` in its Hackage dependencies. If you want to use a
specific commit of `wai-lambda` we recommend using [niv]:

``` shell
$ niv add deckgo/wai-lambda
```

Then add an override to your Nix packages:

``` nix

rec
{
sources = import ./nix/sources.nix; # from niv
pkgs = import sources.nixpkgs {};

myHaskellPackages = pkgs.haskellPackages.override
{ overrides = self: super:
{ "wai-lambda" =
super.callCabal2nix "wai-lambda" sources.wai-lambda;
};
};
}
```

See also the [build](#build) section for producing AWS Lambda packages with
nix.

## Build

_TODO_

For inspiration on how to build fully static executables with Nix, see
[DeckDeckGo](https://github.com/deckgo/deckdeckgo/tree/master/infra)

## Deploy

_TODO_

For inspiration on how to deploy with Terraform and Nix, see
[DeckDeckGo](https://github.com/deckgo/deckdeckgo/tree/master/infra)

## License

MIT © [David Dal Busco](mailto:[email protected]) and [Nicolas Mattia](mailto:[email protected])

[wai]: https://www.stackage.org/package/wai
[spock]: https://www.spock.li/
[servant]: https://docs.servant.dev/en/stable/
[lambda]: https://aws.amazon.com/lambda/
[api-gateway]: https://aws.amazon.com/api-gateway/
[niv]: https://github.com/nmattia/niv