purescript-httpurple/src/HTTPure/Headers.purs

72 lines
2.3 KiB
Haskell
Raw Normal View History

module HTTPure.Headers
( Headers
, empty
2017-09-26 06:08:07 +00:00
, headers
, header
2017-09-26 06:08:07 +00:00
, read
, write
) where
import Prelude
2017-07-18 05:25:14 +00:00
import Control.Monad.Eff as Eff
import Data.Maybe as Maybe
2017-07-18 01:51:43 +00:00
import Data.String as StringUtil
import Data.StrMap as StrMap
2017-09-26 06:08:07 +00:00
import Data.TraversableWithIndex as TraversableWithIndex
import Data.Tuple as Tuple
import Node.HTTP as HTTP
2017-09-26 06:08:07 +00:00
import HTTPure.Lookup as Lookup
2017-09-26 14:47:05 +00:00
-- | The `Headers` type is just sugar for a `StrMap` of `Strings` that
-- | represents the set of headers in an HTTP request or response.
2017-09-26 06:08:07 +00:00
newtype Headers = Headers (StrMap.StrMap String)
2017-09-26 14:47:05 +00:00
-- | Given a string, return the value of the matching header, or an empty string
-- | if no match exists. This search is case-insensitive.
2017-09-26 06:08:07 +00:00
instance lookupHeaders :: Lookup.Lookup Headers String String where
lookup (Headers headers') =
Maybe.fromMaybe "" <<< flip StrMap.lookup headers' <<< StringUtil.toLower
2017-09-26 14:47:05 +00:00
-- | Allow a `Headers` to be represented as a string. This string is formatted
-- | in HTTP headers format.
2017-09-26 06:08:07 +00:00
instance showHeaders :: Show Headers where
show (Headers headers') =
StrMap.foldMap showField headers' <> "\n"
where
showField key value = key <> ": " <> value <> "\n"
2017-09-26 14:47:05 +00:00
-- | Compare two `Headers` objects by comparing the underlying `StrMaps`.
2017-09-26 06:08:07 +00:00
instance eqHeaders :: Eq Headers where
eq (Headers a) (Headers b) = eq a b
2017-07-18 01:51:43 +00:00
2017-09-27 19:34:00 +00:00
-- | Allow one `Headers` objects to be appended to another.
instance semigroupHeaders :: Semigroup Headers where
append (Headers a) (Headers b) = Headers $ StrMap.union b a
2017-09-26 14:47:05 +00:00
-- | Get the headers out of a HTTP `Request` object.
2017-09-26 06:08:07 +00:00
read :: HTTP.Request -> Headers
read = HTTP.requestHeaders >>> Headers
2017-09-26 14:47:05 +00:00
-- | Given an HTTP `Response` and a `Headers` object, return an effect that will
-- | write the `Headers` to the `Response`.
2017-07-18 05:25:14 +00:00
write :: forall e.
HTTP.Response ->
Headers ->
Eff.Eff (http :: HTTP.HTTP | e) Unit
2017-09-26 06:08:07 +00:00
write response (Headers headers') = void $
TraversableWithIndex.traverseWithIndex (HTTP.setHeader response) headers'
-- | Return a `Headers` containing nothing.
empty :: Headers
empty = Headers StrMap.empty
2017-09-26 14:47:05 +00:00
-- | Convert an `Array` of `Tuples` of 2 `Strings` to a `Headers` object.
2017-09-26 06:08:07 +00:00
headers :: Array (Tuple.Tuple String String) -> Headers
headers = StrMap.fromFoldable >>> Headers
-- | Create a singleton header from a key-value pair.
header :: String -> String -> Headers
header key = StrMap.singleton key >>> Headers