purescript-httpurple/Library/HTTPure/Server.purs

59 lines
1.9 KiB
Haskell
Raw Normal View History

2017-07-10 10:17:13 +00:00
module HTTPure.Server
( ServerM
, boot
, handleRequest
, serve
2017-07-10 10:17:13 +00:00
) where
import Prelude (Unit, (>>=))
2017-07-10 10:17:13 +00:00
import Data.Maybe as Maybe
import Node.HTTP as HTTP
2017-07-10 10:17:13 +00:00
import HTTPure.HTTPureM as HTTPureM
import HTTPure.Request as Request
import HTTPure.Response as Response
-- | The ResponseM type simply conveniently wraps up an HTTPure monad that
-- | returns a Unit. This type is the return type of the HTTPure serve and
-- | related methods.
type ServerM e = HTTPureM.HTTPureM e Unit
-- | This function a method which takes a request and returns a ResponseM, an
-- | HTTP request, and an HTTP response. It runs the request, extracts the
-- | Response from the ResponseM, and sends the Response to the HTTP Response.
2017-07-10 10:17:13 +00:00
handleRequest :: forall e.
(Request.Request -> Response.ResponseM e) ->
2017-07-10 10:17:13 +00:00
HTTP.Request ->
HTTP.Response ->
ServerM e
handleRequest router request response =
router (Request.fromHTTPRequest request) >>= Response.send response
-- | Given an options object, an function mapping Request to ResponseM, and an
-- | HTTPureM containing effects to run on boot, creates and runs a HTTPure
-- | server.
2017-07-10 10:17:13 +00:00
boot :: forall e.
HTTP.ListenOptions ->
(Request.Request -> Response.ResponseM e) ->
ServerM e ->
ServerM e
boot options router onStarted =
HTTP.createServer (handleRequest router) >>= \server ->
2017-07-10 10:17:13 +00:00
HTTP.listen server options onStarted
2017-07-10 10:17:13 +00:00
-- | Create and start a server. This is the main entry point for HTTPure. Takes
-- | a port number on which to listen, a function mapping Request to ResponseM,
-- | and an HTTPureM containing effects to run after the server has booted
-- | (usually logging). Returns an HTTPureM containing the server's effects.
2017-07-10 10:17:13 +00:00
serve :: forall e.
Int ->
(Request.Request -> Response.ResponseM e) ->
ServerM e ->
ServerM e
2017-07-10 10:17:13 +00:00
serve port = boot
{ hostname: "localhost"
, port: port
, backlog: Maybe.Nothing
}