Completed
Push — master ( 8a4be1...fe7d42 )
by Constantin
06:22
created

DumpEventsByClass   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 43
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 4

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
wmc 3
lcom 1
cbo 4
dl 0
loc 43
ccs 16
cts 16
cp 1
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 10 1
A dumpEvents() 0 15 2
1
<?php
2
/******************************************************************************
3
 * Copyright (c) 2017 Constantin Galbenu <[email protected]>             *
4
 ******************************************************************************/
5
6
namespace Gica\Cqrs\EventStore\Debug;
7
8
9
use Gica\Cqrs\Event\EventsApplier\EventsApplierOnListener;
10
use Gica\Cqrs\EventStore;
11
use Psr\Log\LoggerInterface;
12
13
class DumpEventsByClass
14
{
15
16
    /**
17
     * @var EventStore
18
     */
19
    private $eventStore;
20
    /**
21
     * @var \Gica\Cqrs\Event\EventsApplier\EventsApplierOnListener
22
     */
23
    private $eventsApplierOnListener;
24
    /**
25
     * @var LoggerInterface
26
     */
27
    private $logger;
28
29 1
    public function __construct(
30
        EventStore $eventStore,
31
        EventsApplierOnListener $eventsApplierOnListener,
32
        LoggerInterface $logger
33
    )
34
    {
35 1
        $this->eventStore = $eventStore;
36 1
        $this->eventsApplierOnListener = $eventsApplierOnListener;
37 1
        $this->logger = $logger;
38 1
    }
39
40 1
    public function dumpEvents(array $eventClasses)
41
    {
42 1
        $this->logger->info(print_r($eventClasses, 1));
43 1
        $this->logger->info("loading events...\n");
44
        /** @var \Gica\Cqrs\Event\EventWithMetaData[] $allEvents */
45 1
        $allEvents = $this->eventStore->loadEventsByClassNames($eventClasses);
46 1
        $this->logger->info("dumping events...\n");
47
48 1
        foreach ($allEvents as $eventWithMetaData) {
49 1
            $this->logger->info("\n");
50 1
            $this->logger->info("Event: " . get_class($eventWithMetaData->getEvent()) . "\n");
51 1
            $this->logger->info("Aggregate: " . $eventWithMetaData->getMetaData()->getAggregateClass() . '#' . $eventWithMetaData->getMetaData()->getAggregateId() . "\n");
52 1
            $this->logger->info("Created: " . $eventWithMetaData->getMetaData()->getDateCreated()->format('c') . "\n");
53
        }
54
    }
55
}