Completed
Push — master ( e6a997...8a29f8 )
by Márk
06:35 queued 03:30
created

QueryParam   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 35
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 2

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 1
Metric Value
wmc 2
c 1
b 0
f 1
lcom 1
cbo 2
dl 0
loc 35
ccs 12
cts 12
cp 1
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A authenticate() 0 16 1
1
<?php
2
3
namespace Http\Message\Authentication;
4
5
use Http\Message\Authentication;
6
use Psr\Http\Message\RequestInterface;
7
8
/**
9
 * Authenticate a PSR-7 Request by adding parameters to its query.
10
 *
11
 * Note: Although in some cases it can be useful, we do not recommend using query parameters for authentication.
12
 * Credentials in the URL is generally unsafe as they are not encrypted, anyone can see them.
13
 *
14
 * @author Márk Sági-Kazár <[email protected]>
15
 */
16
final class QueryParam implements Authentication
17
{
18
    /**
19
     * @var array
20
     */
21
    private $params = [];
22
23
    /**
24
     * @param array $params
25
     */
26 3
    public function __construct(array $params)
27
    {
28 3
        $this->params = $params;
29 3
    }
30
31
    /**
32
     * {@inheritdoc}
33
     */
34 1
    public function authenticate(RequestInterface $request)
35
    {
36 1
        $uri = $request->getUri();
37 1
        $query = $uri->getQuery();
38 1
        $params = [];
39
40 1
        parse_str($query, $params);
41
42 1
        $params = array_merge($params, $this->params);
43
44 1
        $query = http_build_query($params);
45
46 1
        $uri = $uri->withQuery($query);
47
48 1
        return $request->withUri($uri);
49
    }
50
}
51