aboutsummaryrefslogtreecommitdiffstats
path: root/phpBB/includes/di/pass/kernel_pass.php
diff options
context:
space:
mode:
authorDavid King <imkingdavid@gmail.com>2012-11-13 09:28:56 -0500
committerDavid King <imkingdavid@gmail.com>2012-11-16 16:45:29 -0500
commit4b6d538b062a56f55ba221ac8437b4bfc712a475 (patch)
tree7f3e5a6a124d7d0a3eca6a604f14bd522fe5cb5a /phpBB/includes/di/pass/kernel_pass.php
parent7687f069611b35f81c6d0fc87e46b9bb0821d616 (diff)
downloadforums-4b6d538b062a56f55ba221ac8437b4bfc712a475.tar
forums-4b6d538b062a56f55ba221ac8437b4bfc712a475.tar.gz
forums-4b6d538b062a56f55ba221ac8437b4bfc712a475.tar.bz2
forums-4b6d538b062a56f55ba221ac8437b4bfc712a475.tar.xz
forums-4b6d538b062a56f55ba221ac8437b4bfc712a475.zip
[feature/controller] Rename kernel pass class properly
PHPBB3-10864
Diffstat (limited to 'phpBB/includes/di/pass/kernel_pass.php')
-rw-r--r--phpBB/includes/di/pass/kernel_pass.php69
1 files changed, 69 insertions, 0 deletions
diff --git a/phpBB/includes/di/pass/kernel_pass.php b/phpBB/includes/di/pass/kernel_pass.php
new file mode 100644
index 0000000000..d186ff2767
--- /dev/null
+++ b/phpBB/includes/di/pass/kernel_pass.php
@@ -0,0 +1,69 @@
+<?php
+/**
+*
+* @package phpBB3
+* @copyright (c) 2012 phpBB Group
+* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
+*
+*/
+
+/**
+* @ignore
+*/
+if (!defined('IN_PHPBB'))
+{
+ exit;
+}
+
+use Symfony\Component\DependencyInjection\ContainerBuilder;
+use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface;
+
+class phpbb_di_pass_kernel_pass implements CompilerPassInterface
+{
+ /**
+ * Modify the container before it is passed to the rest of the code
+ *
+ * @param ContainerBuilder $container ContainerBuilder object
+ * @return null
+ */
+ public function process(ContainerBuilder $container)
+ {
+ $definition = $container->getDefinition('dispatcher');
+ $user = $container->get('user');
+
+ foreach ($container->findTaggedServiceIds('kernel.event_listener') as $id => $events)
+ {
+ foreach ($events as $event)
+ {
+ $priority = isset($event['priority']) ? $event['priority'] : 0;
+
+ if (!isset($event['event']))
+ {
+ throw new InvalidArgumentException($user->lang('NO_EVENT_ATTRIBUTE', $id));
+ }
+
+ if (!isset($event['method']))
+ {
+ throw new InvalidArgumentException($user->lang('NO_METHOD_ATTRIBUTE', $id));
+ }
+
+ $definition->addMethodCall('addListenerService', array($event['event'], array($id, $event['method']), $priority));
+ }
+ }
+
+ foreach ($container->findTaggedServiceIds('kernel.event_subscriber') as $id => $attributes)
+ {
+ // We must assume that the class value has been correctly filled, even if the service is created by a factory
+ $class = $container->getDefinition($id)->getClass();
+
+ $refClass = new ReflectionClass($class);
+ $interface = 'Symfony\Component\EventDispatcher\EventSubscriberInterface';
+ if (!$refClass->implementsInterface($interface))
+ {
+ throw new InvalidArgumentException($user->lang('SUBSCRIBER_WRONG_TYPE', $id, $interface));
+ }
+
+ $definition->addMethodCall('addSubscriberService', array($id, $class));
+ }
+ }
+}