2017-07-17 23:42:13 +00:00
|
|
|
module Headers where
|
|
|
|
|
2017-07-18 05:31:46 +00:00
|
|
|
import Prelude
|
2017-07-17 23:42:13 +00:00
|
|
|
|
|
|
|
import Control.Monad.Eff.Console as Console
|
|
|
|
import Data.StrMap as StrMap
|
|
|
|
import HTTPure as HTTPure
|
|
|
|
|
|
|
|
-- | Serve the example server on this port
|
|
|
|
port :: Int
|
|
|
|
port = 8082
|
|
|
|
|
|
|
|
-- | Shortcut for `show port`
|
|
|
|
portS :: String
|
|
|
|
portS = show port
|
|
|
|
|
2017-07-18 01:51:43 +00:00
|
|
|
-- | Read X-Input back to the body and set the X-Example header
|
|
|
|
sayHello :: HTTPure.Headers -> HTTPure.Response
|
|
|
|
sayHello = HTTPure.OK responseHeaders <<< flip HTTPure.lookup "X-Input"
|
|
|
|
where
|
|
|
|
responseHeaders = StrMap.singleton "X-Example" "hello world!"
|
|
|
|
|
|
|
|
-- | Route to the correct handler
|
|
|
|
router :: forall e. HTTPure.Request -> HTTPure.ResponseM e
|
|
|
|
router (HTTPure.Get headers _) = pure $ sayHello headers
|
2017-07-19 18:59:55 +00:00
|
|
|
router _ = pure $ HTTPure.NotFound StrMap.empty
|
2017-07-17 23:42:13 +00:00
|
|
|
|
|
|
|
-- | Boot up the server
|
|
|
|
main :: forall e. HTTPure.ServerM (console :: Console.CONSOLE | e)
|
2017-07-18 01:51:43 +00:00
|
|
|
main = HTTPure.serve port router do
|
|
|
|
Console.log $ " ┌──────────────────────────────────────────────┐"
|
|
|
|
Console.log $ " │ Server now up on port " <> portS <> " │"
|
|
|
|
Console.log $ " │ │"
|
|
|
|
Console.log $ " │ To test, run: │"
|
|
|
|
Console.log $ " │ > curl -H 'X-Input: test' -v localhost:" <> portS <> " │"
|
|
|
|
Console.log $ " │ # => ... │"
|
|
|
|
Console.log $ " │ # => ...< X-Example: hello world! │"
|
|
|
|
Console.log $ " │ # => ... │"
|
|
|
|
Console.log $ " │ # => test │"
|
|
|
|
Console.log $ " └──────────────────────────────────────────────┘"
|