SubjectConfirmationNotOnOrAfter   A
last analyzed

Complexity

Total Complexity 3

Size/Duplication

Total Lines 20
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
wmc 3
eloc 7
dl 0
loc 20
rs 10
c 0
b 0
f 0

1 Method

Rating   Name   Duplication   Size   Complexity  
A validate() 0 12 3
1
<?php
2
3
declare(strict_types=1);
4
5
namespace SimpleSAML\SAML2\Assertion\Validation\ConstraintValidator;
6
7
use DateInterval;
8
use SimpleSAML\Assert\Assert;
9
use SimpleSAML\SAML2\Assertion\Validation\Result;
10
use SimpleSAML\SAML2\Assertion\Validation\SubjectConfirmationConstraintValidator;
11
use SimpleSAML\SAML2\Utils;
12
use SimpleSAML\SAML2\XML\saml\SubjectConfirmation;
13
14
class SubjectConfirmationNotOnOrAfter implements SubjectConfirmationConstraintValidator
15
{
16
    /**
17
     * @param \SimpleSAML\SAML2\XML\saml\SubjectConfirmation $subjectConfirmation
18
     * @param \SimpleSAML\SAML2\Assertion\Validation\Result $result
19
     *
20
     * @throws \SimpleSAML\Assert\AssertionFailedException if assertions are false
21
     */
22
    public function validate(
23
        SubjectConfirmation $subjectConfirmation,
24
        Result $result,
25
    ): void {
26
        $data = $subjectConfirmation->getSubjectConfirmationData();
27
        Assert::notNull($data);
28
29
        /** @psalm-suppress PossiblyNullReference */
30
        $notOnOrAfter = $data->getNotOnOrAfter();
31
        $clock = Utils::getContainer()->getClock();
32
        if ($notOnOrAfter !== null && $notOnOrAfter <= ($clock->now()->sub(new DateInterval('PT60S')))) {
33
            $result->addError('NotOnOrAfter in SubjectConfirmationData is in the past');
34
        }
35
    }
36
}
37