Failed Conditions
Push — ng ( 3a2d0f...7d4708 )
by Florent
04:04
created

ContactsParametersRule::handle()   B

Complexity

Conditions 5
Paths 4

Size

Total Lines 17
Code Lines 10

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 17
rs 8.8571
c 0
b 0
f 0
cc 5
eloc 10
nc 4
nop 4
1
<?php
2
3
declare(strict_types=1);
4
5
/*
6
 * The MIT License (MIT)
7
 *
8
 * Copyright (c) 2014-2018 Spomky-Labs
9
 *
10
 * This software may be modified and distributed under the terms
11
 * of the MIT license.  See the LICENSE file for details.
12
 */
13
14
namespace OAuth2Framework\Component\Server\ClientRegistrationEndpoint\Rule;
15
16
use OAuth2Framework\Component\Server\Core\Client\ClientId;
17
use OAuth2Framework\Component\Server\Core\DataBag\DataBag;
18
19
final class ContactsParametersRule implements Rule
20
{
21
    /**
22
     * {@inheritdoc}
23
     */
24
    public function handle(ClientId $clientId, DataBag $commandParameters, DataBag $validatedParameters, callable $next): DataBag
25
    {
26
        if ($commandParameters->has('contacts')) {
27
            $contacts = $commandParameters->get('contacts');
28
            if (!is_array($contacts)) {
29
                throw new \InvalidArgumentException('The parameter "contacts" must be a list of e-mail addresses.');
30
            }
31
            foreach ($contacts as $contact) {
32
                if (!filter_var($contact, FILTER_VALIDATE_EMAIL)) {
33
                    throw new \InvalidArgumentException('The parameter "contacts" must be a list of e-mail addresses.');
34
                }
35
            }
36
            $validatedParameters = $validatedParameters->with('contacts', $contacts);
37
        }
38
39
        return $next($clientId, $commandParameters, $validatedParameters);
40
    }
41
}
42