{-# LANGUAGE OverloadedStrings #-} module Main where import Network.Wai.Handler.Warp import Network.Wai import Network.HTTP.Types import Network.Wai.Parse import Data.Text.Lazy (fromStrict) import qualified Data.Text as Txt import qualified Data.Text.Lazy.Encoding as LTxt import Data.Text.Encoding (decodeUtf8) import Data.ByteString (ByteString) import Data.Maybe (fromMaybe) import Hearth (renderPage, handleForm) main :: IO () main = do runEnv 2019 servePage servePage :: Application servePage req respond = case requestMethod req of "GET" | Just resp <- renderPage (rawPathInfo req) (queryString req) (headerAcceptLang req) -> respond $ responseLBS status200 [] $ LTxt.encodeUtf8 $ fromStrict resp "POST" -> do (query, _) <- parseRequestBodyEx defaultParseRequestBodyOptions lbsBackEnd req redirect <- handleForm (rawPathInfo req) query respond $ responseLBS status301 [(hLocation, redirect)] "" _ -> respond $ responseLBS status404 [] "Page not found!" headerAcceptLang :: Request -> [Txt.Text] headerAcceptLang = parseAcceptLang . lookup hAcceptLanguage . requestHeaders parseAcceptLang :: Maybe ByteString -> [Txt.Text] parseAcceptLang = map dropParam . Txt.splitOn "," . decodeUtf8 . fromMaybe "en" where dropParam = Txt.takeWhile (/= ';')