Web/Servers
happstack-server[edit]
happstack-server contains a low-level HTTP backend, and high-level functions for routing requests, examining request data, and generating responses. happstack-server is part of the Happstack framework, but can be used as an independent entity. The low and high level portions of the server are not cleanly separated into different packages, so it is not the best choice if you only need a low-level backend.
License | BSD3 |
---|---|
Author: | Happstack team, HAppS LLC |
Maintainer: | Happstack team <happs@googlegroups.com> |
Home page: | http://happstack.com |
Documentation: | http://happstack.com/docs |
Package & repositories | Hackage |
Hyena[edit]
Hyena is a simple web application container that can be used to run Haskell web applications behind more robust web servers like Apache.
License | BSD3 |
---|---|
Author | Johan Tibell <johan.tibell@gmail.com> |
Maintainer | Johan Tibell <johan.tibell@gmail.com> |
Announcement | Haskell Cafe |
Package & repositories | Hackage - Github |
Snap Server[edit]
Part of the Snap framework, the Snap HTTP server is similar to Hyena in that it provides a very fast low level web server.
The Snap HTTP server is a high performance web server library written in Haskell. Together with the snap-core library upon which it depends, it provides a clean and efficient Haskell programming interface to the HTTP protocol.
SSL support can be enabled via a compile-time flag.
For more information or to download the latest version, you can visit the Snap project website at http://snapframework.com/.
License | BSD3 |
---|---|
Author | James Sanders, Gregory Collins, Doug Beardsley |
Maintainer | snap@snapframework.com |
Package & repositories | Hackage - Github |
Spock[edit]
Spock is a lightweight Haskell web framework inspired by Ruby's Sinatra. It provides a full toolbox including everything to get a quick start into web programming using Haskell.
License | BSD3 |
---|---|
Author: | Alexander Thiemann |
Maintainer: | Alexander Thiemann, et al |
Home page: | https://www.spock.li/ |
Documentation: | http://happstack.com/docs |
Package & repositories | Hackage - Github |
Warp[edit]
The fastest Haskell web server, targeting the WAI Web/Framework_Interfaces
License: | BSD3 |
---|---|
Author: | Michael Snoyman <michael@snoyman.com> |
Maintainer: | Michael Snoyman <michael@snoyman.com> |
Announcement: | http://docs.yesodweb.com/blog/announcing-warp |
Package & repositories | Hackage - Github |
Example:
{-# LANGUAGE OverloadedStrings #-}
import Network.Wai
import Network.Wai.Handler.Warp
import Network.HTTP.Types (status200)
import Blaze.ByteString.Builder (copyByteString)
import qualified Data.ByteString.UTF8 as BU
import Data.Monoid
main = do
let port = 3000
putStrLn $ "Listening on port " ++ show port
run port app
app req respond = respond $
case pathInfo req of
["yay"] -> yay
x -> index x
yay = responseBuilder status200 [ ("Content-Type", "text/plain") ] $ mconcat $ map copyByteString
[ "yay" ]
index x = responseBuilder status200 [("Content-Type", "text/html")] $ mconcat $ map copyByteString
[ "<p>Hello from ", BU.fromString $ show x, "!</p>"
, "<p><a href='/yay'>yay</a></p>\n" ]
mighttpd / mighttpd2[edit]
High performance web server to handle static files and CGI on WAI/warp. Reverse proxy functionality is also provided to connect web applications behind.
Its performance is comparable to that of nginx written in C (according to the Monad.Reader article linked below).
(Initial version of mighttpd didn't use WAI/warp.)
License: | BSD3 |
---|---|
Author: | Kazu Yamamoto <kazu@iij.ad.jp> |
Maintainer: | Kazu Yamamoto <kazu@iij.ad.jp> |
Announcement: | https://themonadreader.wordpress.com/2011/10/26/issue-19/ |
Package & repositories | Hackage - Homepage |
second-transfer[edit]
Low level web server library built for experimentation and tuning regarding the HTTP/2 protocol.
License: | BSD3 |
---|---|
Author: | Alcides Viamontes E. <a.viamontes.esquivel@gmail.com> |
Maintainer: | Alcides Viamontes E. <a.viamontes.esquivel@gmail.com> |
Package & repositories | Hackage - Homepage |