3 Commits

3 changed files with 73 additions and 55 deletions

View File

@@ -6,23 +6,23 @@ namespace mirzaev\minimal;
// Files of the project // Files of the project
use mirzaev\minimal\router, use mirzaev\minimal\router,
mirzaev\minimal\route, mirzaev\minimal\route,
mirzaev\minimal\controller, mirzaev\minimal\controller,
mirzaev\minimal\model, mirzaev\minimal\model,
mirzaev\minimal\http\request, mirzaev\minimal\http\request,
mirzaev\minimal\http\response, mirzaev\minimal\http\response,
mirzaev\minimal\http\enumerations\status; mirzaev\minimal\http\enumerations\status;
// Built-in libraries // Built-in libraries
use Closure as closure, use Closure as closure,
Exception as exception, Exception as exception,
RuntimeException as exception_runtime, RuntimeException as exception_runtime,
BadMethodCallException as exception_method, BadMethodCallException as exception_method,
DomainException as exception_domain, DomainException as exception_domain,
InvalidArgumentException as exception_argument, InvalidArgumentException as exception_argument,
UnexpectedValueException as exception_value, UnexpectedValueException as exception_value,
LogicException as exception_logic, LogicException as exception_logic,
ReflectionClass as reflection; ReflectionClass as reflection;
/** /**
* Core * Core
@@ -103,7 +103,9 @@ final class core
/** /**
* Destructor * Destructor
*/ */
public function __destruct() {} public function __destruct()
{
}
/** /**
* Start * Start
@@ -128,27 +130,14 @@ final class core
$_SERVER["REQUEST_METHOD"] = $options['method'] ?? 'GET'; $_SERVER["REQUEST_METHOD"] = $options['method'] ?? 'GET';
// Writing URI into the environment constant // Writing URI into the environment constant
$_SERVER['REQUEST_URI'] = $options['uri'] ?? '/'; $_SERVER['REQUEST_URI'] = $options['uri'] ?? '/';
// Writing verstion of HTTP protocol into the environment constant // Writing verstion of HTTP protocol into the environment constant
$_SERVER['SERVER_PROTOCOL'] = $options['protocol'] ?? 'CLI'; $_SERVER['SERVER_PROTOCOL'] = $options['protocol'] ?? 'CLI';
} }
// Preparing the route function // Processing the request and exit (success)
$action = fn(): string => (string) $this->request(new request(environment: true)); return $this->request(new request(environment: true));
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)
return $response;
} }
/** /**
@@ -170,30 +159,14 @@ final class core
// Initialized the route // Initialized the route
if (!empty($parameters)) { if (!empty($parameters)) {
// Recaived parameters // Received parameters
// Merging parameters with the route parameters // Merging parameters with the route parameters
$route->parameters = $parameters + $route->parameters; $route->parameters = $parameters + $route->parameters;
} }
// 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) // Exit (success)
return $response; return $this->route($route, $request);
} }
// Exit (fail) // Exit (fail)
@@ -279,8 +252,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 + $route->variables + $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

View File

@@ -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);
} }
} }

View File

@@ -72,7 +72,7 @@ final class route
// Read // Read
&get => $this->parameters; &get => $this->parameters;
} }
/** /**
* Options * Options
* *
@@ -113,6 +113,18 @@ final class route
// Read // Read
get => $this->options ?? []; get => $this->options ?? [];
} }
/**
* Parameters
*
* @see https://wiki.php.net/rfc/property-hooks (find a table about backed and virtual hooks)
*
* @var array $parameters Arguments for the $this->method (will be concatenated together with generated request parameters)
*/
public array $variables = [] {
// Read
&get => $this->variables;
}
/** /**
* Constructor * Constructor