summaryrefslogtreecommitdiff
path: root/src/Language/GraphQL.hs
diff options
context:
space:
mode:
authorEugen Wissner <belka@caraus.de>2019-08-30 07:26:04 +0200
committerEugen Wissner <belka@caraus.de>2019-08-30 07:26:04 +0200
commit22313d05df7d96cd8106bc42f787bc74d74596de (patch)
treead92241fb9b317176adef1897cfc0c3a0dac55b4 /src/Language/GraphQL.hs
parentc1943c1979a0bfd37dae3a87d863f06938176baf (diff)
downloadgraphql-22313d05df7d96cd8106bc42f787bc74d74596de.tar.gz
Deprecate Language.GraphQL.Execute.Schema
It is not a schema (at least not a complete one), but a resolver list, and the resolvers should be provided by the user separately, because the schema can originate from a GraphQL document. Schema name should be free to provide a data type for the real schema later.
Diffstat (limited to 'src/Language/GraphQL.hs')
-rw-r--r--src/Language/GraphQL.hs43
1 files changed, 21 insertions, 22 deletions
diff --git a/src/Language/GraphQL.hs b/src/Language/GraphQL.hs
index 7ac08d7..c33eb95 100644
--- a/src/Language/GraphQL.hs
+++ b/src/Language/GraphQL.hs
@@ -5,32 +5,31 @@ module Language.GraphQL
) where
import Control.Monad.IO.Class (MonadIO)
-import qualified Data.Text as T
-
import qualified Data.Aeson as Aeson
-import Text.Megaparsec (parse)
-
+import Data.List.NonEmpty (NonEmpty)
+import qualified Data.Text as T
+import Language.GraphQL.Error
import Language.GraphQL.Execute
import Language.GraphQL.Parser
-import Language.GraphQL.Schema
-
-import Language.GraphQL.Error
+import qualified Language.GraphQL.Schema as Schema
+import Text.Megaparsec (parse)
--- | Takes a 'Schema' and text representing a @GraphQL@ request document.
--- If the text parses correctly as a @GraphQL@ query the query is
--- executed according to the given 'Schema'.
---
--- Returns the response as an @Aeson.@'Aeson.Value'.
-graphql :: MonadIO m => Schema m -> T.Text -> m Aeson.Value
+-- | If the text parses correctly as a @GraphQL@ query the query is
+-- executed using the given 'Schema.Resolver's.
+graphql :: MonadIO m
+ => NonEmpty (Schema.Resolver m) -- ^ Resolvers.
+ -> T.Text -- ^ Text representing a @GraphQL@ request document.
+ -> m Aeson.Value -- ^ Response.
graphql = flip graphqlSubs $ const Nothing
--- | Takes a 'Schema', a variable substitution function and text
--- representing a @GraphQL@ request document. If the text parses
--- correctly as a @GraphQL@ query the substitution is applied to the
--- query and the query is then executed according to the given 'Schema'.
---
--- Returns the response as an @Aeson.@'Aeson.Value'.
-graphqlSubs :: MonadIO m => Schema m -> Subs -> T.Text -> m Aeson.Value
-graphqlSubs schema f =
- either parseError (execute schema f)
+-- | If the text parses correctly as a @GraphQL@ query the substitution is
+-- applied to the query and the query is then executed using to the given
+-- 'Schema.Resolver's.
+graphqlSubs :: MonadIO m
+ => NonEmpty (Schema.Resolver m) -- ^ Resolvers.
+ -> Schema.Subs -- ^ Variable substitution function.
+ -> T.Text -- ^ Text representing a @GraphQL@ request document.
+ -> m Aeson.Value -- ^ Response.
+graphqlSubs schema f
+ = either parseError (execute schema f)
. parse document ""