ResultErrorLogger   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 30
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 15
c 1
b 0
f 0
dl 0
loc 30
rs 10
wmc 4

2 Methods

Rating   Name   Duplication   Size   Complexity  
A formatErrorContext() 0 14 2
A __invoke() 0 10 2
1
<?php
2
3
declare(strict_types=1);
4
5
namespace RemotelyLiving\PHPQueryBus\Middleware;
6
7
use Psr\Log;
8
use RemotelyLiving\PHPQueryBus\Interfaces;
9
use RemotelyLiving\PHPQueryBus\Traits;
10
11
final class ResultErrorLogger implements Log\LoggerAwareInterface
12
{
13
    use Traits\Logger;
14
15
    public function __invoke(object $query, callable $next): Interfaces\Result
16
    {
17
        /** @var \RemotelyLiving\PHPQueryBus\Interfaces\Result $result */
18
        $result = $next($query);
19
20
        if ($result->hasErrors()) {
21
            $this->getLogger()->error('Query bus result fetched with errors', $this->formatErrorContext($result));
22
        }
23
24
        return $result;
25
    }
26
27
    private function formatErrorContext(Interfaces\Result $result): array
28
    {
29
        $errorContext = [];
30
        foreach ($result->getErrors() as $error) {
31
            $errorContext[] = [
32
                'ExceptionClass' => get_class($error),
33
                'Message' => $error->getMessage(),
34
                'Line' => $error->getLine(),
35
                'File' => $error->getFile(),
36
                'Trace' => $error->getTraceAsString(),
37
            ];
38
        }
39
40
        return $errorContext;
41
    }
42
}
43