私は、新しいイベントをトリガーしてそれをリッスンする方法を示す本に従っています。このイベントはチャネル 25 と呼ばれ、テスト用の架空のデータが含まれています。error_log を入れてイベントプロセスをトラップし、その動作を確認しました。イベントはトリガーされますが、何らかの理由で聞くことができません。ここにmodule.phpのコピーがあります
イベントをトリガーする場所とそれをリッスンする場所のセクションにコメントしました。
<?php
namespace Debug;
use Zend\ModuleManager\Feature\AutoloaderProviderInterface;
use Zend\Mvc\ModuleRouteListener;
use Zend\ModuleManager\ModuleManager;
use Zend\eventManager\Event;
use Zend\Mvc\MvcEvent;
use Zend\EventManager\EventManager; //manage events (create/listen for events)
class Module implements AutoloaderProviderInterface
{
public function getAutoloaderConfig()
{
return array(
'Zend\Loader\StandardAutoloader' => array(
'namespaces' => array(
__NAMESPACE__ => __DIR__ . '/src/' . __NAMESPACE__,
),
),
);
}
public function getConfig()
{
return include __DIR__ . '/config/module.config.php';
}
public function init(ModuleManager $ModuleManager)
{
$eventManager = $ModuleManager->getEventManager();
$eventManager->attach('loadModules.post', array($this, 'loadedModulesInfo'));
//create new event
$event = new EventManager('channel-25');
$event->trigger('new song', null, array('artist' => 'Adele'));
error_log('New Event Triggered');
}
public function loadedModulesInfo(Event $event)
{
$moduleManager = $event->getTarget();
$loadedModules = $moduleManager->getLoadedModules();
error_log(var_export($loadedModules, true));
}
public function onBootstrap(MvcEvent $event)
{
//Now i will be listening for my sample event
$eventManager = $event->getApplication()->getEventManager();
$sharedEventManager = $eventManager->getSharedManager();
$sharedEventManager->attach('channel-25', 'new song', function(Event $event) {
$artist = $event->getParam('artist');
error_log('Found the Event. The artist is: ' . $artist);
});
}
public function handleError(MvcEvent $event)
{
$controller = $event->getController();
$error = $event->getParam('error');
$exception = $event->getParam('exception');
$message = 'Error: ' . $error;
if($exception instanceof \Exception)
{
$message .= ', Exception(' . $exception->getMessage() . '):' . $exception->getTraceAsString();
}
error_log($message);
}
}