mirror of
https://github.com/Combodo/iTop.git
synced 2026-04-25 11:38:44 +02:00
migration symfony 5 4 (#300)
* symfony 5.4 (diff dev) * symfony 5.4 (working) * symfony 5.4 (update autoload) * symfony 5.4 (remove swiftmailer mailer implementation) * symfony 5.4 (php doc and split Global accessor class) ### Impacted packages: composer require php:">=7.2.5 <8.0.0" symfony/console:5.4.* symfony/dotenv:5.4.* symfony/framework-bundle:5.4.* symfony/twig-bundle:5.4.* symfony/yaml:5.4.* --update-with-dependencies composer require symfony/stopwatch:5.4.* symfony/web-profiler-bundle:5.4.* --dev --update-with-dependencies
This commit is contained in:
@@ -11,6 +11,7 @@
|
||||
|
||||
namespace Symfony\Component\DependencyInjection\Compiler;
|
||||
|
||||
use Symfony\Component\DependencyInjection\ContainerBuilder;
|
||||
use Symfony\Component\DependencyInjection\ContainerInterface;
|
||||
use Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException;
|
||||
use Symfony\Component\DependencyInjection\Reference;
|
||||
@@ -22,15 +23,83 @@ use Symfony\Component\DependencyInjection\Reference;
|
||||
*/
|
||||
class CheckExceptionOnInvalidReferenceBehaviorPass extends AbstractRecursivePass
|
||||
{
|
||||
protected function processValue($value, $isRoot = false)
|
||||
private $serviceLocatorContextIds = [];
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function process(ContainerBuilder $container)
|
||||
{
|
||||
$this->serviceLocatorContextIds = [];
|
||||
foreach ($container->findTaggedServiceIds('container.service_locator_context') as $id => $tags) {
|
||||
$this->serviceLocatorContextIds[$id] = $tags[0]['id'];
|
||||
$container->getDefinition($id)->clearTag('container.service_locator_context');
|
||||
}
|
||||
|
||||
try {
|
||||
return parent::process($container);
|
||||
} finally {
|
||||
$this->serviceLocatorContextIds = [];
|
||||
}
|
||||
}
|
||||
|
||||
protected function processValue($value, bool $isRoot = false)
|
||||
{
|
||||
if (!$value instanceof Reference) {
|
||||
return parent::processValue($value, $isRoot);
|
||||
}
|
||||
if (ContainerInterface::EXCEPTION_ON_INVALID_REFERENCE === $value->getInvalidBehavior() && !$this->container->has($id = (string) $value)) {
|
||||
throw new ServiceNotFoundException($id, $this->currentId);
|
||||
if (ContainerInterface::EXCEPTION_ON_INVALID_REFERENCE < $value->getInvalidBehavior() || $this->container->has($id = (string) $value)) {
|
||||
return $value;
|
||||
}
|
||||
|
||||
return $value;
|
||||
$currentId = $this->currentId;
|
||||
$graph = $this->container->getCompiler()->getServiceReferenceGraph();
|
||||
|
||||
if (isset($this->serviceLocatorContextIds[$currentId])) {
|
||||
$currentId = $this->serviceLocatorContextIds[$currentId];
|
||||
$locator = $this->container->getDefinition($this->currentId)->getFactory()[0];
|
||||
|
||||
foreach ($locator->getArgument(0) as $k => $v) {
|
||||
if ($v->getValues()[0] === $value) {
|
||||
if ($k !== $id) {
|
||||
$currentId = $k.'" in the container provided to "'.$currentId;
|
||||
}
|
||||
throw new ServiceNotFoundException($id, $currentId, null, $this->getAlternatives($id));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if ('.' === $currentId[0] && $graph->hasNode($currentId)) {
|
||||
foreach ($graph->getNode($currentId)->getInEdges() as $edge) {
|
||||
if (!$edge->getValue() instanceof Reference || ContainerInterface::EXCEPTION_ON_INVALID_REFERENCE < $edge->getValue()->getInvalidBehavior()) {
|
||||
continue;
|
||||
}
|
||||
$sourceId = $edge->getSourceNode()->getId();
|
||||
|
||||
if ('.' !== $sourceId[0]) {
|
||||
$currentId = $sourceId;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
throw new ServiceNotFoundException($id, $currentId, null, $this->getAlternatives($id));
|
||||
}
|
||||
|
||||
private function getAlternatives(string $id): array
|
||||
{
|
||||
$alternatives = [];
|
||||
foreach ($this->container->getServiceIds() as $knownId) {
|
||||
if ('' === $knownId || '.' === $knownId[0]) {
|
||||
continue;
|
||||
}
|
||||
|
||||
$lev = levenshtein($id, $knownId);
|
||||
if ($lev <= \strlen($id) / 3 || false !== strpos($knownId, $id)) {
|
||||
$alternatives[] = $knownId;
|
||||
}
|
||||
}
|
||||
|
||||
return $alternatives;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user