summaryrefslogtreecommitdiff
path: root/src/Language/GraphQL/Execute.hs
diff options
context:
space:
mode:
authorEugen Wissner <belka@caraus.de>2020-07-05 14:36:00 +0200
committerEugen Wissner <belka@caraus.de>2020-07-05 14:36:00 +0200
commita6f9cec413c35abdcb0d04a5550334dd2fa7d472 (patch)
treeb16ce8fd038c02ec60664f60bba8d01b08d8d218 /src/Language/GraphQL/Execute.hs
parentb5157e141e765c1313050cc66a2a323b67f3da79 (diff)
downloadgraphql-a6f9cec413c35abdcb0d04a5550334dd2fa7d472.tar.gz
Handle errors using custom types
Fixes #32.
Diffstat (limited to 'src/Language/GraphQL/Execute.hs')
-rw-r--r--src/Language/GraphQL/Execute.hs55
1 files changed, 19 insertions, 36 deletions
diff --git a/src/Language/GraphQL/Execute.hs b/src/Language/GraphQL/Execute.hs
index 45bace0..ff1078c 100644
--- a/src/Language/GraphQL/Execute.hs
+++ b/src/Language/GraphQL/Execute.hs
@@ -1,10 +1,9 @@
-- | This module provides functions to execute a @GraphQL@ request.
module Language.GraphQL.Execute
( execute
- , executeWithName
+ , module Language.GraphQL.Execute.Coerce
) where
-import qualified Data.Aeson as Aeson
import Data.HashMap.Strict (HashMap)
import qualified Data.HashMap.Strict as HashMap
import Data.Sequence (Seq(..))
@@ -19,53 +18,37 @@ import qualified Language.GraphQL.Type.Out as Out
import Language.GraphQL.Type.Schema
-- | The substitution is applied to the document, and the resolvers are applied
--- to the resulting fields.
---
--- Returns the result of the query against the schema wrapped in a /data/
--- field, or errors wrapped in an /errors/ field.
-execute :: (Monad m, VariableValue a)
- => Schema m -- ^ Resolvers.
- -> HashMap.HashMap Name a -- ^ Variable substitution function.
- -> Document -- @GraphQL@ document.
- -> m Aeson.Value
-execute schema = executeRequest schema Nothing
-
--- | The substitution is applied to the document, and the resolvers are applied
-- to the resulting fields. The operation name can be used if the document
-- defines multiple root operations.
--
-- Returns the result of the query against the schema wrapped in a /data/
-- field, or errors wrapped in an /errors/ field.
-executeWithName :: (Monad m, VariableValue a)
- => Schema m -- ^ Resolvers
- -> Text -- ^ Operation name.
+execute :: (Monad m, VariableValue a, Serialize b)
+ => Schema m -- ^ Resolvers.
+ -> Maybe Text -- ^ Operation name.
-> HashMap.HashMap Name a -- ^ Variable substitution function.
- -> Document -- ^ @GraphQL@ Document.
- -> m Aeson.Value
-executeWithName schema operationName =
- executeRequest schema (Just operationName)
-
-executeRequest :: (Monad m, VariableValue a)
- => Schema m
- -> Maybe Text
- -> HashMap.HashMap Name a
- -> Document
- -> m Aeson.Value
-executeRequest schema operationName subs document =
+ -> Document -- @GraphQL@ document.
+ -> m (Response b)
+execute schema operationName subs document =
case Transform.document schema operationName subs document of
Left queryError -> pure $ singleError $ Transform.queryError queryError
- Right (Transform.Document types' rootObjectType operation)
- | (Transform.Query _ fields) <- operation ->
- executeOperation types' rootObjectType fields
- | (Transform.Mutation _ fields) <- operation ->
- executeOperation types' rootObjectType fields
+ Right transformed -> executeRequest transformed
+
+executeRequest :: (Monad m, Serialize a)
+ => Transform.Document m
+ -> m (Response a)
+executeRequest (Transform.Document types' rootObjectType operation)
+ | (Transform.Query _ fields) <- operation =
+ executeOperation types' rootObjectType fields
+ | (Transform.Mutation _ fields) <- operation =
+ executeOperation types' rootObjectType fields
-- This is actually executeMutation, but we don't distinguish between queries
-- and mutations yet.
-executeOperation :: Monad m
+executeOperation :: (Monad m, Serialize a)
=> HashMap Name (Type m)
-> Out.ObjectType m
-> Seq (Transform.Selection m)
- -> m Aeson.Value
+ -> m (Response a)
executeOperation types' objectType fields =
runCollectErrs types' $ executeSelectionSet Definition.Null objectType fields