ControllerResolver

class ControllerResolver implements ControllerResolverInterface

This implementation uses the '_controller' request attribute to determine the controller to execute and uses the request attributes to determine the controller method arguments.

Methods

__construct(LoggerInterface $logger = null)
callable|false getController(Request $request)

Returns the Controller instance associated with a Request.

array getArguments(Request $request, callable $controller)

Returns the arguments to pass to the controller.

Details

__construct(LoggerInterface $logger = null)

Parameters

LoggerInterface $logger

callable|false getController(Request $request)

Returns the Controller instance associated with a Request.

As several resolvers can exist for a single application, a resolver must return false when it is not able to determine the controller.

The resolver must only throw an exception when it should be able to load controller but cannot because of some errors made by the developer.

Parameters

Request $request

Return Value

callable|false A PHP callable representing the Controller, or false if this resolver is not able to determine the controller

Exceptions

LogicException If the controller can't be found

array getArguments(Request $request, callable $controller)

Returns the arguments to pass to the controller.

Parameters

Request $request A Request instance
callable $controller A PHP callable

Return Value

array An array of arguments to pass to the controller

Exceptions

RuntimeException When value for argument given is not provided

© 2004–2017 Fabien Potencier
Licensed under the MIT License.
http://api.symfony.com/2.7/Symfony/Component/HttpKernel/Controller/ControllerResolver.html