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 Larastan\Larastan\Rules; use Illuminate\Databa..
Decoded Output download
<?php
declare(strict_types=1);
namespace Larastan\Larastan\Rules;
use Illuminate\Database\Eloquent\Model;
use PhpParser\Node;
use PhpParser\Node\Expr;
use PhpParser\Node\Expr\StaticCall;
use PhpParser\Node\Identifier;
use PhpParser\Node\Name\FullyQualified;
use PHPStan\Analyser\Scope;
use PHPStan\Reflection\ReflectionProvider;
use PHPStan\Rules\Rule;
use PHPStan\Rules\RuleError;
use PHPStan\Rules\RuleErrorBuilder;
use PHPStan\Type\ObjectType;
/**
* Catches inefficient instantiation of models using Model::make().
*
* For example:
* User::make()
*
* It is functionally equivalent to simply use the constructor:
* new User()
*
* @implements Rule<StaticCall>
*/
class NoModelMakeRule implements Rule
{
public function __construct(protected ReflectionProvider $reflectionProvider)
{
}
public function getNodeType(): string
{
return StaticCall::class;
}
/** @return array<int, RuleError> */
public function processNode(Node $node, Scope $scope): array
{
$name = $node->name;
if (! $name instanceof Identifier) {
return [];
}
if ($name->name !== 'make') {
return [];
}
if (! $this->isCalledOnModel($node, $scope)) {
return [];
}
return [
RuleErrorBuilder::message("Called 'Model::make()' which performs unnecessary work, use 'new Model()'.")
->identifier('larastan.noModelMake')
->line($node->getLine())
->file($scope->getFile())
->build(),
];
}
/**
* Was the expression called on a Model instance?
*/
protected function isCalledOnModel(StaticCall $call, Scope $scope): bool
{
$class = $call->class;
if ($class instanceof FullyQualified) {
$type = new ObjectType($class->toString());
} elseif ($class instanceof Expr) {
$type = $scope->getType($class);
if ($type->isClassStringType()->yes() && $type->getConstantStrings() !== []) {
$type = new ObjectType($type->getConstantStrings()[0]->getValue());
}
} else {
// TODO can we handle relative names, do they even occur here?
return false;
}
return (new ObjectType(Model::class))
->isSuperTypeOf($type)
->yes();
}
}
?>
Did this file decode correctly?
Original Code
<?php
declare(strict_types=1);
namespace Larastan\Larastan\Rules;
use Illuminate\Database\Eloquent\Model;
use PhpParser\Node;
use PhpParser\Node\Expr;
use PhpParser\Node\Expr\StaticCall;
use PhpParser\Node\Identifier;
use PhpParser\Node\Name\FullyQualified;
use PHPStan\Analyser\Scope;
use PHPStan\Reflection\ReflectionProvider;
use PHPStan\Rules\Rule;
use PHPStan\Rules\RuleError;
use PHPStan\Rules\RuleErrorBuilder;
use PHPStan\Type\ObjectType;
/**
* Catches inefficient instantiation of models using Model::make().
*
* For example:
* User::make()
*
* It is functionally equivalent to simply use the constructor:
* new User()
*
* @implements Rule<StaticCall>
*/
class NoModelMakeRule implements Rule
{
public function __construct(protected ReflectionProvider $reflectionProvider)
{
}
public function getNodeType(): string
{
return StaticCall::class;
}
/** @return array<int, RuleError> */
public function processNode(Node $node, Scope $scope): array
{
$name = $node->name;
if (! $name instanceof Identifier) {
return [];
}
if ($name->name !== 'make') {
return [];
}
if (! $this->isCalledOnModel($node, $scope)) {
return [];
}
return [
RuleErrorBuilder::message("Called 'Model::make()' which performs unnecessary work, use 'new Model()'.")
->identifier('larastan.noModelMake')
->line($node->getLine())
->file($scope->getFile())
->build(),
];
}
/**
* Was the expression called on a Model instance?
*/
protected function isCalledOnModel(StaticCall $call, Scope $scope): bool
{
$class = $call->class;
if ($class instanceof FullyQualified) {
$type = new ObjectType($class->toString());
} elseif ($class instanceof Expr) {
$type = $scope->getType($class);
if ($type->isClassStringType()->yes() && $type->getConstantStrings() !== []) {
$type = new ObjectType($type->getConstantStrings()[0]->getValue());
}
} else {
// TODO can we handle relative names, do they even occur here?
return false;
}
return (new ObjectType(Model::class))
->isSuperTypeOf($type)
->yes();
}
}
Function Calls
None |
Stats
MD5 | e0f623f63bbd0e0cea83e40c53a84d4a |
Eval Count | 0 |
Decode Time | 103 ms |