{-# OPTIONS_HADDOCK not-home #-}
{-# LANGUAGE RecordWildCards #-}
module Network.Wai.Internal where
import Data.ByteString.Builder (Builder)
import qualified Data.ByteString as B
import Data.Text (Text)
import Data.Typeable (Typeable)
import Data.Vault.Lazy (Vault)
import Data.Word (Word64)
import qualified Network.HTTP.Types as H
import Network.Socket (SockAddr)
import Data.List (intercalate)
{-# DEPRECATED requestBody "requestBody's name is misleading because it only gets a partial chunk of the body. Use getRequestBodyChunk instead when getting the field, and setRequestBodyChunks when setting the field." #-}
data Request = Request {
Request -> Method
requestMethod :: H.Method
, Request -> HttpVersion
httpVersion :: H.HttpVersion
, Request -> Method
rawPathInfo :: B.ByteString
, Request -> Method
rawQueryString :: B.ByteString
, :: H.RequestHeaders
, Request -> Bool
isSecure :: Bool
, Request -> SockAddr
remoteHost :: SockAddr
, Request -> [Text]
pathInfo :: [Text]
, Request -> Query
queryString :: H.Query
, Request -> IO Method
requestBody :: IO B.ByteString
, Request -> Vault
vault :: Vault
, Request -> RequestBodyLength
requestBodyLength :: RequestBodyLength
, :: Maybe B.ByteString
, :: Maybe B.ByteString
, :: Maybe B.ByteString
, :: Maybe B.ByteString
}
deriving (Typeable)
getRequestBodyChunk :: Request -> IO B.ByteString
getRequestBodyChunk :: Request -> IO Method
getRequestBodyChunk = Request -> IO Method
requestBody
setRequestBodyChunks :: IO B.ByteString -> Request -> Request
setRequestBodyChunks :: IO Method -> Request -> Request
setRequestBodyChunks IO Method
requestBody Request
r =
Request
r {requestBody :: IO Method
requestBody = IO Method
requestBody}
instance Show Request where
show :: Request -> String
show Request{Bool
Query
RequestHeaders
[Text]
Maybe Method
IO Method
Method
HttpVersion
SockAddr
Vault
RequestBodyLength
requestHeaderUserAgent :: Maybe Method
requestHeaderReferer :: Maybe Method
requestHeaderRange :: Maybe Method
requestHeaderHost :: Maybe Method
requestBodyLength :: RequestBodyLength
vault :: Vault
requestBody :: IO Method
queryString :: Query
pathInfo :: [Text]
remoteHost :: SockAddr
isSecure :: Bool
requestHeaders :: RequestHeaders
rawQueryString :: Method
rawPathInfo :: Method
httpVersion :: HttpVersion
requestMethod :: Method
requestHeaderUserAgent :: Request -> Maybe Method
requestHeaderReferer :: Request -> Maybe Method
requestHeaderRange :: Request -> Maybe Method
requestHeaderHost :: Request -> Maybe Method
requestBodyLength :: Request -> RequestBodyLength
vault :: Request -> Vault
requestBody :: Request -> IO Method
queryString :: Request -> Query
pathInfo :: Request -> [Text]
remoteHost :: Request -> SockAddr
isSecure :: Request -> Bool
requestHeaders :: Request -> RequestHeaders
rawQueryString :: Request -> Method
rawPathInfo :: Request -> Method
httpVersion :: Request -> HttpVersion
requestMethod :: Request -> Method
..} = String
"Request {" forall a. [a] -> [a] -> [a]
++ forall a. [a] -> [[a]] -> [a]
intercalate String
", " [String
a forall a. [a] -> [a] -> [a]
++ String
" = " forall a. [a] -> [a] -> [a]
++ String
b | (String
a,String
b) <- [(String, String)]
fields] forall a. [a] -> [a] -> [a]
++ String
"}"
where
fields :: [(String, String)]
fields =
[(String
"requestMethod",forall a. Show a => a -> String
show Method
requestMethod)
,(String
"httpVersion",forall a. Show a => a -> String
show HttpVersion
httpVersion)
,(String
"rawPathInfo",forall a. Show a => a -> String
show Method
rawPathInfo)
,(String
"rawQueryString",forall a. Show a => a -> String
show Method
rawQueryString)
,(String
"requestHeaders",forall a. Show a => a -> String
show RequestHeaders
requestHeaders)
,(String
"isSecure",forall a. Show a => a -> String
show Bool
isSecure)
,(String
"remoteHost",forall a. Show a => a -> String
show SockAddr
remoteHost)
,(String
"pathInfo",forall a. Show a => a -> String
show [Text]
pathInfo)
,(String
"queryString",forall a. Show a => a -> String
show Query
queryString)
,(String
"requestBody",String
"<IO ByteString>")
,(String
"vault",String
"<Vault>")
,(String
"requestBodyLength",forall a. Show a => a -> String
show RequestBodyLength
requestBodyLength)
,(String
"requestHeaderHost",forall a. Show a => a -> String
show Maybe Method
requestHeaderHost)
,(String
"requestHeaderRange",forall a. Show a => a -> String
show Maybe Method
requestHeaderRange)
]
data Response
= ResponseFile H.Status H.ResponseHeaders FilePath (Maybe FilePart)
| ResponseBuilder H.Status H.ResponseHeaders Builder
| ResponseStream H.Status H.ResponseHeaders StreamingBody
| ResponseRaw (IO B.ByteString -> (B.ByteString -> IO ()) -> IO ()) Response
deriving Typeable
type StreamingBody = (Builder -> IO ()) -> IO () -> IO ()
data RequestBodyLength = ChunkedBody | KnownLength Word64 deriving Int -> RequestBodyLength -> ShowS
[RequestBodyLength] -> ShowS
RequestBodyLength -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [RequestBodyLength] -> ShowS
$cshowList :: [RequestBodyLength] -> ShowS
show :: RequestBodyLength -> String
$cshow :: RequestBodyLength -> String
showsPrec :: Int -> RequestBodyLength -> ShowS
$cshowsPrec :: Int -> RequestBodyLength -> ShowS
Show
data FilePart = FilePart
{ FilePart -> Integer
filePartOffset :: Integer
, FilePart -> Integer
filePartByteCount :: Integer
, FilePart -> Integer
filePartFileSize :: Integer
} deriving Int -> FilePart -> ShowS
[FilePart] -> ShowS
FilePart -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [FilePart] -> ShowS
$cshowList :: [FilePart] -> ShowS
show :: FilePart -> String
$cshow :: FilePart -> String
showsPrec :: Int -> FilePart -> ShowS
$cshowsPrec :: Int -> FilePart -> ShowS
Show
data ResponseReceived = ResponseReceived
deriving Typeable