<?php
declare(strict_types=1);
namespace SpringerNature\CPS\AMEDReviewTracker\App\Logger;
use Psr\Log\LoggerInterface;
use SpringerNature\CPS\AMEDReviewTracker\App\Event\AppEvent;
use SpringerNature\CPS\AMEDReviewTracker\App\Event\HasApplicationException;
use Symfony\Component\EventDispatcher\Event;
use Symfony\Component\EventDispatcher\EventDispatcherInterface;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
class AppEventLogger implements EventDispatcherInterface
{
/**
* @var EventDispatcherInterface
*/
private $dispatcher;
/**
* @var LoggerInterface
*/
private $logger;
/**
* @var LoggerInterface
*/
private $auditLogger;
public function __construct(
EventDispatcherInterface $dispatcher,
LoggerInterface $logger,
LoggerInterface $auditLogger
) {
$this->dispatcher = $dispatcher;
$this->logger = $logger;
$this->auditLogger = $auditLogger;
}
/**
* {@inheritdoc}
*/
public function dispatch($event/*, string $eventName = null*/)
{
$eventName = 1 < \func_num_args() ? func_get_arg(1) : null;
if (\is_object($event)) {
$eventName = $eventName ?? \get_class($event);
} else {
$swap = $event;
$event = $eventName ?? new Event();
$eventName = $swap;
if ( ! $event instanceof Event) {
throw new \TypeError(sprintf('Argument 1 passed to "%s::dispatch()" must be an instance of "%s", "%s" given.', EventDispatcherInterface::class, Event::class, \is_object($event) ? \get_class($event) : \gettype($event)));
}
}
$this->logAppEvent($eventName, $event);
return $this->dispatcher->dispatch($event, $eventName);
}
/**
* {@inheritdoc}
*/
public function addListener($eventName, $listener, $priority = 0): void
{
$this->dispatcher->addListener($eventName, $listener, $priority);
}
/**
* {@inheritdoc}
*/
public function addSubscriber(EventSubscriberInterface $subscriber): void
{
$this->dispatcher->addSubscriber($subscriber);
}
/**
* {@inheritdoc}
*/
public function removeListener($eventName, $listener): void
{
$this->dispatcher->removeListener($eventName, $listener);
}
public function removeSubscriber(EventSubscriberInterface $subscriber): void
{
$this->dispatcher->removeSubscriber($subscriber);
}
/**
* {@inheritdoc}
*/
public function getListeners($eventName = null)
{
return $this->dispatcher->getListeners($eventName);
}
/**
* {@inheritdoc}
*/
public function getListenerPriority($eventName, $listener)
{
return $this->dispatcher->getListenerPriority($eventName, $listener);
}
/**
* {@inheritdoc}
*/
public function hasListeners($eventName = null)
{
return $this->dispatcher->hasListeners($eventName);
}
/**
* @param $eventName
* @param \Symfony\Contracts\EventDispatcher\Event|Event|null $event
*/
private function logAppEvent($eventName, $event = null): void
{
if ( ! $event instanceof AppEvent) {
return;
}
if ($event instanceof HasApplicationException && $event->getException()) {
$this->logger->info($event->getException());
}
$this->auditLogger->info($eventName, ['app_event' => $event]);
}
}