diff options
author | Marc Alexander <admin@m-a-styles.de> | 2019-06-05 21:45:42 +0200 |
---|---|---|
committer | Marc Alexander <admin@m-a-styles.de> | 2019-06-05 21:45:42 +0200 |
commit | e419c2cd3b4f6eb24bb1011d326e1aef01a5c25b (patch) | |
tree | 7f7b043fe5f91c69ea621ca4df18bfc7e22802ed /phpBB/phpbb | |
parent | 183d1afcaa780f09ae5cd431f9099e01bbf37e80 (diff) | |
parent | d72498a9c3006210c49cb1690d079d52593db127 (diff) | |
download | forums-e419c2cd3b4f6eb24bb1011d326e1aef01a5c25b.tar forums-e419c2cd3b4f6eb24bb1011d326e1aef01a5c25b.tar.gz forums-e419c2cd3b4f6eb24bb1011d326e1aef01a5c25b.tar.bz2 forums-e419c2cd3b4f6eb24bb1011d326e1aef01a5c25b.tar.xz forums-e419c2cd3b4f6eb24bb1011d326e1aef01a5c25b.zip |
Merge pull request #5583 from marc1706/ticket/15987
[ticket/15987] Table parameters as array
Diffstat (limited to 'phpBB/phpbb')
-rw-r--r-- | phpBB/phpbb/di/container_builder.php | 7 | ||||
-rw-r--r-- | phpBB/phpbb/di/extension/tables.php | 59 |
2 files changed, 65 insertions, 1 deletions
diff --git a/phpBB/phpbb/di/container_builder.php b/phpBB/phpbb/di/container_builder.php index f2708e6de6..70ceb9b5e3 100644 --- a/phpBB/phpbb/di/container_builder.php +++ b/phpBB/phpbb/di/container_builder.php @@ -158,13 +158,18 @@ class container_builder } else { - $this->container_extensions = array(new extension\core($this->get_config_path())); + $this->container_extensions = [ + new extension\core($this->get_config_path()), + ]; if ($this->use_extensions) { $this->load_extensions(); } + // Add tables extension after all extensions + $this->container_extensions[] = new extension\tables(); + // Inject the config if ($this->config_php_file) { diff --git a/phpBB/phpbb/di/extension/tables.php b/phpBB/phpbb/di/extension/tables.php new file mode 100644 index 0000000000..40684b6038 --- /dev/null +++ b/phpBB/phpbb/di/extension/tables.php @@ -0,0 +1,59 @@ +<?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\di\extension; + +use Symfony\Component\DependencyInjection\ContainerBuilder; +use Symfony\Component\HttpKernel\DependencyInjection\Extension; + +/** + * Container tables extension + */ +class tables extends Extension +{ + /** + * {@inheritDoc} + */ + public function load(array $configs, ContainerBuilder $container) + { + // Tables is a reserved parameter and will be overwritten at all times + $tables = []; + + // Add access via 'tables' parameter to acquire array with all tables + $parameterBag = $container->getParameterBag(); + $parameters = $parameterBag->all(); + foreach ($parameters as $parameter_name => $parameter_value) + { + if (!preg_match('/tables\.(.+)/', $parameter_name, $matches)) + { + continue; + } + + $tables[$matches[1]] = $parameter_value; + } + + $container->setParameter('tables', $tables); + } + + /** + * Returns the recommended alias to use in XML. + * + * This alias is also the mandatory prefix to use when using YAML. + * + * @return string The alias + */ + public function getAlias() + { + return 'tables'; + } +} |