| Conditions | 14 | 
| Paths | 72 | 
| Total Lines | 60 | 
| Code Lines | 38 | 
| Lines | 0 | 
| Ratio | 0 % | 
| Changes | 0 | ||
Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.
For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.
Commonly applied refactorings include:
If many parameters/temporary variables are present:
| 1 | <?php | ||
| 72 | public function applyToCollection(Builder $aggregationBuilder, string $resourceClass, string $operationName = null, array $context = []) | ||
| 73 |     { | ||
| 74 | $request = $this->requestStack->getCurrentRequest(); | ||
| 75 |         if (null === $request) { | ||
| 76 | return; | ||
| 77 | } | ||
| 78 | |||
| 79 | $resourceMetadata = $this->resourceMetadataFactory->create($resourceClass); | ||
| 80 |         if (!$this->isPaginationEnabled($request, $resourceMetadata, $operationName)) { | ||
| 81 | return; | ||
| 82 | } | ||
| 83 | |||
| 84 | $itemsPerPage = $resourceMetadata->getCollectionOperationAttribute($operationName, 'pagination_items_per_page', $this->itemsPerPage, true); | ||
| 85 |         if ($request->attributes->get('_graphql')) { | ||
| 86 |             $collectionArgs = $request->attributes->get('_graphql_collections_args', []); | ||
| 87 | $itemsPerPage = $collectionArgs[$resourceClass]['first'] ?? $itemsPerPage; | ||
| 88 | } | ||
| 89 | |||
| 90 |         if ($resourceMetadata->getCollectionOperationAttribute($operationName, 'pagination_client_items_per_page', $this->clientItemsPerPage, true)) { | ||
| 91 | $maxItemsPerPage = $resourceMetadata->getCollectionOperationAttribute($operationName, 'maximum_items_per_page', $this->maximumItemPerPage, true); | ||
| 92 | |||
| 93 | $itemsPerPage = (int) $this->getPaginationParameter($request, $this->itemsPerPageParameterName, $itemsPerPage); | ||
| 94 | $itemsPerPage = (null !== $maxItemsPerPage && $itemsPerPage >= $maxItemsPerPage ? $maxItemsPerPage : $itemsPerPage); | ||
| 95 | } | ||
| 96 | |||
| 97 |         if (0 > $itemsPerPage) { | ||
| 98 |             throw new InvalidArgumentException('Item per page parameter should not be less than 0'); | ||
| 99 | } | ||
| 100 | |||
| 101 | $page = (int) $this->getPaginationParameter($request, $this->pageParameterName, 1); | ||
| 102 | |||
| 103 |         if (1 > $page) { | ||
| 104 |             throw new InvalidArgumentException('Page should not be less than 1'); | ||
| 105 | } | ||
| 106 | |||
| 107 |         if (0 === $itemsPerPage && 1 < $page) { | ||
| 108 |             throw new InvalidArgumentException('Page should not be greater than 1 if itemsPerPage is equal to 0'); | ||
| 109 | } | ||
| 110 | |||
| 111 | $firstResult = ($page - 1) * $itemsPerPage; | ||
| 112 |         if ($request->attributes->get('_graphql')) { | ||
| 113 |             $collectionArgs = $request->attributes->get('_graphql_collections_args', []); | ||
| 114 |             if (isset($collectionArgs[$resourceClass]['after'])) { | ||
| 115 | $after = \base64_decode($collectionArgs[$resourceClass]['after'], true); | ||
| 116 | $firstResult = (int) $after; | ||
| 117 | $firstResult = false === $after ? $firstResult : ++$firstResult; | ||
| 118 | } | ||
| 119 | } | ||
| 120 | |||
| 121 | $repository = $this->managerRegistry->getManagerForClass($resourceClass)->getRepository($resourceClass); | ||
| 122 | $aggregationBuilder | ||
| 123 | ->facet() | ||
| 124 |             ->field('results')->pipeline( | ||
| 125 | $repository->createAggregationBuilder() | ||
| 126 | ->skip($firstResult) | ||
| 127 | ->limit($itemsPerPage) | ||
| 128 | ) | ||
| 129 |             ->field('count')->pipeline( | ||
| 130 | $repository->createAggregationBuilder() | ||
| 131 |                     ->count('count') | ||
| 132 | ); | ||
| 179 |