Completed
Pull Request — master (#48)
by
unknown
01:53
created

Config::getAllScriptPaths()   A

Complexity

Conditions 4
Paths 4

Size

Total Lines 16
Code Lines 9

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 16
rs 9.2
c 0
b 0
f 0
cc 4
eloc 9
nc 4
nop 0
1
<?php declare(strict_types=1);
2
3
namespace Shopware\Psh\Config;
4
5
/**
6
 * Represents the global configuration consisting of multiple environments
7
 */
8
class Config
9
{
10
    /**
11
     * @var string
12
     */
13
    private $header;
14
15
    /**
16
     * @var string
17
     */
18
    private $defaultEnvironment;
19
20
    /**
21
     * @var ConfigEnvironment[]
22
     */
23
    private $environments;
24
25
    /**
26
     * @var array
27
     */
28
    private $params;
29
30
    /**
31
     * @param string|null $header
32
     * @param string $defaultEnvironment
33
     * @param ConfigEnvironment[] $environments
34
     * @param array $params
35
     */
36
    public function __construct(
37
        string $header = null,
38
        string $defaultEnvironment,
39
        array $environments,
40
        array $params
41
    ) {
42
        $this->header = $header;
43
        $this->defaultEnvironment = $defaultEnvironment;
44
        $this->environments = $environments;
45
        $this->params = $params;
46
    }
47
48
    /**
49
     * @return ScriptPath[]
50
     */
51
    public function getAllScriptPaths(): array
52
    {
53
        $paths = [];
54
55
        foreach ($this->environments as $name => $environmentConfig) {
56
            foreach ($environmentConfig->getAllScriptPaths() as $path) {
57
                if ($name !== $this->defaultEnvironment) {
0 ignored issues
show
Unused Code Bug introduced by
The strict comparison !== seems to always evaluate to true as the types of $name (integer) and $this->defaultEnvironment (string) can never be identical. Maybe you want to use a loose comparison != instead?
Loading history...
58
                    $paths[] = new ScriptPath($path, $name);
59
                } else {
60
                    $paths[] = new ScriptPath($path);
61
                }
62
            }
63
        }
64
65
        return $paths;
66
    }
67
68
    /**
69
     * @param string|null $environment
70
     * @return array
71
     */
72
    public function getTemplates(string $environment = null): array
73
    {
74
        return $this->createResult(
75
            [$this->getEnvironment(), 'getTemplates'],
76
            [$this->getEnvironment($environment), 'getTemplates']
77
        );
78
    }
79
80
    /**
81
     * @param string|null $environment
82
     * @return array
83
     */
84
    public function getDynamicVariables(string $environment = null): array
85
    {
86
        return $this->createResult(
87
            [$this->getEnvironment(), 'getDynamicVariables'],
88
            [$this->getEnvironment($environment), 'getDynamicVariables']
89
        );
90
    }
91
92
    /**
93
     * @param string|null $environment
94
     * @return array
95
     */
96
    public function getConstants(string $environment = null): array
97
    {
98
        return $this->createResult(
99
            [$this->getEnvironment(), 'getConstants'],
100
            [$this->getEnvironment($environment), 'getConstants'],
101
            [$this, 'getParams']
102
        );
103
    }
104
105
    /**
106
     * @return string
107
     */
108
    public function getHeader()
109
    {
110
        return $this->header;
111
    }
112
113
    /**
114
     * @return ConfigEnvironment[]
115
     */
116
    public function getEnvironments(): array
117
    {
118
        return $this->environments;
119
    }
120
121
    /**
122
     * @return string
123
     */
124
    public function getDefaultEnvironment(): string
125
    {
126
        return $this->defaultEnvironment;
127
    }
128
129
    /**
130
     * @return array
131
     */
132
    private function getParams() : array
133
    {
134
        return $this->params;
135
    }
136
137
    /**
138
     * @param callable[] ...$valueProviders
139
     * @return array
140
     */
141
    private function createResult(callable ...$valueProviders): array
142
    {
143
        $mergedKeyValues = [];
144
145
        foreach ($valueProviders as $valueProvider) {
146
            foreach ($valueProvider() as $key => $value) {
147
                $mergedKeyValues[$key] = $value;
148
            }
149
        }
150
151
        return $mergedKeyValues;
152
    }
153
154
    /**
155
     * @param string|null $name
156
     * @return ConfigEnvironment
157
     */
158
    private function getEnvironment(string $name = null): ConfigEnvironment
159
    {
160
        if (!$name) {
0 ignored issues
show
Bug Best Practice introduced by
The expression $name of type null|string is loosely compared to false; this is ambiguous if the string can be empty. You might want to explicitly use === null instead.

In PHP, under loose comparison (like ==, or !=, or switch conditions), values of different types might be equal.

For string values, the empty string '' is a special case, in particular the following results might be unexpected:

''   == false // true
''   == null  // true
'ab' == false // false
'ab' == null  // false

// It is often better to use strict comparison
'' === false // false
'' === null  // false
Loading history...
161
            return $this->environments[$this->defaultEnvironment];
162
        }
163
164
        return $this->environments[$name];
165
    }
166
}
167