Compare commits
5 Commits
e604d19eb1
...
3.8.4
| Author | SHA1 | Date | |
|---|---|---|---|
| 89c6d0c814 | |||
| 67a2ea3e1d | |||
| cd4a7912d0 | |||
| 42774c8830 | |||
| b61599aac9 |
1
.gitignore
vendored
1
.gitignore
vendored
@@ -1 +1,2 @@
|
||||
vendor
|
||||
composer.lock
|
||||
|
||||
@@ -14,7 +14,7 @@
|
||||
"name": "Arsen Mirzaev Tatyano-Muradovich",
|
||||
"email": "arsen@mirzaev.sexy",
|
||||
"homepage": "https://mirzaev.sexy",
|
||||
"role": "Programmer"
|
||||
"role": "Creator"
|
||||
}
|
||||
],
|
||||
"support": {
|
||||
@@ -24,6 +24,12 @@
|
||||
"require": {
|
||||
"php": "~8.4"
|
||||
},
|
||||
"suggest": {
|
||||
"mirzaev/baza": "Baza database",
|
||||
"mirzaev/pot": "Template for projects",
|
||||
"mirzaev/languages": "Easy languages integration",
|
||||
"mirzaev/currencies": "Easy currencies integration"
|
||||
},
|
||||
"autoload": {
|
||||
"psr-4": {
|
||||
"mirzaev\\minimal\\": "mirzaev/minimal/system"
|
||||
|
||||
2320
composer.lock
generated
2320
composer.lock
generated
File diff suppressed because it is too large
Load Diff
@@ -6,23 +6,23 @@ namespace mirzaev\minimal;
|
||||
|
||||
// Files of the project
|
||||
use mirzaev\minimal\router,
|
||||
mirzaev\minimal\route,
|
||||
mirzaev\minimal\controller,
|
||||
mirzaev\minimal\model,
|
||||
mirzaev\minimal\http\request,
|
||||
mirzaev\minimal\http\response,
|
||||
mirzaev\minimal\http\enumerations\status;
|
||||
mirzaev\minimal\route,
|
||||
mirzaev\minimal\controller,
|
||||
mirzaev\minimal\model,
|
||||
mirzaev\minimal\http\request,
|
||||
mirzaev\minimal\http\response,
|
||||
mirzaev\minimal\http\enumerations\status;
|
||||
|
||||
// Built-in libraries
|
||||
use Closure as closure,
|
||||
Exception as exception,
|
||||
RuntimeException as exception_runtime,
|
||||
BadMethodCallException as exception_method,
|
||||
DomainException as exception_domain,
|
||||
InvalidArgumentException as exception_argument,
|
||||
UnexpectedValueException as exception_value,
|
||||
LogicException as exception_logic,
|
||||
ReflectionClass as reflection;
|
||||
Exception as exception,
|
||||
RuntimeException as exception_runtime,
|
||||
BadMethodCallException as exception_method,
|
||||
DomainException as exception_domain,
|
||||
InvalidArgumentException as exception_argument,
|
||||
UnexpectedValueException as exception_value,
|
||||
LogicException as exception_logic,
|
||||
ReflectionClass as reflection;
|
||||
|
||||
/**
|
||||
* Core
|
||||
@@ -103,9 +103,7 @@ final class core
|
||||
/**
|
||||
* Destructor
|
||||
*/
|
||||
public function __destruct()
|
||||
{
|
||||
}
|
||||
public function __destruct() {}
|
||||
|
||||
/**
|
||||
* Start
|
||||
|
||||
@@ -10,7 +10,9 @@ use mirzaev\minimal\http\request,
|
||||
mirzaev\minimal\route;
|
||||
|
||||
// Built-in libraries
|
||||
use Closure as closure;
|
||||
use Closure as closure,
|
||||
LogicException as exception_logic
|
||||
;
|
||||
|
||||
/**
|
||||
* Middleware
|
||||
@@ -26,14 +28,14 @@ use Closure as closure;
|
||||
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
|
||||
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
|
||||
*/
|
||||
final class middleware
|
||||
class middleware
|
||||
{
|
||||
/**
|
||||
* Function
|
||||
*
|
||||
* @var closure $function Function
|
||||
* @var closure|array $function Function
|
||||
*/
|
||||
public readonly closure $function;
|
||||
public readonly closure|array $function;
|
||||
|
||||
/**
|
||||
* Constructor
|
||||
@@ -42,10 +44,28 @@ final class middleware
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function __construct(closure $function)
|
||||
public function __construct(?closure $function = null)
|
||||
{
|
||||
// Writing the function
|
||||
$this->function = $function;
|
||||
if (static::class === self::class) {
|
||||
// The middleware class itself
|
||||
|
||||
// Writing the function
|
||||
$this->function = $function;
|
||||
} else {
|
||||
// The middleware inheriting class
|
||||
|
||||
if (method_exists($this, 'middleware')) {
|
||||
// Found the method
|
||||
|
||||
// Writing the function
|
||||
$this->function = [$this, 'middleware'];
|
||||
} else {
|
||||
// Not found the method
|
||||
|
||||
// Exit (fail)
|
||||
throw new exception_logic('The middleware method is not initialized', 500);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -56,9 +76,9 @@ final class middleware
|
||||
*
|
||||
* @return string Output
|
||||
*/
|
||||
public function __invoke(callable $next, controller $controller): string
|
||||
{
|
||||
// Processing the middleware (entering into recursion)
|
||||
return (string) ($this->function)(next: $next, controller: $controller);
|
||||
}
|
||||
public function __invoke(callable $next, controller $controller): string
|
||||
{
|
||||
// Processing the middleware (entering into recursion)
|
||||
return (string) ($this->function)(next: $next, controller: $controller);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -114,18 +114,6 @@ final class route
|
||||
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
|
||||
*
|
||||
|
||||
Reference in New Issue
Block a user