Configuration::getConfigTreeBuilder()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 38
Code Lines 32

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 4
Bugs 0 Features 0
Metric Value
cc 1
eloc 32
c 4
b 0
f 0
nc 1
nop 0
dl 0
loc 38
ccs 0
cts 34
cp 0
crap 2
rs 9.408
1
<?php
2
3
namespace Terox\SubscriptionBundle\DependencyInjection;
4
5
use Symfony\Component\Config\Definition\Builder\TreeBuilder;
6
use Symfony\Component\Config\Definition\ConfigurationInterface;
7
use Terox\SubscriptionBundle\TeroxSubscriptionBundle;
8
9
/**
10
 * This is the class that validates and merges configuration from your app/config files.
11
 *
12
 * To learn more see {@link http://symfony.com/doc/current/cookbook/bundles/configuration.html}
13
 */
14
class Configuration implements ConfigurationInterface
15
{
16
    /**
17
     * {@inheritdoc}
18
     */
19
    public function getConfigTreeBuilder()
20
    {
21
        $treeBuilder = new TreeBuilder();
0 ignored issues
show
Bug introduced by
The call to Symfony\Component\Config...eBuilder::__construct() has too few arguments starting with name. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

21
        $treeBuilder = /** @scrutinizer ignore-call */ new TreeBuilder();

This check compares calls to functions or methods with their respective definitions. If the call has less arguments than are defined, it raises an issue.

If a function is defined several times with a different number of parameters, the check may pick up the wrong definition and report false positives. One codebase where this has been known to happen is Wordpress. Please note the @ignore annotation hint above.

Loading history...
22
        $rootNode    = $treeBuilder->root('terox_subscription');
0 ignored issues
show
Bug introduced by
The method root() does not exist on Symfony\Component\Config...ion\Builder\TreeBuilder. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

22
        /** @scrutinizer ignore-call */ 
23
        $rootNode    = $treeBuilder->root('terox_subscription');

This check looks for calls to methods that do not seem to exist on a given type. It looks for the method on the type itself as well as in inherited classes or implemented interfaces.

This is most likely a typographical error or the method has been renamed.

Loading history...
23
24
        $rootNode
25
            ->children()
26
                ->scalarNode('subscription_class')
27
                    ->isRequired()
28
                    ->cannotBeEmpty()
29
                ->end()
30
31
                ->scalarNode('subscription_repository')
32
                    ->isRequired()
33
                    ->cannotBeEmpty()
34
                ->end()
35
                ->scalarNode('product_repository')
36
                    ->isRequired()
37
                    ->cannotBeEmpty()
38
                ->end()
39
40
                ->arrayNode('reasons')
41
                    ->addDefaultsIfNotSet()
42
                    ->children()
43
                        ->scalarNode('renew')
44
                            ->defaultValue('Subscription expired and auto-renewal')
45
                        ->end()
46
                        ->scalarNode('expire')
47
                            ->defaultValue('Subscription expired')
48
                        ->end()
49
                        ->scalarNode('disable')
50
                            ->defaultValue('Subscription disabled')
51
                        ->end()
52
                    ->end()
53
                ->end()
54
            ->end();
55
56
        return $treeBuilder;
57
    }
58
}
59