LoggerProcessor.php 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. <?php
  2. /**
  3. * @package Grav\Common\Processors
  4. *
  5. * @copyright Copyright (C) 2015 - 2019 Trilby Media, LLC. All rights reserved.
  6. * @license MIT License; see LICENSE file for details.
  7. */
  8. namespace Grav\Common\Processors;
  9. use Grav\Common\Config\Config;
  10. use Monolog\Formatter\LineFormatter;
  11. use Monolog\Handler\SyslogHandler;
  12. use Psr\Http\Message\ResponseInterface;
  13. use Psr\Http\Message\ServerRequestInterface;
  14. use Psr\Http\Server\RequestHandlerInterface;
  15. class LoggerProcessor extends ProcessorBase
  16. {
  17. public $id = '_logger';
  18. public $title = 'Logger';
  19. public function process(ServerRequestInterface $request, RequestHandlerInterface $handler) : ResponseInterface
  20. {
  21. $this->startTimer();
  22. $grav = $this->container;
  23. /** @var Config $config */
  24. $config = $grav['config'];
  25. switch ($config->get('system.log.handler', 'file')) {
  26. case 'syslog':
  27. $log = $grav['log'];
  28. $log->popHandler();
  29. $facility = $config->get('system.log.syslog.facility', 'local6');
  30. $logHandler = new SyslogHandler('grav', $facility);
  31. $formatter = new LineFormatter("%channel%.%level_name%: %message% %extra%");
  32. $logHandler->setFormatter($formatter);
  33. $log->pushHandler($logHandler);
  34. break;
  35. }
  36. $this->stopTimer();
  37. return $handler->handle($request);
  38. }
  39. }