!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/   drwxr-xr-x
Free 83.22 GB of 96.73 GB (86.04%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     ContainerBuilder.php (56.29 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;

use 
Composer\InstalledVersions;
use 
Psr\Container\ContainerInterface as PsrContainerInterface;
use 
Symfony\Component\Config\Resource\ClassExistenceResource;
use 
Symfony\Component\Config\Resource\ComposerResource;
use 
Symfony\Component\Config\Resource\DirectoryResource;
use 
Symfony\Component\Config\Resource\FileExistenceResource;
use 
Symfony\Component\Config\Resource\FileResource;
use 
Symfony\Component\Config\Resource\GlobResource;
use 
Symfony\Component\Config\Resource\ReflectionClassResource;
use 
Symfony\Component\Config\Resource\ResourceInterface;
use 
Symfony\Component\DependencyInjection\Argument\AbstractArgument;
use 
Symfony\Component\DependencyInjection\Argument\IteratorArgument;
use 
Symfony\Component\DependencyInjection\Argument\RewindableGenerator;
use 
Symfony\Component\DependencyInjection\Argument\ServiceClosureArgument;
use 
Symfony\Component\DependencyInjection\Argument\ServiceLocator;
use 
Symfony\Component\DependencyInjection\Argument\ServiceLocatorArgument;
use 
Symfony\Component\DependencyInjection\Attribute\Target;
use 
Symfony\Component\DependencyInjection\Compiler\Compiler;
use 
Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface;
use 
Symfony\Component\DependencyInjection\Compiler\PassConfig;
use 
Symfony\Component\DependencyInjection\Compiler\ResolveEnvPlaceholdersPass;
use 
Symfony\Component\DependencyInjection\Exception\BadMethodCallException;
use 
Symfony\Component\DependencyInjection\Exception\InvalidArgumentException;
use 
Symfony\Component\DependencyInjection\Exception\LogicException;
use 
Symfony\Component\DependencyInjection\Exception\RuntimeException;
use 
Symfony\Component\DependencyInjection\Exception\ServiceCircularReferenceException;
use 
Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException;
use 
Symfony\Component\DependencyInjection\Extension\ExtensionInterface;
use 
Symfony\Component\DependencyInjection\LazyProxy\Instantiator\InstantiatorInterface;
use 
Symfony\Component\DependencyInjection\LazyProxy\Instantiator\RealServiceInstantiator;
use 
Symfony\Component\DependencyInjection\ParameterBag\EnvPlaceholderParameterBag;
use 
Symfony\Component\DependencyInjection\ParameterBag\ParameterBag;
use 
Symfony\Component\DependencyInjection\ParameterBag\ParameterBagInterface;
use 
Symfony\Component\ExpressionLanguage\Expression;
use 
Symfony\Component\ExpressionLanguage\ExpressionFunctionProviderInterface;

/**
 * ContainerBuilder is a DI container that provides an API to easily describe services.
 *
 * @author Fabien Potencier <[email protected]>
 */
class ContainerBuilder extends Container implements TaggedContainerInterface
{
    
/**
     * @var array<string, ExtensionInterface>
     */
    
private $extensions = [];

    
/**
     * @var array<string, ExtensionInterface>
     */
    
private $extensionsByNs = [];

    
/**
     * @var array<string, Definition>
     */
    
private $definitions = [];

    
/**
     * @var array<string, Alias>
     */
    
private $aliasDefinitions = [];

    
/**
     * @var array<string, ResourceInterface>
     */
    
private $resources = [];

    
/**
     * @var array<string, array<array<string, mixed>>>
     */
    
private $extensionConfigs = [];

    
/**
     * @var Compiler
     */
    
private $compiler;

    
/**
     * @var bool
     */
    
private $trackResources;

    
/**
     * @var InstantiatorInterface|null
     */
    
private $proxyInstantiator;

    
/**
     * @var ExpressionLanguage|null
     */
    
private $expressionLanguage;

    
/**
     * @var ExpressionFunctionProviderInterface[]
     */
    
private $expressionLanguageProviders = [];

    
/**
     * @var string[] with tag names used by findTaggedServiceIds
     */
    
private $usedTags = [];

    
/**
     * @var string[][] a map of env var names to their placeholders
     */
    
private $envPlaceholders = [];

    
/**
     * @var int[] a map of env vars to their resolution counter
     */
    
private $envCounters = [];

    
/**
     * @var string[] the list of vendor directories
     */
    
private $vendors;

    
/**
     * @var array<string, ChildDefinition>
     */
    
private $autoconfiguredInstanceof = [];

    
/**
     * @var array<string, callable>
     */
    
private $autoconfiguredAttributes = [];

    
/**
     * @var array<string, bool>
     */
    
private $removedIds = [];

    
/**
     * @var array<int, bool>
     */
    
private $removedBindingIds = [];

    private const 
INTERNAL_TYPES = [
        
'int' => true,
        
'float' => true,
        
'string' => true,
        
'bool' => true,
        
'resource' => true,
        
'object' => true,
        
'array' => true,
        
'null' => true,
        
'callable' => true,
        
'iterable' => true,
        
'mixed' => true,
    ];

    public function 
__construct(ParameterBagInterface $parameterBag null)
    {
        
parent::__construct($parameterBag);

        
$this->trackResources interface_exists(ResourceInterface::class);
        
$this->setDefinition('service_container', (new Definition(ContainerInterface::class))->setSynthetic(true)->setPublic(true));
        
$this->setAlias(PsrContainerInterface::class, new Alias('service_container'false))->setDeprecated('symfony/dependency-injection''5.1'$deprecationMessage 'The "%alias_id%" autowiring alias is deprecated. Define it explicitly in your app if you want to keep using it.');
        
$this->setAlias(ContainerInterface::class, new Alias('service_container'false))->setDeprecated('symfony/dependency-injection''5.1'$deprecationMessage);
    }

    
/**
     * @var array<string, \ReflectionClass>
     */
    
private $classReflectors;

    
/**
     * Sets the track resources flag.
     *
     * If you are not using the loaders and therefore don't want
     * to depend on the Config component, set this flag to false.
     */
    
public function setResourceTracking(bool $track)
    {
        
$this->trackResources $track;
    }

    
/**
     * Checks if resources are tracked.
     *
     * @return bool
     */
    
public function isTrackingResources(): bool
    
{
        return 
$this->trackResources;
    }

    
/**
     * Sets the instantiator to be used when fetching proxies.
     */
    
public function setProxyInstantiator(InstantiatorInterface $proxyInstantiator)
    {
        
$this->proxyInstantiator $proxyInstantiator;
    }

    public function 
registerExtension(ExtensionInterface $extension)
    {
        
$this->extensions[$extension->getAlias()] = $extension;

        if (
false !== $extension->getNamespace()) {
            
$this->extensionsByNs[$extension->getNamespace()] = $extension;
        }
    }

    
/**
     * Returns an extension by alias or namespace.
     *
     * @return ExtensionInterface
     *
     * @throws LogicException if the extension is not registered
     */
    
public function getExtension(string $name): ExtensionInterface
    
{
        if (isset(
$this->extensions[$name])) {
            return 
$this->extensions[$name];
        }

        if (isset(
$this->extensionsByNs[$name])) {
            return 
$this->extensionsByNs[$name];
        }

        throw new 
LogicException(sprintf('Container extension "%s" is not registered.'$name));
    }

    
/**
     * Returns all registered extensions.
     *
     * @return array<string, ExtensionInterface>
     */
    
public function getExtensions(): array
    {
        return 
$this->extensions;
    }

    
/**
     * Checks if we have an extension.
     *
     * @return bool
     */
    
public function hasExtension(string $name): bool
    
{
        return isset(
$this->extensions[$name]) || isset($this->extensionsByNs[$name]);
    }

    
/**
     * Returns an array of resources loaded to build this configuration.
     *
     * @return ResourceInterface[]
     */
    
public function getResources(): array
    {
        return 
array_values($this->resources);
    }

    
/**
     * @return $this
     */
    
public function addResource(ResourceInterface $resource): static
    {
        if (!
$this->trackResources) {
            return 
$this;
        }

        if (
$resource instanceof GlobResource && $this->inVendors($resource->getPrefix())) {
            return 
$this;
        }

        
$this->resources[(string) $resource] = $resource;

        return 
$this;
    }

    
/**
     * Sets the resources for this configuration.
     *
     * @param array<string, ResourceInterface> $resources
     *
     * @return $this
     */
    
public function setResources(array $resources): static
    {
        if (!
$this->trackResources) {
            return 
$this;
        }

        
$this->resources $resources;

        return 
$this;
    }

    
/**
     * Adds the object class hierarchy as resources.
     *
     * @param object|string $object An object instance or class name
     *
     * @return $this
     */
    
public function addObjectResource(object|string $object): static
    {
        if (
$this->trackResources) {
            if (\
is_object($object)) {
                
$object = \get_class($object);
            }
            if (!isset(
$this->classReflectors[$object])) {
                
$this->classReflectors[$object] = new \ReflectionClass($object);
            }
            
$class $this->classReflectors[$object];

            foreach (
$class->getInterfaceNames() as $name) {
                if (
null === $interface = &$this->classReflectors[$name]) {
                    
$interface = new \ReflectionClass($name);
                }
                
$file $interface->getFileName();
                if (
false !== $file && file_exists($file)) {
                    
$this->fileExists($file);
                }
            }
            do {
                
$file $class->getFileName();
                if (
false !== $file && file_exists($file)) {
                    
$this->fileExists($file);
                }
                foreach (
$class->getTraitNames() as $name) {
                    
$this->addObjectResource($name);
                }
            } while (
$class $class->getParentClass());
        }

        return 
$this;
    }

    
/**
     * Retrieves the requested reflection class and registers it for resource tracking.
     *
     * @throws \ReflectionException when a parent class/interface/trait is not found and $throw is true
     *
     * @final
     */
    
public function getReflectionClass(?string $classbool $throw true): ?\ReflectionClass
    
{
        if (!
$class $this->getParameterBag()->resolveValue($class)) {
            return 
null;
        }

        if (isset(
self::INTERNAL_TYPES[$class])) {
            return 
null;
        }

        
$resource $classReflector null;

        try {
            if (isset(
$this->classReflectors[$class])) {
                
$classReflector $this->classReflectors[$class];
            } elseif (
class_exists(ClassExistenceResource::class)) {
                
$resource = new ClassExistenceResource($classfalse);
                
$classReflector $resource->isFresh(0) ? false : new \ReflectionClass($class);
            } else {
                
$classReflector class_exists($class) ? new \ReflectionClass($class) : false;
            }
        } catch (\
ReflectionException $e) {
            if (
$throw) {
                throw 
$e;
            }
        }

        if (
$this->trackResources) {
            if (!
$classReflector) {
                
$this->addResource($resource ?? new ClassExistenceResource($classfalse));
            } elseif (!
$classReflector->isInternal()) {
                
$path $classReflector->getFileName();

                if (!
$this->inVendors($path)) {
                    
$this->addResource(new ReflectionClassResource($classReflector$this->vendors));
                }
            }
            
$this->classReflectors[$class] = $classReflector;
        }

        return 
$classReflector ?: null;
    }

    
/**
     * Checks whether the requested file or directory exists and registers the result for resource tracking.
     *
     * @param string      $path          The file or directory path for which to check the existence
     * @param bool|string $trackContents Whether to track contents of the given resource. If a string is passed,
     *                                   it will be used as pattern for tracking contents of the requested directory
     *
     * @final
     */
    
public function fileExists(string $pathbool|string $trackContents true): bool
    
{
        
$exists file_exists($path);

        if (!
$this->trackResources || $this->inVendors($path)) {
            return 
$exists;
        }

        if (!
$exists) {
            
$this->addResource(new FileExistenceResource($path));

            return 
$exists;
        }

        if (
is_dir($path)) {
            if (
$trackContents) {
                
$this->addResource(new DirectoryResource($path, \is_string($trackContents) ? $trackContents null));
            } else {
                
$this->addResource(new GlobResource($path'/*'false));
            }
        } elseif (
$trackContents) {
            
$this->addResource(new FileResource($path));
        }

        return 
$exists;
    }

    
/**
     * Loads the configuration for an extension.
     *
     * @param string                    $extension The extension alias or namespace
     * @param array<string, mixed>|null $values    An array of values that customizes the extension
     *
     * @return $this
     *
     * @throws BadMethodCallException When this ContainerBuilder is compiled
     * @throws \LogicException        if the extension is not registered
     */
    
public function loadFromExtension(string $extension, array $values null): static
    {
        if (
$this->isCompiled()) {
            throw new 
BadMethodCallException('Cannot load from an extension on a compiled container.');
        }

        
$namespace $this->getExtension($extension)->getAlias();

        
$this->extensionConfigs[$namespace][] = $values ?? [];

        return 
$this;
    }

    
/**
     * Adds a compiler pass.
     *
     * @param string $type     The type of compiler pass
     * @param int    $priority Used to sort the passes
     *
     * @return $this
     */
    
public function addCompilerPass(CompilerPassInterface $passstring $type PassConfig::TYPE_BEFORE_OPTIMIZATIONint $priority 0): static
    {
        
$this->getCompiler()->addPass($pass$type$priority);

        
$this->addObjectResource($pass);

        return 
$this;
    }

    
/**
     * Returns the compiler pass config which can then be modified.
     *
     * @return PassConfig
     */
    
public function getCompilerPassConfig(): PassConfig
    
{
        return 
$this->getCompiler()->getPassConfig();
    }

    
/**
     * Returns the compiler.
     *
     * @return Compiler
     */
    
public function getCompiler(): Compiler
    
{
        if (
null === $this->compiler) {
            
$this->compiler = new Compiler();
        }

        return 
$this->compiler;
    }

    
/**
     * Sets a service.
     *
     * @throws BadMethodCallException When this ContainerBuilder is compiled
     */
    
public function set(string $id, ?object $service)
    {
        if (
$this->isCompiled() && (isset($this->definitions[$id]) && !$this->definitions[$id]->isSynthetic())) {
            
// setting a synthetic service on a compiled container is alright
            
throw new BadMethodCallException(sprintf('Setting service "%s" for an unknown or non-synthetic service definition on a compiled container is not allowed.'$id));
        }

        unset(
$this->definitions[$id], $this->aliasDefinitions[$id], $this->removedIds[$id]);

        
parent::set($id$service);
    }

    
/**
     * Removes a service definition.
     */
    
public function removeDefinition(string $id)
    {
        if (isset(
$this->definitions[$id])) {
            unset(
$this->definitions[$id]);
            
$this->removedIds[$id] = true;
        }
    }

    public function 
has(string $id): bool
    
{
        return isset(
$this->definitions[$id]) || isset($this->aliasDefinitions[$id]) || parent::has($id);
    }

    
/**
     * @return object|null
     *
     * @throws InvalidArgumentException          when no definitions are available
     * @throws ServiceCircularReferenceException When a circular reference is detected
     * @throws ServiceNotFoundException          When the service is not defined
     * @throws \Exception
     *
     * @see Reference
     */
    
public function get(string $idint $invalidBehavior ContainerInterface::EXCEPTION_ON_INVALID_REFERENCE): ?object
    
{
        if (
$this->isCompiled() && isset($this->removedIds[$id]) && ContainerInterface::EXCEPTION_ON_INVALID_REFERENCE >= $invalidBehavior) {
            return 
parent::get($id);
        }

        return 
$this->doGet($id$invalidBehavior);
    }

    private function 
doGet(string $idint $invalidBehavior ContainerInterface::EXCEPTION_ON_INVALID_REFERENCE, array &$inlineServices nullbool $isConstructorArgument false): mixed
    
{
        if (isset(
$inlineServices[$id])) {
            return 
$inlineServices[$id];
        }
        if (
null === $inlineServices) {
            
$isConstructorArgument true;
            
$inlineServices = [];
        }
        try {
            if (
ContainerInterface::IGNORE_ON_UNINITIALIZED_REFERENCE === $invalidBehavior) {
                return 
parent::get($id$invalidBehavior);
            }
            if (
$service parent::get($idContainerInterface::NULL_ON_INVALID_REFERENCE)) {
                return 
$service;
            }
        } catch (
ServiceCircularReferenceException $e) {
            if (
$isConstructorArgument) {
                throw 
$e;
            }
        }

        if (!isset(
$this->definitions[$id]) && isset($this->aliasDefinitions[$id])) {
            
$alias $this->aliasDefinitions[$id];

            if (
$alias->isDeprecated()) {
                
$deprecation $alias->getDeprecation($id);
                
trigger_deprecation($deprecation['package'], $deprecation['version'], $deprecation['message']);
            }

            return 
$this->doGet((string) $alias$invalidBehavior$inlineServices$isConstructorArgument);
        }

        try {
            
$definition $this->getDefinition($id);
        } catch (
ServiceNotFoundException $e) {
            if (
ContainerInterface::EXCEPTION_ON_INVALID_REFERENCE $invalidBehavior) {
                return 
null;
            }

            throw 
$e;
        }

        if (
$definition->hasErrors() && $e $definition->getErrors()) {
            throw new 
RuntimeException(reset($e));
        }

        if (
$isConstructorArgument) {
            
$this->loading[$id] = true;
        }

        try {
            return 
$this->createService($definition$inlineServices$isConstructorArgument$id);
        } finally {
            if (
$isConstructorArgument) {
                unset(
$this->loading[$id]);
            }
        }
    }

    
/**
     * Merges a ContainerBuilder with the current ContainerBuilder configuration.
     *
     * Service definitions overrides the current defined ones.
     *
     * But for parameters, they are overridden by the current ones. It allows
     * the parameters passed to the container constructor to have precedence
     * over the loaded ones.
     *
     *     $container = new ContainerBuilder(new ParameterBag(['foo' => 'bar']));
     *     $loader = new LoaderXXX($container);
     *     $loader->load('resource_name');
     *     $container->register('foo', 'stdClass');
     *
     * In the above example, even if the loaded resource defines a foo
     * parameter, the value will still be 'bar' as defined in the ContainerBuilder
     * constructor.
     *
     * @throws BadMethodCallException When this ContainerBuilder is compiled
     */
    
public function merge(self $container)
    {
        if (
$this->isCompiled()) {
            throw new 
BadMethodCallException('Cannot merge on a compiled container.');
        }

        
$this->addDefinitions($container->getDefinitions());
        
$this->addAliases($container->getAliases());
        
$this->getParameterBag()->add($container->getParameterBag()->all());

        if (
$this->trackResources) {
            foreach (
$container->getResources() as $resource) {
                
$this->addResource($resource);
            }
        }

        foreach (
$this->extensions as $name => $extension) {
            if (!isset(
$this->extensionConfigs[$name])) {
                
$this->extensionConfigs[$name] = [];
            }

            
$this->extensionConfigs[$name] = array_merge($this->extensionConfigs[$name], $container->getExtensionConfig($name));
        }

        if (
$this->getParameterBag() instanceof EnvPlaceholderParameterBag && $container->getParameterBag() instanceof EnvPlaceholderParameterBag) {
            
$envPlaceholders $container->getParameterBag()->getEnvPlaceholders();
            
$this->getParameterBag()->mergeEnvPlaceholders($container->getParameterBag());
        } else {
            
$envPlaceholders = [];
        }

        foreach (
$container->envCounters as $env => $count) {
            if (!
$count && !isset($envPlaceholders[$env])) {
                continue;
            }
            if (!isset(
$this->envCounters[$env])) {
                
$this->envCounters[$env] = $count;
            } else {
                
$this->envCounters[$env] += $count;
            }
        }

        foreach (
$container->getAutoconfiguredInstanceof() as $interface => $childDefinition) {
            if (isset(
$this->autoconfiguredInstanceof[$interface])) {
                throw new 
InvalidArgumentException(sprintf('"%s" has already been autoconfigured and merge() does not support merging autoconfiguration for the same class/interface.'$interface));
            }

            
$this->autoconfiguredInstanceof[$interface] = $childDefinition;
        }

        foreach (
$container->getAutoconfiguredAttributes() as $attribute => $configurator) {
            if (isset(
$this->autoconfiguredAttributes[$attribute])) {
                throw new 
InvalidArgumentException(sprintf('"%s" has already been autoconfigured and merge() does not support merging autoconfiguration for the same attribute.'$attribute));
            }

            
$this->autoconfiguredAttributes[$attribute] = $configurator;
        }
    }

    
/**
     * Returns the configuration array for the given extension.
     *
     * @return array<array<string, mixed>>
     */
    
public function getExtensionConfig(string $name): array
    {
        if (!isset(
$this->extensionConfigs[$name])) {
            
$this->extensionConfigs[$name] = [];
        }

        return 
$this->extensionConfigs[$name];
    }

    
/**
     * Prepends a config array to the configs of the given extension.
     *
     * @param array<string, mixed> $config
     */
    
public function prependExtensionConfig(string $name, array $config)
    {
        if (!isset(
$this->extensionConfigs[$name])) {
            
$this->extensionConfigs[$name] = [];
        }

        
array_unshift($this->extensionConfigs[$name], $config);
    }

    
/**
     * Compiles the container.
     *
     * This method passes the container to compiler
     * passes whose job is to manipulate and optimize
     * the container.
     *
     * The main compiler passes roughly do four things:
     *
     *  * The extension configurations are merged;
     *  * Parameter values are resolved;
     *  * The parameter bag is frozen;
     *  * Extension loading is disabled.
     *
     * @param bool $resolveEnvPlaceholders Whether %env()% parameters should be resolved using the current
     *                                     env vars or be replaced by uniquely identifiable placeholders.
     *                                     Set to "true" when you want to use the current ContainerBuilder
     *                                     directly, keep to "false" when the container is dumped instead.
     */
    
public function compile(bool $resolveEnvPlaceholders false)
    {
        
$compiler $this->getCompiler();

        if (
$this->trackResources) {
            foreach (
$compiler->getPassConfig()->getPasses() as $pass) {
                
$this->addObjectResource($pass);
            }
        }
        
$bag $this->getParameterBag();

        if (
$resolveEnvPlaceholders && $bag instanceof EnvPlaceholderParameterBag) {
            
$compiler->addPass(new ResolveEnvPlaceholdersPass(), PassConfig::TYPE_AFTER_REMOVING, -1000);
        }

        
$compiler->compile($this);

        foreach (
$this->definitions as $id => $definition) {
            if (
$this->trackResources && $definition->isLazy()) {
                
$this->getReflectionClass($definition->getClass());
            }
        }

        
$this->extensionConfigs = [];

        if (
$bag instanceof EnvPlaceholderParameterBag) {
            if (
$resolveEnvPlaceholders) {
                
$this->parameterBag = new ParameterBag($this->resolveEnvPlaceholders($bag->all(), true));
            }

            
$this->envPlaceholders $bag->getEnvPlaceholders();
        }

        
parent::compile();

        foreach (
$this->definitions $this->aliasDefinitions as $id => $definition) {
            if (!
$definition->isPublic() || $definition->isPrivate()) {
                
$this->removedIds[$id] = true;
            }
        }
    }

    
/**
     * {@inheritdoc}
     */
    
public function getServiceIds(): array
    {
        return 
array_map('strval'array_unique(array_merge(array_keys($this->getDefinitions()), array_keys($this->aliasDefinitions), parent::getServiceIds())));
    }

    
/**
     * Gets removed service or alias ids.
     *
     * @return array<string, bool>
     */
    
public function getRemovedIds(): array
    {
        return 
$this->removedIds;
    }

    
/**
     * Adds the service aliases.
     *
     * @param array<string, string|Alias> $aliases
     */
    
public function addAliases(array $aliases)
    {
        foreach (
$aliases as $alias => $id) {
            
$this->setAlias($alias$id);
        }
    }

    
/**
     * Sets the service aliases.
     *
     * @param array<string, string|Alias> $aliases
     */
    
public function setAliases(array $aliases)
    {
        
$this->aliasDefinitions = [];
        
$this->addAliases($aliases);
    }

    
/**
     * Sets an alias for an existing service.
     *
     * @param string       $alias The alias to create
     * @param string|Alias $id    The service to alias
     *
     * @return Alias
     *
     * @throws InvalidArgumentException if the id is not a string or an Alias
     * @throws InvalidArgumentException if the alias is for itself
     */
    
public function setAlias(string $aliasstring|Alias $id): Alias
    
{
        if (
'' === $alias || '\\' === $alias[-1] || \strlen($alias) !== strcspn($alias"\0\r\n'")) {
            throw new 
InvalidArgumentException(sprintf('Invalid alias id: "%s".'$alias));
        }

        if (\
is_string($id)) {
            
$id = new Alias($id);
        } elseif (!
$id instanceof Alias) {
            throw new 
InvalidArgumentException('$id must be a string, or an Alias object.');
        }

        if (
$alias === (string) $id) {
            throw new 
InvalidArgumentException(sprintf('An alias cannot reference itself, got a circular reference on "%s".'$alias));
        }

        unset(
$this->definitions[$alias], $this->removedIds[$alias]);

        return 
$this->aliasDefinitions[$alias] = $id;
    }

    public function 
removeAlias(string $alias)
    {
        if (isset(
$this->aliasDefinitions[$alias])) {
            unset(
$this->aliasDefinitions[$alias]);
            
$this->removedIds[$alias] = true;
        }
    }

    
/**
     * @return bool
     */
    
public function hasAlias(string $id): bool
    
{
        return isset(
$this->aliasDefinitions[$id]);
    }

    
/**
     * @return array<string, Alias>
     */
    
public function getAliases(): array
    {
        return 
$this->aliasDefinitions;
    }

    
/**
     * @return Alias
     *
     * @throws InvalidArgumentException if the alias does not exist
     */
    
public function getAlias(string $id): Alias
    
{
        if (!isset(
$this->aliasDefinitions[$id])) {
            throw new 
InvalidArgumentException(sprintf('The service alias "%s" does not exist.'$id));
        }

        return 
$this->aliasDefinitions[$id];
    }

    
/**
     * Registers a service definition.
     *
     * This methods allows for simple registration of service definition
     * with a fluid interface.
     *
     * @return Definition
     */
    
public function register(string $idstring $class null): Definition
    
{
        return 
$this->setDefinition($id, new Definition($class));
    }

    
/**
     * Registers an autowired service definition.
     *
     * This method implements a shortcut for using setDefinition() with
     * an autowired definition.
     *
     * @return Definition
     */
    
public function autowire(string $idstring $class null): Definition
    
{
        return 
$this->setDefinition($id, (new Definition($class))->setAutowired(true));
    }

    
/**
     * Adds the service definitions.
     *
     * @param array<string, Definition> $definitions
     */
    
public function addDefinitions(array $definitions)
    {
        foreach (
$definitions as $id => $definition) {
            
$this->setDefinition($id$definition);
        }
    }

    
/**
     * Sets the service definitions.
     *
     * @param array<string, Definition> $definitions
     */
    
public function setDefinitions(array $definitions)
    {
        
$this->definitions = [];
        
$this->addDefinitions($definitions);
    }

    
/**
     * Gets all service definitions.
     *
     * @return array<string, Definition>
     */
    
public function getDefinitions(): array
    {
        return 
$this->definitions;
    }

    
/**
     * Sets a service definition.
     *
     * @return Definition
     *
     * @throws BadMethodCallException When this ContainerBuilder is compiled
     */
    
public function setDefinition(string $idDefinition $definition): Definition
    
{
        if (
$this->isCompiled()) {
            throw new 
BadMethodCallException('Adding definition to a compiled container is not allowed.');
        }

        if (
'' === $id || '\\' === $id[-1] || \strlen($id) !== strcspn($id"\0\r\n'")) {
            throw new 
InvalidArgumentException(sprintf('Invalid service id: "%s".'$id));
        }

        unset(
$this->aliasDefinitions[$id], $this->removedIds[$id]);

        return 
$this->definitions[$id] = $definition;
    }

    
/**
     * Returns true if a service definition exists under the given identifier.
     *
     * @return bool
     */
    
public function hasDefinition(string $id): bool
    
{
        return isset(
$this->definitions[$id]);
    }

    
/**
     * Gets a service definition.
     *
     * @return Definition
     *
     * @throws ServiceNotFoundException if the service definition does not exist
     */
    
public function getDefinition(string $id): Definition
    
{
        if (!isset(
$this->definitions[$id])) {
            throw new 
ServiceNotFoundException($id);
        }

        return 
$this->definitions[$id];
    }

    
/**
     * Gets a service definition by id or alias.
     *
     * The method "unaliases" recursively to return a Definition instance.
     *
     * @return Definition
     *
     * @throws ServiceNotFoundException if the service definition does not exist
     */
    
public function findDefinition(string $id): Definition
    
{
        
$seen = [];
        while (isset(
$this->aliasDefinitions[$id])) {
            
$id = (string) $this->aliasDefinitions[$id];

            if (isset(
$seen[$id])) {
                
$seen array_values($seen);
                
$seen = \array_slice($seenarray_search($id$seen));
                
$seen[] = $id;

                throw new 
ServiceCircularReferenceException($id$seen);
            }

            
$seen[$id] = $id;
        }

        return 
$this->getDefinition($id);
    }

    
/**
     * Creates a service for a service definition.
     *
     * @return mixed
     *
     * @throws RuntimeException         When the factory definition is incomplete
     * @throws RuntimeException         When the service is a synthetic service
     * @throws InvalidArgumentException When configure callable is not callable
     */
    
private function createService(Definition $definition, array &$inlineServicesbool $isConstructorArgument falsestring $id nullbool $tryProxy true): mixed
    
{
        if (
null === $id && isset($inlineServices[$h spl_object_hash($definition)])) {
            return 
$inlineServices[$h];
        }

        if (
$definition instanceof ChildDefinition) {
            throw new 
RuntimeException(sprintf('Constructing service "%s" from a parent definition is not supported at build time.'$id));
        }

        if (
$definition->isSynthetic()) {
            throw new 
RuntimeException(sprintf('You have requested a synthetic service ("%s"). The DIC does not know how to construct this service.'$id));
        }

        if (
$definition->isDeprecated()) {
            
$deprecation $definition->getDeprecation($id);
            
trigger_deprecation($deprecation['package'], $deprecation['version'], $deprecation['message']);
        }

        if (
$tryProxy && $definition->isLazy() && !$tryProxy = !($proxy $this->proxyInstantiator) || $proxy instanceof RealServiceInstantiator) {
            
$proxy $proxy->instantiateProxy(
                
$this,
                
$definition,
                
$id, function () use ($definition, &$inlineServices$id) {
                    return 
$this->createService($definition$inlineServicestrue$idfalse);
                }
            );
            
$this->shareService($definition$proxy$id$inlineServices);

            return 
$proxy;
        }

        
$parameterBag $this->getParameterBag();

        if (
null !== $definition->getFile()) {
            require_once 
$parameterBag->resolveValue($definition->getFile());
        }

        
$arguments $this->doResolveServices($parameterBag->unescapeValue($parameterBag->resolveValue($definition->getArguments())), $inlineServices$isConstructorArgument);

        if (
null !== $factory $definition->getFactory()) {
            if (\
is_array($factory)) {
                
$factory = [$this->doResolveServices($parameterBag->resolveValue($factory[0]), $inlineServices$isConstructorArgument), $factory[1]];
            } elseif (!\
is_string($factory)) {
                throw new 
RuntimeException(sprintf('Cannot create service "%s" because of invalid factory.'$id));
            }
        }

        if (
null !== $id && $definition->isShared() && isset($this->services[$id]) && ($tryProxy || !$definition->isLazy())) {
            return 
$this->services[$id];
        }

        if (
null !== $factory) {
            
$service $factory(...$arguments);

            if (!
$definition->isDeprecated() && \is_array($factory) && \is_string($factory[0])) {
                
$r = new \ReflectionClass($factory[0]);

                if (
strpos($r->getDocComment(), "\n * @deprecated ")) {
                    
trigger_deprecation('''''The "%s" service relies on the deprecated "%s" factory class. It should either be deprecated or its factory upgraded.'$id$r->name);
                }
            }
        } else {
            
$r = new \ReflectionClass($parameterBag->resolveValue($definition->getClass()));

            
$service null === $r->getConstructor() ? $r->newInstance() : $r->newInstanceArgs(array_values($arguments));

            if (!
$definition->isDeprecated() && strpos($r->getDocComment(), "\n * @deprecated ")) {
                
trigger_deprecation('''''The "%s" service relies on the deprecated "%s" class. It should either be deprecated or its implementation upgraded.'$id$r->name);
            }
        }

        
$lastWitherIndex null;
        foreach (
$definition->getMethodCalls() as $k => $call) {
            if (
$call[2] ?? false) {
                
$lastWitherIndex $k;
            }
        }

        if (
null === $lastWitherIndex && ($tryProxy || !$definition->isLazy())) {
            
// share only if proxying failed, or if not a proxy, and if no withers are found
            
$this->shareService($definition$service$id$inlineServices);
        }

        
$properties $this->doResolveServices($parameterBag->unescapeValue($parameterBag->resolveValue($definition->getProperties())), $inlineServices);
        foreach (
$properties as $name => $value) {
            
$service->$name $value;
        }

        foreach (
$definition->getMethodCalls() as $k => $call) {
            
$service $this->callMethod($service$call$inlineServices);

            if (
$lastWitherIndex === $k && ($tryProxy || !$definition->isLazy())) {
                
// share only if proxying failed, or if not a proxy, and this is the last wither
                
$this->shareService($definition$service$id$inlineServices);
            }
        }

        if (
$callable $definition->getConfigurator()) {
            if (\
is_array($callable)) {
                
$callable[0] = $parameterBag->resolveValue($callable[0]);

                if (
$callable[0] instanceof Reference) {
                    
$callable[0] = $this->doGet((string) $callable[0], $callable[0]->getInvalidBehavior(), $inlineServices);
                } elseif (
$callable[0] instanceof Definition) {
                    
$callable[0] = $this->createService($callable[0], $inlineServices);
                }
            }

            if (!\
is_callable($callable)) {
                throw new 
InvalidArgumentException(sprintf('The configure callable for class "%s" is not a callable.'get_debug_type($service)));
            }

            
$callable($service);
        }

        return 
$service;
    }

    
/**
     * Replaces service references by the real service instance and evaluates expressions.
     *
     * @param mixed $value
     *
     * @return mixed The same value with all service references replaced by
     *               the real service instances and all expressions evaluated
     */
    
public function resolveServices(mixed $value): mixed
    
{
        return 
$this->doResolveServices($value);
    }

    private function 
doResolveServices(mixed $value, array &$inlineServices = [], bool $isConstructorArgument false): mixed
    
{
        if (\
is_array($value)) {
            foreach (
$value as $k => $v) {
                
$value[$k] = $this->doResolveServices($v$inlineServices$isConstructorArgument);
            }
        } elseif (
$value instanceof ServiceClosureArgument) {
            
$reference $value->getValues()[0];
            
$value = function () use ($reference) {
                return 
$this->resolveServices($reference);
            };
        } elseif (
$value instanceof IteratorArgument) {
            
$value = new RewindableGenerator(function () use ($value, &$inlineServices) {
                foreach (
$value->getValues() as $k => $v) {
                    foreach (
self::getServiceConditionals($v) as $s) {
                        if (!
$this->has($s)) {
                            continue 
2;
                        }
                    }
                    foreach (
self::getInitializedConditionals($v) as $s) {
                        if (!
$this->doGet($sContainerInterface::IGNORE_ON_UNINITIALIZED_REFERENCE$inlineServices)) {
                            continue 
2;
                        }
                    }

                    yield 
$k => $this->doResolveServices($v$inlineServices);
                }
            }, function () use (
$value): int {
                
$count 0;
                foreach (
$value->getValues() as $v) {
                    foreach (
self::getServiceConditionals($v) as $s) {
                        if (!
$this->has($s)) {
                            continue 
2;
                        }
                    }
                    foreach (
self::getInitializedConditionals($v) as $s) {
                        if (!
$this->doGet($sContainerInterface::IGNORE_ON_UNINITIALIZED_REFERENCE)) {
                            continue 
2;
                        }
                    }

                    ++
$count;
                }

                return 
$count;
            });
        } elseif (
$value instanceof ServiceLocatorArgument) {
            
$refs $types = [];
            foreach (
$value->getValues() as $k => $v) {
                if (
$v) {
                    
$refs[$k] = [$v];
                    
$types[$k] = $v instanceof TypedReference $v->getType() : '?';
                }
            }
            
$value = new ServiceLocator(\Closure::fromCallable([$this'resolveServices']), $refs$types);
        } elseif (
$value instanceof Reference) {
            
$value $this->doGet((string) $value$value->getInvalidBehavior(), $inlineServices$isConstructorArgument);
        } elseif (
$value instanceof Definition) {
            
$value $this->createService($value$inlineServices$isConstructorArgument);
        } elseif (
$value instanceof Parameter) {
            
$value $this->getParameter((string) $value);
        } elseif (
$value instanceof Expression) {
            
$value $this->getExpressionLanguage()->evaluate($value, ['container' => $this]);
        } elseif (
$value instanceof AbstractArgument) {
            throw new 
RuntimeException($value->getTextWithContext());
        }

        return 
$value;
    }

    
/**
     * Returns service ids for a given tag.
     *
     * Example:
     *
     *     $container->register('foo')->addTag('my.tag', ['hello' => 'world']);
     *
     *     $serviceIds = $container->findTaggedServiceIds('my.tag');
     *     foreach ($serviceIds as $serviceId => $tags) {
     *         foreach ($tags as $tag) {
     *             echo $tag['hello'];
     *         }
     *     }
     *
     * @return array<string, array> An array of tags with the tagged service as key, holding a list of attribute arrays
     */
    
public function findTaggedServiceIds(string $namebool $throwOnAbstract false): array
    {
        
$this->usedTags[] = $name;
        
$tags = [];
        foreach (
$this->getDefinitions() as $id => $definition) {
            if (
$definition->hasTag($name)) {
                if (
$throwOnAbstract && $definition->isAbstract()) {
                    throw new 
InvalidArgumentException(sprintf('The service "%s" tagged "%s" must not be abstract.'$id$name));
                }
                
$tags[$id] = $definition->getTag($name);
            }
        }

        return 
$tags;
    }

    
/**
     * Returns all tags the defined services use.
     *
     * @return string[]
     */
    
public function findTags(): array
    {
        
$tags = [];
        foreach (
$this->getDefinitions() as $id => $definition) {
            
$tags[] = array_keys($definition->getTags());
        }

        return 
array_unique(array_merge([], ...$tags));
    }

    
/**
     * Returns all tags not queried by findTaggedServiceIds.
     *
     * @return string[]
     */
    
public function findUnusedTags(): array
    {
        return 
array_values(array_diff($this->findTags(), $this->usedTags));
    }

    public function 
addExpressionLanguageProvider(ExpressionFunctionProviderInterface $provider)
    {
        
$this->expressionLanguageProviders[] = $provider;
    }

    
/**
     * @return ExpressionFunctionProviderInterface[]
     */
    
public function getExpressionLanguageProviders(): array
    {
        return 
$this->expressionLanguageProviders;
    }

    
/**
     * Returns a ChildDefinition that will be used for autoconfiguring the interface/class.
     *
     * @return ChildDefinition
     */
    
public function registerForAutoconfiguration(string $interface): ChildDefinition
    
{
        if (!isset(
$this->autoconfiguredInstanceof[$interface])) {
            
$this->autoconfiguredInstanceof[$interface] = new ChildDefinition('');
        }

        return 
$this->autoconfiguredInstanceof[$interface];
    }

    
/**
     * Registers an attribute that will be used for autoconfiguring annotated classes.
     *
     * The third argument passed to the callable is the reflector of the
     * class/method/property/parameter that the attribute targets. Using one or many of
     * \ReflectionClass|\ReflectionMethod|\ReflectionProperty|\ReflectionParameter as a type-hint
     * for this argument allows filtering which attributes should be passed to the callable.
     *
     * @template T
     *
     * @param class-string<T>                                $attributeClass
     * @param callable(ChildDefinition, T, \Reflector): void $configurator
     */
    
public function registerAttributeForAutoconfiguration(string $attributeClass, callable $configurator): void
    
{
        
$this->autoconfiguredAttributes[$attributeClass] = $configurator;
    }

    
/**
     * Registers an autowiring alias that only binds to a specific argument name.
     *
     * The argument name is derived from $name if provided (from $id otherwise)
     * using camel case: "foo.bar" or "foo_bar" creates an alias bound to
     * "$fooBar"-named arguments with $type as type-hint. Such arguments will
     * receive the service $id when autowiring is used.
     */
    
public function registerAliasForArgument(string $idstring $typestring $name null): Alias
    
{
        
$name = (new Target($name ?? $id))->name;

        if (!
preg_match('/^[a-zA-Z_\x7f-\xff]/'$name)) {
            throw new 
InvalidArgumentException(sprintf('Invalid argument name "%s" for service "%s": the first character must be a letter.'$name$id));
        }

        return 
$this->setAlias($type.' $'.$name$id);
    }

    
/**
     * Returns an array of ChildDefinition[] keyed by interface.
     *
     * @return array<string, ChildDefinition>
     */
    
public function getAutoconfiguredInstanceof(): array
    {
        return 
$this->autoconfiguredInstanceof;
    }

    
/**
     * @return array<string, callable>
     */
    
public function getAutoconfiguredAttributes(): array
    {
        return 
$this->autoconfiguredAttributes;
    }

    
/**
     * Resolves env parameter placeholders in a string or an array.
     *
     * @param mixed            $value     The value to resolve
     * @param string|true|null $format    A sprintf() format returning the replacement for each env var name or
     *                                    null to resolve back to the original "%env(VAR)%" format or
     *                                    true to resolve to the actual values of the referenced env vars
     * @param array            &$usedEnvs Env vars found while resolving are added to this array
     *
     * @return mixed The value with env parameters resolved if a string or an array is passed
     */
    
public function resolveEnvPlaceholders($value$format null, array &$usedEnvs null): mixed
    
{
        if (
null === $format) {
            
$format '%%env(%s)%%';
        }

        
$bag $this->getParameterBag();
        if (
true === $format) {
            
$value $bag->resolveValue($value);
        }

        if (
$value instanceof Definition) {
            
$value = (array) $value;
        }

        if (\
is_array($value)) {
            
$result = [];
            foreach (
$value as $k => $v) {
                
$result[\is_string($k) ? $this->resolveEnvPlaceholders($k$format$usedEnvs) : $k] = $this->resolveEnvPlaceholders($v$format$usedEnvs);
            }

            return 
$result;
        }

        if (!\
is_string($value) || 38 > \strlen($value) || !preg_match('/env[_(]/i'$value)) {
            return 
$value;
        }
        
$envPlaceholders $bag instanceof EnvPlaceholderParameterBag $bag->getEnvPlaceholders() : $this->envPlaceholders;

        
$completed false;
        foreach (
$envPlaceholders as $env => $placeholders) {
            foreach (
$placeholders as $placeholder) {
                if (
false !== stripos($value$placeholder)) {
                    if (
true === $format) {
                        
$resolved $bag->escapeValue($this->getEnv($env));
                    } else {
                        
$resolved sprintf($format$env);
                    }
                    if (
$placeholder === $value) {
                        
$value $resolved;
                        
$completed true;
                    } else {
                        if (!\
is_string($resolved) && !is_numeric($resolved)) {
                            throw new 
RuntimeException(sprintf('A string value must be composed of strings and/or numbers, but found parameter "env(%s)" of type "%s" inside string value "%s".'$envget_debug_type($resolved), $this->resolveEnvPlaceholders($value)));
                        }
                        
$value str_ireplace($placeholder$resolved$value);
                    }
                    
$usedEnvs[$env] = $env;
                    
$this->envCounters[$env] = isset($this->envCounters[$env]) ? $this->envCounters[$env] : 1;

                    if (
$completed) {
                        break 
2;
                    }
                }
            }
        }

        return 
$value;
    }

    
/**
     * Get statistics about env usage.
     *
     * @return int[] The number of time each env vars has been resolved
     */
    
public function getEnvCounters(): array
    {
        
$bag $this->getParameterBag();
        
$envPlaceholders $bag instanceof EnvPlaceholderParameterBag $bag->getEnvPlaceholders() : $this->envPlaceholders;

        foreach (
$envPlaceholders as $env => $placeholders) {
            if (!isset(
$this->envCounters[$env])) {
                
$this->envCounters[$env] = 0;
            }
        }

        return 
$this->envCounters;
    }

    
/**
     * @final
     */
    
public function log(CompilerPassInterface $passstring $message)
    {
        
$this->getCompiler()->log($pass$this->resolveEnvPlaceholders($message));
    }

    
/**
     * Checks whether a class is available and will remain available in the "no-dev" mode of Composer.
     *
     * When parent packages are provided and if any of them is in dev-only mode,
     * the class will be considered available even if it is also in dev-only mode.
     */
    
final public static function willBeAvailable(string $packagestring $class, array $parentPackages): bool
    
{
        
$skipDeprecation < \func_num_args() && func_get_arg(3);
        
$hasRuntimeApi class_exists(InstalledVersions::class);

        if (!
$hasRuntimeApi && !$skipDeprecation) {
            
trigger_deprecation('symfony/dependency-injection''5.4''Calling "%s" when dependencies have been installed with Composer 1 is deprecated. Consider upgrading to Composer 2.'__METHOD__);
        }

        if (!
class_exists($class) && !interface_exists($classfalse) && !trait_exists($classfalse)) {
            return 
false;
        }

        if (!
$hasRuntimeApi || !InstalledVersions::isInstalled($package) || InstalledVersions::isInstalled($packagefalse)) {
            return 
true;
        }

        
// the package is installed but in dev-mode only, check if this applies to one of the parent packages too

        
$rootPackage InstalledVersions::getRootPackage()['name'] ?? '';

        if (
'symfony/symfony' === $rootPackage) {
            return 
true;
        }

        foreach (
$parentPackages as $parentPackage) {
            if (
$rootPackage === $parentPackage || (InstalledVersions::isInstalled($parentPackage) && !InstalledVersions::isInstalled($parentPackagefalse))) {
                return 
true;
            }
        }

        return 
false;
    }

    
/**
     * Gets removed binding ids.
     *
     * @return array<int, bool>
     *
     * @internal
     */
    
public function getRemovedBindingIds(): array
    {
        return 
$this->removedBindingIds;
    }

    
/**
     * Removes bindings for a service.
     *
     * @internal
     */
    
public function removeBindings(string $id)
    {
        if (
$this->hasDefinition($id)) {
            foreach (
$this->getDefinition($id)->getBindings() as $key => $binding) {
                [, 
$bindingId] = $binding->getValues();
                
$this->removedBindingIds[(int) $bindingId] = true;
            }
        }
    }

    
/**
     * Returns the Service Conditionals.
     *
     * @param mixed $value An array of conditionals to return
     *
     * @return string[]
     *
     * @internal
     */
    
public static function getServiceConditionals($value): array
    {
        
$services = [];

        if (\
is_array($value)) {
            foreach (
$value as $v) {
                
$services array_unique(array_merge($servicesself::getServiceConditionals($v)));
            }
        } elseif (
$value instanceof Reference && ContainerInterface::IGNORE_ON_INVALID_REFERENCE === $value->getInvalidBehavior()) {
            
$services[] = (string) $value;
        }

        return 
$services;
    }

    
/**
     * Returns the initialized conditionals.
     *
     * @param mixed $value An array of conditionals to return
     *
     * @return string[]
     *
     * @internal
     */
    
public static function getInitializedConditionals($value): array
    {
        
$services = [];

        if (\
is_array($value)) {
            foreach (
$value as $v) {
                
$services array_unique(array_merge($servicesself::getInitializedConditionals($v)));
            }
        } elseif (
$value instanceof Reference && ContainerInterface::IGNORE_ON_UNINITIALIZED_REFERENCE === $value->getInvalidBehavior()) {
            
$services[] = (string) $value;
        }

        return 
$services;
    }

    
/**
     * Computes a reasonably unique hash of a value.
     *
     * @param mixed $value A serializable value
     *
     * @return string
     */
    
public static function hash(mixed $value): string
    
{
        
$hash substr(base64_encode(hash('sha256'serialize($value), true)), 07);

        return 
str_replace(['/''+'], ['.''_'], $hash);
    }

    
/**
     * {@inheritdoc}
     */
    
protected function getEnv(string $name): mixed
    
{
        
$value parent::getEnv($name);
        
$bag $this->getParameterBag();

        if (!\
is_string($value) || !$bag instanceof EnvPlaceholderParameterBag) {
            return 
$value;
        }

        
$envPlaceholders $bag->getEnvPlaceholders();
        if (isset(
$envPlaceholders[$name][$value])) {
            
$bag = new ParameterBag($bag->all());

            return 
$bag->unescapeValue($bag->get("env($name)"));
        }
        foreach (
$envPlaceholders as $env => $placeholders) {
            if (isset(
$placeholders[$value])) {
                return 
$this->getEnv($env);
            }
        }

        
$this->resolving["env($name)"] = true;
        try {
            return 
$bag->unescapeValue($this->resolveEnvPlaceholders($bag->escapeValue($value), true));
        } finally {
            unset(
$this->resolving["env($name)"]);
        }
    }

    private function 
callMethod(object $service, array $call, array &$inlineServices): mixed
    
{
        foreach (
self::getServiceConditionals($call[1]) as $s) {
            if (!
$this->has($s)) {
                return 
$service;
            }
        }
        foreach (
self::getInitializedConditionals($call[1]) as $s) {
            if (!
$this->doGet($sContainerInterface::IGNORE_ON_UNINITIALIZED_REFERENCE$inlineServices)) {
                return 
$service;
            }
        }

        
$result $service->{$call[0]}(...$this->doResolveServices($this->getParameterBag()->unescapeValue($this->getParameterBag()->resolveValue($call[1])), $inlineServices));

        return empty(
$call[2]) ? $service $result;
    }

    
/**
     * Shares a given service in the container.
     *
     * @param mixed $service
     */
    
private function shareService(Definition $definitionmixed $service, ?string $id, array &$inlineServices)
    {
        
$inlineServices[$id ?? spl_object_hash($definition)] = $service;

        if (
null !== $id && $definition->isShared()) {
            
$this->services[$id] = $service;
            unset(
$this->loading[$id]);
        }
    }

    private function 
getExpressionLanguage(): ExpressionLanguage
    
{
        if (
null === $this->expressionLanguage) {
            if (!
class_exists(\Symfony\Component\ExpressionLanguage\ExpressionLanguage::class)) {
                throw new 
LogicException('Unable to use expressions as the Symfony ExpressionLanguage component is not installed.');
            }
            
$this->expressionLanguage = new ExpressionLanguage(null$this->expressionLanguageProviders);
        }

        return 
$this->expressionLanguage;
    }

    private function 
inVendors(string $path): bool
    
{
        if (
null === $this->vendors) {
            
$this->vendors = (new ComposerResource())->getVendors();
        }
        
$path realpath($path) ?: $path;

        foreach (
$this->vendors as $vendor) {
            if (
str_starts_with($path$vendor) && false !== strpbrk(substr($path, \strlen($vendor), 1), '/'.\DIRECTORY_SEPARATOR)) {
                
$this->addResource(new FileResource($vendor.'/composer/installed.json'));

                return 
true;
            }
        }

        return 
false;
    }
}

:: 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.0112 ]--