From c8168c6793a35c25fd9cc73647670d4bc559faac Mon Sep 17 00:00:00 2001 From: mcop1 <89011527+mcop1@users.noreply.github.com> Date: Thu, 24 Oct 2024 09:00:44 +0200 Subject: [PATCH] [Bug]: GraphQL - Using Fragment inside Inline Fragment returns only null values (#901) * Fixed support for inline fragments * Apply php-cs-fixer changes * Removed unnecessary `continue` --------- Co-authored-by: mcop1 --- .../FieldHelper/AbstractFieldHelper.php | 60 ++++++++++++------- 1 file changed, 40 insertions(+), 20 deletions(-) diff --git a/src/GraphQL/FieldHelper/AbstractFieldHelper.php b/src/GraphQL/FieldHelper/AbstractFieldHelper.php index aaf086ac..5f6eeb8a 100644 --- a/src/GraphQL/FieldHelper/AbstractFieldHelper.php +++ b/src/GraphQL/FieldHelper/AbstractFieldHelper.php @@ -152,29 +152,49 @@ 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); } } + } 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); + } } } }