aboutsummaryrefslogtreecommitdiffstats
path: root/phpBB/includes/di
diff options
context:
space:
mode:
authorDavid King <imkingdavid@gmail.com>2012-10-21 16:37:03 -0400
committerDavid King <imkingdavid@gmail.com>2012-11-16 16:25:14 -0500
commit97957d679250c642969a09b002f4125889a5f4fa (patch)
tree06b62ca5789b76b8648f0f7d0679b66e061b016b /phpBB/includes/di
parent5c86a1660d436cf16448ae6c978237833e3e86b7 (diff)
downloadforums-97957d679250c642969a09b002f4125889a5f4fa.tar
forums-97957d679250c642969a09b002f4125889a5f4fa.tar.gz
forums-97957d679250c642969a09b002f4125889a5f4fa.tar.bz2
forums-97957d679250c642969a09b002f4125889a5f4fa.tar.xz
forums-97957d679250c642969a09b002f4125889a5f4fa.zip
[feature/controller-new] Rename kernel compiler pass class
PHPBB3-10864
Diffstat (limited to 'phpBB/includes/di')
-rw-r--r--phpBB/includes/di/pass/kernel.php69
1 files changed, 69 insertions, 0 deletions
diff --git a/phpBB/includes/di/pass/kernel.php b/phpBB/includes/di/pass/kernel.php
new file mode 100644
index 0000000000..7b190a6236
--- /dev/null
+++ b/phpBB/includes/di/pass/kernel.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 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));
+ }
+ }
+}