!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/uploads/script/vendor/enlightn/enlightn/src/PHPStan/   drwxr-xr-x
Free 13.06 GB of 57.97 GB (22.52%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     MassAssignmentModelStaticRule.php (2.09 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

namespace Enlightn\Enlightn\PHPStan;

use 
Illuminate\Database\Eloquent\Model;
use 
PhpParser\Node;
use 
PhpParser\Node\Expr\StaticCall;
use 
PHPStan\Analyser\Scope;
use 
PHPStan\Rules\Rule;

class 
MassAssignmentModelStaticRule implements Rule
{
    use 
AnalyzesNodes;

    
/**
     * @return string
     */
    
public function getNodeType(): string
    
{
        return 
StaticCall::class;
    }

    
/**
     * @param Node $node
     * @param Scope $scope
     * @return string[]
     */
    
public function processNode(Node $nodeScope $scope): array
    {
        if (! 
$node->name instanceof Node\Identifier) {
            return [];
        }

        if (
$node->class instanceof Node\Name
            
&& ! is_subclass_of($scope->resolveName($node->class), Model::class)) {
            
// We are only looking at static calls on a Model class
            
return [];
        }

        if (
$node->class instanceof Node\Expr && ! $this->isCalledOn($node->class$scopeModel::class)) {
            
// We are only looking at static calls on a Model class
            
return [];
        }

        if (! 
in_array($methodName $node->name->toString(), [
            
'create''forceCreate''firstOrCreate''updateOrCreate''insert''upsert',
            
'update''insertOrIgnore''make''firstOrNew',
        ])) {
            return [];
        }

        if (isset(
$node->args[0]) && $this->retrievesRequestInput($node->args[0], $scope)) {
            return [
                
sprintf(
                    
"Static call to %s method on a Model class with request data may result in a "
                    
."mass assignment vulnerability.",
                    
$methodName
                
),
            ];
        }

        return [];
    }

    
/**
     * Determine whether the Arg was a request->all() method call.
     *
     * @param \PhpParser\Node\Arg $arg
     * @param \PHPStan\Analyser\Scope $scope
     * @return bool
     */
    
protected function retrievesRequestInput(Node\Arg $argScope $scope)
    {
        return 
$arg->value instanceof Node\Expr && $this->isRequestArrayData($arg->value$scope);
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0049 ]--