Passed
Push — main ( 0944b1...2b73b7 )
by Iain
06:16
created

ObolScheduler::scheduleNextCharge()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 2
c 1
b 0
f 0
nc 1
nop 1
dl 0
loc 4
rs 10
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\Subscription;
16
17
use Obol\Provider\ProviderInterface;
18
use Parthenon\Billing\Entity\Subscription;
19
20
class ObolScheduler implements SchedulerInterface
21
{
22
    public function __construct(private ProviderInterface $provider)
23
    {
24
    }
25
26
    public function scheduleNextCharge(Subscription $subscription): void
27
    {
28
        $obolSubscription = $this->provider->subscriptions()->get($subscription->getMainExternalReference(), $subscription->getChildExternalReference());
29
        $subscription->setValidUntil($obolSubscription->getValidUntil());
0 ignored issues
show
Bug introduced by
It seems like $obolSubscription->getValidUntil() can also be of type null; however, parameter $validUntil of Parthenon\Billing\Entity...iption::setValidUntil() does only seem to accept DateTimeInterface, maybe add an additional type check? ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

29
        $subscription->setValidUntil(/** @scrutinizer ignore-type */ $obolSubscription->getValidUntil());
Loading history...
30
    }
31
}
32