Compare commits
1 Commits
3.8.3
...
e604d19eb1
| Author | SHA1 | Date | |
|---|---|---|---|
| e604d19eb1 |
1
.gitignore
vendored
1
.gitignore
vendored
@@ -1,2 +1 @@
|
|||||||
vendor
|
vendor
|
||||||
composer.lock
|
|
||||||
|
|||||||
@@ -14,7 +14,7 @@
|
|||||||
"name": "Arsen Mirzaev Tatyano-Muradovich",
|
"name": "Arsen Mirzaev Tatyano-Muradovich",
|
||||||
"email": "arsen@mirzaev.sexy",
|
"email": "arsen@mirzaev.sexy",
|
||||||
"homepage": "https://mirzaev.sexy",
|
"homepage": "https://mirzaev.sexy",
|
||||||
"role": "Creator"
|
"role": "Programmer"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"support": {
|
"support": {
|
||||||
@@ -24,10 +24,6 @@
|
|||||||
"require": {
|
"require": {
|
||||||
"php": "~8.4"
|
"php": "~8.4"
|
||||||
},
|
},
|
||||||
"suggest": {
|
|
||||||
"mirzaev/baza": "Baza database",
|
|
||||||
"mirzaev/pot": "Template for projects"
|
|
||||||
},
|
|
||||||
"autoload": {
|
"autoload": {
|
||||||
"psr-4": {
|
"psr-4": {
|
||||||
"mirzaev\\minimal\\": "mirzaev/minimal/system"
|
"mirzaev\\minimal\\": "mirzaev/minimal/system"
|
||||||
|
|||||||
2320
composer.lock
generated
Executable file
2320
composer.lock
generated
Executable file
File diff suppressed because it is too large
Load Diff
@@ -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
|
||||||
|
|||||||
@@ -10,9 +10,7 @@ use mirzaev\minimal\http\request,
|
|||||||
mirzaev\minimal\route;
|
mirzaev\minimal\route;
|
||||||
|
|
||||||
// Built-in libraries
|
// Built-in libraries
|
||||||
use Closure as closure,
|
use Closure as closure;
|
||||||
LogicException as exception_logic
|
|
||||||
;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Middleware
|
* Middleware
|
||||||
@@ -28,14 +26,14 @@ use Closure as closure,
|
|||||||
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
|
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
|
||||||
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
|
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
|
||||||
*/
|
*/
|
||||||
class middleware
|
final class middleware
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Function
|
* Function
|
||||||
*
|
*
|
||||||
* @var closure|array $function Function
|
* @var closure $function Function
|
||||||
*/
|
*/
|
||||||
public readonly closure|array $function;
|
public readonly closure $function;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
@@ -44,28 +42,10 @@ class middleware
|
|||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function __construct(?closure $function = null)
|
public function __construct(closure $function)
|
||||||
{
|
{
|
||||||
if (static::class === self::class) {
|
|
||||||
// The middleware class itself
|
|
||||||
|
|
||||||
// Writing the function
|
// Writing the function
|
||||||
$this->function = $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);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -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