ClassHeaderProcessor::getCallingClassName()   B
last analyzed

Complexity

Conditions 6
Paths 10

Size

Total Lines 21
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 11
CRAP Score 6.6829

Importance

Changes 0
Metric Value
dl 0
loc 21
ccs 11
cts 15
cp 0.7332
rs 8.7624
c 0
b 0
f 0
cc 6
eloc 14
nc 10
nop 0
crap 6.6829
1
<?php
2
namespace Yoanm\BehatUtilsExtension\Logger\Processor;
3
4
use Monolog\Logger;
5
6
/**
7
 * Will automatically add header with the calling class name
8
 */
9
class ClassHeaderProcessor
10
{
11
    /**
12
     * @param  array $record
13
     * @return array
14
     */
15 1
    public function __invoke(array $record)
16
    {
17 1
        $record['message'] = sprintf(
18 1
            '[%s] %s',
19 1
            $this->getCallingClassName(),
20 1
            $record['message']
21 1
        );
22
23 1
        return $record;
24
    }
25
26
    /**
27
     * @return string
28
     */
29 1
    private function getCallingClassName()
30
    {
31 1
        $trace = debug_backtrace();
32 1
        $loggerFound = false;
33 1
        $classIndex = 2;
34 1
        foreach ($trace as $index => $traceData) {
35 1
            if (true === $loggerFound) {
36
                // If Logger hash been found and current class it not Logger (in case of internal calls)
37
                if (Logger::class !== $traceData['class']) {
38
                    $classIndex = $index;
39
                    break;
40
                }
41
            } else {
42 1
                $loggerFound = isset($traceData['class']) && Logger::class == $traceData['class'];
43
            }
44 1
        }
45
46 1
        return isset($trace[$classIndex]['class'])
47 1
            ? preg_replace('#(?:[^\\\]+\\\)#', '', $trace[$classIndex]['class'])
48 1
            : 'UNDEFINED';
49
    }
50
}
51