Commit a53ce590 authored by Fabien Potencier's avatar Fabien Potencier

updated the Monolog provider to use the newest features of Monolog and the Symfony bridge

parent 588c52a0
...@@ -15,10 +15,12 @@ use Pimple\Container; ...@@ -15,10 +15,12 @@ use Pimple\Container;
use Pimple\ServiceProviderInterface; use Pimple\ServiceProviderInterface;
use Monolog\Formatter\LineFormatter; use Monolog\Formatter\LineFormatter;
use Monolog\Logger; use Monolog\Logger;
use Monolog\Handler\StreamHandler; use Monolog\Handler;
use Monolog\ErrorHandler;
use Silex\Application; use Silex\Application;
use Silex\Api\BootableProviderInterface; use Silex\Api\BootableProviderInterface;
use Symfony\Bridge\Monolog\Handler\DebugHandler; use Symfony\Bridge\Monolog\Handler\DebugHandler;
use Symfony\Bridge\Monolog\Handler\FingersCrossed\NotFoundActivationStrategy;
use Silex\EventListener\LogListener; use Silex\EventListener\LogListener;
/** /**
...@@ -40,6 +42,10 @@ class MonologServiceProvider implements ServiceProviderInterface, BootableProvid ...@@ -40,6 +42,10 @@ class MonologServiceProvider implements ServiceProviderInterface, BootableProvid
return new DebugHandler($level); return new DebugHandler($level);
}; };
$app['monolog.not_found_activation_strategy'] = function () use ($app) {
return new NotFoundActivationStrategy($app['request_stack'], array('^/'), $app['monolog.level']);
};
} }
$app['monolog.logger.class'] = $bridge ? 'Symfony\Bridge\Monolog\Logger' : 'Monolog\Logger'; $app['monolog.logger.class'] = $bridge ? 'Symfony\Bridge\Monolog\Logger' : 'Monolog\Logger';
...@@ -47,12 +53,13 @@ class MonologServiceProvider implements ServiceProviderInterface, BootableProvid ...@@ -47,12 +53,13 @@ class MonologServiceProvider implements ServiceProviderInterface, BootableProvid
$app['monolog'] = function ($app) { $app['monolog'] = function ($app) {
$log = new $app['monolog.logger.class']($app['monolog.name']); $log = new $app['monolog.logger.class']($app['monolog.name']);
$log->pushHandler($app['monolog.handler']); $handler = new Handler\GroupHandler($app['monolog.handlers']);
if (isset($app['monolog.not_found_activation_strategy'])) {
if ($app['debug'] && isset($app['monolog.handler.debug'])) { $handler = new Handler\FingersCrossedHandler($handler, $app['monolog.not_found_activation_strategy']);
$log->pushHandler($app['monolog.handler.debug']);
} }
$log->pushHandler($handler);
return $log; return $log;
}; };
...@@ -63,12 +70,26 @@ class MonologServiceProvider implements ServiceProviderInterface, BootableProvid ...@@ -63,12 +70,26 @@ class MonologServiceProvider implements ServiceProviderInterface, BootableProvid
$app['monolog.handler'] = function () use ($app) { $app['monolog.handler'] = function () use ($app) {
$level = MonologServiceProvider::translateLevel($app['monolog.level']); $level = MonologServiceProvider::translateLevel($app['monolog.level']);
$handler = new StreamHandler($app['monolog.logfile'], $level, $app['monolog.bubble'], $app['monolog.permission']); $handler = new Handler\StreamHandler($app['monolog.logfile'], $level, $app['monolog.bubble'], $app['monolog.permission']);
$handler->setFormatter($app['monolog.formatter']); $handler->setFormatter($app['monolog.formatter']);
return $handler; return $handler;
}; };
$app['monolog.handlers'] = function () use ($app) {
$handlers = array();
if ($app['monolog.logfile']) {
$handlers[] = $app['monolog.handler'];
}
if ($app['debug'] && isset($app['monolog.handler.debug'])) {
$handlers[] = $app['monolog.handler.debug'];
}
return $handlers;
};
$app['monolog.level'] = function () { $app['monolog.level'] = function () {
return Logger::DEBUG; return Logger::DEBUG;
}; };
...@@ -77,14 +98,17 @@ class MonologServiceProvider implements ServiceProviderInterface, BootableProvid ...@@ -77,14 +98,17 @@ class MonologServiceProvider implements ServiceProviderInterface, BootableProvid
return new LogListener($app['logger'], $app['monolog.exception.logger_filter']); return new LogListener($app['logger'], $app['monolog.exception.logger_filter']);
}; };
$app['monolog.name'] = 'myapp'; $app['monolog.name'] = 'app';
$app['monolog.bubble'] = true; $app['monolog.bubble'] = true;
$app['monolog.permission'] = null; $app['monolog.permission'] = null;
$app['monolog.exception.logger_filter'] = null; $app['monolog.exception.logger_filter'] = null;
$app['monolog.logfile'] = null;
} }
public function boot(Application $app) public function boot(Application $app)
{ {
ErrorHandler::register($app['monolog']);
if (isset($app['monolog.listener'])) { if (isset($app['monolog.listener'])) {
$app['dispatcher']->addSubscriber($app['monolog.listener']); $app['dispatcher']->addSubscriber($app['monolog.listener']);
} }
......
...@@ -39,6 +39,7 @@ class MonologTraitTest extends \PHPUnit_Framework_TestCase ...@@ -39,6 +39,7 @@ class MonologTraitTest extends \PHPUnit_Framework_TestCase
'monolog.handler' => function () use ($app) { 'monolog.handler' => function () use ($app) {
return new TestHandler($app['monolog.level']); return new TestHandler($app['monolog.level']);
}, },
'monolog.logfile' => 'php://memory',
)); ));
return $app; return $app;
......
...@@ -66,11 +66,12 @@ class MonologServiceProviderTest extends \PHPUnit_Framework_TestCase ...@@ -66,11 +66,12 @@ class MonologServiceProviderTest extends \PHPUnit_Framework_TestCase
{ {
$app = new Application(); $app = new Application();
$app->register(new MonologServiceProvider()); $app->register(new MonologServiceProvider(), array(
$app['monolog.formatter'] = new JsonFormatter(); 'monolog.formatter' => new JsonFormatter(),
$app['monolog.logfile'] = 'php://memory'; 'monolog.logfile' => 'php://memory',
));
$this->assertInstanceOf('Monolog\Formatter\JsonFormatter', $app['logger']->popHandler()->getFormatter()); $this->assertInstanceOf('Monolog\Formatter\JsonFormatter', $app['monolog.handler']->getFormatter());
} }
public function testErrorLogging() public function testErrorLogging()
...@@ -197,13 +198,14 @@ class MonologServiceProviderTest extends \PHPUnit_Framework_TestCase ...@@ -197,13 +198,14 @@ class MonologServiceProviderTest extends \PHPUnit_Framework_TestCase
{ {
$app = new Application(); $app = new Application();
$app->register(new MonologServiceProvider()); $app->register(new MonologServiceProvider(), array(
'monolog.handler' => function () use ($app) {
$app['monolog.handler'] = function () use ($app) { $level = MonologServiceProvider::translateLevel($app['monolog.level']);
$level = MonologServiceProvider::translateLevel($app['monolog.level']);
return new TestHandler($level); return new TestHandler($level);
}; },
'monolog.logfile' => 'php://memory',
));
return $app; return $app;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment