Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x

AccessDeprecatedPropertyRule.php

Namespace

PHPStan\Rules\Deprecations

File

vendor/phpstan/phpstan-deprecation-rules/src/Rules/Deprecations/AccessDeprecatedPropertyRule.php

View source
<?php

declare (strict_types=1);
namespace PHPStan\Rules\Deprecations;

use PhpParser\Node;
use PhpParser\Node\Expr\PropertyFetch;
use PhpParser\Node\Identifier;
use PHPStan\Analyser\Scope;
use PHPStan\Broker\ClassNotFoundException;
use PHPStan\Reflection\MissingPropertyFromReflectionException;
use PHPStan\Reflection\ReflectionProvider;
use PHPStan\Rules\Rule;
use PHPStan\Rules\RuleErrorBuilder;
use function sprintf;
use function strtolower;

/**
 * @implements Rule<PropertyFetch>
 */
class AccessDeprecatedPropertyRule implements Rule {
    
    /** @var ReflectionProvider */
    private $reflectionProvider;
    
    /** @var DeprecatedScopeHelper */
    private $deprecatedScopeHelper;
    public function __construct(ReflectionProvider $reflectionProvider, DeprecatedScopeHelper $deprecatedScopeHelper) {
        $this->reflectionProvider = $reflectionProvider;
        $this->deprecatedScopeHelper = $deprecatedScopeHelper;
    }
    public function getNodeType() : string {
        return PropertyFetch::class;
    }
    public function processNode(Node $node, Scope $scope) : array {
        if ($this->deprecatedScopeHelper
            ->isScopeDeprecated($scope)) {
            return [];
        }
        if (!$node->name instanceof Identifier) {
            return [];
        }
        $propertyName = $node->name->name;
        $propertyAccessedOnType = $scope->getType($node->var);
        $referencedClasses = $propertyAccessedOnType->getObjectClassNames();
        foreach ($referencedClasses as $referencedClass) {
            try {
                $classReflection = $this->reflectionProvider
                    ->getClass($referencedClass);
                $propertyReflection = $classReflection->getProperty($propertyName, $scope);
                if ($propertyReflection->isDeprecated()
                    ->yes()) {
                    $description = $propertyReflection->getDeprecatedDescription();
                    if ($description === null) {
                        return [
                            RuleErrorBuilder::message(sprintf('Access to deprecated property $%s of %s %s.', $propertyName, strtolower($propertyReflection->getDeclaringClass()
                                ->getClassTypeDescription()), $propertyReflection->getDeclaringClass()
                                ->getName()))
                                ->identifier('property.deprecated')
                                ->build(),
                        ];
                    }
                    return [
                        RuleErrorBuilder::message(sprintf("Access to deprecated property \$%s of %s %s:\n%s", $propertyName, strtolower($propertyReflection->getDeclaringClass()
                            ->getClassTypeDescription()), $propertyReflection->getDeclaringClass()
                            ->getName(), $description))
                            ->identifier('property.deprecated')
                            ->build(),
                    ];
                }
            } catch (ClassNotFoundException $e) {
                // Other rules will notify if the class is not found
            } catch (MissingPropertyFromReflectionException $e) {
                // Other rules will notify if the property is not found
            }
        }
        return [];
    }

}

Classes

Title Deprecated Summary
AccessDeprecatedPropertyRule @implements Rule<PropertyFetch>

API Navigation

  • Drupal Core 11.1.x
  • Topics
  • Classes
  • Functions
  • Constants
  • Globals
  • Files
  • Namespaces
  • Deprecated
  • Services
RSS feed
Powered by Drupal