Completed
Push — master ( 2470f1...9c0667 )
by Jeroen
9s
created

FeederLoggingSubscriber::getSubscribedEvents()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 10
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 7
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 0
Metric Value
c 1
b 0
f 0
dl 0
loc 10
ccs 7
cts 7
cp 1
rs 9.4285
cc 1
eloc 7
nc 1
nop 0
crap 1
1
<?php
2
3
namespace TreeHouse\IoBundle\EventListener;
4
5
use Psr\Log\LoggerInterface;
6
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
7
use TreeHouse\Feeder\Event\FailedItemModificationEvent;
8
use TreeHouse\Feeder\Event\ResourceEvent;
9
use TreeHouse\Feeder\Event\TransportEvent;
10
use TreeHouse\Feeder\FeedEvents;
11
12
class FeederLoggingSubscriber implements EventSubscriberInterface
13
{
14
    /**
15
     * @var LoggerInterface
16
     */
17
    protected $logger;
18
19
    /**
20
     * @param LoggerInterface $logger
21
     */
22 4
    public function __construct(LoggerInterface $logger)
23
    {
24 4
        $this->logger = $logger;
25 4
    }
26
27
    /**
28
     * @inheritdoc
29
     */
30 4
    public static function getSubscribedEvents()
31
    {
32
        return [
33 4
            FeedEvents::FETCH_CACHED => 'onFetchCached',
34 4
            FeedEvents::PRE_FETCH => 'onPreFetch',
35 4
            FeedEvents::POST_FETCH => 'onPostFetch',
36 4
            FeedEvents::RESOURCE_START => 'onResourceStart',
37 4
            FeedEvents::ITEM_MODIFICATION_FAILED => 'onItemModificationFailure',
38 4
        ];
39
    }
40
41
    /**
42
     * FeedEvents::FETCH_CACHED event.
43
     */
44 2
    public function onFetchCached()
45
    {
46 2
        $this->logger->info('Using cached feed');
47 2
    }
48
49
    /**
50
     * @param TransportEvent $event
51
     */
52 4
    public function onPreFetch(TransportEvent $event)
53
    {
54 4
        $size = $event->getTransport()->getSize();
55
56 4
        $this->logger->info(
57 4
            sprintf(
58 4
                'Fetching %s (%s KB)',
59 4
                (string) $event->getTransport(),
60 4
                $size > 0 ? number_format(round($size / 1024), 0, ',', '.') : 'unknown'
61 4
            )
62 4
        );
63 4
    }
64
65
    /**
66
     * @param TransportEvent $event
67
     */
68 4
    public function onPostFetch(TransportEvent $event)
69
    {
70 4
        $this->logger->info(sprintf('Saved to %s', $event->getTransport()->getDestination()));
71 4
    }
72
73
    /**
74
     * @param ResourceEvent $event
75
     */
76 4
    public function onResourceStart(ResourceEvent $event)
77
    {
78 4
        $this->logger->debug(sprintf(
79 4
            'Processing resource %s (%d resources left)',
80 4
            (string) $event->getResource()->getTransport(),
81 4
            $event->getResources()->count()
82 4
        ));
83 4
    }
84
85
    /**
86
     * @param FailedItemModificationEvent $event
87
     */
88
    public function onItemModificationFailure(FailedItemModificationEvent $event)
89
    {
90
        $this->logger->warning($event->getException()->getMessage());
91
    }
92
}
93