Documentation ¶
Overview ¶
Package astnormalization helps to transform parsed GraphQL AST's into a easier to use structure.
Example ¶
This examples shows how the normalization package helps "simplifying" a GraphQL AST.
Input:
subscription sub { ... multipleSubscriptions ... on Subscription { newMessage { body sender } } } fragment newMessageFields on Message { body: body sender ... on Body { body } } fragment multipleSubscriptions on Subscription { newMessage { body sender } newMessage { ... newMessageFields } newMessage { body body sender } ... on Subscription { newMessage { body sender } } disallowedSecondRootField }
Output:
subscription sub { newMessage { body sender } disallowedSecondRootField } fragment newMessageFields on Message { body sender } fragment multipleSubscriptions on Subscription { newMessage { body sender } disallowedSecondRootField }
Index ¶
- func NormalizeNamedOperation(operation, definition *ast.Document, operationName []byte, ...)
- func NormalizeOperation(operation, definition *ast.Document, report *operationreport.Report)
- type Depth
- type Depths
- type FragmentDefinitionRemoval
- type FragmentSpreadDepth
- type OperationNormalizer
- type Option
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func NormalizeNamedOperation ¶
func NormalizeNamedOperation(operation, definition *ast.Document, operationName []byte, report *operationreport.Report)
func NormalizeOperation ¶
func NormalizeOperation(operation, definition *ast.Document, report *operationreport.Report)
NormalizeOperation creates a default Normalizer and applies all rules to a given AST In case you're using OperationNormalizer in a hot path you shouldn't be using this function. Create a new OperationNormalizer using NewNormalizer() instead and re-use it.
Types ¶
type Depth ¶
type Depth struct { SpreadRef int Depth int SpreadName ast.ByteSlice // contains filtered or unexported fields }
Depth holds all necessary information to understand the Depth of a Fragment Node
type FragmentDefinitionRemoval ¶
type FragmentDefinitionRemoval struct { }
type FragmentSpreadDepth ¶
type FragmentSpreadDepth struct {
// contains filtered or unexported fields
}
FragmentSpreadDepth is a helper for nested Fragments to calculate the actual depth of a Fragment Node
func (*FragmentSpreadDepth) Get ¶
func (r *FragmentSpreadDepth) Get(operation, definition *ast.Document, report *operationreport.Report, depths *Depths)
Get returns all FragmentSpread Depths for a given AST
type OperationNormalizer ¶
type OperationNormalizer struct {
// contains filtered or unexported fields
}
OperationNormalizer walks a given AST and applies all registered rules
func NewNormalizer ¶
func NewNormalizer(removeFragmentDefinitions, extractVariables bool) *OperationNormalizer
NewNormalizer creates a new OperationNormalizer and sets up all default rules
func NewWithOpts ¶
func NewWithOpts(opts ...Option) *OperationNormalizer
NewWithOpts creates a new OperationNormalizer with Options
func (*OperationNormalizer) NormalizeNamedOperation ¶
func (o *OperationNormalizer) NormalizeNamedOperation(operation, definition *ast.Document, operationName []byte, report *operationreport.Report)
NormalizeNamedOperation applies all registered rules to one specific named operation in the AST
func (*OperationNormalizer) NormalizeOperation ¶
func (o *OperationNormalizer) NormalizeOperation(operation, definition *ast.Document, report *operationreport.Report)
NormalizeOperation applies all registered rules to the AST
type Option ¶
type Option func(options *options)
func WithExtractVariables ¶
func WithExtractVariables() Option
func WithRemoveFragmentDefinitions ¶
func WithRemoveFragmentDefinitions() Option
func WithRemoveUnusedVariables ¶
func WithRemoveUnusedVariables() Option
Source Files ¶
- astnormalization.go
- directive_include_skip.go
- enum_type_extending.go
- field_deduplication.go
- field_selection_merging.go
- fragment_definition_removal.go
- fragment_spread_inlining.go
- fragmentspread_depth.go
- inline_fragment_merging.go
- input_object_type_extending.go
- interface_type_extending.go
- object_type_extending.go
- remove_self_aliasing.go
- remove_type_extensions.go
- scalar_type_extending.go
- union_type_extending.go
- variables_extraction.go
- variables_unused_deletion.go