Failed Conditions
Push — master ( d2d721...8007f2 )
by Yo
02:30
created

ClassHeaderProcessor   A

Complexity

Total Complexity 8

Size/Duplication

Total Lines 41
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 0

Test Coverage

Coverage 0%

Importance

Changes 0
Metric Value
dl 0
loc 41
c 0
b 0
f 0
wmc 8
lcom 0
cbo 0
ccs 0
cts 28
cp 0
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __invoke() 0 10 1
B getCallingClassName() 0 20 7
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
    public function __invoke(array $record)
16
    {
17
        $record['message'] = sprintf(
18
            '[%s] %s',
19
            $this->getCallingClassName(),
20
            $record['message']
21
        );
22
23
        return $record;
24
    }
25
26
    /**
27
     * @return string
28
     */
29
    private function getCallingClassName()
30
    {
31
        $trace = debug_backtrace();
32
        $loggerFound = false;
33
        $classIndex = 2;
34
        foreach ($trace as $index => $traceData) {
35
            if (true === $loggerFound) {
36
                if (!isset($traceData['class']) || Logger::class !== $traceData['class']) {
37
                    $classIndex = $index;
38
                    break;
39
                }
40
            } else {
41
                $loggerFound = isset($traceData['class']) && Logger::class == $traceData['class'];
42
            }
43
        }
44
45
        return isset($trace[$classIndex]['class'])
46
            ? preg_replace('#(?:[^\\\]+\\\)#', '', $trace[$classIndex]['class'])
47
            : 'UNDEFINED';
48
    }
49
}
50