2017-07-10 10:17:13 +00:00
|
|
|
module HTTPure.Server
|
2017-07-14 06:28:57 +00:00
|
|
|
( ServerM
|
|
|
|
, boot
|
|
|
|
, handleRequest
|
|
|
|
, serve
|
2017-07-10 10:17:13 +00:00
|
|
|
) where
|
2017-05-25 19:12:29 +00:00
|
|
|
|
2017-07-14 06:28:57 +00:00
|
|
|
import Prelude (Unit, (>>=))
|
2017-05-25 19:12:29 +00:00
|
|
|
|
2017-07-10 10:17:13 +00:00
|
|
|
import Data.Maybe as Maybe
|
|
|
|
import Node.HTTP as HTTP
|
2017-05-25 19:12:29 +00:00
|
|
|
|
2017-07-10 10:17:13 +00:00
|
|
|
import HTTPure.HTTPureM as HTTPureM
|
|
|
|
import HTTPure.Request as Request
|
|
|
|
import HTTPure.Response as Response
|
|
|
|
|
2017-07-14 06:28:57 +00:00
|
|
|
-- | 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.
|
2017-07-14 06:28:57 +00:00
|
|
|
(Request.Request -> Response.ResponseM e) ->
|
2017-07-10 10:17:13 +00:00
|
|
|
HTTP.Request ->
|
|
|
|
HTTP.Response ->
|
2017-07-14 06:28:57 +00:00
|
|
|
ServerM e
|
|
|
|
handleRequest router request response =
|
|
|
|
router (Request.fromHTTPRequest request) >>= Response.send response
|
2017-05-25 19:12:29 +00:00
|
|
|
|
2017-07-14 06:28:57 +00:00
|
|
|
-- | 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 ->
|
2017-07-14 06:28:57 +00:00
|
|
|
(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-05-25 19:12:29 +00:00
|
|
|
|
2017-07-10 10:17:13 +00:00
|
|
|
-- | Create and start a server. This is the main entry point for HTTPure. Takes
|
2017-07-14 06:28:57 +00:00
|
|
|
-- | 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 ->
|
2017-07-14 06:28:57 +00:00
|
|
|
(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
|
|
|
|
}
|