-- Copyright 2020 Fernando Rincon Martin
-- 
-- Licensed under the Apache License, Version 2.0 (the "License");
-- you may not use this file except in compliance with the License.
-- You may obtain a copy of the License at
-- 
--     http://www.apache.org/licenses/LICENSE-2.0
-- 
-- Unless required by applicable law or agreed to in writing, software
-- distributed under the License is distributed on an "AS IS" BASIS,
-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-- See the License for the specific language governing permissions and
-- limitations under the License.
-------------------------------------------------------------------------------
{-# LANGUAGE QuasiQuotes #-}
{-# LANGUAGE OverloadedStrings #-}
module Network.Wai.Routing.Purescheme.Core.Header
  ( headerValue
  )
where
  
import Network.Wai.Routing.Purescheme.Core.Basic

import Data.ByteString (ByteString)
import qualified Data.CaseInsensitive as CI
import Network.Wai (requestHeaders)

-- | Extract the value of the first HTTP request header with a given name
headerValue :: ByteString -> (Maybe ByteString -> GenericApplication b) -> GenericApplication b
headerValue :: ByteString
-> (Maybe ByteString -> GenericApplication b)
-> GenericApplication b
headerValue ByteString
name Maybe ByteString -> GenericApplication b
f Request
req =
  let
    maybeValue :: Maybe ByteString
maybeValue = CI ByteString -> [(CI ByteString, ByteString)] -> Maybe ByteString
forall a b. Eq a => a -> [(a, b)] -> Maybe b
lookup (ByteString -> CI ByteString
forall s. FoldCase s => s -> CI s
CI.mk ByteString
name) (Request -> [(CI ByteString, ByteString)]
requestHeaders Request
req)
  in
    Maybe ByteString -> GenericApplication b
f Maybe ByteString
maybeValue Request
req