!C99Shell v. 2.0 [PHP 7 Update] [25.02.2019]!

Software: nginx/1.23.4. PHP/5.6.40-65+ubuntu20.04.1+deb.sury.org+1 

uname -a: Linux foro-restaurado-2 5.15.0-1040-oracle #46-Ubuntu SMP Fri Jul 14 21:47:21 UTC 2023
aarch64
 

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

Safe-mode: OFF (not secure)

/usr/share/php/Symfony/Component/DependencyInjection/Compiler/   drwxr-xr-x
Free 83.26 GB of 96.73 GB (86.07%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


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

/*
 * This file is part of the Symfony package.
 *
 * (c) Fabien Potencier <[email protected]>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Symfony\Component\DependencyInjection\Compiler;

use 
Symfony\Component\DependencyInjection\Definition;
use 
Symfony\Contracts\Service\Attribute\Required;

/**
 * Looks for definitions with autowiring enabled and registers their corresponding "@required" methods as setters.
 *
 * @author Nicolas Grekas <[email protected]>
 */
class AutowireRequiredMethodsPass extends AbstractRecursivePass
{
    
/**
     * {@inheritdoc}
     */
    
protected function processValue($valuebool $isRoot false)
    {
        
$value parent::processValue($value$isRoot);

        if (!
$value instanceof Definition || !$value->isAutowired() || $value->isAbstract() || !$value->getClass()) {
            return 
$value;
        }
        if (!
$reflectionClass $this->container->getReflectionClass($value->getClass(), false)) {
            return 
$value;
        }

        
$alreadyCalledMethods = [];
        
$withers = [];

        foreach (
$value->getMethodCalls() as [$method]) {
            
$alreadyCalledMethods[strtolower($method)] = true;
        }

        foreach (
$reflectionClass->getMethods() as $reflectionMethod) {
            
$r $reflectionMethod;

            if (
$r->isConstructor() || isset($alreadyCalledMethods[strtolower($r->name)])) {
                continue;
            }

            while (
true) {
                if (\
PHP_VERSION_ID >= 80000 && $r->getAttributes(Required::class)) {
                    if (
$this->isWither($r$r->getDocComment() ?: '')) {
                        
$withers[] = [$r->name, [], true];
                    } else {
                        
$value->addMethodCall($r->name, []);
                    }
                    break;
                }
                if (
false !== $doc $r->getDocComment()) {
                    if (
false !== stripos($doc'@required') && preg_match('#(?:^/\*\*|\n\s*+\*)\s*+@required(?:\s|\*/$)#i'$doc)) {
                        if (
$this->isWither($reflectionMethod$doc)) {
                            
$withers[] = [$reflectionMethod->name, [], true];
                        } else {
                            
$value->addMethodCall($reflectionMethod->name, []);
                        }
                        break;
                    }
                    if (
false === stripos($doc'@inheritdoc') || !preg_match('#(?:^/\*\*|\n\s*+\*)\s*+(?:\{@inheritdoc\}|@inheritdoc)(?:\s|\*/$)#i'$doc)) {
                        break;
                    }
                }
                try {
                    
$r $r->getPrototype();
                } catch (\
ReflectionException $e) {
                    break; 
// method has no prototype
                
}
            }
        }

        if (
$withers) {
            
// Prepend withers to prevent creating circular loops
            
$setters $value->getMethodCalls();
            
$value->setMethodCalls($withers);
            foreach (
$setters as $call) {
                
$value->addMethodCall($call[0], $call[1], $call[2] ?? false);
            }
        }

        return 
$value;
    }

    private function 
isWither(\ReflectionMethod $reflectionMethodstring $doc): bool
    
{
        
$match preg_match('#(?:^/\*\*|\n\s*+\*)\s*+@return\s++(static|\$this)[\s\*]#i'$doc$matches);
        if (
$match && 'static' === $matches[1]) {
            return 
true;
        }

        if (
$match && '$this' === $matches[1]) {
            return 
false;
        }

        
$reflectionType $reflectionMethod->hasReturnType() ? $reflectionMethod->getReturnType() : null;

        return 
$reflectionType instanceof \ReflectionNamedType && 'static' === $reflectionType->getName();
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

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

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

--[ c99shell v. 2.0 [PHP 7 Update] [25.02.2019] maintained by HackingTool | HackingTool | Generation time: 0.0044 ]--