diff options
| author | Joas Schilling <nickvergessen@gmx.de> | 2015-01-20 23:27:54 +0100 |
|---|---|---|
| committer | Joas Schilling <nickvergessen@gmx.de> | 2015-01-20 23:27:54 +0100 |
| commit | a5fae1b1f09358f8a24ff32fc5192395cd314244 (patch) | |
| tree | e4944e89871808f1ada2df59e8cf815d3d2203ec /phpBB/phpbb/event | |
| parent | d0e5c0a1871c37bfea780cc525e996749b13a0ee (diff) | |
| parent | dab07283573689fcc6eb2c4e270ac37c3a573959 (diff) | |
| download | forums-a5fae1b1f09358f8a24ff32fc5192395cd314244.tar forums-a5fae1b1f09358f8a24ff32fc5192395cd314244.tar.gz forums-a5fae1b1f09358f8a24ff32fc5192395cd314244.tar.bz2 forums-a5fae1b1f09358f8a24ff32fc5192395cd314244.tar.xz forums-a5fae1b1f09358f8a24ff32fc5192395cd314244.zip | |
Merge pull request #3293 from Nicofuma/ticket/13489
[ticket/13489] Disable the event dispatcher in the migrator
Diffstat (limited to 'phpBB/phpbb/event')
| -rw-r--r-- | phpBB/phpbb/event/dispatcher.php | 35 | ||||
| -rw-r--r-- | phpBB/phpbb/event/dispatcher_interface.php | 10 |
2 files changed, 45 insertions, 0 deletions
diff --git a/phpBB/phpbb/event/dispatcher.php b/phpBB/phpbb/event/dispatcher.php index 9a786022c2..1c4abeb108 100644 --- a/phpBB/phpbb/event/dispatcher.php +++ b/phpBB/phpbb/event/dispatcher.php @@ -14,6 +14,7 @@ namespace phpbb\event; use Symfony\Component\EventDispatcher\ContainerAwareEventDispatcher; +use Symfony\Component\EventDispatcher\Event; /** * Extension of the Symfony2 EventDispatcher @@ -32,6 +33,11 @@ use Symfony\Component\EventDispatcher\ContainerAwareEventDispatcher; class dispatcher extends ContainerAwareEventDispatcher implements dispatcher_interface { /** + * @var bool + */ + protected $disabled = false; + + /** * {@inheritdoc} */ public function trigger_event($eventName, $data = array()) @@ -40,4 +46,33 @@ class dispatcher extends ContainerAwareEventDispatcher implements dispatcher_int $this->dispatch($eventName, $event); return $event->get_data_filtered(array_keys($data)); } + + /** + * {@inheritdoc} + */ + public function dispatch($eventName, Event $event = null) + { + if ($this->disabled) + { + return $event; + } + + return parent::dispatch($eventName, $event); + } + + /** + * {@inheritdoc} + */ + public function disable() + { + $this->disabled = true; + } + + /** + * {@inheritdoc} + */ + public function enable() + { + $this->disabled = false; + } } diff --git a/phpBB/phpbb/event/dispatcher_interface.php b/phpBB/phpbb/event/dispatcher_interface.php index 50a3ef9101..c66aa98260 100644 --- a/phpBB/phpbb/event/dispatcher_interface.php +++ b/phpBB/phpbb/event/dispatcher_interface.php @@ -37,4 +37,14 @@ interface dispatcher_interface extends \Symfony\Component\EventDispatcher\EventD * @return mixed */ public function trigger_event($eventName, $data = array()); + + /** + * Disable the event dispatcher. + */ + public function disable(); + + /** + * Enable the event dispatcher. + */ + public function enable(); } |
