mego dibil
This commit is contained in:
@@ -163,40 +163,8 @@ final class core
|
|||||||
$route->parameters = $parameters + $route->parameters;
|
$route->parameters = $parameters + $route->parameters;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Preparing the route function
|
|
||||||
$action = function() use ($request, $route): string {
|
|
||||||
// Writing the request options from the route options
|
|
||||||
$request->options = $route->options;
|
|
||||||
|
|
||||||
// Preparing the route function
|
|
||||||
$action = fn(): string => (string) $this->route($route, $request);
|
|
||||||
|
|
||||||
foreach ($route->middlewares as $middleware) {
|
|
||||||
// Iterating over the route middlewares
|
|
||||||
|
|
||||||
// Preparing the middleware function
|
|
||||||
$action = fn(): string => $middleware(next: $action);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Processing middlewares and the route functions
|
|
||||||
$response = $action();
|
|
||||||
|
|
||||||
// Exit (success)
|
|
||||||
return $response;
|
|
||||||
};
|
|
||||||
|
|
||||||
foreach ($this->router->middlewares as $middleware) {
|
|
||||||
// Iterating over the router middlewares
|
|
||||||
|
|
||||||
// Preparing the middleware function
|
|
||||||
$action = fn(): string => $middleware(next: $action);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Processing middlewares and the router request function
|
|
||||||
$response = $action();
|
|
||||||
|
|
||||||
// Exit (success)
|
// Exit (success)
|
||||||
return $response;
|
return $this->route($route, $request);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Exit (fail)
|
// Exit (fail)
|
||||||
@@ -282,8 +250,40 @@ final class core
|
|||||||
// Found the method of the controller
|
// Found the method of the controller
|
||||||
|
|
||||||
try {
|
try {
|
||||||
// Executing method of the controller and exit (success)
|
// Preparing the route function
|
||||||
return $route->controller->{$route->method}(...($route->parameters + $request->parameters));
|
$action = function() use ($request, $route): string {
|
||||||
|
// Writing the request options from the route options
|
||||||
|
$request->options = $route->options;
|
||||||
|
|
||||||
|
// Processing the method of the controller and exit (success)
|
||||||
|
$action = fn(): string => (string) $route->controller->{$route->method}(...($route->parameters + $request->parameters));
|
||||||
|
|
||||||
|
foreach ($route->middlewares as $middleware) {
|
||||||
|
// Iterating over the route middlewares
|
||||||
|
|
||||||
|
// Preparing the middleware function
|
||||||
|
$action = fn(): string => $middleware(next: $action, controller: $route->controller);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Processing middlewares and the route functions
|
||||||
|
$response = $action();
|
||||||
|
|
||||||
|
// Exit (success)
|
||||||
|
return $response;
|
||||||
|
};
|
||||||
|
|
||||||
|
foreach ($this->router->middlewares as $middleware) {
|
||||||
|
// Iterating over the router middlewares
|
||||||
|
|
||||||
|
// Preparing the middleware function
|
||||||
|
$action = fn(): string => $middleware(next: $action, controller: $route->controller);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Processing middlewares and the router request function
|
||||||
|
$response = $action();
|
||||||
|
|
||||||
|
// Exit (success)
|
||||||
|
return $response;
|
||||||
} catch (exception $exception) {
|
} catch (exception $exception) {
|
||||||
// Catched an exception
|
// Catched an exception
|
||||||
|
|
||||||
|
@@ -6,6 +6,7 @@ namespace mirzaev\minimal;
|
|||||||
|
|
||||||
// Files of the project
|
// Files of the project
|
||||||
use mirzaev\minimal\http\request,
|
use mirzaev\minimal\http\request,
|
||||||
|
mirzaev\minimal\controller,
|
||||||
mirzaev\minimal\route;
|
mirzaev\minimal\route;
|
||||||
|
|
||||||
// Built-in libraries
|
// Built-in libraries
|
||||||
@@ -51,13 +52,13 @@ final class middleware
|
|||||||
* Invoke
|
* Invoke
|
||||||
*
|
*
|
||||||
* @param callable $next
|
* @param callable $next
|
||||||
|
* @param controller $controller
|
||||||
*
|
*
|
||||||
* @return string Output
|
* @return string Output
|
||||||
*/
|
*/
|
||||||
public function __invoke(callable $next): string
|
public function __invoke(callable $next, controller $controller): string
|
||||||
{
|
{
|
||||||
// Processing the middleware (entering into recursion)
|
// Processing the middleware (entering into recursion)
|
||||||
|
return (string) ($this->function)(next: $next, controller: $controller);
|
||||||
return (string) ($this->function)(next: $next);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user