Environment   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 41
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 3

Importance

Changes 0
Metric Value
wmc 4
lcom 1
cbo 3
dl 0
loc 41
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A load() 0 5 1
A parseEnv() 0 18 3
1
<?php
2
/**
3
 * Phossa Project
4
 *
5
 * PHP version 5.4
6
 *
7
 * @category  Library
8
 * @package   Phossa2\Env
9
 * @copyright Copyright (c) 2016 phossa.com
10
 * @license   http://mit-license.org/ MIT License
11
 * @link      http://www.phossa.com/
12
 */
13
/*# declare(strict_types=1); */
14
15
namespace Phossa2\Env;
16
17
use Phossa2\Env\Traits\LoadEnvTrait;
18
use Phossa2\Env\Traits\ParseEnvTrait;
19
use Phossa2\Shared\Base\ObjectAbstract;
20
21
/**
22
 * Load environment key/value pairs from certain path.
23
 *
24
 * - support shell behavior
25
 * - support ${param:-word} and ${param:=word}
26
 * - extra support for PHP superglobals like '${_SERVER.HTTP_HOST}'
27
 * - added support for ${BASH_SOURCE} etc.
28
 *
29
 * @package Phossa2\Env
30
 * @author  Hong Zhang <[email protected]>
31
 * @version 2.0.2
32
 * @since   2.0.0 added
33
 * @since   2.0.2 added support for ${0} etc.
34
 * @sincee  2.0.3 changed to ${BASH_SOURCE}, default overload is TRUE
35
 * @since   2.0.4 using ReferenceTrait
36
 */
37
class Environment extends ObjectAbstract implements EnvironmentInterface
38
{
39
    use LoadEnvTrait, ParseEnvTrait;
40
41
    /**
42
     * {@inheritDoc}
43
     */
44
    public function load(/*# string */ $path, /*# bool */ $overload = true)
45
    {
46
        $pairs = $this->loadEnv($path);
47
        return $this->parseEnv($pairs, $path, (bool) $overload);
48
    }
49
50
    /**
51
     * Parse & set env
52
     *
53
     * @param  array $envs env pairs
54
     * @param  string $path current path
55
     * @param  bool $overload overwrite existing env or not
56
     * @return $this
57
     * @access protected
58
     */
59
    protected function parseEnv(
60
        array $envs,
61
        /*# string */ $path,
62
        /*# bool */ $overload
63
    )/*# : array */ {
64
        foreach ($envs as $key => $val) {
65
            // source another env file
66
            if ($this->source_marker === $val) {
67
                $src = $this->expandPath($this->deReference($key), $path);
68
                $this->load($src, $overload);
69
70
            // set env
71
            } else {
72
                $this->setEnv($key, $this->deReference($val), $overload);
73
            }
74
        }
75
        return $this;
76
    }
77
}
78