60 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
<?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\Component\Translation\DependencyInjection;
 | 
						|
 | 
						|
use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface;
 | 
						|
use Symfony\Component\DependencyInjection\ContainerBuilder;
 | 
						|
use Symfony\Component\DependencyInjection\Exception\InvalidArgumentException;
 | 
						|
use Symfony\Component\Translation\TranslatorBagInterface;
 | 
						|
use Symfony\Contracts\Translation\TranslatorInterface;
 | 
						|
 | 
						|
/**
 | 
						|
 * @author Abdellatif Ait boudad <a.aitboudad@gmail.com>
 | 
						|
 */
 | 
						|
class LoggingTranslatorPass implements CompilerPassInterface
 | 
						|
{
 | 
						|
    public function process(ContainerBuilder $container): void
 | 
						|
    {
 | 
						|
        if (!$container->hasAlias('logger') || !$container->hasAlias('translator')) {
 | 
						|
            return;
 | 
						|
        }
 | 
						|
 | 
						|
        if (!$container->hasParameter('translator.logging') || !$container->getParameter('translator.logging')) {
 | 
						|
            return;
 | 
						|
        }
 | 
						|
 | 
						|
        $translatorAlias = $container->getAlias('translator');
 | 
						|
        $definition = $container->getDefinition((string) $translatorAlias);
 | 
						|
        $class = $container->getParameterBag()->resolveValue($definition->getClass());
 | 
						|
 | 
						|
        if (!$r = $container->getReflectionClass($class)) {
 | 
						|
            throw new InvalidArgumentException(sprintf('Class "%s" used for service "%s" cannot be found.', $class, $translatorAlias));
 | 
						|
        }
 | 
						|
 | 
						|
        if (!$r->isSubclassOf(TranslatorInterface::class) || !$r->isSubclassOf(TranslatorBagInterface::class)) {
 | 
						|
            return;
 | 
						|
        }
 | 
						|
 | 
						|
        $container->getDefinition('translator.logging')->setDecoratedService('translator');
 | 
						|
        $warmer = $container->getDefinition('translation.warmer');
 | 
						|
        $subscriberAttributes = $warmer->getTag('container.service_subscriber');
 | 
						|
        $warmer->clearTag('container.service_subscriber');
 | 
						|
 | 
						|
        foreach ($subscriberAttributes as $k => $v) {
 | 
						|
            if ((!isset($v['id']) || 'translator' !== $v['id']) && (!isset($v['key']) || 'translator' !== $v['key'])) {
 | 
						|
                $warmer->addTag('container.service_subscriber', $v);
 | 
						|
            }
 | 
						|
        }
 | 
						|
        $warmer->addTag('container.service_subscriber', ['key' => 'translator', 'id' => 'translator.logging.inner']);
 | 
						|
    }
 | 
						|
}
 |