ToggleTrait   A
last analyzed

Complexity

Total Complexity 5

Size/Duplication

Total Lines 49
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 0

Test Coverage

Coverage 0%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 5
c 1
b 0
f 0
lcom 1
cbo 0
dl 0
loc 49
ccs 0
cts 20
cp 0
rs 10

5 Methods

Rating   Name   Duplication   Size   Complexity  
A setToggleManager() 0 4 1
A setContext() 0 4 1
A getToggleManager() 0 4 1
A getContext() 0 4 1
A isActive() 0 4 1
1
<?php
2
/**
3
 * zf2-featureflags.
4
 *
5
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
6
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
7
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
8
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
9
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
10
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
11
 * SOFTWARE.
12
 *
13
 * @copyright 2016 MehrAlsNix (http://www.mehralsnix.de)
14
 * @license   http://www.opensource.org/licenses/mit-license.php MIT
15
 *
16
 * @link      http://github.com/MehrAlsNix/zf2-featureflags
17
 */
18
19
namespace MehrAlsNix\FeatureToggle\Traits;
20
21
use Qandidate\Toggle\Context;
22
use Qandidate\Toggle\ToggleManager;
23
24
trait ToggleTrait
25
{
26
    /** @var ToggleManager $toggleManager */
27
    protected $toggleManager;
28
29
    /** @var Context $context */
30
    protected $context;
31
32
    /**
33
     * @param ToggleManager $toggleManager
34
     */
35
    public function setToggleManager(ToggleManager $toggleManager)
36
    {
37
        $this->toggleManager = $toggleManager;
38
    }
39
40
    /**
41
     * @param Context $context
42
     */
43
    public function setContext(Context $context)
44
    {
45
        $this->context = $context;
46
    }
47
48
    /**
49
     * @return ToggleManager
50
     */
51
    public function getToggleManager()
52
    {
53
        return $this->toggleManager;
54
    }
55
56
    /**
57
     * @return Context
58
     */
59
    public function getContext()
60
    {
61
        return $this->context;
62
    }
63
64
    /**
65
     * @param string $name
66
     * @return boolean
67
     */
68
    public function isActive($name)
69
    {
70
        return $this->toggleManager->active($name, $this->getContext());
71
    }
72
}
73