{-# LANGUAGE NoImplicitPrelude #-} module Data.Morpheus.Parser ( parseTypeDefinitions, parseTypeSystemDefinition, parseRequest, parseRequestWith, ) where import Data.ByteString.Lazy (ByteString) import Data.Morpheus.Ext.SemigroupM ((<:>)) import qualified Data.Morpheus.Parsing.Document.TypeSystem as P ( parseSchema, parseTypeDefinitions, ) import Data.Morpheus.Parsing.Request.Parser (parseGQL) import Data.Morpheus.Schema.Schema (internalSchema) import Data.Morpheus.Types.IO ( GQLRequest (..), ) import Data.Morpheus.Types.Internal.AST ( ANY, CONST, GQLQuery (..), Operation, Schema (..), TypeDefinition (..), VALID, ) import Data.Morpheus.Types.Internal.Config ( Config (..), VALIDATION_MODE (..), ) import Data.Morpheus.Types.Internal.Resolving ( Eventless, ) import Data.Morpheus.Validation.Document.Validation ( validateSchema, ) import Data.Morpheus.Validation.Query.Validation ( validateRequest, ) import Relude hiding (ByteString) parseTypeSystemDefinition :: ByteString -> Eventless (Schema VALID) parseTypeSystemDefinition = P.parseSchema >=> validateSchema True Config { debug = False, validationMode = FULL_VALIDATION } parseTypeDefinitions :: ByteString -> Eventless [TypeDefinition ANY CONST] parseTypeDefinitions = P.parseTypeDefinitions parseRequest :: GQLRequest -> Eventless GQLQuery parseRequest = parseGQL parseRequestWith :: Config -> Schema VALID -> GQLRequest -> Eventless (Operation VALID) parseRequestWith config schema req = do qu <- parseRequest req fuillSchema <- internalSchema <:> schema validateRequest config fuillSchema qu