1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- <?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\DependencyInjection\Compiler;
- use Symfony\Component\DependencyInjection\ChildDefinition;
- use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface;
- use Symfony\Component\DependencyInjection\ContainerBuilder;
- use Symfony\Component\DependencyInjection\Reference;
- /**
- * Registers processors in Monolog loggers or handlers.
- *
- * @author Christophe Coevoet <stof@notk.org>
- */
- class AddProcessorsPass implements CompilerPassInterface
- {
- public function process(ContainerBuilder $container)
- {
- if (!$container->hasDefinition('monolog.logger')) {
- return;
- }
- foreach ($container->findTaggedServiceIds('monolog.processor') as $id => $tags) {
- foreach ($tags as $tag) {
- if (!empty($tag['channel']) && !empty($tag['handler'])) {
- throw new \InvalidArgumentException(sprintf('you cannot specify both the "handler" and "channel" attributes for the "monolog.processor" tag on service "%s"', $id));
- }
- if (!empty($tag['handler'])) {
- $definition = $container->findDefinition(sprintf('monolog.handler.%s', $tag['handler']));
- $parentDef = $definition;
- while (!$parentDef->getClass() && $parentDef instanceof ChildDefinition) {
- $parentDef = $container->findDefinition($parentDef->getParent());
- }
- $class = $container->getParameterBag()->resolveValue($parentDef->getClass());
- if (!method_exists($class, 'pushProcessor')) {
- throw new \InvalidArgumentException(sprintf('The "%s" handler does not accept processors', $tag['handler']));
- }
- } elseif (!empty($tag['channel'])) {
- if ('app' === $tag['channel']) {
- $definition = $container->getDefinition('monolog.logger');
- } else {
- $definition = $container->getDefinition(sprintf('monolog.logger.%s', $tag['channel']));
- }
- } else {
- $definition = $container->getDefinition('monolog.logger_prototype');
- }
- if (!empty($tag['method'])) {
- $processor = [new Reference($id), $tag['method']];
- } else {
- // If no method is defined, fallback to use __invoke
- $processor = new Reference($id);
- }
- $definition->addMethodCall('pushProcessor', [$processor]);
- }
- }
- }
- }
|