|
@@ -0,0 +1,39 @@
|
|
|
|
+<?php
|
|
|
|
+
|
|
|
|
+/*
|
|
|
|
+ * This file is part of the Symfony package.
|
|
|
|
+ *
|
|
|
|
+ * (c) Fabien Potencier <fabien.potencier@symfony-project.com>
|
|
|
|
+ *
|
|
|
|
+ * For the full copyright and license information, please view the LICENSE
|
|
|
|
+ * file that was distributed with this source code.
|
|
|
|
+ */
|
|
|
|
+
|
|
|
|
+namespace Symfony\Bundle\MonologBundle\DependencyInjection\Compiler;
|
|
|
|
+
|
|
|
|
+use Symfony\Component\DependencyInjection\Reference;
|
|
|
|
+use Symfony\Component\DependencyInjection\ContainerBuilder;
|
|
|
|
+use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface;
|
|
|
|
+use Symfony\Component\DependencyInjection\Definition;
|
|
|
|
+use Monolog\Logger;
|
|
|
|
+
|
|
|
|
+/**
|
|
|
|
+ * Replaces the default logger by another one with its own channel for tagged services.
|
|
|
|
+ *
|
|
|
|
+ * @author Christophe Coevoet <stof@notk.org>
|
|
|
|
+ */
|
|
|
|
+class DebugHandlerPass implements CompilerPassInterface
|
|
|
|
+{
|
|
|
|
+ protected $channels = array();
|
|
|
|
+
|
|
|
|
+ public function process(ContainerBuilder $container)
|
|
|
|
+ {
|
|
|
|
+ if (!$container->hasDefinition('monolog.logger_prototype') || !$container->hasDefinition('profiler')) {
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ $debugHandler = new Definition('%monolog.handler.debug.class%', array(Logger::DEBUG, true));
|
|
|
|
+ $container->setDefinition('monolog.handler.debug', $debugHandler);
|
|
|
|
+ $container->getDefinition('monolog.logger_prototype')->addMethodCall('pushHandler', array (new Reference('monolog.handler.debug')));
|
|
|
|
+ }
|
|
|
|
+}
|