Compare commits
	
		
			3 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| e604d19eb1 | |||
| 234691f011 | |||
| 69702888d1 | 
@@ -103,7 +103,9 @@ final class core
 | 
				
			|||||||
	/**
 | 
						/**
 | 
				
			||||||
	 * Destructor
 | 
						 * Destructor
 | 
				
			||||||
	 */
 | 
						 */
 | 
				
			||||||
	public function __destruct() {}
 | 
						public function __destruct()
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/**
 | 
						/**
 | 
				
			||||||
	 * Start
 | 
						 * Start
 | 
				
			||||||
@@ -134,21 +136,8 @@ final class core
 | 
				
			|||||||
			$_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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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);
 | 
					 | 
				
			||||||
	 }
 | 
						 }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -114,6 +114,18 @@ final class route
 | 
				
			|||||||
		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
 | 
				
			||||||
	 *
 | 
						 *
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user