2021-05-10 00:23:30 +00:00
< ? php
/*
* This file is part of the Symfony package .
*
* ( c ) Fabien Potencier < fabien @ symfony . com >
*
* For the full copyright and license information , please view the LICENSE
* file that was distributed with this source code .
*/
2022-04-17 00:35:02 +00:00
namespace RectorPrefix20220417\Symfony\Component\DependencyInjection ;
2021-05-10 00:23:30 +00:00
2022-04-17 00:35:02 +00:00
use RectorPrefix20220417\Symfony\Component\DependencyInjection\Argument\RewindableGenerator ;
use RectorPrefix20220417\Symfony\Component\DependencyInjection\Argument\ServiceLocator as ArgumentServiceLocator ;
use RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\EnvNotFoundException ;
use RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\InvalidArgumentException ;
use RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\ParameterCircularReferenceException ;
use RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\RuntimeException ;
use RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\ServiceCircularReferenceException ;
use RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException ;
use RectorPrefix20220417\Symfony\Component\DependencyInjection\ParameterBag\EnvPlaceholderParameterBag ;
use RectorPrefix20220417\Symfony\Component\DependencyInjection\ParameterBag\FrozenParameterBag ;
use RectorPrefix20220417\Symfony\Component\DependencyInjection\ParameterBag\ParameterBagInterface ;
use RectorPrefix20220417\Symfony\Contracts\Service\ResetInterface ;
2021-05-10 00:23:30 +00:00
// Help opcache.preload discover always-needed symbols
2022-04-17 00:35:02 +00:00
\class_exists ( \RectorPrefix20220417\Symfony\Component\DependencyInjection\Argument\RewindableGenerator :: class );
\class_exists ( \RectorPrefix20220417\Symfony\Component\DependencyInjection\Argument\ServiceLocator :: class );
2021-05-10 00:23:30 +00:00
/**
* Container is a dependency injection container .
*
* It gives access to object instances ( services ) .
* Services and parameters are simple key / pair stores .
* The container can have four possible behaviors when a service
* does not exist ( or is not initialized for the last case ) :
*
* * EXCEPTION_ON_INVALID_REFERENCE : Throws an exception ( the default )
* * NULL_ON_INVALID_REFERENCE : Returns null
* * IGNORE_ON_INVALID_REFERENCE : Ignores the wrapping command asking for the reference
* ( for instance , ignore a setter if the service does not exist )
* * IGNORE_ON_UNINITIALIZED_REFERENCE : Ignores / returns null for uninitialized services or invalid references
*
* @ author Fabien Potencier < fabien @ symfony . com >
* @ author Johannes M . Schmitt < schmittjoh @ gmail . com >
*/
2022-04-17 00:35:02 +00:00
class Container implements \RectorPrefix20220417\Symfony\Component\DependencyInjection\ContainerInterface , \RectorPrefix20220417\Symfony\Contracts\Service\ResetInterface
2021-05-10 00:23:30 +00:00
{
protected $parameterBag ;
protected $services = [];
protected $privates = [];
protected $fileMap = [];
protected $methodMap = [];
protected $factories = [];
protected $aliases = [];
protected $loading = [];
protected $resolving = [];
protected $syntheticIds = [];
2022-02-14 01:03:53 +00:00
/**
* @ var mixed []
*/
2021-05-10 00:23:30 +00:00
private $envCache = [];
2022-02-14 01:03:53 +00:00
/**
* @ var bool
*/
2021-05-10 00:23:30 +00:00
private $compiled = \false ;
2022-02-14 01:03:53 +00:00
/**
* @ var \Closure
*/
2021-05-10 00:23:30 +00:00
private $getEnv ;
2022-04-17 00:35:02 +00:00
public function __construct ( \RectorPrefix20220417\Symfony\Component\DependencyInjection\ParameterBag\ParameterBagInterface $parameterBag = null )
2021-05-10 00:23:30 +00:00
{
2022-04-17 00:35:02 +00:00
$this -> parameterBag = $parameterBag ? ? new \RectorPrefix20220417\Symfony\Component\DependencyInjection\ParameterBag\EnvPlaceholderParameterBag ();
2021-05-10 00:23:30 +00:00
}
/**
* Compiles the container .
*
* This method does two things :
*
* * Parameter values are resolved ;
* * The parameter bag is frozen .
*/
public function compile ()
{
$this -> parameterBag -> resolve ();
2022-04-17 00:35:02 +00:00
$this -> parameterBag = new \RectorPrefix20220417\Symfony\Component\DependencyInjection\ParameterBag\FrozenParameterBag ( $this -> parameterBag -> all ());
2021-05-10 00:23:30 +00:00
$this -> compiled = \true ;
}
/**
* Returns true if the container is compiled .
*/
2022-02-14 01:03:53 +00:00
public function isCompiled () : bool
2021-05-10 00:23:30 +00:00
{
return $this -> compiled ;
}
/**
* Gets the service container parameter bag .
*/
2022-04-17 00:35:02 +00:00
public function getParameterBag () : \RectorPrefix20220417\Symfony\Component\DependencyInjection\ParameterBag\ParameterBagInterface
2021-05-10 00:23:30 +00:00
{
return $this -> parameterBag ;
}
/**
* Gets a parameter .
*
2022-02-28 10:23:34 +00:00
* @ return array | bool | string | int | float | \UnitEnum | null
2021-05-10 00:23:30 +00:00
*
* @ throws InvalidArgumentException if the parameter is not defined
*/
2021-12-10 10:22:23 +00:00
public function getParameter ( string $name )
2021-05-10 00:23:30 +00:00
{
return $this -> parameterBag -> get ( $name );
}
2022-02-14 01:03:53 +00:00
public function hasParameter ( string $name ) : bool
2021-05-10 00:23:30 +00:00
{
return $this -> parameterBag -> has ( $name );
}
/**
2022-02-28 10:23:34 +00:00
* @ param mixed [] | bool | float | int | string | \UnitEnum | null $value
2021-05-10 00:23:30 +00:00
*/
2021-12-10 10:22:23 +00:00
public function setParameter ( string $name , $value )
2021-05-10 00:23:30 +00:00
{
$this -> parameterBag -> set ( $name , $value );
}
/**
* Sets a service .
*
* Setting a synthetic service to null resets it : has () returns false and get ()
* behaves in the same way as if the service was never created .
*/
2022-03-24 21:23:19 +00:00
public function set ( string $id , ? object $service )
2021-05-10 00:23:30 +00:00
{
// Runs the internal initializer; used by the dumped container to include always-needed files
if ( isset ( $this -> privates [ 'service_container' ]) && $this -> privates [ 'service_container' ] instanceof \Closure ) {
$initialize = $this -> privates [ 'service_container' ];
unset ( $this -> privates [ 'service_container' ]);
$initialize ();
}
if ( 'service_container' === $id ) {
2022-04-17 00:35:02 +00:00
throw new \RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\InvalidArgumentException ( 'You cannot set service "service_container".' );
2021-05-10 00:23:30 +00:00
}
if ( ! ( isset ( $this -> fileMap [ $id ]) || isset ( $this -> methodMap [ $id ]))) {
if ( isset ( $this -> syntheticIds [ $id ]) || ! isset ( $this -> getRemovedIds ()[ $id ])) {
// no-op
} elseif ( null === $service ) {
2022-04-17 00:35:02 +00:00
throw new \RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\InvalidArgumentException ( \sprintf ( 'The "%s" service is private, you cannot unset it.' , $id ));
2021-05-10 00:23:30 +00:00
} else {
2022-04-17 00:35:02 +00:00
throw new \RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\InvalidArgumentException ( \sprintf ( 'The "%s" service is private, you cannot replace it.' , $id ));
2021-05-10 00:23:30 +00:00
}
} elseif ( isset ( $this -> services [ $id ])) {
2022-04-17 00:35:02 +00:00
throw new \RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\InvalidArgumentException ( \sprintf ( 'The "%s" service is already initialized, you cannot replace it.' , $id ));
2021-05-10 00:23:30 +00:00
}
if ( isset ( $this -> aliases [ $id ])) {
unset ( $this -> aliases [ $id ]);
}
if ( null === $service ) {
unset ( $this -> services [ $id ]);
return ;
}
$this -> services [ $id ] = $service ;
}
2022-02-14 01:03:53 +00:00
public function has ( string $id ) : bool
2021-05-10 00:23:30 +00:00
{
if ( isset ( $this -> aliases [ $id ])) {
$id = $this -> aliases [ $id ];
}
if ( isset ( $this -> services [ $id ])) {
return \true ;
}
if ( 'service_container' === $id ) {
return \true ;
}
return isset ( $this -> fileMap [ $id ]) || isset ( $this -> methodMap [ $id ]);
}
/**
* Gets a service .
*
* @ throws ServiceCircularReferenceException When a circular reference is detected
* @ throws ServiceNotFoundException When the service is not defined
* @ throws \Exception if an exception has been thrown when the service has been resolved
*
* @ see Reference
*/
2022-03-24 21:23:19 +00:00
public function get ( string $id , int $invalidBehavior = self :: EXCEPTION_ON_INVALID_REFERENCE ) : ? object
2021-05-10 00:23:30 +00:00
{
return $this -> services [ $id ] ? ? $this -> services [ $id = $this -> aliases [ $id ] ? ? $id ] ? ? ( 'service_container' === $id ? $this : ( $this -> factories [ $id ] ? ? [ $this , 'make' ])( $id , $invalidBehavior ));
}
/**
* Creates a service .
*
* As a separate method to allow " get() " to use the really fast `??` operator .
*/
2021-07-05 23:06:30 +00:00
private function make ( string $id , int $invalidBehavior )
2021-05-10 00:23:30 +00:00
{
if ( isset ( $this -> loading [ $id ])) {
2022-04-17 00:35:02 +00:00
throw new \RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\ServiceCircularReferenceException ( $id , \array_merge ( \array_keys ( $this -> loading ), [ $id ]));
2021-05-10 00:23:30 +00:00
}
$this -> loading [ $id ] = \true ;
try {
if ( isset ( $this -> fileMap [ $id ])) {
return 4 === $invalidBehavior ? null : $this -> load ( $this -> fileMap [ $id ]);
} elseif ( isset ( $this -> methodMap [ $id ])) {
return 4 === $invalidBehavior ? null : $this -> { $this -> methodMap [ $id ]}();
}
} catch ( \Exception $e ) {
unset ( $this -> services [ $id ]);
throw $e ;
} finally {
unset ( $this -> loading [ $id ]);
}
2022-02-14 01:03:53 +00:00
if ( self :: EXCEPTION_ON_INVALID_REFERENCE === $invalidBehavior ) {
2021-05-10 00:23:30 +00:00
if ( ! $id ) {
2022-04-17 00:35:02 +00:00
throw new \RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException ( $id );
2021-05-10 00:23:30 +00:00
}
if ( isset ( $this -> syntheticIds [ $id ])) {
2022-04-17 00:35:02 +00:00
throw new \RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException ( $id , null , null , [], \sprintf ( 'The "%s" service is synthetic, it needs to be set at boot time before it can be used.' , $id ));
2021-05-10 00:23:30 +00:00
}
if ( isset ( $this -> getRemovedIds ()[ $id ])) {
2022-04-17 00:35:02 +00:00
throw new \RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException ( $id , null , null , [], \sprintf ( 'The "%s" service or alias has been removed or inlined when the container was compiled. You should either make it public, or stop using the container directly and use dependency injection instead.' , $id ));
2021-05-10 00:23:30 +00:00
}
$alternatives = [];
foreach ( $this -> getServiceIds () as $knownId ) {
if ( '' === $knownId || '.' === $knownId [ 0 ]) {
continue ;
}
$lev = \levenshtein ( $id , $knownId );
2021-07-21 13:46:30 +00:00
if ( $lev <= \strlen ( $id ) / 3 || \strpos ( $knownId , $id ) !== \false ) {
2021-05-10 00:23:30 +00:00
$alternatives [] = $knownId ;
}
}
2022-04-17 00:35:02 +00:00
throw new \RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException ( $id , null , null , $alternatives );
2021-05-10 00:23:30 +00:00
}
return null ;
}
/**
* Returns true if the given service has actually been initialized .
*/
2022-02-14 01:03:53 +00:00
public function initialized ( string $id ) : bool
2021-05-10 00:23:30 +00:00
{
if ( isset ( $this -> aliases [ $id ])) {
$id = $this -> aliases [ $id ];
}
if ( 'service_container' === $id ) {
return \false ;
}
return isset ( $this -> services [ $id ]);
}
/**
* { @ inheritdoc }
*/
public function reset ()
{
$services = $this -> services + $this -> privates ;
$this -> services = $this -> factories = $this -> privates = [];
foreach ( $services as $service ) {
try {
2022-04-17 00:35:02 +00:00
if ( $service instanceof \RectorPrefix20220417\Symfony\Contracts\Service\ResetInterface ) {
2021-05-10 00:23:30 +00:00
$service -> reset ();
}
} catch ( \Throwable $e ) {
continue ;
}
}
}
/**
* Gets all service ids .
*
2021-11-30 07:57:42 +00:00
* @ return string []
2021-05-10 00:23:30 +00:00
*/
2022-02-14 01:03:53 +00:00
public function getServiceIds () : array
2021-05-10 00:23:30 +00:00
{
return \array_map ( 'strval' , \array_unique ( \array_merge ([ 'service_container' ], \array_keys ( $this -> fileMap ), \array_keys ( $this -> methodMap ), \array_keys ( $this -> aliases ), \array_keys ( $this -> services ))));
}
/**
* Gets service ids that existed at compile time .
*/
2022-02-14 01:03:53 +00:00
public function getRemovedIds () : array
2021-05-10 00:23:30 +00:00
{
return [];
}
/**
* Camelizes a string .
*/
2022-02-14 01:03:53 +00:00
public static function camelize ( string $id ) : string
2021-05-10 00:23:30 +00:00
{
return \strtr ( \ucwords ( \strtr ( $id , [ '_' => ' ' , '.' => '_ ' , '\\' => '_ ' ])), [ ' ' => '' ]);
}
/**
* A string to underscore .
*/
2022-02-14 01:03:53 +00:00
public static function underscore ( string $id ) : string
2021-05-10 00:23:30 +00:00
{
return \strtolower ( \preg_replace ([ '/([A-Z]+)([A-Z][a-z])/' , '/([a-z\\d])([A-Z])/' ], [ '\\1_\\2' , '\\1_\\2' ], \str_replace ( '_' , '.' , $id )));
}
/**
* Creates a service by requiring its factory file .
*/
2021-12-10 10:22:23 +00:00
protected function load ( string $file )
2021-05-10 00:23:30 +00:00
{
return require $file ;
}
/**
* Fetches a variable from the environment .
*
* @ throws EnvNotFoundException When the environment variable is not found and has no default value
2022-02-14 01:03:53 +00:00
* @ return mixed
2021-05-10 00:23:30 +00:00
*/
2021-12-10 10:22:23 +00:00
protected function getEnv ( string $name )
2021-05-10 00:23:30 +00:00
{
if ( isset ( $this -> resolving [ $envName = " env( { $name } ) " ])) {
2022-04-17 00:35:02 +00:00
throw new \RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\ParameterCircularReferenceException ( \array_keys ( $this -> resolving ));
2021-05-10 00:23:30 +00:00
}
if ( isset ( $this -> envCache [ $name ]) || \array_key_exists ( $name , $this -> envCache )) {
return $this -> envCache [ $name ];
}
if ( ! $this -> has ( $id = 'container.env_var_processors_locator' )) {
2022-04-17 00:35:02 +00:00
$this -> set ( $id , new \RectorPrefix20220417\Symfony\Component\DependencyInjection\ServiceLocator ([]));
2021-05-10 00:23:30 +00:00
}
2022-02-14 01:03:53 +00:00
$this -> getEnv = $this -> getEnv ? ? \Closure :: fromCallable ([ $this , 'getEnv' ]);
2021-05-10 00:23:30 +00:00
$processors = $this -> get ( $id );
if ( \false !== ( $i = \strpos ( $name , ':' ))) {
$prefix = \substr ( $name , 0 , $i );
$localName = \substr ( $name , 1 + $i );
} else {
$prefix = 'string' ;
$localName = $name ;
}
2022-04-17 00:35:02 +00:00
$processor = $processors -> has ( $prefix ) ? $processors -> get ( $prefix ) : new \RectorPrefix20220417\Symfony\Component\DependencyInjection\EnvVarProcessor ( $this );
2021-05-10 00:23:30 +00:00
$this -> resolving [ $envName ] = \true ;
try {
return $this -> envCache [ $name ] = $processor -> getEnv ( $prefix , $localName , $this -> getEnv );
} finally {
unset ( $this -> resolving [ $envName ]);
}
}
/**
* @ internal
2022-02-14 01:03:53 +00:00
* @ param string | true $registry
* @ param bool | string $load
* @ return mixed
2021-05-10 00:23:30 +00:00
*/
2021-12-10 10:22:23 +00:00
protected final function getService ( $registry , string $id , ? string $method , $load )
2021-05-10 00:23:30 +00:00
{
if ( 'service_container' === $id ) {
return $this ;
}
if ( \is_string ( $load )) {
2022-04-17 00:35:02 +00:00
throw new \RectorPrefix20220417\Symfony\Component\DependencyInjection\Exception\RuntimeException ( $load );
2021-05-10 00:23:30 +00:00
}
if ( null === $method ) {
return \false !== $registry ? $this -> { $registry }[ $id ] ? ? null : null ;
}
if ( \false !== $registry ) {
return $this -> { $registry }[ $id ] ? ? ( $this -> { $registry }[ $id ] = $load ? $this -> load ( $method ) : $this -> { $method }());
}
if ( ! $load ) {
return $this -> { $method }();
}
return ( $factory = $this -> factories [ $id ] ? ? $this -> factories [ 'service_container' ][ $id ] ? ? null ) ? $factory () : $this -> load ( $method );
}
private function __clone ()
{
}
}