Skip to content

Commit

Permalink
[Bug]: GraphQL - Using Fragment inside Inline Fragment returns only n…
Browse files Browse the repository at this point in the history
…ull values (#901)

* Fixed support for inline fragments

* Apply php-cs-fixer changes

* Removed unnecessary `continue`

---------

Co-authored-by: mcop1 <[email protected]>
  • Loading branch information
mcop1 and mcop1 authored Oct 24, 2024
1 parent 9f4a052 commit c8168c6
Showing 1 changed file with 40 additions and 20 deletions.
60 changes: 40 additions & 20 deletions src/GraphQL/FieldHelper/AbstractFieldHelper.php
Original file line number Diff line number Diff line change
Expand Up @@ -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);
}
}
}
}

0 comments on commit c8168c6

Please sign in to comment.