LoggingTranslatorPass.php 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. <?php
  2. /*
  3. * This file is part of the Symfony package.
  4. *
  5. * (c) Fabien Potencier <fabien@symfony.com>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Symfony\Component\Translation\DependencyInjection;
  11. use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface;
  12. use Symfony\Component\DependencyInjection\ContainerBuilder;
  13. use Symfony\Component\DependencyInjection\Exception\InvalidArgumentException;
  14. use Symfony\Component\Translation\TranslatorBagInterface;
  15. use Symfony\Contracts\Translation\TranslatorInterface;
  16. /**
  17. * @author Abdellatif Ait boudad <a.aitboudad@gmail.com>
  18. */
  19. class LoggingTranslatorPass implements CompilerPassInterface
  20. {
  21. public function process(ContainerBuilder $container): void
  22. {
  23. if (!$container->hasAlias('logger') || !$container->hasAlias('translator')) {
  24. return;
  25. }
  26. if (!$container->hasParameter('translator.logging') || !$container->getParameter('translator.logging')) {
  27. return;
  28. }
  29. $translatorAlias = $container->getAlias('translator');
  30. $definition = $container->getDefinition((string) $translatorAlias);
  31. $class = $container->getParameterBag()->resolveValue($definition->getClass());
  32. if (!$r = $container->getReflectionClass($class)) {
  33. throw new InvalidArgumentException(sprintf('Class "%s" used for service "%s" cannot be found.', $class, $translatorAlias));
  34. }
  35. if (!$r->isSubclassOf(TranslatorInterface::class) || !$r->isSubclassOf(TranslatorBagInterface::class)) {
  36. return;
  37. }
  38. $container->getDefinition('translator.logging')->setDecoratedService('translator');
  39. $warmer = $container->getDefinition('translation.warmer');
  40. $subscriberAttributes = $warmer->getTag('container.service_subscriber');
  41. $warmer->clearTag('container.service_subscriber');
  42. foreach ($subscriberAttributes as $k => $v) {
  43. if ((!isset($v['id']) || 'translator' !== $v['id']) && (!isset($v['key']) || 'translator' !== $v['key'])) {
  44. $warmer->addTag('container.service_subscriber', $v);
  45. }
  46. }
  47. $warmer->addTag('container.service_subscriber', ['key' => 'translator', 'id' => 'translator.logging.inner']);
  48. }
  49. }