|
|
|
|
@@ -22,7 +22,10 @@ use Closure as closure,
|
|
|
|
|
InvalidArgumentException as exception_argument,
|
|
|
|
|
UnexpectedValueException as exception_value,
|
|
|
|
|
LogicException as exception_logic,
|
|
|
|
|
ReflectionClass as reflection;
|
|
|
|
|
Error as error,
|
|
|
|
|
ArgumentCountError as error_argument_count,
|
|
|
|
|
ReflectionClass as reflection,
|
|
|
|
|
ReflectionMethod as reflection_method;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Core
|
|
|
|
|
@@ -255,8 +258,23 @@ final class core
|
|
|
|
|
// Writing the request options from the route options
|
|
|
|
|
$request->options = $route->options;
|
|
|
|
|
|
|
|
|
|
// Initializing the controller method arguments
|
|
|
|
|
$arguments = $route->parameters + $route->variables + $request->parameters;
|
|
|
|
|
|
|
|
|
|
// Processing the method of the controller and exit (success)
|
|
|
|
|
$action = fn(): string => (string) $route->controller->{$route->method}(...($route->parameters + $route->variables + $request->parameters));
|
|
|
|
|
$action = function () use ($route, $request, $arguments): string {
|
|
|
|
|
if (array_keys($arguments) === array_column((new reflection_method($route->controller, $route->method))->getParameters(), 'name')) {
|
|
|
|
|
// Arguments match the controller method arguments
|
|
|
|
|
|
|
|
|
|
// Exit (success)
|
|
|
|
|
return (string) $route->controller->{$route->method}(...$arguments);
|
|
|
|
|
} else {
|
|
|
|
|
// Arguments not match the controller method arguments
|
|
|
|
|
|
|
|
|
|
// Exit (success)
|
|
|
|
|
return (string) $route->controller->{$route->method}($arguments);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
foreach ($route->middlewares as $middleware) {
|
|
|
|
|
// Iterating over the route middlewares
|
|
|
|
|
|