2017-05-25 19:12:29 +00:00
|
|
|
module HTTPure.Request
|
2017-07-14 06:28:57 +00:00
|
|
|
( Request(..)
|
2017-05-25 19:12:29 +00:00
|
|
|
, fromHTTPRequest
|
|
|
|
) where
|
|
|
|
|
2017-07-14 06:28:57 +00:00
|
|
|
import Prelude ((<>))
|
|
|
|
|
|
|
|
import Data.Show as Show
|
2017-07-10 10:17:13 +00:00
|
|
|
import Node.HTTP as HTTP
|
2017-05-25 19:12:29 +00:00
|
|
|
|
2017-07-14 06:28:57 +00:00
|
|
|
import HTTPure.Body as Body
|
|
|
|
import HTTPure.Headers as Headers
|
|
|
|
import HTTPure.Path as Path
|
2017-05-25 19:12:29 +00:00
|
|
|
|
2017-07-14 06:28:57 +00:00
|
|
|
-- | A Request is a method along with headers, a path, and sometimes a body.
|
|
|
|
data Request
|
|
|
|
= Get Headers.Headers Path.Path
|
|
|
|
| Post Headers.Headers Path.Path Body.Body
|
|
|
|
| Put Headers.Headers Path.Path Body.Body
|
|
|
|
| Delete Headers.Headers Path.Path
|
2017-05-25 19:12:29 +00:00
|
|
|
|
2017-07-14 06:28:57 +00:00
|
|
|
-- | When using show on a Request, print the method and the path.
|
|
|
|
instance show :: Show.Show Request where
|
|
|
|
show (Get _ path) = "GET: " <> path
|
|
|
|
show (Post _ path _) = "POST: " <> path
|
|
|
|
show (Put _ path _) = "PUT: " <> path
|
|
|
|
show (Delete _ path) = "DELETE: " <> path
|
|
|
|
|
|
|
|
-- | Given an HTTP Request object, this method will convert it to an HTTPure
|
|
|
|
-- | Request object.
|
|
|
|
fromHTTPRequest :: HTTP.Request -> Request
|
|
|
|
fromHTTPRequest request =
|
|
|
|
case method of
|
|
|
|
"POST" -> Post headers path ""
|
|
|
|
"PUT" -> Put headers path ""
|
|
|
|
"DELETE" -> Delete headers path
|
|
|
|
_ -> Get headers path
|
|
|
|
where
|
|
|
|
method = HTTP.requestMethod request
|
|
|
|
headers = HTTP.requestHeaders request
|
|
|
|
path = HTTP.requestURL request
|