Passed
Push — main ( c10eb7...8e6581 )
by Iain
04:32
created

ReceiptRepository::getForPayment()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 10
Code Lines 6

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 6
nc 1
nop 1
dl 0
loc 10
rs 10
c 0
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
/*
6
 * Copyright Iain Cambridge 2020-2023.
7
 *
8
 * Use of this software is governed by the Business Source License included in the LICENSE file and at https://getparthenon.com/docs/next/license.
9
 *
10
 * Change Date: TBD ( 3 years after 2.2.0 release )
11
 *
12
 * On the date above, in accordance with the Business Source License, use of this software will be governed by the open source license specified in the LICENSE file.
13
 */
14
15
namespace Parthenon\Billing\Repository\Orm;
16
17
use Parthenon\Athena\Repository\DoctrineCrudRepository;
18
use Parthenon\Billing\Entity\Payment;
19
use Parthenon\Billing\Repository\ReceiptRepositoryInterface;
20
21
class ReceiptRepository extends DoctrineCrudRepository implements ReceiptRepositoryInterface
22
{
23
    public function getForPayment(Payment $payment): array
24
    {
25
        $qb = $this->entityRepository->createQueryBuilder('r');
26
        $qb->where(':payment MEMBER OF r.payments')
27
            ->setParameter('payment', $payment)
28
            ->orderBy('r.createdAt', 'DESC');
29
30
        $result = $qb->getQuery()->getResult();
31
32
        return $result;
0 ignored issues
show
Bug Best Practice introduced by
The expression return $result could return the type integer which is incompatible with the type-hinted return array. Consider adding an additional type-check to rule them out.
Loading history...
33
    }
34
}
35