Skip to content

Commit

Permalink
[MonologBundle] Added FirePHPHandler support
Browse files Browse the repository at this point in the history
  • Loading branch information
Seldaek committed Apr 25, 2011
1 parent 3bca4b7 commit f4d1196
Show file tree
Hide file tree
Showing 3 changed files with 67 additions and 0 deletions.
Expand Up @@ -123,6 +123,14 @@ private function buildHandler(ContainerBuilder $container, $name, array $handler
));
break;

case 'firephp':
$definition->setArguments(array(
$handler['level'],
$handler['bubble'],
));
$definition->addTag('kernel.listener', array('event' => 'onCoreResponse'));
break;

case 'rotating_file':
if (!isset($handler['path'])) {
$handler['path'] = '%kernel.logs_dir%/%kernel.environment%.log';
Expand Down
58 changes: 58 additions & 0 deletions src/Symfony/Bundle/MonologBundle/Logger/FirePHPHandler.php
@@ -0,0 +1,58 @@
<?php

/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/

namespace Symfony\Bundle\MonologBundle\Logger;

use Monolog\Handler\FirePHPHandler as BaseFirePHPHandler;
use Symfony\Component\HttpKernel\Event\FilterResponseEvent;
use Symfony\Component\HttpFoundation\Response;

/**
* FirePHPHandler.
*
* @author Jordi Boggiano <j.boggiano@seld.be>
*/
class FirePHPHandler extends BaseFirePHPHandler
{
/**
* @var array
*/
private $headers = array();

/**
* @var Response
*/
private $response;

/**
* {@inheritDoc}
*/
protected function sendHeader($header, $content)
{
if ($this->response) {
$this->response->headers->set($header, $content);
} else {
$this->headers[$header] = $content;
}
}

/**
* Adds the headers to the response once it's created
*/
public function onCoreResponse(FilterResponseEvent $event)
{
$this->response = $event->getResponse();
foreach ($this->headers as $header => $content) {
$this->response->headers->set($header, $content);
}
$this->headers = array();
}
}
Expand Up @@ -13,6 +13,7 @@
<parameter key="monolog.handler.syslog.class">Monolog\Handler\SyslogHandler</parameter>
<parameter key="monolog.handler.null.class">Monolog\Handler\NullHandler</parameter>
<parameter key="monolog.handler.test.class">Monolog\Handler\TestHandler</parameter>
<parameter key="monolog.handler.firephp.class">Symfony\Bundle\MonologBundle\Logger\FirePHPHandler</parameter>
<parameter key="monolog.handler.debug.class">Symfony\Bundle\MonologBundle\Logger\DebugHandler</parameter>
</parameters>

Expand Down

0 comments on commit f4d1196

Please sign in to comment.