forked from pavlokomarov/roach-php-core
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLoggerExtension.php
More file actions
84 lines (70 loc) · 2.18 KB
/
LoggerExtension.php
File metadata and controls
84 lines (70 loc) · 2.18 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
<?php
declare(strict_types=1);
/**
* Copyright (c) 2021 Kai Sassnowski
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*
* @see https://github.com/roach-php/roach
*/
namespace RoachPHP\Extensions;
use Psr\Log\LoggerInterface;
use RoachPHP\Events\ItemDropped;
use RoachPHP\Events\ItemScraped;
use RoachPHP\Events\RequestDropped;
use RoachPHP\Events\RequestSending;
use RoachPHP\Events\RunFinished;
use RoachPHP\Events\RunStarting;
use RoachPHP\Support\Configurable;
final class LoggerExtension implements ExtensionInterface
{
use Configurable;
public function __construct(private LoggerInterface $logger)
{
}
public static function getSubscribedEvents(): array
{
return [
RunStarting::NAME => ['onRunStarting', 100],
RunFinished::NAME => ['onRunFinished', 100],
RequestSending::NAME => ['onRequestSending', 100],
RequestDropped::NAME => ['onRequestDropped', 100],
ItemScraped::NAME => ['onItemScraped', 100],
ItemDropped::NAME => ['onItemDropped', 100],
];
}
public function onRunStarting(RunStarting $event): void
{
$this->logger->info('Run starting');
}
public function onRunFinished(RunFinished $event): void
{
$this->logger->info('Run finished');
}
public function onRequestSending(RequestSending $event): void
{
$this->logger->info('Dispatching request', [
'uri' => $event->request->getUri(),
]);
}
public function onRequestDropped(RequestDropped $event): void
{
$request = $event->request;
$this->logger->info('Request dropped', [
'uri' => $request->getUri(),
'reason' => $request->getDropReason(),
]);
}
public function onItemScraped(ItemScraped $event): void
{
$this->logger->info('Item scraped', $event->item->all());
}
public function onItemDropped(ItemDropped $event): void
{
$this->logger->info('Item dropped', [
'item' => $event->item->all(),
'reason' => $event->item->getDropReason(),
]);
}
}