|
11 | 11 |
|
12 | 12 | namespace yswery\DNS\Event\Subscriber; |
13 | 13 |
|
14 | | -use Psr\Log\AbstractLogger; |
15 | | -use Psr\Log\LogLevel; |
16 | | -use Symfony\Component\EventDispatcher\EventSubscriberInterface; |
17 | | -use yswery\DNS\Event\Events; |
18 | | -use yswery\DNS\Event\QueryReceiveEvent; |
19 | | -use yswery\DNS\Event\QueryResponseEvent; |
20 | | -use yswery\DNS\Event\ServerExceptionEvent; |
21 | | -use yswery\DNS\Event\ServerStartEvent; |
| 14 | +use Psr\Log\LoggerInterface; |
| 15 | +use Psr\Log\LoggerTrait; |
22 | 16 |
|
23 | | -class EchoLogger extends AbstractLogger implements EventSubscriberInterface |
| 17 | +class EchoLogger extends LoggerSubscriber implements LoggerInterface |
24 | 18 | { |
25 | | - public static function getSubscribedEvents(): array |
26 | | - { |
27 | | - return [ |
28 | | - Events::SERVER_START => 'onServerStart', |
29 | | - Events::SERVER_START_FAIL => 'onException', |
30 | | - Events::SERVER_EXCEPTION => 'onException', |
31 | | - Events::QUERY_RECEIVE => 'onQueryReceive', |
32 | | - Events::QUERY_RESPONSE => 'onQueryResponse', |
33 | | - ]; |
34 | | - } |
35 | | - |
36 | | - public function onServerStart(ServerStartEvent $event): void |
37 | | - { |
38 | | - $this->log(LogLevel::INFO, 'Server started.'); |
39 | | - $this->log(LogLevel::INFO, sprintf('Listening on %s', $event->getSocket()->getLocalAddress())); |
40 | | - } |
41 | | - |
42 | | - public function onException(ServerExceptionEvent $event): void |
43 | | - { |
44 | | - $this->log(LogLevel::ERROR, $event->getException()->getMessage()); |
45 | | - } |
46 | | - |
47 | | - public function onQueryReceive(QueryReceiveEvent $event): void |
48 | | - { |
49 | | - foreach ($event->getMessage()->getQuestions() as $question) { |
50 | | - $this->log(LogLevel::INFO, 'Query: '.$question); |
51 | | - } |
52 | | - } |
| 19 | + use LoggerTrait; |
53 | 20 |
|
54 | | - public function onQueryResponse(QueryResponseEvent $event): void |
| 21 | + public function __construct() |
55 | 22 | { |
56 | | - foreach ($event->getMessage()->getAnswers() as $answer) { |
57 | | - $this->log(LogLevel::INFO, 'Answer: '.$answer); |
58 | | - } |
| 23 | + $this->setLogger($this); |
59 | 24 | } |
60 | 25 |
|
61 | 26 | public function log($level, $message, array $context = []) |
|
0 commit comments