Http -is:module

A library for client-side HTTP The HTTP package supports client-side web programming in Haskell. It lets you set up HTTP connections, transmitting requests and processing the responses coming back, all from within the comforts of Haskell. It's dependent on the network package to operate, but other than that, the implementation is all written in Haskell. A basic API for issuing single HTTP requests + receiving responses is provided. On top of that, a session-level abstraction is also on offer (the BrowserAction monad); it taking care of handling the management of persistent connections, proxies, state (cookies) and authentication credentials required to handle multi-step interactions with a web server. The representation of the bytes flowing across is extensible via the use of a type class, letting you pick the representation of requests and responses that best fits your use. Some pre-packaged, common instances are provided for you (ByteString, String). Here's an example use:
do
rsp <- Network.HTTP.simpleHTTP (getRequest "http://www.haskell.org/")
-- fetch document and return it (as a 'String'.)
fmap (take 100) (getResponseBody rsp)

do
(_, rsp)
<- Network.Browser.browse $ do
setAllowRedirects True -- handle HTTP redirects
request $ getRequest "http://www.haskell.org/"
return (take 100 (rspBody rsp))
Note: This package does not support HTTPS connections. If you need HTTPS, take a look at the following packages:
http://
HTTP
http://
HTTP
guard which checks that an insecure connection was made via http:// Example:
handler :: ServerPart Response
handler =
do http
...
Parse an HTTP(S) import This corresponds to the http rule from the official grammar
Given host name, produce a Url which has “http” as its scheme and empty path. This also sets port to 80.
Begin constructing a Request, starting with the request line.
HTTP Version. Note that the Show instance is intended merely for debugging.
An exception which may be generated by this library
Most exceptions are specific to a Request. Inspect the HttpExceptionContent value for details on what occurred.
An exception was thrown when inflating a response body.
HTTP/2 specific data. Since: 3.2.7
An exception which may be generated by this library