Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
| Total | |
0.00% |
0 / 1 |
|
0.00% |
0 / 4 |
CRAP | |
0.00% |
0 / 65 |
| container_factory | |
0.00% |
0 / 1 |
|
0.00% |
0 / 4 |
182 | |
0.00% |
0 / 65 |
| __construct | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 8 |
|||
| get | |
0.00% |
0 / 1 |
12 | |
0.00% |
0 / 7 |
|||
| get_parameter | |
0.00% |
0 / 1 |
6 | |
0.00% |
0 / 7 |
|||
| build_container | |
0.00% |
0 / 1 |
56 | |
0.00% |
0 / 43 |
|||
| <?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. | |
| * | |
| */ | |
| namespace phpbb\install\helper; | |
| use phpbb\install\exception\cannot_build_container_exception; | |
| use phpbb\language\language; | |
| use phpbb\request\request; | |
| class container_factory | |
| { | |
| /** | |
| * @var language | |
| */ | |
| protected $language; | |
| /** | |
| * @var string | |
| */ | |
| protected $phpbb_root_path; | |
| /** | |
| * @var string | |
| */ | |
| protected $php_ext; | |
| /** | |
| * @var \phpbb\request\request | |
| */ | |
| protected $request; | |
| /** | |
| * @var update_helper | |
| */ | |
| protected $update_helper; | |
| /** | |
| * The full phpBB container | |
| * | |
| * @var \Symfony\Component\DependencyInjection\ContainerInterface | |
| */ | |
| protected $container; | |
| /** | |
| * Constructor | |
| * | |
| * @param language $language Language service | |
| * @param request $request Request interface | |
| * @param update_helper $update_helper Update helper | |
| * @param string $phpbb_root_path Path to phpBB's root | |
| * @param string $php_ext Extension of PHP files | |
| */ | |
| public function __construct(language $language, request $request, update_helper $update_helper, $phpbb_root_path, $php_ext) | |
| { | |
| $this->language = $language; | |
| $this->request = $request; | |
| $this->update_helper = $update_helper; | |
| $this->phpbb_root_path = $phpbb_root_path; | |
| $this->php_ext = $php_ext; | |
| $this->container = null; | |
| } | |
| /** | |
| * Container getter | |
| * | |
| * @param null|string $service_name Name of the service to return | |
| * | |
| * @return \Symfony\Component\DependencyInjection\ContainerInterface|Object phpBB's dependency injection container | |
| * or the service specified in $service_name | |
| * | |
| * @throws \phpbb\install\exception\cannot_build_container_exception When container cannot be built | |
| * @throws \Symfony\Component\DependencyInjection\Exception\InvalidArgumentException If the service is not defined | |
| * @throws \Symfony\Component\DependencyInjection\Exception\ServiceCircularReferenceException When a circular reference is detected | |
| * @throws \Symfony\Component\DependencyInjection\Exception\ServiceNotFoundException When the service is not defined | |
| */ | |
| public function get($service_name = null) | |
| { | |
| // Check if container was built, if not try to build it | |
| if ($this->container === null) | |
| { | |
| $this->build_container(); | |
| } | |
| return ($service_name === null) ? $this->container : $this->container->get($service_name); | |
| } | |
| /** | |
| * Returns the specified parameter from the container | |
| * | |
| * @param string $param_name | |
| * | |
| * @return mixed | |
| * | |
| * @throws \phpbb\install\exception\cannot_build_container_exception When container cannot be built | |
| */ | |
| public function get_parameter($param_name) | |
| { | |
| // Check if container was built, if not try to build it | |
| if ($this->container === null) | |
| { | |
| $this->build_container(); | |
| } | |
| return $this->container->getParameter($param_name); | |
| } | |
| /** | |
| * Build dependency injection container | |
| * | |
| * @throws \phpbb\install\exception\cannot_build_container_exception When container cannot be built | |
| */ | |
| protected function build_container() | |
| { | |
| // If the container has been already built just return. | |
| // Although this should never happen | |
| if ($this->container instanceof \Symfony\Component\DependencyInjection\ContainerInterface) | |
| { | |
| return; | |
| } | |
| // Check whether container can be built | |
| // We need config.php for that so let's check if it has been set up yet | |
| if (!filesize($this->phpbb_root_path . 'config.' . $this->php_ext)) | |
| { | |
| throw new cannot_build_container_exception(); | |
| } | |
| $phpbb_config_php_file = new \phpbb\config_php_file($this->phpbb_root_path, $this->php_ext); | |
| $phpbb_container_builder = new \phpbb\di\container_builder($this->phpbb_root_path, $this->php_ext); | |
| // For BC with functions that we need during install | |
| global $phpbb_container, $table_prefix; | |
| $disable_super_globals = $this->request->super_globals_disabled(); | |
| // This is needed because container_builder::get_env_parameters() uses $_SERVER | |
| if ($disable_super_globals) | |
| { | |
| $this->request->enable_super_globals(); | |
| } | |
| $other_config_path = $this->phpbb_root_path . 'install/update/new/config'; | |
| $config_path = (is_dir($other_config_path)) ? $other_config_path : $this->phpbb_root_path . 'config'; | |
| $this->container = $phpbb_container_builder | |
| ->with_environment('production') | |
| ->with_config($phpbb_config_php_file) | |
| ->with_config_path($config_path) | |
| ->without_compiled_container() | |
| ->get_container(); | |
| // Setting request is required for the compatibility globals as those are generated from | |
| // this container | |
| if (!$this->container->isFrozen()) | |
| { | |
| $this->container->register('request')->setSynthetic(true); | |
| $this->container->register('language')->setSynthetic(true); | |
| } | |
| $this->container->set('request', $this->request); | |
| $this->container->set('language', $this->language); | |
| $this->container->compile(); | |
| $phpbb_container = $this->container; | |
| $table_prefix = $phpbb_config_php_file->get('table_prefix'); | |
| // Restore super globals to previous state | |
| if ($disable_super_globals) | |
| { | |
| $this->request->disable_super_globals(); | |
| } | |
| // Get compatibilty globals and constants | |
| $this->update_helper->include_file('includes/compatibility_globals.' . $this->php_ext); | |
| register_compatibility_globals(); | |
| $this->update_helper->include_file('includes/constants.' . $this->php_ext); | |
| } | |
| } |