2017-10-26 21:19:30 +00:00
|
|
|
module Examples.Middleware.Main where
|
2017-09-27 19:34:00 +00:00
|
|
|
|
|
|
|
import Prelude
|
2022-05-04 21:02:29 +00:00
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
import Effect.Class (liftEffect)
|
|
|
|
import Effect.Console (log)
|
2022-05-04 21:02:29 +00:00
|
|
|
import HTTPure (Request, ResponseM, ServerM, fullPath, header, ok, ok', serve)
|
2017-09-27 19:34:00 +00:00
|
|
|
|
|
|
|
-- | A middleware that logs at the beginning and end of each request
|
2021-03-22 19:02:36 +00:00
|
|
|
loggingMiddleware ::
|
2021-11-19 06:16:35 +00:00
|
|
|
(Request -> ResponseM) ->
|
|
|
|
Request ->
|
|
|
|
ResponseM
|
2017-09-27 19:34:00 +00:00
|
|
|
loggingMiddleware router request = do
|
2021-11-19 06:16:35 +00:00
|
|
|
liftEffect $ log $ "Request starting for " <> path
|
2017-09-27 19:34:00 +00:00
|
|
|
response <- router request
|
2021-11-19 06:16:35 +00:00
|
|
|
liftEffect $ log $ "Request ending for " <> path
|
2017-09-27 19:34:00 +00:00
|
|
|
pure response
|
2017-09-29 16:52:21 +00:00
|
|
|
where
|
2021-11-19 06:16:35 +00:00
|
|
|
path = fullPath request
|
2017-09-27 19:34:00 +00:00
|
|
|
|
|
|
|
-- | A middleware that adds the X-Middleware header to the response, if it
|
|
|
|
-- | wasn't already in the response
|
2021-03-22 19:02:36 +00:00
|
|
|
headerMiddleware ::
|
2021-11-19 06:16:35 +00:00
|
|
|
(Request -> ResponseM) ->
|
|
|
|
Request ->
|
|
|
|
ResponseM
|
2017-09-27 19:34:00 +00:00
|
|
|
headerMiddleware router request = do
|
2018-08-20 02:50:07 +00:00
|
|
|
response@{ headers } <- router request
|
2021-11-19 06:16:35 +00:00
|
|
|
pure $ response { headers = header' <> headers }
|
2017-09-27 19:34:00 +00:00
|
|
|
where
|
2021-11-19 06:16:35 +00:00
|
|
|
header' = header "X-Middleware" "middleware"
|
2017-09-27 19:34:00 +00:00
|
|
|
|
|
|
|
-- | A middleware that sends the body "Middleware!" instead of running the
|
|
|
|
-- | router when requesting /middleware
|
2021-03-22 19:02:36 +00:00
|
|
|
pathMiddleware ::
|
2021-11-19 06:16:35 +00:00
|
|
|
(Request -> ResponseM) ->
|
|
|
|
Request ->
|
|
|
|
ResponseM
|
|
|
|
pathMiddleware _ { path: [ "middleware" ] } = ok "Middleware!"
|
2017-09-27 19:34:00 +00:00
|
|
|
pathMiddleware router request = router request
|
|
|
|
|
|
|
|
-- | Say 'hello' when run, and add a default value to the X-Middleware header
|
2021-11-19 06:16:35 +00:00
|
|
|
sayHello :: Request -> ResponseM
|
|
|
|
sayHello _ = ok' (header "X-Middleware" "router") "hello"
|
|
|
|
|
|
|
|
-- | The stack of middlewares to use for the server
|
|
|
|
middlewareStack :: (Request -> ResponseM) -> Request -> ResponseM
|
|
|
|
middlewareStack = loggingMiddleware <<< headerMiddleware <<< pathMiddleware
|
2017-09-27 19:34:00 +00:00
|
|
|
|
|
|
|
-- | Boot up the server
|
2021-11-19 06:16:35 +00:00
|
|
|
main :: ServerM
|
2021-03-22 19:02:36 +00:00
|
|
|
main =
|
2021-11-19 06:16:35 +00:00
|
|
|
serve 8080 (middlewareStack sayHello) do
|
|
|
|
log " ┌───────────────────────────────────────┐"
|
|
|
|
log " │ Server now up on port 8080 │"
|
|
|
|
log " │ │"
|
|
|
|
log " │ To test, run: │"
|
|
|
|
log " │ > curl -v localhost:8080 │"
|
|
|
|
log " │ # => ... │"
|
|
|
|
log " │ # => ...< X-Middleware: router │"
|
|
|
|
log " │ # => ... │"
|
|
|
|
log " │ # => hello │"
|
|
|
|
log " │ > curl -v localhost:8080/middleware │"
|
|
|
|
log " │ # => ... │"
|
|
|
|
log " │ # => ...< X-Middleware: middleware │"
|
|
|
|
log " │ # => ... │"
|
|
|
|
log " │ # => Middleware! │"
|
|
|
|
log " └───────────────────────────────────────┘"
|