2017-07-14 06:28:57 +00:00
|
|
|
module HTTPure.Headers
|
|
|
|
( Headers
|
2017-07-18 01:51:43 +00:00
|
|
|
, lookup
|
2017-07-17 23:42:13 +00:00
|
|
|
, write
|
2017-07-14 06:28:57 +00:00
|
|
|
) where
|
|
|
|
|
2017-07-18 05:31:46 +00:00
|
|
|
import Prelude
|
2017-07-17 23:42:13 +00:00
|
|
|
|
2017-07-18 05:25:14 +00:00
|
|
|
import Control.Monad.Eff as Eff
|
2017-07-17 23:42:13 +00:00
|
|
|
import Data.Maybe as Maybe
|
2017-07-18 01:51:43 +00:00
|
|
|
import Data.String as StringUtil
|
2017-07-14 06:28:57 +00:00
|
|
|
import Data.StrMap as StrMap
|
2017-07-17 23:42:13 +00:00
|
|
|
import Data.Traversable as Traversable
|
|
|
|
import Node.HTTP as HTTP
|
|
|
|
|
2017-07-14 06:28:57 +00:00
|
|
|
-- | The Headers type is just sugar for a StrMap of Strings that represents the
|
|
|
|
-- | set of headers sent or received in an HTTP request or response.
|
|
|
|
type Headers = StrMap.StrMap String
|
2017-07-17 23:42:13 +00:00
|
|
|
|
2017-07-18 01:51:43 +00:00
|
|
|
-- | Return the value of the given header.
|
|
|
|
lookup :: Headers -> String -> String
|
|
|
|
lookup headers =
|
|
|
|
Maybe.fromMaybe "" <<< flip StrMap.lookup headers <<< StringUtil.toLower
|
|
|
|
|
2017-07-17 23:42:13 +00:00
|
|
|
-- | Write a set of headers to the given HTTP Response.
|
2017-07-18 05:25:14 +00:00
|
|
|
write :: forall e.
|
|
|
|
HTTP.Response ->
|
|
|
|
Headers ->
|
|
|
|
Eff.Eff (http :: HTTP.HTTP | e) Unit
|
2017-07-23 06:13:47 +00:00
|
|
|
write response headers =
|
|
|
|
void $ Traversable.traverse writeHeader $ StrMap.keys headers
|
2017-07-17 23:42:13 +00:00
|
|
|
where
|
|
|
|
getHeader header = Maybe.fromMaybe "" $ StrMap.lookup header headers
|
|
|
|
writeHeader header = HTTP.setHeader response header $ getHeader header
|