Completed
Pull Request — master (#19)
by Yuan
01:58
created

ManagerBase::getQueryString()   B

Complexity

Conditions 6
Paths 8

Size

Total Lines 17
Code Lines 11

Duplication

Lines 8
Ratio 47.06 %

Code Coverage

Tests 0
CRAP Score 42

Importance

Changes 0
Metric Value
dl 8
loc 17
ccs 0
cts 0
cp 0
rs 8.8571
c 0
b 0
f 0
cc 6
eloc 11
nc 8
nop 1
crap 42
1
<?php
2
3
namespace Acquia\LiftClient\Manager;
4
5
use GuzzleHttp\ClientInterface;
6
use Psr\Http\Message\RequestInterface;
7
8
abstract class ManagerBase
9
{
10
    /**
11
     * @var array A list of query parameters that the URL could possibly have
12
     */
13
    protected $queryParameters = [];
14
15 96
    /**
16
     * @var \GuzzleHttp\ClientInterface The request client
17 96
     */
18 96
    protected $client;
19
20
    /**
21
     * @param \GuzzleHttp\ClientInterface $client The request client
22
     */
23
    public function __construct(ClientInterface $client)
24
    {
25
        $this->client = $client;
26
    }
27
28
    /**
29
     * Get the client.
30
     *
31
     * @return \GuzzleHttp\ClientInterface The request client
32
     */
33
    public function getClient() {
34
      return $this->client;
35
    }
36
37
    /**
38
     * Make the given Request and return as JSON Decoded PHP object.
39
     *
40
     * @param \Psr\Http\Message\RequestInterface $request
41
     *
42
     * @return mixed the value encoded in <i>json</i> in appropriate
43
     *               PHP type. Values true, false and
44
     *               null (case-insensitive) are returned as <b>TRUE</b>, <b>FALSE</b>
45
     *               and <b>NULL</b> respectively. <b>NULL</b> is returned if the
46
     *               <i>json</i> cannot be decoded or if the encoded
47
     *               data is deeper than the recursion limit
48
     */
49
    protected function getResponseJson(RequestInterface $request)
50
    {
51
        $response = $this->client->send($request);
52
        $body = (string) $response->getBody();
53
54
        return json_decode($body, true);
55
    }
56
57
    /**
58
     * Get query string of using the options.
59
     *
60
     * @param $options The options
61
     * @return string  The query string
62
     */
63
    protected function getQueryString($options) {
64
      $queries = [];
65
      foreach ($this->queryParameters as $queryName => $queryDefaultValue) {
66
        // Use user value if possible.
67 View Code Duplication
        if (isset($options[$queryName])) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
68
          $queries[] = $queryName . '=' . $options[$queryName];
69
          continue;
70
        }
71
        // Use default value if possible.
72 View Code Duplication
        if (!isset($options[$queryName]) && is_string($queryDefaultValue)) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
73
          $queries[] = $queryName . '=' . $queryDefaultValue;
74
          continue;
75
        }
76
      }
77
      $queryString = implode('&', $queries);
78
      return empty($queryString) ? '' : '?' . $queryString;
79
    }
80
81
}
82