2017-05-25 19:12:29 +00:00
|
|
|
module HTTPure.Response
|
|
|
|
( Response
|
|
|
|
, fromHTTPResponse
|
|
|
|
, write
|
|
|
|
) where
|
|
|
|
|
2017-07-10 10:17:13 +00:00
|
|
|
import Prelude (Unit, bind, discard, pure, unit)
|
2017-05-25 19:12:29 +00:00
|
|
|
|
2017-07-10 10:17:13 +00:00
|
|
|
import Control.Monad.Eff as Eff
|
|
|
|
import Node.Encoding as Encoding
|
|
|
|
import Node.HTTP as HTTP
|
|
|
|
import Node.Stream as Stream
|
2017-05-25 19:12:29 +00:00
|
|
|
|
2017-07-10 10:17:13 +00:00
|
|
|
-- | The Response type takes as it's parameter an effects row. It is a Record
|
|
|
|
-- | type with two fields:
|
|
|
|
-- |
|
|
|
|
-- | - `httpResponse`: The raw underlying HTTP response.
|
|
|
|
-- | - `stream`: The raw response converted to a Writable stream.
|
|
|
|
-- |
|
|
|
|
-- | Neither field is intended to be accessed directly, rather it is recommended
|
|
|
|
-- | to use the methods exported by this module.
|
|
|
|
type Response e =
|
|
|
|
{ httpResponse :: HTTP.Response
|
|
|
|
, stream :: Stream.Writable () (http :: HTTP.HTTP | e)
|
|
|
|
}
|
2017-05-25 19:12:29 +00:00
|
|
|
|
2017-07-10 10:17:13 +00:00
|
|
|
-- | Convert a Node.HTTP Response into a HTTPure Response.
|
|
|
|
fromHTTPResponse :: forall e. HTTP.Response -> Response e
|
|
|
|
fromHTTPResponse response =
|
|
|
|
{ httpResponse: response
|
|
|
|
, stream: HTTP.responseAsStream response
|
|
|
|
}
|
2017-05-25 19:12:29 +00:00
|
|
|
|
2017-07-10 10:17:13 +00:00
|
|
|
-- | Write a string into the Response output.
|
|
|
|
write :: forall e. Response e -> String -> Eff.Eff (http :: HTTP.HTTP | e) Unit
|
2017-05-25 19:12:29 +00:00
|
|
|
write response str = do
|
2017-07-10 10:17:13 +00:00
|
|
|
_ <- Stream.writeString response.stream Encoding.UTF8 str noop
|
|
|
|
Stream.end response.stream noop
|
|
|
|
noop
|
|
|
|
where
|
|
|
|
noop = pure unit
|