FirePHPHandler.php 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. <?php
  2. /*
  3. * This file is part of the Symfony package.
  4. *
  5. * (c) Fabien Potencier <fabien@symfony.com>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Symfony\Bridge\Monolog\Handler;
  11. use Monolog\Handler\FirePHPHandler as BaseFirePHPHandler;
  12. use Symfony\Component\HttpKernel\Event\FilterResponseEvent;
  13. use Symfony\Component\HttpFoundation\Response;
  14. use Symfony\Component\HttpKernel\HttpKernelInterface;
  15. /**
  16. * FirePHPHandler.
  17. *
  18. * @author Jordi Boggiano <j.boggiano@seld.be>
  19. */
  20. class FirePHPHandler extends BaseFirePHPHandler
  21. {
  22. /**
  23. * @var array
  24. */
  25. private $headers = array();
  26. /**
  27. * @var Response
  28. */
  29. private $response;
  30. /**
  31. * Adds the headers to the response once it's created
  32. */
  33. public function onKernelResponse(FilterResponseEvent $event)
  34. {
  35. if (HttpKernelInterface::MASTER_REQUEST !== $event->getRequestType()) {
  36. return;
  37. }
  38. if (!preg_match('{\bFirePHP/\d+\.\d+\b}', $event->getRequest()->headers->get('User-Agent'))
  39. && !$event->getRequest()->headers->has('X-FirePHP-Version')) {
  40. $this->sendHeaders = false;
  41. $this->headers = array();
  42. return;
  43. }
  44. $this->response = $event->getResponse();
  45. foreach ($this->headers as $header => $content) {
  46. $this->response->headers->set($header, $content);
  47. }
  48. $this->headers = array();
  49. }
  50. /**
  51. * {@inheritDoc}
  52. */
  53. protected function sendHeader($header, $content)
  54. {
  55. if (!$this->sendHeaders) {
  56. return;
  57. }
  58. if ($this->response) {
  59. $this->response->headers->set($header, $content);
  60. } else {
  61. $this->headers[$header] = $content;
  62. }
  63. }
  64. /**
  65. * Override default behavior since we check the user agent in onKernelResponse
  66. */
  67. protected function headersAccepted()
  68. {
  69. return true;
  70. }
  71. }