LoggingMiddleware::execute()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 15
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 7
c 1
b 0
f 0
nc 1
nop 2
dl 0
loc 15
rs 10
1
<?php
2
3
/**
4
 * This file is part of byrokrat\giroapp.
5
 *
6
 * byrokrat\giroapp is free software: you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License as published
8
 * by the Free Software Foundation, either version 3 of the License, or
9
 * (at your option) any later version.
10
 *
11
 * byrokrat\giroapp is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with byrokrat\giroapp. If not, see <http://www.gnu.org/licenses/>.
18
 *
19
 * Copyright 2016-21 Hannes Forsgård
20
 */
21
22
declare(strict_types=1);
23
24
namespace byrokrat\giroapp\CommandBus\Helper;
25
26
use byrokrat\giroapp\DependencyInjection\DispatcherProperty;
27
use byrokrat\giroapp\Event;
28
use League\Tactician\Middleware;
29
30
final class LoggingMiddleware implements Middleware
31
{
32
    use DispatcherProperty;
33
34
    public function execute($command, callable $next)
35
    {
36
        $commandClass = get_class($command);
37
38
        $this->dispatcher->dispatch(
39
            new Event\DebugEvent("Enter command $commandClass")
40
        );
41
42
        $returnValue = $next($command);
43
44
        $this->dispatcher->dispatch(
45
            new Event\DebugEvent("Command $commandClass finished without errors")
46
        );
47
48
        return $returnValue;
49
    }
50
}
51