ControllerResolver to enhance controllers beyond Symfony's basic handling.
It adds two behaviors:
Expanded class hierarchy of ControllerResolver
class ControllerResolver extends BaseControllerResolver {
/**
* The injection container that should be injected into all controllers.
*
* @var Symfony\Component\DependencyInjection\ContainerInterface
*/
protected $container;
/**
* Constructs a new ControllerResolver.
*
* @param Symfony\Component\DependencyInjection\ContainerInterface $container
* A ContainerInterface instance.
* @param Symfony\Component\HttpKernel\Log\LoggerInterface $logger
* (optional) A LoggerInterface instance.
*/
public function __construct(ContainerInterface $container, LoggerInterface $logger = NULL) {
$this->container = $container;
parent::__construct($logger);
}
/**
* Returns a callable for the given controller.
*
* @param string $controller
* A Controller string.
*
* @return mixed
* A PHP callable.
*
* @throws \LogicException
* If the controller cannot be parsed
*
* @throws \InvalidArgumentException
* If the controller class does not exist
*/
protected function createController($controller) {
// Controller in the service:method notation.
$count = substr_count($controller, ':');
if ($count == 1) {
list($service, $method) = explode(':', $controller, 2);
return array(
$this->container
->get($service),
$method,
);
}
// Controller in the class::method notation.
if (strpos($controller, '::') !== FALSE) {
list($class, $method) = explode('::', $controller, 2);
if (!class_exists($class)) {
throw new \InvalidArgumentException(sprintf('Class "%s" does not exist.', $class));
}
// @todo Remove the second in_array() once that interface has been removed.
if (in_array('Drupal\\Core\\Controller\\ControllerInterface', class_implements($class))) {
$controller = $class::create($this->container);
}
else {
$controller = new $class();
}
}
else {
throw new \LogicException(sprintf('Unable to parse the controller name "%s".', $controller));
}
if ($controller instanceof ContainerAwareInterface) {
$controller
->setContainer($this->container);
}
return array(
$controller,
$method,
);
}
}
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ControllerResolver:: |
protected | property | The injection container that should be injected into all controllers. | |
ControllerResolver:: |
private | property | ||
ControllerResolver:: |
protected | function |
Returns a callable for the given controller. Overrides ControllerResolver:: |
|
ControllerResolver:: |
protected | function | ||
ControllerResolver:: |
public | function |
Returns the arguments to pass to the controller. Overrides ControllerResolverInterface:: |
|
ControllerResolver:: |
public | function |
Returns the Controller instance associated with a Request. Overrides ControllerResolverInterface:: |
|
ControllerResolver:: |
public | function |
Constructs a new ControllerResolver. Overrides ControllerResolver:: |