Completed
Push — master ( b659c5...c65770 )
by Michael
10:22
created

VerbosityMappingTrait::applyVerbosityMap()   B

Complexity

Conditions 6
Paths 6

Size

Total Lines 61
Code Lines 50

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 42

Importance

Changes 0
Metric Value
dl 0
loc 61
ccs 0
cts 53
cp 0
rs 8.6806
c 0
b 0
f 0
cc 6
eloc 50
nc 6
nop 1
crap 42

How to fix   Long Method   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
declare(strict_types = 1);
3
/**
4
 * Contains trait VerbosityMappingTrait.
5
 *
6
 * PHP version 7.0+
7
 *
8
 * LICENSE:
9
 * This file is part of Yet Another Php Eve Api Library also know as Yapeal
10
 * which can be used to access the Eve Online API data and place it into a
11
 * database.
12
 * Copyright (C) 2016-2017 Michael Cummings
13
 *
14
 * This program is free software: you can redistribute it and/or modify it
15
 * under the terms of the GNU Lesser General Public License as published by the
16
 * Free Software Foundation, either version 3 of the License, or (at your
17
 * option) any later version.
18
 *
19
 * This program is distributed in the hope that it will be useful, but WITHOUT
20
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
21
 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
22
 * for more details.
23
 *
24
 * You should have received a copy of the GNU Lesser General Public License
25
 * along with this program. If not, see
26
 * <http://spdx.org/licenses/LGPL-3.0.html>.
27
 *
28
 * You should be able to find a copy of this license in the COPYING-LESSER.md
29
 * file. A copy of the GNU GPL should also be available in the COPYING.md file.
30
 *
31
 * @copyright 2016-2017 Michael Cummings
32
 * @license   LGPL-3.0+
33
 * @author    Michael Cummings <[email protected]>
34
 */
35
namespace Yapeal\Console;
36
37
use Symfony\Component\Console\Output\OutputInterface;
38
use Yapeal\Log\Logger;
39
40
/** @noinspection PhpUnnecessaryFullyQualifiedNameInspection */
41
/**
42
 * Trait VerbosityMappingTrait.
43
 *
44
 * @method \Yapeal\Container\ContainerInterface getDic()
45
 */
46
trait VerbosityMappingTrait
47
{
48
    /**
49
     * @param OutputInterface $output
50
     *
51
     * @return $this Fluent Interface.
52
     * @throws \DomainException
53
     * @throws \InvalidArgumentException
54
     * @throws \UnexpectedValueException
55
     */
56
    protected function applyVerbosityMap(OutputInterface $output)
57
    {
58
        $dic = $this->getDic();
59
        $verbosity = $output->getVerbosity();
60
        /**
61
         * @var \Yapeal\Event\MediatorInterface $yem
62
         * @var \Yapeal\Log\ActivationStrategy  $strategy
63
         * @var \Yapeal\Log\LineFormatter       $cliLF
64
         * @var \Yapeal\Log\LineFormatter       $fileSystemLF
65
         * @var \Yapeal\Log\StreamHandler       $cliStream
66
         * @var \Yapeal\Log\StreamHandler       $fileSystemStream
67
         */
68
        $yem = $dic['Yapeal.Event.Callable.Mediator'];
69
        $cliLF = $dic['Yapeal.Log.Callable.CliLF'];
70
        $cliLF->setPrettyJson(true);
71
        $cliStream = $dic['Yapeal.Log.Callable.Cli'];
72
        $cliStream->setPreserve(true);
73
        $fileSystemLF = $dic['Yapeal.Log.Callable.FileSystemLF'];
74
        $fileSystemLF->setPrettyJson(true);
75
        $fileSystemStream = $dic['Yapeal.Log.Callable.FileSystem'];
76
        $fileSystemStream->setPreserve(true);
77
        $strategy = $dic['Yapeal.Log.Callable.Strategy'];
78
        switch ($verbosity) {
79
            case $output::VERBOSITY_QUIET:
80
                $cliLF->setPrettyJson(false);
81
                $cliStream->setPreserve(false);
82
                $fileSystemLF->setPrettyJson(false);
83
                $strategy->setActionLevel(Logger::ERROR);
84
                $mess = 'Yapeal-ng has switched to quiet mode. Beyond this point only ERROR or higher level messages will trigger logging';
0 ignored issues
show
Coding Style introduced by
This line exceeds maximum limit of 120 characters; contains 139 characters

Overly long lines are hard to read on any screen. Most code styles therefor impose a maximum limit on the number of characters in a line.

Loading history...
85
                $yem->triggerLogEvent('Yapeal.Log.log', Logger::ERROR, $mess);
86
                break;
87
            case $output::VERBOSITY_NORMAL:
88
                $cliLF->setPrettyJson(false);
89
                $cliStream->setPreserve(false);
90
                $fileSystemLF->setPrettyJson(false);
91
                $strategy->setActionLevel(Logger::WARNING);
92
                $mess = 'Yapeal-ng has switched to normal mode. Beyond this point any WARNING or higher level messages will trigger logging';
0 ignored issues
show
Coding Style introduced by
This line exceeds maximum limit of 120 characters; contains 141 characters

Overly long lines are hard to read on any screen. Most code styles therefor impose a maximum limit on the number of characters in a line.

Loading history...
93
                $yem->triggerLogEvent('Yapeal.Log.log', Logger::WARNING, $mess);
94
                break;
95
            case $output::VERBOSITY_VERBOSE:
96
                $cliLF->setPrettyJson(false);
97
                $strategy->setActionLevel(Logger::NOTICE);
98
                $mess = 'Yapeal-ng has switched to verbose mode. Beyond this point any NOTICE or higher level messages will trigger logging';
0 ignored issues
show
Coding Style introduced by
This line exceeds maximum limit of 120 characters; contains 141 characters

Overly long lines are hard to read on any screen. Most code styles therefor impose a maximum limit on the number of characters in a line.

Loading history...
99
                $yem->triggerLogEvent('Yapeal.Log.log', Logger::NOTICE, $mess);
100
                break;
101
            case $output::VERBOSITY_VERY_VERBOSE:
102
                $strategy->setActionLevel(Logger::INFO);
103
                $mess = 'Yapeal-ng switched to very verbose mode. Beyond this point any INFO or higher level messages will trigger logging';
0 ignored issues
show
Coding Style introduced by
This line exceeds maximum limit of 120 characters; contains 140 characters

Overly long lines are hard to read on any screen. Most code styles therefor impose a maximum limit on the number of characters in a line.

Loading history...
104
                $yem->triggerLogEvent('Yapeal.Log.log', Logger::INFO, $mess);
105
                break;
106
            case $output::VERBOSITY_DEBUG:
107
                $strategy->setActionLevel(Logger::DEBUG);
108
                $mess = 'Yapeal-ng has switched to debug mode. Beyond this point all message levels will trigger logging';
0 ignored issues
show
Coding Style introduced by
This line exceeds maximum limit of 120 characters; contains 122 characters

Overly long lines are hard to read on any screen. Most code styles therefor impose a maximum limit on the number of characters in a line.

Loading history...
109
                $yem->triggerLogEvent('Yapeal.Log.log', Logger::DEBUG, $mess);
110
                break;
111
            default:
112
                $mess = 'Unexpected and unknown verbosity value received from OutputInterface. Aborting ...';
113
                throw new \UnexpectedValueException($mess, 2);
114
        }
115
        return $this;
116
    }
117
}
118