module MultiRoute where import Prelude import Control.Monad.Eff.Console as Console import HTTPure as HTTPure -- | Serve the example server on this port port :: Int port = 8081 -- | Shortcut for `show port` portS :: String portS = show port -- | Specify the routes router :: forall e. HTTPure.Request -> HTTPure.ResponseM e router { path: [ "hello" ] } = HTTPure.ok "hello" router { path: [ "goodbye" ] } = HTTPure.ok "goodbye" router _ = HTTPure.notFound -- | Boot up the server main :: forall e. HTTPure.ServerM (console :: Console.CONSOLE | e) 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 localhost:" <> portS <> "/hello # => hello │" Console.log $ " │ > curl localhost:" <> portS <> "/goodbye # => goodbye │" Console.log $ " └───────────────────────────────────────────────┘"