mirror of
https://github.com/hasura/graphql-engine.git
synced 2024-12-17 12:31:52 +03:00
ec8b2c80b5
* remove phase one/two distinction and hdbquery typeclass * move extensions to default-extensions * switch to LazyTx which only acquires a connection if needed * move defns from TH module into Ops module * remove tojson orphan instance for http exception * remove orphan instance for dmlp1 * getTopLevelNodes will not throw any exceptions
44 lines
1.3 KiB
Haskell
44 lines
1.3 KiB
Haskell
module Hasura.HTTP
|
|
( wreqOptions
|
|
, HttpException(..)
|
|
) where
|
|
|
|
import Control.Lens hiding ((.=))
|
|
import Hasura.Prelude
|
|
|
|
import qualified Data.Aeson as J
|
|
import qualified Data.Text.Encoding as T
|
|
import qualified Network.HTTP.Client as HTTP
|
|
import qualified Network.HTTP.Types as HTTP
|
|
import qualified Network.Wreq as Wreq
|
|
|
|
import Hasura.Server.Version (currentVersion)
|
|
|
|
wreqOptions :: HTTP.Manager -> [HTTP.Header] -> Wreq.Options
|
|
wreqOptions manager hdrs =
|
|
Wreq.defaults
|
|
& Wreq.headers .~ contentType : userAgent : hdrs
|
|
& Wreq.checkResponse ?~ (\_ _ -> return ())
|
|
& Wreq.manager .~ Right manager
|
|
where
|
|
contentType = ("Content-Type", "application/json")
|
|
userAgent = ( "User-Agent"
|
|
, "hasura-graphql-engine/" <> T.encodeUtf8 currentVersion
|
|
)
|
|
|
|
newtype HttpException
|
|
= HttpException
|
|
{ unHttpException :: HTTP.HttpException }
|
|
deriving (Show)
|
|
|
|
instance J.ToJSON HttpException where
|
|
toJSON = \case
|
|
(HttpException (HTTP.InvalidUrlException _ e)) ->
|
|
J.object [ "type" J..= ("invalid_url" :: Text)
|
|
, "message" J..= e
|
|
]
|
|
(HttpException (HTTP.HttpExceptionRequest _ cont)) ->
|
|
J.object [ "type" J..= ("http_exception" :: Text)
|
|
, "message" J..= show cont
|
|
]
|