module MultiRoute where import Prelude (discard, pure, show, (<>), ($)) 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 = 8081 -- | Shortcut for `show port` portS :: String portS = show port -- | Specify the routes router :: forall e. HTTPure.Request -> HTTPure.ResponseM e router (HTTPure.Get _ "/hello") = pure $ HTTPure.OK StrMap.empty "hello" router (HTTPure.Get _ "/goodbye") = pure $ HTTPure.OK StrMap.empty "goodbye" router _ = pure $ HTTPure.OK StrMap.empty "" -- | 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 $ " └───────────────────────────────────────────────┘"