matthew revised this gist . Go to revision
No changes
matthew revised this gist . Go to revision
No changes
Matthew Weier O'Phinney revised this gist . Go to revision
1 file changed, 41 insertions
Module.php(file created)
| @@ -0,0 +1,41 @@ | |||
| 1 | + | <?php | |
| 2 | + | ||
| 3 | + | // In a module class somewhere... | |
| 4 | + | use Zend\EventManager\LazyListener; | |
| 5 | + | use Zend\Mvc\MvcEvent; | |
| 6 | + | ||
| 7 | + | class Module | |
| 8 | + | { | |
| 9 | + | public function onBootstrap(MvcEvent $e) | |
| 10 | + | { | |
| 11 | + | $app = $e->getApplication(); | |
| 12 | + | $services = $app->getServiceManager(); | |
| 13 | + | $events = $app->getEventManager(); | |
| 14 | + | ||
| 15 | + | $listener = new LazyListener([ | |
| 16 | + | 'listener' => YourShortCircuitingListener::class, | |
| 17 | + | 'method' => '__invoke', | |
| 18 | + | ], $services); | |
| 19 | + | ||
| 20 | + | $events->attach(MvcEvent::EVENT_ROUTE, $listener, PHP_INT_MAX); | |
| 21 | + | } | |
| 22 | + | } | |
| 23 | + | ||
| 24 | + | // And now for the listener... | |
| 25 | + | class YourShortCircuitingListener | |
| 26 | + | { | |
| 27 | + | public function __invoke(MvcEvent $e) | |
| 28 | + | { | |
| 29 | + | $request = $e->getRequest(); | |
| 30 | + | if (/* some criteria that, if met, means we should continue normal operation */) { | |
| 31 | + | return; | |
| 32 | + | } | |
| 33 | + | ||
| 34 | + | // At this point, we know we want to short-circuit | |
| 35 | + | $response = $e->getResponse(); | |
| 36 | + | ||
| 37 | + | // populate the response | |
| 38 | + | ||
| 39 | + | return $response; | |
| 40 | + | } | |
| 41 | + | } | |
Newer
Older