mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-25 21:56:32 +02:00 
			
		
		
		
	Also use union types consistently instead of question marks. Fixed with php-cs-fixer. PHPBB-17496
		
			
				
	
	
		
			210 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			210 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
| *
 | |
| * This file is part of the phpBB Forum Software package.
 | |
| *
 | |
| * @copyright (c) phpBB Limited <https://www.phpbb.com>
 | |
| * @license GNU General Public License, version 2 (GPL-2.0)
 | |
| *
 | |
| * For full copyright and license information, please see
 | |
| * the docs/CREDITS.txt file.
 | |
| *
 | |
| */
 | |
| use Symfony\Component\DependencyInjection\ContainerInterface;
 | |
| use Symfony\Component\DependencyInjection\ScopeInterface;
 | |
| 
 | |
| class phpbb_mock_container_builder implements ContainerInterface
 | |
| {
 | |
| 	protected $services = array();
 | |
| 	protected $parameters = array();
 | |
| 
 | |
| 	public function __construct()
 | |
| 	{
 | |
| 		$this->setParameter('debug.load_time', false);
 | |
| 		$this->setParameter('session.log_errors', false);
 | |
| 		$this->setParameter('session.force_sid', true);
 | |
| 		$this->setParameter('finder.cache', false);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Sets a service.
 | |
| 	*
 | |
| 	* @param string $id      The service identifier
 | |
| 	* @param object $service The service instance
 | |
| 	* @param bool $shared Whether service is shared
 | |
| 	*
 | |
| 	* @api
 | |
| 	*/
 | |
| 	public function set($id, $service, $shared = false)
 | |
| 	{
 | |
| 		$this->services[$id] = $service;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Gets a service.
 | |
| 	*
 | |
| 	* @param string $id              The service identifier
 | |
| 	* @param int    $invalidBehavior The behavior when the service does not exist
 | |
| 	*
 | |
| 	* @return object The associated service
 | |
| 	*
 | |
| 	* @throws InvalidArgumentException if the service is not defined
 | |
| 	* @throws ServiceCircularReferenceException When a circular reference is detected
 | |
| 	* @throws ServiceNotFoundException When the service is not defined
 | |
| 	*
 | |
| 	* @see Reference
 | |
| 	*
 | |
| 	* @api
 | |
| 	*/
 | |
| 	public function get(string $id, int $invalidBehavior = self::EXCEPTION_ON_INVALID_REFERENCE): object|null
 | |
| 	{
 | |
| 		if ($this->has($id))
 | |
| 		{
 | |
| 			$service = $this->services[$id];
 | |
| 			if (is_array($service) && isset($service[0]) && is_callable($service[0]))
 | |
| 			{
 | |
| 				return call_user_func_array($service[0], $service[1]);
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				return $service;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		throw new Exception('Could not find service: ' . $id);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Returns true if the given service is defined.
 | |
| 	*
 | |
| 	* @param string $id The service identifier
 | |
| 	*
 | |
| 	* @return bool true if the service is defined, false otherwise
 | |
| 	*
 | |
| 	* @api
 | |
| 	*/
 | |
| 	public function has(string $id): bool
 | |
| 	{
 | |
| 		return isset($this->services[$id]);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Gets a parameter.
 | |
| 	*
 | |
| 	* @param string $name The parameter name
 | |
| 	*
 | |
| 	* @return mixed  The parameter value
 | |
| 	*
 | |
| 	* @throws InvalidArgumentException if the parameter is not defined
 | |
| 	*
 | |
| 	* @api
 | |
| 	*/
 | |
| 	public function getParameter(string $name): mixed
 | |
| 	{
 | |
| 		if ($this->hasParameter($name))
 | |
| 		{
 | |
| 			return $this->parameters[$name];
 | |
| 		}
 | |
| 
 | |
| 		throw new Exception('Could not find parameter: ' . $name);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Checks if a parameter exists.
 | |
| 	*
 | |
| 	* @param string $name The parameter name
 | |
| 	*
 | |
| 	* @return bool The presence of parameter in container
 | |
| 	*
 | |
| 	* @api
 | |
| 	*/
 | |
| 	public function hasParameter(string $name): bool
 | |
| 	{
 | |
| 		return isset($this->parameters[$name]);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Sets a parameter.
 | |
| 	*
 | |
| 	* @param string $name  The parameter name
 | |
| 	* @param mixed  $value The parameter value
 | |
| 	*
 | |
| 	* @api
 | |
| 	*/
 | |
| 	public function setParameter($name, $value)
 | |
| 	{
 | |
| 		$this->parameters[$name] = $value;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Enters the given scope
 | |
| 	*
 | |
| 	* @param string $name
 | |
| 	*
 | |
| 	* @api
 | |
| 	*/
 | |
| 	public function enterScope($name)
 | |
| 	{
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Leaves the current scope, and re-enters the parent scope
 | |
| 	*
 | |
| 	* @param string $name
 | |
| 	*
 | |
| 	* @api
 | |
| 	*/
 | |
| 	public function leaveScope($name)
 | |
| 	{
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Adds a scope to the container
 | |
| 	*
 | |
| 	* @param ScopeInterface $scope
 | |
| 	*
 | |
| 	* @api
 | |
| 	*/
 | |
| 	public function addScope(ScopeInterface $scope)
 | |
| 	{
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Whether this container has the given scope
 | |
| 	*
 | |
| 	* @param string $name
 | |
| 	*
 | |
| 	* @return Boolean
 | |
| 	*
 | |
| 	* @api
 | |
| 	*/
 | |
| 	public function hasScope($name)
 | |
| 	{
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	* Determines whether the given scope is currently active.
 | |
| 	*
 | |
| 	* It does however not check if the scope actually exists.
 | |
| 	*
 | |
| 	* @param string $name
 | |
| 	*
 | |
| 	* @return Boolean
 | |
| 	*
 | |
| 	* @api
 | |
| 	*/
 | |
| 	public function isScopeActive($name)
 | |
| 	{
 | |
| 	}
 | |
| 
 | |
| 	public function isCompiled()
 | |
| 	{
 | |
| 		return false;
 | |
| 	}
 | |
| 
 | |
| 	public function initialized($id): bool
 | |
| 	{
 | |
| 		return true;
 | |
| 	}
 | |
| }
 |