Passed
Pull Request — master (#10)
by Gocha
11:52
created

ResultIterator::iterate()   B

Complexity

Conditions 6
Paths 20

Size

Total Lines 30

Duplication

Lines 30
Ratio 100 %

Code Coverage

Tests 0
CRAP Score 42

Importance

Changes 0
Metric Value
dl 30
loc 30
ccs 0
cts 24
cp 0
rs 8.8177
c 0
b 0
f 0
cc 6
nc 20
nop 2
crap 42
1
<?php
2
declare(strict_types=1);
3
4
namespace Paysera\Pagination\Service\ODM;
5
6
use Paysera\Pagination\Entity\ODM\ConfiguredQuery;
7
use Paysera\Pagination\Entity\Pager;
8
use Psr\Log\LoggerInterface;
9
use Generator;
10
11 View Code Duplication
class ResultIterator
0 ignored issues
show
Duplication introduced by
This class seems to be duplicated in your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
12
{
13
    private $resultProvider;
14
    private $logger;
15
    private $defaultPageSize;
16
17
    public function __construct(
18
        ResultProvider $resultProvider,
19
        LoggerInterface $logger,
20
        int $defaultPageSize
21
    ) {
22
        $this->resultProvider = $resultProvider;
23
        $this->logger = $logger;
24
        $this->defaultPageSize = $defaultPageSize;
25
    }
26
27
    public function iterate(ConfiguredQuery $configuredQuery, Pager $startPager = null): Generator
28
    {
29
        $pager = $startPager !== null ? clone $startPager : new Pager();
30
        if ($pager->getLimit() === null) {
31
            $pager->setLimit($this->defaultPageSize);
32
        }
33
34
        while (true) {
35
            $result = $this->resultProvider->getResultForQuery($configuredQuery, $pager);
36
37
            foreach ($result->getItems() as $item) {
38
                yield $item;
39
            }
40
41
            $this->handleCycleEnd();
42
43
            if (!$result->hasNext()) {
44
                $this->logger->info('Finished iterating');
45
                return;
46
            }
47
48
            $pager = (new Pager())
49
                ->setOrderingPairs($pager->getOrderingPairs())
50
                ->setLimit($pager->getLimit())
51
                ->setAfter($result->getNextCursor())
52
            ;
53
54
            $this->logger->info('Continuing with iteration', ['after' => $result->getNextCursor()]);
55
        }
56
    }
57
58
    protected function handleCycleEnd()
59
    {
60
        // intentionally empty – override in extended classes
61
    }
62
}
63