Completed
Push — master ( 7a412d...12f3d9 )
by Petre
02:34
created

ConsulEnvManagerBuilder   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 72
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 2

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
wmc 4
lcom 1
cbo 2
dl 0
loc 72
ccs 18
cts 18
cp 1
rs 10
c 0
b 0
f 0

4 Methods

Rating   Name   Duplication   Size   Complexity  
A build() 0 15 1
A withConsulServer() 0 6 1
A withOverwriteEvenIfDefined() 0 6 1
A clear() 0 5 1
1
<?php
2
declare(strict_types = 1);
3
4
namespace DL\ConsulPhpEnvVar\Builder;
5
6
use DL\ConsulPhpEnvVar\Enum\ManagerDefaults;
7
use DL\ConsulPhpEnvVar\Service\ConsulEnvManager;
8
use SensioLabs\Consul\ServiceFactory;
9
10
/**
11
 * Assists with the construction of Consul environment managers.
12
 *
13
 * @package DL\ConsulPhpEnvVar\Builder
14
 * @author  Petre Pătrașc <[email protected]>
15
 */
16
class ConsulEnvManagerBuilder
17
{
18
    /**
19
     * @var string
20
     */
21
    protected $consulServer = ManagerDefaults::CONSUL_SERVER_DEFAULT;
22
23
    /**
24
     * @var bool
25
     */
26
    protected $overwriteEvenIfDefined = ManagerDefaults::OVERWRITE_DEFAULT;
27
28
    /**
29
     * Build the manager with the properties that have been defined.
30
     *
31
     * @return ConsulEnvManager
32
     */
33 4
    public function build(): ConsulEnvManager
34
    {
35 4
        $kv = (new ServiceFactory([
36 4
            'base_uri' => $this->consulServer
37 4
        ]))->get('kv');
38
39 4
        $manager = new ConsulEnvManager(
40
            $kv,
41 4
            $this->overwriteEvenIfDefined
42
        );
43
44 4
        $this->clear();
45
46 4
        return $manager;
47
    }
48
49
    /**
50
     * Provide the URL of a Consul server.
51
     *
52
     * @param string $consulServer
53
     *
54
     * @return ConsulEnvManagerBuilder
55
     */
56 2
    public function withConsulServer(string $consulServer): ConsulEnvManagerBuilder
57
    {
58 2
        $this->consulServer = $consulServer;
59
60 2
        return $this;
61
    }
62
63
    /**
64
     * Enable the flag that redefines environmental variables
65
     * even if they have been previously defined.
66
     *
67
     * @param bool $overwriteEvenIfDefined
68
     *
69
     * @return ConsulEnvManagerBuilder
70
     */
71 2
    public function withOverwriteEvenIfDefined(bool $overwriteEvenIfDefined): ConsulEnvManagerBuilder
72
    {
73 2
        $this->overwriteEvenIfDefined = $overwriteEvenIfDefined;
74
75 2
        return $this;
76
    }
77
78
    /**
79
     * Clear all of the fields to their default values.
80
     * Used for long-running PHP or Singletons.
81
     */
82 4
    private function clear()
83
    {
84 4
        $this->consulServer           = ManagerDefaults::CONSUL_SERVER_DEFAULT;
85 4
        $this->overwriteEvenIfDefined = ManagerDefaults::OVERWRITE_DEFAULT;
86 4
    }
87
}
88