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

withOverwriteEvenIfDefined()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 6
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 3
CRAP Score 1

Importance

Changes 0
Metric Value
dl 0
loc 6
ccs 3
cts 3
cp 1
rs 9.4285
c 0
b 0
f 0
cc 1
eloc 3
nc 1
nop 1
crap 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