Completed
Pull Request — master (#244)
by Alejandro
01:39
created

ExceptionWithNewLineProcessor::__invoke()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 15

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 9
CRAP Score 2

Importance

Changes 0
Metric Value
cc 2
nc 2
nop 1
dl 0
loc 15
ccs 9
cts 9
cp 1
crap 2
rs 9.7666
c 0
b 0
f 0
1
<?php
2
declare(strict_types=1);
3
4
namespace Shlinkio\Shlink\Common\Logger\Processor;
5
6
use const PHP_EOL;
7
use function str_replace;
8
use function strpos;
9
10
final class ExceptionWithNewLineProcessor
11
{
12
    private const EXCEPTION_PLACEHOLDER = '{e}';
13
14 6
    public function __invoke(array $record)
15
    {
16 6
        $message = $record['message'];
17 6
        $messageHasExceptionPlaceholder = strpos($message, self::EXCEPTION_PLACEHOLDER) !== false;
18
19 6
        if ($messageHasExceptionPlaceholder) {
20 3
            $record['message'] = str_replace(
21 3
                self::EXCEPTION_PLACEHOLDER,
22 3
                PHP_EOL . self::EXCEPTION_PLACEHOLDER,
23 3
                $message
24
            );
25
        }
26
27 6
        return $record;
28
    }
29
}
30