Documentation ¶
Index ¶
- Constants
- Variables
- func CycleErrorMessage(fragName string, spreadNames []string) string
- func FieldASTsToNodeASTs(fieldASTs []*ast.Field) []ast.Node
- func IsAbstractType(ttype any) bool
- func IsCompositeType(ttype any) bool
- func IsInputType(ttype Type) bool
- func IsLeafType(ttype Type) bool
- func IsOutputType(ttype Type) bool
- func MisplaceDirectiveMessage(directiveName, location string) string
- func NewLocatedError(err any, nodes []ast.Node) *gqlerrors.Error
- func RequestTypeNames(doc *ast.Document)
- func UndefinedFieldMessage(fieldName string, ttypeName string, suggestedTypeNames []string, ...) string
- func UndefinedVarMessage(varName string, opName string) string
- func UnusedVariableMessage(varName string, opName string) string
- func VisitUsingRules(schema *Schema, typeInfo *TypeInfo, astDoc *ast.Document, ...) []gqlerrors.FormattedError
- type Abstract
- type Argument
- type ArgumentConfig
- type BuildExecutionCtxParams
- type CollectFieldsParams
- type Composite
- type Directive
- type DirectiveConfig
- type Enum
- func (gt *Enum) Description() string
- func (gt *Enum) Error() error
- func (gt *Enum) Name() string
- func (gt *Enum) ParseLiteral(valueAST ast.Value) any
- func (gt *Enum) ParseValue(value any) any
- func (gt *Enum) Serialize(value any) any
- func (gt *Enum) String() string
- func (gt *Enum) Values() []*EnumValueDefinition
- type EnumConfig
- type EnumValueConfig
- type EnumValueConfigMap
- type EnumValueDefinition
- type ExecuteFieldsParams
- type ExecuteOperationParams
- type ExecuteParams
- type ExecutionContext
- type Field
- type FieldArgument
- type FieldConfigArgument
- type FieldDefinition
- type FieldDefinitionMap
- type FieldResolveFn
- type Fields
- type FieldsThunk
- type HasSelectionSet
- type Input
- type InputObject
- func (gt *InputObject) AddInputField(fieldName string, fieldConfig *InputObjectFieldConfig)
- func (gt *InputObject) Description() string
- func (gt *InputObject) Error() error
- func (gt *InputObject) Fields() InputObjectFieldMap
- func (gt *InputObject) Name() string
- func (gt *InputObject) String() string
- type InputObjectConfig
- type InputObjectConfigFieldMap
- type InputObjectConfigFieldMapThunk
- type InputObjectField
- type InputObjectFieldConfig
- type InputObjectFieldMap
- type InputObjectFields
- type Interface
- type InterfaceConfig
- type InterfacesThunk
- type IsTypeOfFn
- type IsTypeOfParams
- type Leaf
- type List
- type Named
- type NonNull
- type Nullable
- type Object
- type ObjectConfig
- type Output
- type Params
- type ParseLiteralFn
- type ParseValueFn
- type ResolveInfo
- type ResolveParams
- type ResolveTypeFn
- type ResolveTypeParams
- type Result
- type Scalar
- type ScalarConfig
- type Schema
- func (gq *Schema) Directive(name string) *Directive
- func (gq *Schema) Directives() []*Directive
- func (gq *Schema) IsPossibleType(abstractType Abstract, possibleType *Object) bool
- func (gq *Schema) MutationType() *Object
- func (gq *Schema) PossibleTypes(abstractType Abstract) []*Object
- func (gq *Schema) QueryType() *Object
- func (gq *Schema) SubscriptionType() *Object
- func (gq *Schema) Type(name string) Type
- func (gq *Schema) TypeMap() TypeMap
- type SchemaConfig
- type SerializeFn
- type Type
- type TypeInfo
- func (ti *TypeInfo) Argument() *Argument
- func (ti *TypeInfo) Directive() *Directive
- func (ti *TypeInfo) Enter(node ast.Node)
- func (ti *TypeInfo) FieldDef() *FieldDefinition
- func (ti *TypeInfo) InputType() Input
- func (ti *TypeInfo) Leave(node ast.Node)
- func (ti *TypeInfo) ParentType() Composite
- func (ti *TypeInfo) Type() Output
- type TypeInfoConfig
- type TypeMap
- type Union
- type UnionConfig
- type ValidationContext
- func (ctx *ValidationContext) Argument() *Argument
- func (ctx *ValidationContext) Directive() *Directive
- func (ctx *ValidationContext) Document() *ast.Document
- func (ctx *ValidationContext) Errors() []gqlerrors.FormattedError
- func (ctx *ValidationContext) FieldDef() *FieldDefinition
- func (ctx *ValidationContext) Fragment(name string) *ast.FragmentDefinition
- func (ctx *ValidationContext) FragmentSpreads(node HasSelectionSet) []*ast.FragmentSpread
- func (ctx *ValidationContext) InputType() Input
- func (ctx *ValidationContext) ParentType() Composite
- func (ctx *ValidationContext) RecursiveVariableUsages(operation *ast.OperationDefinition) []*VariableUsage
- func (ctx *ValidationContext) RecursivelyReferencedFragments(operation *ast.OperationDefinition) []*ast.FragmentDefinition
- func (ctx *ValidationContext) ReportError(err error)
- func (ctx *ValidationContext) Schema() *Schema
- func (ctx *ValidationContext) Type() Output
- func (ctx *ValidationContext) VariableUsages(node HasSelectionSet) []*VariableUsage
- type ValidationResult
- type ValidationRuleFn
- type ValidationRuleInstance
- func ArgumentsOfCorrectTypeRule(context *ValidationContext) *ValidationRuleInstance
- func DefaultValuesOfCorrectTypeRule(context *ValidationContext) *ValidationRuleInstance
- func FieldsOnCorrectTypeRule(context *ValidationContext) *ValidationRuleInstance
- func FragmentsOnCompositeTypesRule(context *ValidationContext) *ValidationRuleInstance
- func KnownArgumentNamesRule(context *ValidationContext) *ValidationRuleInstance
- func KnownDirectivesRule(context *ValidationContext) *ValidationRuleInstance
- func KnownFragmentNamesRule(context *ValidationContext) *ValidationRuleInstance
- func KnownTypeNamesRule(context *ValidationContext) *ValidationRuleInstance
- func LoneAnonymousOperationRule(context *ValidationContext) *ValidationRuleInstance
- func NoFragmentCyclesRule(context *ValidationContext) *ValidationRuleInstance
- func NoUndefinedVariablesRule(context *ValidationContext) *ValidationRuleInstance
- func NoUnusedFragmentsRule(context *ValidationContext) *ValidationRuleInstance
- func NoUnusedVariablesRule(context *ValidationContext) *ValidationRuleInstance
- func OverlappingFieldsCanBeMergedRule(context *ValidationContext) *ValidationRuleInstance
- func PossibleFragmentSpreadsRule(context *ValidationContext) *ValidationRuleInstance
- func ProvidedNonNullArgumentsRule(context *ValidationContext) *ValidationRuleInstance
- func ScalarLeafsRule(context *ValidationContext) *ValidationRuleInstance
- func UniqueArgumentNamesRule(context *ValidationContext) *ValidationRuleInstance
- func UniqueFragmentNamesRule(context *ValidationContext) *ValidationRuleInstance
- func UniqueInputFieldNamesRule(context *ValidationContext) *ValidationRuleInstance
- func UniqueOperationNamesRule(context *ValidationContext) *ValidationRuleInstance
- func UniqueVariableNamesRule(context *ValidationContext) *ValidationRuleInstance
- func VariablesAreInputTypesRule(context *ValidationContext) *ValidationRuleInstance
- func VariablesInAllowedPositionRule(context *ValidationContext) *ValidationRuleInstance
- type VariableUsage
Constants ¶
const ( // Operations DirectiveLocationQuery = "QUERY" DirectiveLocationMutation = "MUTATION" DirectiveLocationSubscription = "SUBSCRIPTION" DirectiveLocationField = "FIELD" DirectiveLocationFragmentDefinition = "FRAGMENT_DEFINITION" DirectiveLocationFragmentSpread = "FRAGMENT_SPREAD" DirectiveLocationInlineFragment = "INLINE_FRAGMENT" // Schema Definitions DirectiveLocationSchema = "SCHEMA" DirectiveLocationScalar = "SCALAR" DirectiveLocationObject = "OBJECT" DirectiveLocationFieldDefinition = "FIELD_DEFINITION" DirectiveLocationArgumentDefinition = "ARGUMENT_DEFINITION" DirectiveLocationInterface = "INTERFACE" DirectiveLocationUnion = "UNION" DirectiveLocationEnum = "ENUM" DirectiveLocationEnumValue = "ENUM_VALUE" DirectiveLocationInputObject = "INPUT_OBJECT" DirectiveLocationInputFieldDefinition = "INPUT_FIELD_DEFINITION" )
const ( TypeKindScalar = "SCALAR" TypeKindObject = "OBJECT" TypeKindInterface = "INTERFACE" TypeKindUnion = "UNION" TypeKindEnum = "ENUM" TypeKindInputObject = "INPUT_OBJECT" TypeKindList = "LIST" TypeKindNonNull = "NON_NULL" )
const DefaultDeprecationReason = "No longer supported"
DefaultDeprecationReason Constant string used for default reason for a deprecation.
Variables ¶
var Boolean = NewScalar(ScalarConfig{ Name: "Boolean", Description: "The `Boolean` scalar type represents `true` or `false`.", Serialize: coerceBool, ParseValue: coerceBool, ParseLiteral: func(valueAST ast.Value) any { switch valueAST := valueAST.(type) { case *ast.BooleanValue: return valueAST.Value } return nil }, })
Boolean is the GraphQL boolean type definition
var DeprecatedDirective = NewDirective(DirectiveConfig{ Name: "deprecated", Description: "Marks an element of a GraphQL schema as no longer supported.", Args: FieldConfigArgument{ "reason": &ArgumentConfig{ Type: String, Description: "Explains why this element was deprecated, usually also including a " + "suggestion for how to access supported similar data. Formatted" + "in [Markdown](https://daringfireball.net/projects/markdown/).", DefaultValue: DefaultDeprecationReason, }, }, Locations: []string{ DirectiveLocationFieldDefinition, DirectiveLocationEnumValue, }, })
DeprecatedDirective Used to declare element of a GraphQL schema as deprecated.
var Float = NewScalar(ScalarConfig{ Name: "Float", Description: "The `Float` scalar type represents signed double-precision fractional " + "values as specified by " + "[IEEE 754](http://en.wikipedia.org/wiki/IEEE_floating_point). ", Serialize: coerceFloat64, ParseValue: coerceFloat64, ParseLiteral: func(valueAST ast.Value) any { switch valueAST := valueAST.(type) { case *ast.FloatValue: if floatValue, err := strconv.ParseFloat(valueAST.Value, 64); err == nil { return floatValue } case *ast.IntValue: if floatValue, err := strconv.ParseFloat(valueAST.Value, 64); err == nil { return floatValue } } return nil }, })
Float is the GraphQL float type definition.
var ID = NewScalar(ScalarConfig{ Name: "ID", Description: "The `ID` scalar type represents a unique identifier, often used to " + "refetch an object or as key for a cache. The ID type appears in a JSON " + "response as a String; however, it is not intended to be human-readable. " + "When expected as an input type, any string (such as `\"4\"`) or integer " + "(such as `4`) input value will be accepted as an ID.", Serialize: coerceString, ParseValue: coerceString, ParseLiteral: func(valueAST ast.Value) any { switch valueAST := valueAST.(type) { case *ast.IntValue: return valueAST.Value case *ast.StringValue: return valueAST.Value } return nil }, })
ID is the GraphQL id type definition
var IncludeDirective = NewDirective(DirectiveConfig{ Name: "include", Description: "Directs the executor to include this field or fragment only when " + "the `if` argument is true.", Locations: []string{ DirectiveLocationField, DirectiveLocationFragmentSpread, DirectiveLocationInlineFragment, }, Args: FieldConfigArgument{ "if": &ArgumentConfig{ Type: NewNonNull(Boolean), Description: "Included when true.", }, }, })
IncludeDirective is used to conditionally include fields or fragments.
var Int = NewScalar(ScalarConfig{ Name: "Int", Description: "The `Int` scalar type represents non-fractional signed whole numeric " + "values. Int can represent values between -(2^31) and 2^31 - 1. ", Serialize: coerceInt, ParseValue: coerceInt, ParseLiteral: func(valueAST ast.Value) any { switch valueAST := valueAST.(type) { case *ast.IntValue: if intValue, err := strconv.Atoi(valueAST.Value); err == nil { return intValue } } return nil }, })
Int is the GraphQL Integer type definition.
var NameRegExp = regexp.MustCompile("^[_a-zA-Z][_a-zA-Z0-9]*$")
var SkipDirective = NewDirective(DirectiveConfig{ Name: "skip", Description: "Directs the executor to skip this field or fragment when the `if` " + "argument is true.", Args: FieldConfigArgument{ "if": &ArgumentConfig{ Type: NewNonNull(Boolean), Description: "Skipped when true.", }, }, Locations: []string{ DirectiveLocationField, DirectiveLocationFragmentSpread, DirectiveLocationInlineFragment, }, })
SkipDirective Used to conditionally skip (exclude) fields or fragments.
var SpecifiedDirectives = []*Directive{ IncludeDirective, SkipDirective, DeprecatedDirective, }
SpecifiedRules The full list of specified directives.
var SpecifiedRules = []ValidationRuleFn{ ArgumentsOfCorrectTypeRule, DefaultValuesOfCorrectTypeRule, FieldsOnCorrectTypeRule, FragmentsOnCompositeTypesRule, KnownArgumentNamesRule, KnownDirectivesRule, KnownFragmentNamesRule, KnownTypeNamesRule, LoneAnonymousOperationRule, NoFragmentCyclesRule, NoUndefinedVariablesRule, NoUnusedFragmentsRule, NoUnusedVariablesRule, PossibleFragmentSpreadsRule, ProvidedNonNullArgumentsRule, ScalarLeafsRule, UniqueArgumentNamesRule, UniqueFragmentNamesRule, UniqueInputFieldNamesRule, UniqueOperationNamesRule, UniqueVariableNamesRule, VariablesAreInputTypesRule, VariablesInAllowedPositionRule, }
SpecifiedRules set includes all validation rules defined by the GraphQL spec.
var String = NewScalar(ScalarConfig{ Name: "String", Description: "The `String` scalar type represents textual data, represented as UTF-8 " + "character sequences. The String type is most often used by GraphQL to " + "represent free-form human-readable text.", Serialize: coerceString, ParseValue: coerceString, ParseLiteral: func(valueAST ast.Value) any { switch valueAST := valueAST.(type) { case *ast.StringValue: return valueAST.Value } return nil }, })
String is the GraphQL string type definition
Functions ¶
func CycleErrorMessage ¶
func IsAbstractType ¶
func IsCompositeType ¶
IsCompositeType determines if given type is a GraphQLComposite type
func IsInputType ¶
IsInputType determines if given type is a GraphQLInputType
func IsLeafType ¶
IsLeafType determines if given type is a leaf value
func IsOutputType ¶
IsOutputType determines if given type is a GraphQLOutputType
func RequestTypeNames ¶
RequestTypeNames rewrites an ast document to include __typename in all selection sets.
func UndefinedFieldMessage ¶
func UndefinedVarMessage ¶
func UnusedVariableMessage ¶
func VisitUsingRules ¶
func VisitUsingRules(schema *Schema, typeInfo *TypeInfo, astDoc *ast.Document, rules []ValidationRuleFn) []gqlerrors.FormattedError
VisitUsingRules This uses a specialized visitor which runs multiple visitors in parallel, while maintaining the visitor skip and break API.
@internal Had to expose it to unit test experimental customizable validation feature, but not meant for public consumption
Types ¶
type Abstract ¶
type Abstract interface {
Name() string
}
Abstract interface for types that may describe the parent context of a selection set.
type Argument ¶
type Argument struct { PrivateName string `json:"name"` Type Input `json:"type"` DefaultValue any `json:"defaultValue"` PrivateDescription string `json:"description"` }
func (*Argument) Description ¶
type ArgumentConfig ¶
type BuildExecutionCtxParams ¶
type BuildExecutionCtxParams struct { Schema Schema Root any AST *ast.Document OperationName string Args map[string]any Errors []gqlerrors.FormattedError Result *Result DeprecatedFieldFn func(context.Context, *Object, *FieldDefinition) error // TODO: Abstract this to possibly handle more types FieldDefinitionDirectiveHandler func(context.Context, *ast.Directive, *FieldDefinition) error DisallowIntrospection bool }
type CollectFieldsParams ¶
type CollectFieldsParams struct { ExeContext *ExecutionContext RuntimeType *Object // previously known as OperationType SelectionSet *ast.SelectionSet Fields map[string][]*ast.Field VisitedFragmentNames map[string]struct{} }
type Composite ¶
Composite interface for types that may describe the parent context of a selection set.
type Directive ¶
type Directive struct { Name string `json:"name"` Description string `json:"description"` Locations []string `json:"locations"` Args []*Argument `json:"args"` // contains filtered or unexported fields }
Directive structs are used by the GraphQL runtime as a way of modifying execution behavior. Type system creators will usually not create these directly.
func NewDirective ¶
func NewDirective(config DirectiveConfig) *Directive
type DirectiveConfig ¶
type DirectiveConfig struct { Name string `json:"name"` Description string `json:"description"` Locations []string `json:"locations"` Args FieldConfigArgument `json:"args"` }
DirectiveConfig options for creating a new GraphQLDirective
type Enum ¶
type Enum struct { PrivateName string `json:"name"` PrivateDescription string `json:"description"` // contains filtered or unexported fields }
var DirectiveLocationEnumType *Enum
DirectiveLocationEnumType is type definition for __DirectiveLocation
var TypeKindEnumType *Enum
TypeKindEnumType is type definition for __TypeKind
func NewEnum ¶
func NewEnum(config EnumConfig) *Enum
func (*Enum) Description ¶
func (*Enum) ParseValue ¶
func (*Enum) Values ¶
func (gt *Enum) Values() []*EnumValueDefinition
type EnumConfig ¶
type EnumConfig struct { Name string `json:"name"` Values EnumValueConfigMap `json:"values"` Description string `json:"description"` }
type EnumValueConfig ¶
type EnumValueConfigMap ¶
type EnumValueConfigMap map[string]*EnumValueConfig
type EnumValueDefinition ¶
type ExecuteFieldsParams ¶
type ExecuteOperationParams ¶
type ExecuteOperationParams struct { ExecutionContext *ExecutionContext Root any Operation ast.Definition }
type ExecuteParams ¶
type ExecuteParams struct { Schema Schema Root any AST *ast.Document OperationName string Args map[string]any DeprecatedFieldFn func(ctx context.Context, parent *Object, fieldDef *FieldDefinition) error // TODO: Abstract this to possibly handle more types FieldDefinitionDirectiveHandler func(context.Context, *ast.Directive, *FieldDefinition) error DisallowIntrospection bool // TimeoutWait is the amount of time to allow for resolvers to handle // a context deadline error before the executor does. TimeoutWait time.Duration }
type ExecutionContext ¶
type ExecutionContext struct { Schema Schema Fragments map[string]*ast.FragmentDefinition Root any Operation ast.Definition VariableValues map[string]any Errors []gqlerrors.FormattedError DeprecatedFieldFn func(context.Context, *Object, *FieldDefinition) error // TODO: Abstract this to possibly handle more types FieldDefinitionDirectiveHandler func(context.Context, *ast.Directive, *FieldDefinition) error DisallowIntrospection bool }
type Field ¶
type Field struct { Name string `json:"name"` // used by graphlql-relay Type Output `json:"type"` Args FieldConfigArgument `json:"args"` Resolve FieldResolveFn DeprecationReason string `json:"deprecationReason,omitempty"` Description string `json:"description"` Directives []*ast.Directive `json:"directives,omitempty"` }
type FieldArgument ¶
type FieldConfigArgument ¶
type FieldConfigArgument map[string]*ArgumentConfig
type FieldDefinition ¶
type FieldDefinition struct { Name string `json:"name"` Description string `json:"description"` Type Output `json:"type"` Args []*Argument `json:"args"` Resolve FieldResolveFn `json:"-"` DeprecationReason string `json:"deprecationReason,omitempty"` Directives []*ast.Directive `json:"directives,omitempty"` }
var SchemaMetaFieldDef *FieldDefinition
SchemaMetaFieldDef Meta field definition for Schema
var TypeMetaFieldDef *FieldDefinition
TypeMetaFieldDef Meta field definition for types
var TypeNameMetaFieldDef *FieldDefinition
TypeNameMetaFieldDef Meta field definition for type names
func DefaultTypeInfoFieldDef ¶
func DefaultTypeInfoFieldDef(schema *Schema, parentType Type, fieldAST *ast.Field) *FieldDefinition
DefaultTypeInfoFieldDef Not exactly the same as the executor's definition of FieldDef, in this statically evaluated environment we do not always have an Object type, and need to handle Interface and Union types.
type FieldDefinitionMap ¶
type FieldDefinitionMap map[string]*FieldDefinition
type FieldResolveFn ¶
type FieldResolveFn func(ctx context.Context, p ResolveParams) (any, error)
type FieldsThunk ¶
type FieldsThunk func() Fields
type HasSelectionSet ¶
type HasSelectionSet interface { GetLoc() ast.Location GetSelectionSet() *ast.SelectionSet }
type Input ¶
Input interface for types that may be used as input types for arguments and directives.
type InputObject ¶
type InputObject struct { PrivateName string `json:"name"` PrivateDescription string `json:"description"` // contains filtered or unexported fields }
InputObject Type Definition
An input object defines a structured collection of fields which may be supplied to a field argument.
Using `NonNull` will ensure that a value must be provided by the query ¶
Example:
var GeoPoint = new InputObject({ name: 'GeoPoint', fields: { lat: { type: new NonNull(Float) }, lon: { type: new NonNull(Float) }, alt: { type: Float, defaultValue: 0 }, } });
func NewInputObject ¶
func NewInputObject(config InputObjectConfig) *InputObject
func (*InputObject) AddInputField ¶
func (gt *InputObject) AddInputField(fieldName string, fieldConfig *InputObjectFieldConfig)
func (*InputObject) Description ¶
func (gt *InputObject) Description() string
func (*InputObject) Error ¶
func (gt *InputObject) Error() error
func (*InputObject) Fields ¶
func (gt *InputObject) Fields() InputObjectFieldMap
func (*InputObject) Name ¶
func (gt *InputObject) Name() string
func (*InputObject) String ¶
func (gt *InputObject) String() string
type InputObjectConfig ¶
type InputObjectConfigFieldMap ¶
type InputObjectConfigFieldMap map[string]*InputObjectFieldConfig
type InputObjectConfigFieldMapThunk ¶
type InputObjectConfigFieldMapThunk func() InputObjectConfigFieldMap
type InputObjectField ¶
type InputObjectField struct { PrivateName string `json:"name"` Type Input `json:"type"` DefaultValue any `json:"defaultValue"` PrivateDescription string `json:"description"` }
func (*InputObjectField) Description ¶
func (st *InputObjectField) Description() string
func (*InputObjectField) Error ¶
func (st *InputObjectField) Error() error
func (*InputObjectField) Name ¶
func (st *InputObjectField) Name() string
func (*InputObjectField) String ¶
func (st *InputObjectField) String() string
type InputObjectFieldConfig ¶
type InputObjectFieldMap ¶
type InputObjectFieldMap map[string]*InputObjectField
type InputObjectFields ¶
type InputObjectFields map[string]*InputObjectField
type Interface ¶
type Interface struct { PrivateName string `json:"name"` PrivateDescription string `json:"description"` ResolveType ResolveTypeFn // contains filtered or unexported fields }
Interface Type Definition
When a field can return one of a heterogeneous set of types, a Interface type is used to describe what types are possible, what fields are in common across all types, as well as a function to determine which type is actually used when the field is resolved.
Example:
var EntityType = new Interface({ name: 'Entity', fields: { name: { type: String } } });
func NewInterface ¶
func NewInterface(config InterfaceConfig) *Interface
func (*Interface) AddFieldConfig ¶
func (*Interface) Description ¶
func (*Interface) Fields ¶
func (it *Interface) Fields() FieldDefinitionMap
type InterfaceConfig ¶
type InterfaceConfig struct { Name string `json:"name"` Fields any `json:"fields"` ResolveType ResolveTypeFn Description string `json:"description"` }
type InterfacesThunk ¶
type InterfacesThunk func() []*Interface
type IsTypeOfFn ¶
type IsTypeOfFn func(p IsTypeOfParams) bool
type IsTypeOfParams ¶
type IsTypeOfParams struct { // Value that needs to be resolve. // Use this to decide which GraphQLObject this value maps to. Value any // Info is a collection of information about the current execution state. Info ResolveInfo }
IsTypeOfParams Params for IsTypeOfFn()
type Leaf ¶
type Leaf interface { Name() string Description() string String() string Error() error Serialize(value any) any }
Leaf interface for types that may be leaf values
type List ¶
type List struct { OfType Type `json:"ofType"` // contains filtered or unexported fields }
List Modifier
A list is a kind of type marker, a wrapping type which points to another type. Lists are often created within the context of defining the fields of an object type.
Example:
var PersonType = new Object({ name: 'Person', fields: () => ({ parents: { type: new List(Person) }, children: { type: new List(Person) }, }) })
func (*List) Description ¶
type Named ¶
type Named interface {
String() string
}
Named interface for types that do not include modifiers like List or NonNull.
type NonNull ¶
type NonNull struct { OfType Type `json:"ofType"` // contains filtered or unexported fields }
NonNull Modifier
A non-null is a kind of type marker, a wrapping type which points to another type. Non-null types enforce that their values are never null and can ensure an error is raised if this ever occurs during a request. It is useful for fields which you can make a strong guarantee on non-nullability, for example usually the id field of a database row will never be null.
Example:
var RowType = new Object({ name: 'Row', fields: () => ({ id: { type: new NonNull(String) }, }) })
Note: the enforcement of non-nullability occurs within the executor.
func NewNonNull ¶
func (*NonNull) Description ¶
type Nullable ¶
type Nullable interface { }
Nullable interface for types that can accept null as a value.
func GetNullable ¶
GetNullable returns the Nullable type of the given GraphQL type
type Object ¶
type Object struct { PrivateName string `json:"name"` PrivateDescription string `json:"description"` IsTypeOf IsTypeOfFn // contains filtered or unexported fields }
Object Type Definition
Almost all of the GraphQL types you define will be object Object types have a name, but most importantly describe their fields. Example:
var AddressType = new Object({ name: 'Address', fields: { street: { type: String }, number: { type: Int }, formatted: { type: String, resolve(obj) { return obj.number + ' ' + obj.street } } } });
When two types need to refer to each other, or a type needs to refer to itself in a field, you can use a function expression (aka a closure or a thunk) to supply the fields lazily.
Example:
var PersonType = new Object({ name: 'Person', fields: () => ({ name: { type: String }, bestFriend: { type: PersonType }, }) });
/
var DirectiveType *Object
DirectiveType is type definition for __Directive
var EnumValueType *Object
EnumValueType is type definition for __EnumValue
var FieldType *Object
FieldType is type definition for __Field
var InputValueType *Object
InputValueType is type definition for __InputValue
var SchemaType *Object
SchemaType is type definition for __Schema
var TypeType *Object
TypeType is type definition for __Type
func NewObject ¶
func NewObject(config ObjectConfig) *Object
func (*Object) AddFieldConfig ¶
func (*Object) Description ¶
func (*Object) Fields ¶
func (gt *Object) Fields() FieldDefinitionMap
func (*Object) Interfaces ¶
type ObjectConfig ¶
type ObjectConfig struct { Name string `json:"name"` Interfaces any `json:"interfaces"` Fields any `json:"fields"` IsTypeOf IsTypeOfFn `json:"isTypeOf"` Description string `json:"description"` }
type Params ¶
type Params struct { // Schema is the GraphQL type system to use when validating and executing a query. Schema Schema // RequestString is a GraphQL language formatted string representing the requested operation. RequestString string // RootObject is the value provided as the first argument to resolver functions on the top // level type (e.g. the query object type). RootObject map[string]any // VariableValues is a mapping of variable name to runtime value to use for all variables // defined in the requestString. VariableValues map[string]any // OperationName is the name of the operation to use if requestString contains multiple // possible operations. Can be omitted if requestString contains only // one operation. OperationName string }
type ParseLiteralFn ¶
ParseLiteralFn is a function type for parsing the literal value of a GraphQLScalar type
type ParseValueFn ¶
ParseValueFn is a function type for parsing the value of a GraphQLScalar type
type ResolveInfo ¶
type ResolveParams ¶
type ResolveParams struct { // Source is the source value Source any // Args is a map of arguments for current GraphQL request Args map[string]any // Info is a collection of information about the current execution state. Info ResolveInfo }
ResolveParams Params for FieldResolveFn()
type ResolveTypeFn ¶
type ResolveTypeFn func(ctx context.Context, p ResolveTypeParams) *Object
type ResolveTypeParams ¶
type ResolveTypeParams struct { // Value that needs to be resolve. // Use this to decide which GraphQLObject this value maps to. Value any // Info is a collection of information about the current execution state. Info ResolveInfo }
ResolveTypeParams Params for ResolveTypeFn()
type Result ¶
type Result struct { Data any `json:"data"` Errors []gqlerrors.FormattedError `json:"errors,omitempty"` }
type Scalar ¶
type Scalar struct { PrivateName string `json:"name"` PrivateDescription string `json:"description"` // contains filtered or unexported fields }
Scalar Type Definition
The leaf values of any request and input values to arguments are Scalars (or Enums) and are defined with a name and a series of functions used to parse input from ast or variables and to ensure validity.
Example:
var OddType = new Scalar({ name: 'Odd', serialize(value) { return value % 2 === 1 ? value : null; } });
func (*Scalar) Description ¶
func (*Scalar) ParseValue ¶
type ScalarConfig ¶
type ScalarConfig struct { Name string `json:"name"` Description string `json:"description"` Serialize SerializeFn ParseValue ParseValueFn ParseLiteral ParseLiteralFn }
ScalarConfig options for creating a new GraphQLScalar
type Schema ¶
type Schema struct {
// contains filtered or unexported fields
}
Schema Definition A Schema is created by supplying the root types of each type of operation, query, mutation (optional) and subscription (optional). A schema definition is then supplied to the validator and executor. Example:
myAppSchema, err := NewSchema(SchemaConfig({ Query: MyAppQueryRootType, Mutation: MyAppMutationRootType, Subscription: MyAppSubscriptionRootType, });
Note: If an array of `directives` are provided to GraphQLSchema, that will be the exact list of directives represented and allowed. If `directives` is not provided then a default set of the specified directives (e.g. @include and @skip) will be used. If you wish to provide *additional* directives to these specified directives, you must explicitly declare them. Example:
const MyAppSchema = new GraphQLSchema({ ... directives: specifiedDirectives.concat([ myCustomDirective ]), })
func NewSchema ¶
func NewSchema(config SchemaConfig) (Schema, error)
func (*Schema) Directives ¶
func (*Schema) IsPossibleType ¶
func (*Schema) MutationType ¶
func (*Schema) PossibleTypes ¶
func (*Schema) SubscriptionType ¶
type SchemaConfig ¶
type SerializeFn ¶
SerializeFn is a function type for serializing a GraphQLScalar type value
type TypeInfo ¶
type TypeInfo struct {
// contains filtered or unexported fields
}
func NewTypeInfo ¶
func NewTypeInfo(opts *TypeInfoConfig) *TypeInfo
func (*TypeInfo) FieldDef ¶
func (ti *TypeInfo) FieldDef() *FieldDefinition
func (*TypeInfo) ParentType ¶
type TypeInfoConfig ¶
type TypeInfoConfig struct { Schema *Schema // NOTE: this experimental optional second parameter is only needed in order // to support non-spec-compliant codebases. You should never need to use it. // It may disappear in the future. FieldDefFn fieldDefFn }
type Union ¶
type Union struct { PrivateName string `json:"name"` PrivateDescription string `json:"description"` ResolveType ResolveTypeFn // contains filtered or unexported fields }
Union Type Definition
When a field can return one of a heterogeneous set of types, a Union type is used to describe what types are possible as well as providing a function to determine which type is actually used when the field is resolved.
Example:
var PetType = new Union({ name: 'Pet', types: [ DogType, CatType ], resolveType(value) { if (value instanceof Dog) { return DogType; } if (value instanceof Cat) { return CatType; } } });
func NewUnion ¶
func NewUnion(config UnionConfig) *Union
func (*Union) Description ¶
type UnionConfig ¶
type UnionConfig struct { Name string `json:"name"` Types []*Object `json:"types"` ResolveType ResolveTypeFn Description string `json:"description"` }
type ValidationContext ¶
type ValidationContext struct {
// contains filtered or unexported fields
}
func NewValidationContext ¶
func NewValidationContext(schema *Schema, astDoc *ast.Document, typeInfo *TypeInfo) *ValidationContext
func (*ValidationContext) Argument ¶
func (ctx *ValidationContext) Argument() *Argument
func (*ValidationContext) Directive ¶
func (ctx *ValidationContext) Directive() *Directive
func (*ValidationContext) Document ¶
func (ctx *ValidationContext) Document() *ast.Document
func (*ValidationContext) Errors ¶
func (ctx *ValidationContext) Errors() []gqlerrors.FormattedError
func (*ValidationContext) FieldDef ¶
func (ctx *ValidationContext) FieldDef() *FieldDefinition
func (*ValidationContext) Fragment ¶
func (ctx *ValidationContext) Fragment(name string) *ast.FragmentDefinition
func (*ValidationContext) FragmentSpreads ¶
func (ctx *ValidationContext) FragmentSpreads(node HasSelectionSet) []*ast.FragmentSpread
func (*ValidationContext) InputType ¶
func (ctx *ValidationContext) InputType() Input
func (*ValidationContext) ParentType ¶
func (ctx *ValidationContext) ParentType() Composite
func (*ValidationContext) RecursiveVariableUsages ¶
func (ctx *ValidationContext) RecursiveVariableUsages(operation *ast.OperationDefinition) []*VariableUsage
func (*ValidationContext) RecursivelyReferencedFragments ¶
func (ctx *ValidationContext) RecursivelyReferencedFragments(operation *ast.OperationDefinition) []*ast.FragmentDefinition
func (*ValidationContext) ReportError ¶
func (ctx *ValidationContext) ReportError(err error)
func (*ValidationContext) Schema ¶
func (ctx *ValidationContext) Schema() *Schema
func (*ValidationContext) Type ¶
func (ctx *ValidationContext) Type() Output
func (*ValidationContext) VariableUsages ¶
func (ctx *ValidationContext) VariableUsages(node HasSelectionSet) []*VariableUsage
type ValidationResult ¶
type ValidationResult struct { IsValid bool Errors []gqlerrors.FormattedError }
func ValidateDocument ¶
func ValidateDocument(schema *Schema, astDoc *ast.Document, rules []ValidationRuleFn) (vr ValidationResult)
ValidateDocument implements the "Validation" section of the spec.
Validation runs synchronously, returning an array of encountered errors, or an empty array if no errors were encountered and the document is valid.
A list of specific validation rules may be provided. If not provided, the default list of rules defined by the GraphQL specification will be used.
Each validation rules is a function which returns a visitor (see the language/visitor API). Visitor methods are expected to return GraphQLErrors, or Arrays of GraphQLErrors when invalid.
type ValidationRuleFn ¶
type ValidationRuleFn func(context *ValidationContext) *ValidationRuleInstance
type ValidationRuleInstance ¶
func ArgumentsOfCorrectTypeRule ¶
func ArgumentsOfCorrectTypeRule(context *ValidationContext) *ValidationRuleInstance
ArgumentsOfCorrectTypeRule Argument values of correct type
A GraphQL document is only valid if all field argument literal values are of the type expected by their position.
func DefaultValuesOfCorrectTypeRule ¶
func DefaultValuesOfCorrectTypeRule(context *ValidationContext) *ValidationRuleInstance
DefaultValuesOfCorrectTypeRule Variable default values of correct type
A GraphQL document is only valid if all variable default values are of the type expected by their definition.
func FieldsOnCorrectTypeRule ¶
func FieldsOnCorrectTypeRule(context *ValidationContext) *ValidationRuleInstance
FieldsOnCorrectTypeRule Fields on correct type
A GraphQL document is only valid if all fields selected are defined by the parent type, or are an allowed meta field such as __typenamme
func FragmentsOnCompositeTypesRule ¶
func FragmentsOnCompositeTypesRule(context *ValidationContext) *ValidationRuleInstance
FragmentsOnCompositeTypesRule Fragments on composite type
Fragments use a type condition to determine if they apply, since fragments can only be spread into a composite type (object, interface, or union), the type condition must also be a composite type.
func KnownArgumentNamesRule ¶
func KnownArgumentNamesRule(context *ValidationContext) *ValidationRuleInstance
KnownArgumentNamesRule Known argument names
A GraphQL field is only valid if all supplied arguments are defined by that field.
func KnownDirectivesRule ¶
func KnownDirectivesRule(context *ValidationContext) *ValidationRuleInstance
KnownDirectivesRule Known directives
A GraphQL document is only valid if all `@directives` are known by the schema and legally positioned.
func KnownFragmentNamesRule ¶
func KnownFragmentNamesRule(context *ValidationContext) *ValidationRuleInstance
KnownFragmentNamesRule Known fragment names
A GraphQL document is only valid if all `...Fragment` fragment spreads refer to fragments defined in the same document.
func KnownTypeNamesRule ¶
func KnownTypeNamesRule(context *ValidationContext) *ValidationRuleInstance
KnownTypeNamesRule Known type names
A GraphQL document is only valid if referenced types (specifically variable definitions and fragment conditions) are defined by the type schema.
func LoneAnonymousOperationRule ¶
func LoneAnonymousOperationRule(context *ValidationContext) *ValidationRuleInstance
LoneAnonymousOperationRule Lone anonymous operation
A GraphQL document is only valid if when it contains an anonymous operation (the query short-hand) that it contains only that one operation definition.
func NoFragmentCyclesRule ¶
func NoFragmentCyclesRule(context *ValidationContext) *ValidationRuleInstance
NoFragmentCyclesRule No fragment cycles
func NoUndefinedVariablesRule ¶
func NoUndefinedVariablesRule(context *ValidationContext) *ValidationRuleInstance
NoUndefinedVariablesRule No undefined variables
A GraphQL operation is only valid if all variables encountered, both directly and via fragment spreads, are defined by that operation.
func NoUnusedFragmentsRule ¶
func NoUnusedFragmentsRule(context *ValidationContext) *ValidationRuleInstance
NoUnusedFragmentsRule No unused fragments
A GraphQL document is only valid if all fragment definitions are spread within operations, or spread within other fragments spread within operations.
func NoUnusedVariablesRule ¶
func NoUnusedVariablesRule(context *ValidationContext) *ValidationRuleInstance
NoUnusedVariablesRule No unused variables
A GraphQL operation is only valid if all variables defined by an operation are used, either directly or within a spread fragment.
func OverlappingFieldsCanBeMergedRule ¶
func OverlappingFieldsCanBeMergedRule(context *ValidationContext) *ValidationRuleInstance
OverlappingFieldsCanBeMergedRule Overlapping fields can be merged
A selection set is only valid if all fields (including spreading any fragments) either correspond to distinct response names or can be merged without ambiguity.
func PossibleFragmentSpreadsRule ¶
func PossibleFragmentSpreadsRule(context *ValidationContext) *ValidationRuleInstance
PossibleFragmentSpreadsRule Possible fragment spread
A fragment spread is only valid if the type condition could ever possibly be true: if there is a non-empty intersection of the possible parent types, and possible types which pass the type condition.
func ProvidedNonNullArgumentsRule ¶
func ProvidedNonNullArgumentsRule(context *ValidationContext) *ValidationRuleInstance
ProvidedNonNullArgumentsRule Provided required arguments
A field or directive is only valid if all required (non-null) field arguments have been provided.
func ScalarLeafsRule ¶
func ScalarLeafsRule(context *ValidationContext) *ValidationRuleInstance
ScalarLeafsRule Scalar leafs
A GraphQL document is valid only if all leaf fields (fields without sub selections) are of scalar or enum types.
func UniqueArgumentNamesRule ¶
func UniqueArgumentNamesRule(context *ValidationContext) *ValidationRuleInstance
UniqueArgumentNamesRule Unique argument names
A GraphQL field or directive is only valid if all supplied arguments are uniquely named.
func UniqueFragmentNamesRule ¶
func UniqueFragmentNamesRule(context *ValidationContext) *ValidationRuleInstance
UniqueFragmentNamesRule Unique fragment names
A GraphQL document is only valid if all defined fragments have unique names.
func UniqueInputFieldNamesRule ¶
func UniqueInputFieldNamesRule(context *ValidationContext) *ValidationRuleInstance
UniqueInputFieldNamesRule Unique input field names
A GraphQL input object value is only valid if all supplied fields are uniquely named.
func UniqueOperationNamesRule ¶
func UniqueOperationNamesRule(context *ValidationContext) *ValidationRuleInstance
UniqueOperationNamesRule Unique operation names
A GraphQL document is only valid if all defined operations have unique names.
func UniqueVariableNamesRule ¶
func UniqueVariableNamesRule(context *ValidationContext) *ValidationRuleInstance
UniqueVariableNamesRule Unique variable names
A GraphQL operation is only valid if all its variables are uniquely named.
func VariablesAreInputTypesRule ¶
func VariablesAreInputTypesRule(context *ValidationContext) *ValidationRuleInstance
VariablesAreInputTypesRule Variables are input types
A GraphQL operation is only valid if all the variables it defines are of input types (scalar, enum, or input object).
func VariablesInAllowedPositionRule ¶
func VariablesInAllowedPositionRule(context *ValidationContext) *ValidationRuleInstance
VariablesInAllowedPositionRule Variables passed to field arguments conform to type
type VariableUsage ¶
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
cmd
|
|
examples
|
|
Package gqldecode provides a decoder that unmarshals GraphQL input arguments into a struct.
|
Package gqldecode provides a decoder that unmarshals GraphQL input arguments into a struct. |
language
|
|