From eee1a350c33b07432afb5f4f1b28303ad6427077 Mon Sep 17 00:00:00 2001 From: nikolay Date: Sun, 19 Jun 2016 13:31:42 +0300 Subject: [PATCH 1/4] AcceptableViewModelSelector - notice fix InjectTemplateListener - injectTemplate : set $preferRouteMatchController view config param if exists. This way apigility rest service can return proper view per api . prefer_route_match_controller should be set at the config route to true : controller_map should be set at the config view_manager also . --- src/Controller/Plugin/AcceptableViewModelSelector.php | 3 +++ src/View/Http/InjectTemplateListener.php | 3 +++ 2 files changed, 6 insertions(+) diff --git a/src/Controller/Plugin/AcceptableViewModelSelector.php b/src/Controller/Plugin/AcceptableViewModelSelector.php index 2049d8f07..6a9330554 100644 --- a/src/Controller/Plugin/AcceptableViewModelSelector.php +++ b/src/Controller/Plugin/AcceptableViewModelSelector.php @@ -209,6 +209,9 @@ public function getDefaultMatchAgainst() protected function injectViewModelName($modelAcceptString, $modelName) { $modelName = str_replace('\\', '|', $modelName); + $modelAcceptString = (is_array($modelAcceptString )) + ? $modelAcceptString[key($modelAcceptString)] + : $modelAcceptString; return $modelAcceptString . '; ' . self::INJECT_VIEWMODEL_NAME . '="' . $modelName . '", '; } diff --git a/src/View/Http/InjectTemplateListener.php b/src/View/Http/InjectTemplateListener.php index 4f7c79566..e245f35c6 100644 --- a/src/View/Http/InjectTemplateListener.php +++ b/src/View/Http/InjectTemplateListener.php @@ -61,6 +61,9 @@ public function injectTemplate(MvcEvent $e) } $routeMatch = $e->getRouteMatch(); + $preferRouteMatchController = $routeMatch->getParam('prefer_route_match_controller', false); + $this->setPreferRouteMatchController($preferRouteMatchController); + $controller = $e->getTarget(); if (is_object($controller)) { $controller = get_class($controller); From b58e9f106b31ceb2ffabba66f700f784a7aa38ec Mon Sep 17 00:00:00 2001 From: nikolay Date: Sun, 19 Jun 2016 14:22:25 +0300 Subject: [PATCH 2/4] injectTemplateListener - injectTemplate update to match the unit test --- src/View/Http/InjectTemplateListener.php | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/View/Http/InjectTemplateListener.php b/src/View/Http/InjectTemplateListener.php index e245f35c6..c986b9c8d 100644 --- a/src/View/Http/InjectTemplateListener.php +++ b/src/View/Http/InjectTemplateListener.php @@ -61,8 +61,9 @@ public function injectTemplate(MvcEvent $e) } $routeMatch = $e->getRouteMatch(); - $preferRouteMatchController = $routeMatch->getParam('prefer_route_match_controller', false); - $this->setPreferRouteMatchController($preferRouteMatchController); + if($preferRouteMatchController = $routeMatch->getParam('prefer_route_match_controller', false)){ + $this->setPreferRouteMatchController($preferRouteMatchController); + } $controller = $e->getTarget(); if (is_object($controller)) { From 3ff440828eed003a322277337ab5616de5304e73 Mon Sep 17 00:00:00 2001 From: nikolay Date: Sun, 19 Jun 2016 19:40:13 +0300 Subject: [PATCH 3/4] AcceptableViewModelSelector notice fixed InjectTemplateListener to work with preferController routeMatch flag and controller_map , so it can return proper template when using Apigility rest service --- .../Plugin/AcceptableViewModelSelector.php | 2 +- src/View/Http/InjectTemplateListener.php | 2 +- test/View/InjectTemplateListenerTest.php | 24 +++++++++++++++++++ 3 files changed, 26 insertions(+), 2 deletions(-) diff --git a/src/Controller/Plugin/AcceptableViewModelSelector.php b/src/Controller/Plugin/AcceptableViewModelSelector.php index 6a9330554..2fb4f2dc0 100644 --- a/src/Controller/Plugin/AcceptableViewModelSelector.php +++ b/src/Controller/Plugin/AcceptableViewModelSelector.php @@ -209,7 +209,7 @@ public function getDefaultMatchAgainst() protected function injectViewModelName($modelAcceptString, $modelName) { $modelName = str_replace('\\', '|', $modelName); - $modelAcceptString = (is_array($modelAcceptString )) + $modelAcceptString = (is_array($modelAcceptString)) ? $modelAcceptString[key($modelAcceptString)] : $modelAcceptString; return $modelAcceptString . '; ' . self::INJECT_VIEWMODEL_NAME . '="' . $modelName . '", '; diff --git a/src/View/Http/InjectTemplateListener.php b/src/View/Http/InjectTemplateListener.php index c986b9c8d..b8fb16309 100644 --- a/src/View/Http/InjectTemplateListener.php +++ b/src/View/Http/InjectTemplateListener.php @@ -61,7 +61,7 @@ public function injectTemplate(MvcEvent $e) } $routeMatch = $e->getRouteMatch(); - if($preferRouteMatchController = $routeMatch->getParam('prefer_route_match_controller', false)){ + if ($preferRouteMatchController = $routeMatch->getParam('prefer_route_match_controller', false)) { $this->setPreferRouteMatchController($preferRouteMatchController); } diff --git a/test/View/InjectTemplateListenerTest.php b/test/View/InjectTemplateListenerTest.php index 34466567d..f264d7358 100644 --- a/test/View/InjectTemplateListenerTest.php +++ b/test/View/InjectTemplateListenerTest.php @@ -340,4 +340,28 @@ public function testPrefersRouteMatchController() $this->assertEquals('some/other/service/namespace/sample', $myViewModel->getTemplate()); } + + public function testPrefersRouteMatchControllerWithRouteMatchAndControllerMap() + { + $this->assertFalse($this->listener->isPreferRouteMatchController()); + $controllerMap = [ + 'Some\Other\Service\Namespace\Controller\Sample' => 'another/sample' + ]; + + $this->routeMatch->setParam('prefer_route_match_controller', true); + $this->routeMatch->setParam('controller', 'Some\Other\Service\Namespace\Controller\Sample'); + + $preferRouteMatchControllerRouteMatchConfig = $this->routeMatch->getParam('prefer_route_match_controller', false); + $this->listener->setPreferRouteMatchController($preferRouteMatchControllerRouteMatchConfig); + $this->listener->setControllerMap($controllerMap); + + $myViewModel = new ViewModel(); + $myController = new \ZendTest\Mvc\Controller\TestAsset\SampleController(); + + $this->event->setTarget($myController); + $this->event->setResult($myViewModel); + $this->listener->injectTemplate($this->event); + + $this->assertEquals('another/sample', $myViewModel->getTemplate()); + } } From bdf5b045a2570e2f87c2e798b162fd5a684ae17e Mon Sep 17 00:00:00 2001 From: Matthew Weier O'Phinney Date: Thu, 30 Jun 2016 15:27:36 -0500 Subject: [PATCH 4/4] Added CHANGELOG for #163 --- CHANGELOG.md | 32 +++++++++++++++++++++++- test/View/InjectTemplateListenerTest.php | 13 +++++----- 2 files changed, 38 insertions(+), 7 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 2ba470eb0..5c52cdd8a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,7 +6,37 @@ All notable changes to this project will be documented in this file, in reverse ### Added -- Nothing. +- [#163](https://github.com/zendframework/zend-mvc/pull/163) adds support to the + `AcceptableViewModelSelector` plugin for controller maps in the `view_manager` + configuration in the format: + + ```php + [ + 'ControllerClassName' => 'view/name', + ] + ``` + + This fixes an issue observed when running with Apigility. + +- [#163](https://github.com/zendframework/zend-mvc/pull/163) adds support to the + `InjectTemplateListener` for specifying whether or not to prefer the + controller matched during routing via routing configuration: + + ```php + 'route-name' => [ + /* ... */ + 'options' => [ + /* ... */ + 'defaults' => [ + /* ... */ + 'prefer_route_match_controller' => true, + ], + ], + ], + ``` + + This allows actions that might otherwise skip injection of the template + to force the injection. ### Deprecated diff --git a/test/View/InjectTemplateListenerTest.php b/test/View/InjectTemplateListenerTest.php index f264d7358..fb5e11ae6 100644 --- a/test/View/InjectTemplateListenerTest.php +++ b/test/View/InjectTemplateListenerTest.php @@ -17,6 +17,7 @@ use Zend\Router\RouteMatch; use Zend\Mvc\View\Http\InjectTemplateListener; use Zend\View\Model\ViewModel; +use ZendTest\Mvc\Controller\TestAsset\SampleController; class InjectTemplateListenerTest extends TestCase { @@ -108,7 +109,7 @@ public function testBypassesTemplateInjectionIfResultViewModelAlreadyHasATemplat public function testMapsSubNamespaceToSubDirectory() { $myViewModel = new ViewModel(); - $myController = new \ZendTest\Mvc\Controller\TestAsset\SampleController(); + $myController = new SampleController(); $this->event->setTarget($myController); $this->event->setResult($myViewModel); @@ -158,7 +159,7 @@ public function testMapsSubNamespaceToSubDirectoryWithControllerFromEventTarget( $moduleRouteListener->onRoute($this->event); $myViewModel = new ViewModel(); - $myController = new \ZendTest\Mvc\Controller\TestAsset\SampleController(); + $myController = new SampleController(); $this->event->setTarget($myController); $this->event->setResult($myViewModel); @@ -183,7 +184,7 @@ public function testMapsSubNamespaceToSubDirectoryWithControllerFromEventTargetS $template1 = $myViewModel->getTemplate(); $myViewModel = new ViewModel(); - $myController = new \ZendTest\Mvc\Controller\TestAsset\SampleController(); + $myController = new SampleController(); $this->event->setTarget($myController); $this->event->setResult($myViewModel); @@ -204,7 +205,7 @@ public function testControllerMatchedByMapIsInflected() $this->listener->setControllerMap(['ZendTest' => true]); $myViewModel = new ViewModel(); - $myController = new \ZendTest\Mvc\Controller\TestAsset\SampleController(); + $myController = new SampleController(); $this->event->setTarget($myController); $this->event->setResult($myViewModel); @@ -332,7 +333,7 @@ public function testPrefersRouteMatchController() $this->listener->setPreferRouteMatchController(true); $this->routeMatch->setParam('controller', 'Some\Other\Service\Namespace\Controller\Sample'); $myViewModel = new ViewModel(); - $myController = new \ZendTest\Mvc\Controller\TestAsset\SampleController(); + $myController = new SampleController(); $this->event->setTarget($myController); $this->event->setResult($myViewModel); @@ -356,7 +357,7 @@ public function testPrefersRouteMatchControllerWithRouteMatchAndControllerMap() $this->listener->setControllerMap($controllerMap); $myViewModel = new ViewModel(); - $myController = new \ZendTest\Mvc\Controller\TestAsset\SampleController(); + $myController = new SampleController(); $this->event->setTarget($myController); $this->event->setResult($myViewModel);