Passed
Push — main ( ce54f9...f825c1 )
by Iain
05:05
created

PaymentRepository::getPaymentsForCustomer()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 1
nc 1
nop 1
dl 0
loc 3
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\CustomerInterface;
19
use Parthenon\Billing\Entity\Payment;
20
use Parthenon\Billing\Entity\Subscription;
21
use Parthenon\Billing\Repository\PaymentRepositoryInterface;
22
23
class PaymentRepository extends DoctrineCrudRepository implements PaymentRepositoryInterface
24
{
25
    public function getPaymentsForSubscription(Subscription $subscription): array
26
    {
27
        $qb = $this->entityRepository->createQueryBuilder('p');
28
        $qb->where(':subscription MEMBER OF p.subscriptions')
29
            ->setParameter('subscription', $subscription)
30
            ->orderBy('p.createdAt', 'DESC');
31
32
        $result = $qb->getQuery()->getResult();
33
34
        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...
35
    }
36
37
    public function getLastPaymentForSubscription(Subscription $subscription): Payment
38
    {
39
        $qb = $this->entityRepository->createQueryBuilder('p');
40
        $qb->where(':subscription MEMBER OF p.subscriptions')
41
            ->setParameter('subscription', $subscription)
42
            ->orderBy('p.createdAt', 'DESC')
43
            ->setMaxResults(1);
44
45
        $result = $qb->getQuery()->getSingleResult();
46
47
        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 Parthenon\Billing\Entity\Payment. Consider adding an additional type-check to rule them out.
Loading history...
48
    }
49
50
    public function getLastPaymentForCustomer(CustomerInterface $customer): Payment
51
    {
52
        return $this->entityRepository->findOneBy(['customer' => $customer], ['createdAt' => 'DESC']);
0 ignored issues
show
Bug Best Practice introduced by
The expression return $this->entityRepo...'createdAt' => 'DESC')) could return the type null which is incompatible with the type-hinted return Parthenon\Billing\Entity\Payment. Consider adding an additional type-check to rule them out.
Loading history...
53
    }
54
55
    public function getPaymentsForCustomer(CustomerInterface $customer): array
56
    {
57
        return $this->entityRepository->findBy(['customer' => $customer]);
58
    }
59
}
60