wai/warp-tls/pong.hs

78 lines
2.1 KiB
Haskell

{-# LANGUAGE OverloadedStrings #-}
import Network.Wai
import Network.Wai.Handler.Warp (defaultSettings, settingsPort)
import Network.Wai.Handler.WarpTLS
import Network.HTTP.Types (status200)
import Blaze.ByteString.Builder (copyByteString)
import Data.Monoid
import qualified Data.Conduit as C
import qualified Data.Conduit.List as CL
import Network.HTTP.ReverseProxy
import Network.HTTP.Conduit
main = do
putStrLn "https://localhost:3009/"
manager <- newManager def
runTLS (tlsSettings "config/tls-cert" "config/tls-key") defaultSettings { settingsPort = 3009 } app
app req = return $
case rawPathInfo req of
"/builder/withlen" -> builderWithLen
"/builder/nolen" -> builderNoLen
"/file/withlen" -> fileWithLen
"/file/nolen" -> fileNoLen
"/source/withlen" -> sourceWithLen
"/source/nolen" -> sourceNoLen
x -> index x
builderWithLen = ResponseBuilder
status200
[ ("Content-Type", "text/plain")
, ("Content-Length", "4")
]
$ copyByteString "PONG"
builderNoLen = ResponseBuilder
status200
[ ("Content-Type", "text/plain")
]
$ copyByteString "PONG"
sourceWithLen = ResponseSource
status200
[ ("Content-Type", "text/plain")
, ("Content-Length", "4")
]
$ CL.sourceList [C.Chunk $ copyByteString "PONG"]
sourceNoLen = ResponseSource
status200
[ ("Content-Type", "text/plain")
]
$ CL.sourceList [C.Chunk $ copyByteString "PONG"]
fileWithLen = ResponseFile
status200
[ ("Content-Type", "text/plain")
, ("Content-Length", "4")
]
"pong.txt"
Nothing
fileNoLen = ResponseFile
status200
[ ("Content-Type", "text/plain")
]
"pong.txt"
Nothing
index p = ResponseBuilder status200 [("Content-Type", "text/html")] $ mconcat $ map copyByteString
[ "<p><a href='/builder/withlen'>builder withlen</a></p>\n"
, "<p><a href='/builder/nolen'>builder nolen</a></p>\n"
, "<p><a href='/file/withlen'>file withlen</a></p>\n"
, "<p><a href='/file/nolen'>file nolen</a></p>\n"
, "<p><a href='/source/withlen'>source withlen</a></p>\n"
, "<p><a href='/source/nolen'>source nolen</a></p>\n"
, p
]