{-# LANGUAGE PatternSynonyms #-}
module Hasura.GraphQL.Schema.Parser
(
FieldParser,
pattern P.FieldParser,
InputFieldsParser,
pattern P.InputFieldsParser,
Parser,
pattern P.Parser,
Schema,
pattern P.Schema,
ConflictingDefinitions,
pattern P.ConflictingDefinitions,
Definition,
pattern P.Definition,
Type,
Directive,
pattern P.Directive,
DirectiveInfo,
pattern P.DirectiveInfo,
FieldInfo,
pattern P.FieldInfo,
InputFieldInfo,
pattern P.InputFieldInfo,
HasTypeDefinitions,
SomeDefinitionTypeInfo,
pattern P.SomeDefinitionTypeInfo,
TypeDefinitionsWrapper,
pattern TypeDefinitionsWrapper,
P.ParseErrorCode (..),
toQErr,
module Hasura.GraphQL.Parser,
Memoize.MonadMemoize,
memoizeOn,
memoize,
)
where
import Control.Monad.Error.Class
import Control.Monad.Memoize qualified as Memoize
import Data.Typeable
import Hasura.Base.Error
import Hasura.Base.ErrorMessage (ErrorMessage (fromErrorMessage))
import Hasura.GraphQL.Parser hiding
( ConflictingDefinitions (..),
Definition,
Directive,
DirectiveInfo,
FieldInfo,
FieldParser,
HasTypeDefinitions,
InputFieldInfo,
InputFieldsParser,
ParseErrorCode (..),
Parser,
Schema,
SomeDefinitionTypeInfo,
Type,
TypeDefinitionsWrapper,
)
import Hasura.GraphQL.Parser qualified as P
import Hasura.Prelude
import Hasura.RQL.Types.Metadata.Object
import Language.Haskell.TH qualified as TH
type FieldParser = P.FieldParser MetadataObjId
type Parser = P.Parser MetadataObjId
type Schema = P.Schema MetadataObjId
type ConflictingDefinitions = P.ConflictingDefinitions MetadataObjId
type Type = P.Type MetadataObjId
type InputFieldsParser = P.InputFieldsParser MetadataObjId
type Definition = P.Definition MetadataObjId
type Directive = P.Directive MetadataObjId
type DirectiveInfo = P.DirectiveInfo MetadataObjId
type FieldInfo = P.FieldInfo MetadataObjId
type InputFieldInfo = P.InputFieldInfo MetadataObjId
type HasTypeDefinitions = P.HasTypeDefinitions MetadataObjId
type SomeDefinitionTypeInfo = P.SomeDefinitionTypeInfo MetadataObjId
type TypeDefinitionsWrapper = P.TypeDefinitionsWrapper MetadataObjId
pattern TypeDefinitionsWrapper :: () => forall a. HasTypeDefinitions a => a -> TypeDefinitionsWrapper
pattern $bTypeDefinitionsWrapper :: a -> TypeDefinitionsWrapper
$mTypeDefinitionsWrapper :: forall r.
TypeDefinitionsWrapper
-> (forall a. HasTypeDefinitions a => a -> r) -> (Void# -> r) -> r
TypeDefinitionsWrapper typeDef = P.TypeDefinitionsWrapper typeDef
toQErr :: (MonadError QErr m) => Either ParseError a -> m a
toQErr :: Either ParseError a -> m a
toQErr = (ParseError -> m a) -> (a -> m a) -> Either ParseError a -> m a
forall a c b. (a -> c) -> (b -> c) -> Either a b -> c
either (QErr -> m a
forall e (m :: * -> *) a. MonadError e m => e -> m a
throwError (QErr -> m a) -> (ParseError -> QErr) -> ParseError -> m a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ParseError -> QErr
parseErrorToQErr) a -> m a
forall (f :: * -> *) a. Applicative f => a -> f a
pure
where
parseErrorToQErr :: ParseError -> QErr
parseErrorToQErr :: ParseError -> QErr
parseErrorToQErr ParseError {JSONPath
pePath :: ParseError -> JSONPath
pePath :: JSONPath
pePath, ErrorMessage
peMessage :: ParseError -> ErrorMessage
peMessage :: ErrorMessage
peMessage, ParseErrorCode
peCode :: ParseError -> ParseErrorCode
peCode :: ParseErrorCode
peCode} =
(Code -> Text -> QErr
err400 (ParseErrorCode -> Code
parseErrorCodeToCode ParseErrorCode
peCode) (ErrorMessage -> Text
fromErrorMessage ErrorMessage
peMessage)) {qePath :: JSONPath
qePath = JSONPath
pePath}
parseErrorCodeToCode :: P.ParseErrorCode -> Code
parseErrorCodeToCode :: ParseErrorCode -> Code
parseErrorCodeToCode ParseErrorCode
P.ValidationFailed = Code
ValidationFailed
parseErrorCodeToCode ParseErrorCode
P.ParseFailed = Code
ParseFailed
parseErrorCodeToCode ParseErrorCode
P.ConflictingDefinitionsError = Code
Unexpected
parseErrorCodeToCode ParseErrorCode
P.NotSupported = Code
NotSupported
memoizeOn ::
(Memoize.MonadMemoize m, Ord a, Typeable a, Typeable p, MonadParse n, Typeable b) =>
TH.Name ->
a ->
m (p n b) ->
m (p n b)
memoizeOn :: Name -> a -> m (p n b) -> m (p n b)
memoizeOn = Name -> a -> m (p n b) -> m (p n b)
forall (m :: * -> *) a p.
(MonadMemoize m, Ord a, Typeable a, Typeable p) =>
Name -> a -> m p -> m p
Memoize.memoizeOn
memoize ::
(Memoize.MonadMemoize m, Ord a, Typeable a, Typeable p, MonadParse n, Typeable b) =>
TH.Name ->
(a -> m (p n b)) ->
(a -> m (p n b))
memoize :: Name -> (a -> m (p n b)) -> a -> m (p n b)
memoize = Name -> (a -> m (p n b)) -> a -> m (p n b)
forall (m :: * -> *) a p.
(MonadMemoize m, Ord a, Typeable a, Typeable p) =>
Name -> (a -> m p) -> a -> m p
Memoize.memoize