|
@@ -93,22 +93,23 @@ class ControllerResolver implements ControllerResolverInterface
|
|
*/
|
|
*/
|
|
public function getArguments(Request $request, $controller)
|
|
public function getArguments(Request $request, $controller)
|
|
{
|
|
{
|
|
- $attributes = $request->attributes->all();
|
|
|
|
-
|
|
|
|
if (is_array($controller)) {
|
|
if (is_array($controller)) {
|
|
$r = new \ReflectionMethod($controller[0], $controller[1]);
|
|
$r = new \ReflectionMethod($controller[0], $controller[1]);
|
|
- $repr = sprintf('%s::%s()', get_class($controller[0]), $controller[1]);
|
|
|
|
} elseif (is_object($controller)) {
|
|
} elseif (is_object($controller)) {
|
|
$r = new \ReflectionObject($controller);
|
|
$r = new \ReflectionObject($controller);
|
|
$r = $r->getMethod('__invoke');
|
|
$r = $r->getMethod('__invoke');
|
|
- $repr = get_class($controller);
|
|
|
|
} else {
|
|
} else {
|
|
$r = new \ReflectionFunction($controller);
|
|
$r = new \ReflectionFunction($controller);
|
|
- $repr = $controller;
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ return $this->doGetArguments($request, $controller, $r->getParameters());
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ protected function doGetArguments(Request $request, $controller, array $parameters)
|
|
|
|
+ {
|
|
|
|
+ $attributes = $request->attributes->all();
|
|
$arguments = array();
|
|
$arguments = array();
|
|
- foreach ($r->getParameters() as $param) {
|
|
|
|
|
|
+ foreach ($parameters as $param) {
|
|
if (array_key_exists($param->getName(), $attributes)) {
|
|
if (array_key_exists($param->getName(), $attributes)) {
|
|
$arguments[] = $attributes[$param->getName()];
|
|
$arguments[] = $attributes[$param->getName()];
|
|
} elseif ($param->getClass() && $param->getClass()->isInstance($request)) {
|
|
} elseif ($param->getClass() && $param->getClass()->isInstance($request)) {
|
|
@@ -116,6 +117,14 @@ class ControllerResolver implements ControllerResolverInterface
|
|
} elseif ($param->isDefaultValueAvailable()) {
|
|
} elseif ($param->isDefaultValueAvailable()) {
|
|
$arguments[] = $param->getDefaultValue();
|
|
$arguments[] = $param->getDefaultValue();
|
|
} else {
|
|
} else {
|
|
|
|
+ if (is_array($controller)) {
|
|
|
|
+ $repr = sprintf('%s::%s()', get_class($controller[0]), $controller[1]);
|
|
|
|
+ } elseif (is_object($controller)) {
|
|
|
|
+ $repr = get_class($controller);
|
|
|
|
+ } else {
|
|
|
|
+ $repr = $controller;
|
|
|
|
+ }
|
|
|
|
+
|
|
throw new \RuntimeException(sprintf('Controller "%s" requires that you provide a value for the "$%s" argument (because there is no default value or because there is a non optional argument after this one).', $repr, $param->getName()));
|
|
throw new \RuntimeException(sprintf('Controller "%s" requires that you provide a value for the "$%s" argument (because there is no default value or because there is a non optional argument after this one).', $repr, $param->getName()));
|
|
}
|
|
}
|
|
}
|
|
}
|