Returns a callable for the given controller.
string $controller: A Controller string.
mixed A PHP callable.
\LogicException If the controller cannot be parsed
\InvalidArgumentException If the controller class does not exist
Overrides ControllerResolver::createController
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,
);
}