Copyright | (c) Peter Thiemann 20012002 (c) Bjorn Bringert 2005-2006 |
---|---|
License | BSD-style |
Maintainer | Anders Kaseorg <andersk@mit.edu> |
Stability | experimental |
Portability | non-portable |
Safe Haskell | None |
Language | Haskell2010 |
Parsing of the multipart format from RFC2046. Partly based on code from WASHMail.
Synopsis
- data MultiPart = MultiPart [BodyPart]
- data BodyPart = BodyPart Headers ByteString
- parseMultipartBody :: String -> ByteString -> MultiPart
- hGetMultipartBody :: String -> Handle -> IO MultiPart
- showMultipartBody :: String -> MultiPart -> ByteString
- type Headers = [(HeaderName, String)]
- newtype HeaderName = HeaderName String
- data ContentType = ContentType {}
- data ContentTransferEncoding = ContentTransferEncoding String
- data ContentDisposition = ContentDisposition String [(String, String)]
- parseContentType :: MonadFail m => String -> m ContentType
- getContentType :: MonadFail m => Headers -> m ContentType
- getContentTransferEncoding :: MonadFail m => Headers -> m ContentTransferEncoding
- getContentDisposition :: MonadFail m => Headers -> m ContentDisposition
Multi-part messages
:: String | Boundary |
-> ByteString | |
-> MultiPart |
Read a multi-part message from a ByteString
.
Read a multi-part message from a Handle
.
Fails on parse errors.
showMultipartBody :: String -> MultiPart -> ByteString Source #
Headers
type Headers = [(HeaderName, String)] Source #
HTTP headers.
newtype HeaderName Source #
A string with case insensitive equality and comparisons.
Instances
Eq HeaderName Source # | |
Defined in Network.Multipart.Header (==) :: HeaderName -> HeaderName -> Bool # (/=) :: HeaderName -> HeaderName -> Bool # | |
Ord HeaderName Source # | |
Defined in Network.Multipart.Header compare :: HeaderName -> HeaderName -> Ordering # (<) :: HeaderName -> HeaderName -> Bool # (<=) :: HeaderName -> HeaderName -> Bool # (>) :: HeaderName -> HeaderName -> Bool # (>=) :: HeaderName -> HeaderName -> Bool # max :: HeaderName -> HeaderName -> HeaderName # min :: HeaderName -> HeaderName -> HeaderName # | |
Show HeaderName Source # | |
Defined in Network.Multipart.Header showsPrec :: Int -> HeaderName -> ShowS # show :: HeaderName -> String # showList :: [HeaderName] -> ShowS # |
data ContentType Source #
A MIME media type value.
The Show
instance is derived automatically.
Use showContentType
to obtain the standard
string representation.
See http://www.ietf.org/rfc/rfc2046.txt for more
information about MIME media types.
ContentType | |
|
Instances
Eq ContentType Source # | |
Defined in Network.Multipart.Header (==) :: ContentType -> ContentType -> Bool # (/=) :: ContentType -> ContentType -> Bool # | |
Ord ContentType Source # | |
Defined in Network.Multipart.Header compare :: ContentType -> ContentType -> Ordering # (<) :: ContentType -> ContentType -> Bool # (<=) :: ContentType -> ContentType -> Bool # (>) :: ContentType -> ContentType -> Bool # (>=) :: ContentType -> ContentType -> Bool # max :: ContentType -> ContentType -> ContentType # min :: ContentType -> ContentType -> ContentType # | |
Read ContentType Source # | |
Defined in Network.Multipart.Header readsPrec :: Int -> ReadS ContentType # readList :: ReadS [ContentType] # readPrec :: ReadPrec ContentType # readListPrec :: ReadPrec [ContentType] # | |
Show ContentType Source # | |
Defined in Network.Multipart.Header showsPrec :: Int -> ContentType -> ShowS # show :: ContentType -> String # showList :: [ContentType] -> ShowS # | |
HeaderValue ContentType Source # | |
Defined in Network.Multipart.Header |
data ContentTransferEncoding Source #
Instances
data ContentDisposition Source #
Instances
Eq ContentDisposition Source # | |
Defined in Network.Multipart.Header (==) :: ContentDisposition -> ContentDisposition -> Bool # (/=) :: ContentDisposition -> ContentDisposition -> Bool # | |
Ord ContentDisposition Source # | |
Defined in Network.Multipart.Header compare :: ContentDisposition -> ContentDisposition -> Ordering # (<) :: ContentDisposition -> ContentDisposition -> Bool # (<=) :: ContentDisposition -> ContentDisposition -> Bool # (>) :: ContentDisposition -> ContentDisposition -> Bool # (>=) :: ContentDisposition -> ContentDisposition -> Bool # max :: ContentDisposition -> ContentDisposition -> ContentDisposition # min :: ContentDisposition -> ContentDisposition -> ContentDisposition # | |
Read ContentDisposition Source # | |
Defined in Network.Multipart.Header | |
Show ContentDisposition Source # | |
Defined in Network.Multipart.Header showsPrec :: Int -> ContentDisposition -> ShowS # show :: ContentDisposition -> String # showList :: [ContentDisposition] -> ShowS # | |
HeaderValue ContentDisposition Source # | |
parseContentType :: MonadFail m => String -> m ContentType Source #
Parse the standard representation of a content-type.
If the input cannot be parsed, this function calls
MonadFail
with a (hopefully) informative error message.
getContentType :: MonadFail m => Headers -> m ContentType Source #
getContentTransferEncoding :: MonadFail m => Headers -> m ContentTransferEncoding Source #
getContentDisposition :: MonadFail m => Headers -> m ContentDisposition Source #