Command line runner for Wai apps (using Warp) with TLS, CGI, socket activation & graceful shutdown
https://hackage.haskell.org/package/wai-cli
- Haskell 100%
| library/Network/Wai | ||
| .gitignore | ||
| CODE_OF_CONDUCT.md | ||
| README.md | ||
| Setup.hs | ||
| stack.yaml | ||
| stack.yaml.lock | ||
| UNLICENSE | ||
| wai-cli.cabal | ||
wai-cli

A command line runner for Wai apps (using Warp) with support for:
--protocol http --port 8000TCP sockets--protocol unix --socket /var/run/app/sockUNIX domain sockets--protocol cgirunning as a CGI app (the original serverless lambda functions from the 90s)--protocol fastcgirunning as a FastCGI app (OPTIONAL! You need to build with thefastcgicabal flag and you need to havelibfcgi(e.g.fcgi-devkitpackage on FreeBSD) installed)--protocol activatesocket activation (systemd-compatible, but not restricted to systemd in any way. see soad for an interesting use of (de)activation!)--protocol (http+tls|unix+tls|activate+tls) --tlskey key.pem --tlscert cert.pemTLS (can be turned off with a cabal flag to avoid compiling the TLS library)--graceful (none|serve-normally|serve-503)graceful shutdown (on TERM signal)--devloggingdevelopment logging (fromwai-extra)- printing a pretty and colorful run message (e.g.
Running on http port 3000 with 4 CPUs) (you can replace it with your own, or with nothing)
Usage
Add a dependency on wai-cli and write something like this:
{-# LANGUAGE OverloadedStrings #-}
import Web.Scotty
import Network.Wai.Cli
import Data.Monoid (mconcat)
app = scottyApp $ do
get "/:word" $ do
beam <- param "word"
html $ mconcat ["<h1>Scotty, ", beam, " me up!</h1>"]
main = defWaiMain =<< app
Want to use command line args for your application-specific settings? Don't. Use environment variables instead. Possibly with dotenv to load some of them from a file. envy is a really awesome way to read them.
License
This is free and unencumbered software released into the public domain.
For more information, please refer to the UNLICENSE file or unlicense.org.