Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
<?php declare (strict_types=1); namespace Rector\Symfony\NodeAnalyzer; use PhpParser\Nod..
Decoded Output download
<?php
declare (strict_types=1);
namespace Rector\Symfony\NodeAnalyzer;
use PhpParser\Node\Expr\MethodCall;
use PhpParser\Node\Stmt\Class_;
use PhpParser\Node\Stmt\Property;
use PHPStan\Type\ObjectType;
use Rector\Naming\Naming\PropertyNaming;
use Rector\NodeManipulator\PropertyManipulator;
use Rector\NodeNameResolver\NodeNameResolver;
use Rector\Php80\NodeAnalyzer\PromotedPropertyResolver;
use Rector\PostRector\ValueObject\PropertyMetadata;
final class DependencyInjectionMethodCallAnalyzer
{
/**
* @readonly
* @var \Rector\Naming\Naming\PropertyNaming
*/
private $propertyNaming;
/**
* @readonly
* @var \Rector\Symfony\NodeAnalyzer\ServiceTypeMethodCallResolver
*/
private $serviceTypeMethodCallResolver;
/**
* @readonly
* @var \Rector\Php80\NodeAnalyzer\PromotedPropertyResolver
*/
private $promotedPropertyResolver;
/**
* @readonly
* @var \Rector\NodeNameResolver\NodeNameResolver
*/
private $nodeNameResolver;
/**
* @readonly
* @var \Rector\NodeManipulator\PropertyManipulator
*/
private $propertyManipulator;
public function __construct(PropertyNaming $propertyNaming, \Rector\Symfony\NodeAnalyzer\ServiceTypeMethodCallResolver $serviceTypeMethodCallResolver, PromotedPropertyResolver $promotedPropertyResolver, NodeNameResolver $nodeNameResolver, PropertyManipulator $propertyManipulator)
{
$this->propertyNaming = $propertyNaming;
$this->serviceTypeMethodCallResolver = $serviceTypeMethodCallResolver;
$this->promotedPropertyResolver = $promotedPropertyResolver;
$this->nodeNameResolver = $nodeNameResolver;
$this->propertyManipulator = $propertyManipulator;
}
public function replaceMethodCallWithPropertyFetchAndDependency(Class_ $class, MethodCall $methodCall) : ?PropertyMetadata
{
$serviceType = $this->serviceTypeMethodCallResolver->resolve($methodCall);
if (!$serviceType instanceof ObjectType) {
return null;
}
$resolvedPropertyNameByType = $this->propertyManipulator->resolveExistingClassPropertyNameByType($class, $serviceType);
if (\is_string($resolvedPropertyNameByType)) {
$propertyName = $resolvedPropertyNameByType;
} else {
$propertyName = $this->propertyNaming->fqnToVariableName($serviceType);
$propertyName = $this->resolveNewPropertyNameWhenExists($class, $propertyName, $propertyName);
}
return new PropertyMetadata($propertyName, $serviceType);
}
private function resolveNewPropertyNameWhenExists(Class_ $class, string $originalPropertyName, string $propertyName, int $count = 1) : string
{
$lastCount = \substr($propertyName, \strlen($originalPropertyName));
if (\is_numeric($lastCount)) {
$count = (int) $lastCount;
}
$promotedPropertyParams = $this->promotedPropertyResolver->resolveFromClass($class);
foreach ($promotedPropertyParams as $promotedPropertyParam) {
if ($this->nodeNameResolver->isName($promotedPropertyParam->var, $propertyName)) {
$propertyName = $this->resolveIncrementPropertyName($originalPropertyName, $count);
return $this->resolveNewPropertyNameWhenExists($class, $originalPropertyName, $propertyName, $count);
}
}
$property = $class->getProperty($propertyName);
if (!$property instanceof Property) {
return $propertyName;
}
$propertyName = $this->resolveIncrementPropertyName($originalPropertyName, $count);
return $this->resolveNewPropertyNameWhenExists($class, $originalPropertyName, $propertyName, $count);
}
private function resolveIncrementPropertyName(string $originalPropertyName, int $count) : string
{
++$count;
return $originalPropertyName . $count;
}
}
?>
Did this file decode correctly?
Original Code
<?php
declare (strict_types=1);
namespace Rector\Symfony\NodeAnalyzer;
use PhpParser\Node\Expr\MethodCall;
use PhpParser\Node\Stmt\Class_;
use PhpParser\Node\Stmt\Property;
use PHPStan\Type\ObjectType;
use Rector\Naming\Naming\PropertyNaming;
use Rector\NodeManipulator\PropertyManipulator;
use Rector\NodeNameResolver\NodeNameResolver;
use Rector\Php80\NodeAnalyzer\PromotedPropertyResolver;
use Rector\PostRector\ValueObject\PropertyMetadata;
final class DependencyInjectionMethodCallAnalyzer
{
/**
* @readonly
* @var \Rector\Naming\Naming\PropertyNaming
*/
private $propertyNaming;
/**
* @readonly
* @var \Rector\Symfony\NodeAnalyzer\ServiceTypeMethodCallResolver
*/
private $serviceTypeMethodCallResolver;
/**
* @readonly
* @var \Rector\Php80\NodeAnalyzer\PromotedPropertyResolver
*/
private $promotedPropertyResolver;
/**
* @readonly
* @var \Rector\NodeNameResolver\NodeNameResolver
*/
private $nodeNameResolver;
/**
* @readonly
* @var \Rector\NodeManipulator\PropertyManipulator
*/
private $propertyManipulator;
public function __construct(PropertyNaming $propertyNaming, \Rector\Symfony\NodeAnalyzer\ServiceTypeMethodCallResolver $serviceTypeMethodCallResolver, PromotedPropertyResolver $promotedPropertyResolver, NodeNameResolver $nodeNameResolver, PropertyManipulator $propertyManipulator)
{
$this->propertyNaming = $propertyNaming;
$this->serviceTypeMethodCallResolver = $serviceTypeMethodCallResolver;
$this->promotedPropertyResolver = $promotedPropertyResolver;
$this->nodeNameResolver = $nodeNameResolver;
$this->propertyManipulator = $propertyManipulator;
}
public function replaceMethodCallWithPropertyFetchAndDependency(Class_ $class, MethodCall $methodCall) : ?PropertyMetadata
{
$serviceType = $this->serviceTypeMethodCallResolver->resolve($methodCall);
if (!$serviceType instanceof ObjectType) {
return null;
}
$resolvedPropertyNameByType = $this->propertyManipulator->resolveExistingClassPropertyNameByType($class, $serviceType);
if (\is_string($resolvedPropertyNameByType)) {
$propertyName = $resolvedPropertyNameByType;
} else {
$propertyName = $this->propertyNaming->fqnToVariableName($serviceType);
$propertyName = $this->resolveNewPropertyNameWhenExists($class, $propertyName, $propertyName);
}
return new PropertyMetadata($propertyName, $serviceType);
}
private function resolveNewPropertyNameWhenExists(Class_ $class, string $originalPropertyName, string $propertyName, int $count = 1) : string
{
$lastCount = \substr($propertyName, \strlen($originalPropertyName));
if (\is_numeric($lastCount)) {
$count = (int) $lastCount;
}
$promotedPropertyParams = $this->promotedPropertyResolver->resolveFromClass($class);
foreach ($promotedPropertyParams as $promotedPropertyParam) {
if ($this->nodeNameResolver->isName($promotedPropertyParam->var, $propertyName)) {
$propertyName = $this->resolveIncrementPropertyName($originalPropertyName, $count);
return $this->resolveNewPropertyNameWhenExists($class, $originalPropertyName, $propertyName, $count);
}
}
$property = $class->getProperty($propertyName);
if (!$property instanceof Property) {
return $propertyName;
}
$propertyName = $this->resolveIncrementPropertyName($originalPropertyName, $count);
return $this->resolveNewPropertyNameWhenExists($class, $originalPropertyName, $propertyName, $count);
}
private function resolveIncrementPropertyName(string $originalPropertyName, int $count) : string
{
++$count;
return $originalPropertyName . $count;
}
}
Function Calls
None |
Stats
MD5 | cab298e0317cb93f27432a24a30cfc53 |
Eval Count | 0 |
Decode Time | 99 ms |