From ea9f24cea78f369bc89ef50cce8c6edc4ee920ed Mon Sep 17 00:00:00 2001 From: Marco Perberschlager Date: Wed, 23 Oct 2024 16:22:21 +0200 Subject: [PATCH] Fixed support for inline fragments --- .../FieldHelper/AbstractFieldHelper.php | 63 +++++++++++++------ 1 file changed, 43 insertions(+), 20 deletions(-) diff --git a/src/GraphQL/FieldHelper/AbstractFieldHelper.php b/src/GraphQL/FieldHelper/AbstractFieldHelper.php index aaf086ac..34e20fb5 100644 --- a/src/GraphQL/FieldHelper/AbstractFieldHelper.php +++ b/src/GraphQL/FieldHelper/AbstractFieldHelper.php @@ -152,29 +152,52 @@ public function processSelections(&$data, $selections, $container, $args, $conte } foreach ($selections as $selectionNode) { - if ($selectionNode instanceof FieldNode) { - $this->doExtractData($selectionNode, $data, $container, $args, $context, $resolveInfo); - } elseif ($selectionNode instanceof InlineFragmentNode) { - $inlineSelectionSetNode = $selectionNode->selectionSet; - /** @var NodeList $inlineSelections */ - $inlineSelections = $inlineSelectionSetNode->selections; - $count = $inlineSelections->count(); - for ($i = 0; $i < $count; $i++) { - $inlineNode = $inlineSelections[$i]; - if ($inlineNode instanceof FieldNode) { - $this->doExtractData($inlineNode, $data, $container, $args, $context, $resolveInfo); - } + $this->processSelectionNode($data, $selectionNode, $container, $args, $context, $resolveInfo); + } + } + + private function processSelectionNode( + &$data, + $selectionNode, + $container, + $args, + $context, + ResolveInfo $resolveInfo + ): void + { + if(!$selectionNode) { + return; + } + + if ($selectionNode instanceof FieldNode) { + $this->doExtractData($selectionNode, $data, $container, $args, $context, $resolveInfo); + } elseif ($selectionNode instanceof InlineFragmentNode) { + $inlineSelectionSetNode = $selectionNode->selectionSet; + /** @var NodeList $inlineSelections */ + $inlineSelections = $inlineSelectionSetNode->selections; + $count = $inlineSelections->count(); + for ($i = 0; $i < $count; $i++) { + $inlineNode = $inlineSelections[$i]; + if ($inlineNode instanceof FieldNode) { + $this->doExtractData($inlineNode, $data, $container, $args, $context, $resolveInfo); + + continue; } - } elseif ($selectionNode instanceof FragmentSpreadNode) { - $fragmentName = $selectionNode->name->value; - $knownFragments = $resolveInfo->fragments; - $resolvedFragment = $knownFragments[$fragmentName]; - if ($resolvedFragment) { - $fragmentSelectionSet = $resolvedFragment->selectionSet; - $fragmentSelections = $fragmentSelectionSet->selections; - $this->processSelections($data, $fragmentSelections, $container, $args, $context, $resolveInfo); + if($inlineNode instanceof FragmentSpreadNode) { + $this->processSelectionNode($data, $inlineNode, $container, $args, $context, $resolveInfo); + + continue; } } + } elseif ($selectionNode instanceof FragmentSpreadNode) { + $fragmentName = $selectionNode->name->value; + $knownFragments = $resolveInfo->fragments; + $resolvedFragment = $knownFragments[$fragmentName]; + if ($resolvedFragment) { + $fragmentSelectionSet = $resolvedFragment->selectionSet; + $fragmentSelections = $fragmentSelectionSet->selections; + $this->processSelections($data, $fragmentSelections, $container, $args, $context, $resolveInfo); + } } } }