Compare commits
4 Commits
Author | SHA1 | Date | |
---|---|---|---|
d5f4955070 | |||
74c3decaa6 | |||
e9f7cd39b6 | |||
476037b062 |
@@ -195,36 +195,36 @@ final class core
|
|||||||
unset($controller);
|
unset($controller);
|
||||||
|
|
||||||
if (!isset($route->controller->model)) {
|
if (!isset($route->controller->model)) {
|
||||||
//
|
// Not initialized the model in the controller
|
||||||
|
|
||||||
// Initializing name if the model class
|
// Initializing name if the model class
|
||||||
$model = $route->model;
|
$model = $route->model;
|
||||||
|
|
||||||
if ($route->model instanceof model) {
|
if ($route->model instanceof model) {
|
||||||
// Initialized the model
|
// Initialized the model
|
||||||
} else if (class_exists($model = "$this->namespace\\models\\$model")) {
|
} else if (class_exists($model = "$this->namespace\\models\\$model")) {
|
||||||
// Found the model by its name
|
// Found the model by its name
|
||||||
|
|
||||||
// Initializing the model
|
// Initializing the model
|
||||||
$route->model = new $model;
|
$route->model = new $model;
|
||||||
} else if (!empty($route->model)) {
|
} else if (!empty($route->model)) {
|
||||||
// Not found the model and $route->model has a value
|
// Not found the model and $route->model has a value
|
||||||
|
|
||||||
// Exit (fail)
|
// Exit (fail)
|
||||||
throw new exception_domain("Failed to find the model: $model", status::not_implemented->value);
|
throw new exception_domain("Failed to find the model: $model", status::not_implemented->value);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Deinitializing name of the model class
|
||||||
|
unset($model);
|
||||||
|
|
||||||
|
if ($route->model instanceof model) {
|
||||||
|
// Initialized the model
|
||||||
|
|
||||||
|
// Writing the model to the controller
|
||||||
|
$route->controller->model = $route->model;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Deinitializing name of the model class
|
|
||||||
unset($model);
|
|
||||||
|
|
||||||
if ($route->model instanceof model) {
|
|
||||||
// Initialized the model
|
|
||||||
|
|
||||||
// Writing the model to the controller
|
|
||||||
$route->controller->model = $route->model;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Writing the request to the controller
|
// Writing the request to the controller
|
||||||
$route->controller->request = $request;
|
$route->controller->request = $request;
|
||||||
|
|
||||||
@@ -234,11 +234,11 @@ final class core
|
|||||||
try {
|
try {
|
||||||
// Executing method of the controller and exit (success)
|
// Executing method of the controller and exit (success)
|
||||||
return $route->controller->{$route->method}(...($route->parameters + $request->parameters));
|
return $route->controller->{$route->method}(...($route->parameters + $request->parameters));
|
||||||
} catch (exception $e) {
|
} catch (exception $exception) {
|
||||||
// Catched an exception
|
// Catched an exception
|
||||||
|
|
||||||
// Exit (fail)
|
// Exit (fail)
|
||||||
throw new exception_runtime(...$e);
|
throw new exception_runtime('Caught an error while processing the route', status::internal_server_error->value, $exception);
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
@@ -115,6 +115,7 @@ enum content: string
|
|||||||
return match ($this) {
|
return match ($this) {
|
||||||
self::jpeg => 'jpg',
|
self::jpeg => 'jpg',
|
||||||
self::png => 'png',
|
self::png => 'png',
|
||||||
|
self::webp => 'webp',
|
||||||
self::form, self::mixed, self::alternative, self::related => throw new exception_argument('Content can not have file extension', status::internal_server_error->value),
|
self::form, self::mixed, self::alternative, self::related => throw new exception_argument('Content can not have file extension', status::internal_server_error->value),
|
||||||
default => throw new exception_domain('Failed to recognize content: ' . $this->value, status::not_found->value)
|
default => throw new exception_domain('Failed to recognize content: ' . $this->value, status::not_found->value)
|
||||||
};
|
};
|
||||||
|
@@ -16,8 +16,8 @@ namespace mirzaev\minimal\http\enumerations;
|
|||||||
*/
|
*/
|
||||||
enum protocol: string
|
enum protocol: string
|
||||||
{
|
{
|
||||||
case http_3 = 'HTTP/3';
|
case http_3 = 'HTTP/3.0';
|
||||||
case http_2 = 'HTTP/2';
|
case http_2 = 'HTTP/2.0';
|
||||||
case http_1_1 = 'HTTP/1.1';
|
case http_1_1 = 'HTTP/1.1';
|
||||||
case http_1 = 'hTTP/1.0';
|
case http_1 = 'hTTP/1.0';
|
||||||
case http_0_9 = 'HTTP/0.9';
|
case http_0_9 = 'HTTP/0.9';
|
||||||
|
@@ -51,7 +51,7 @@ final class request
|
|||||||
*/
|
*/
|
||||||
public method $method {
|
public method $method {
|
||||||
// Write
|
// Write
|
||||||
set (method|string $value) {
|
set(method|string $value) {
|
||||||
if (isset($this->{__PROPERTY__})) {
|
if (isset($this->{__PROPERTY__})) {
|
||||||
// The property is already initialized
|
// The property is already initialized
|
||||||
|
|
||||||
@@ -61,23 +61,23 @@ final class request
|
|||||||
|
|
||||||
if ($value instanceof method) {
|
if ($value instanceof method) {
|
||||||
// Received implementation of the method
|
// Received implementation of the method
|
||||||
|
|
||||||
// Writing
|
// Writing
|
||||||
$this->method = $value;
|
$this->method = $value;
|
||||||
} else {
|
} else {
|
||||||
// Received a string literal (excected name of the method)
|
// Received a string literal (excected name of the method)
|
||||||
|
|
||||||
// Initializing implementator of the method
|
// Initializing implementator of the method
|
||||||
$method = method::{strtolower($value)};
|
$method = method::{strtolower($value)};
|
||||||
|
|
||||||
if ($method instanceof method) {
|
if ($method instanceof method) {
|
||||||
// Initialized implementator of the method
|
// Initialized implementator of the method
|
||||||
|
|
||||||
// Writing
|
// Writing
|
||||||
$this->method = $method;
|
$this->method = $method;
|
||||||
} else {
|
} else {
|
||||||
// Not initialized implementator of the method
|
// Not initialized implementator of the method
|
||||||
|
|
||||||
// Exit (fail)
|
// Exit (fail)
|
||||||
throw new exception_domain('Failed to recognize method: ' . $value, status::not_implemented->value);
|
throw new exception_domain('Failed to recognize method: ' . $value, status::not_implemented->value);
|
||||||
}
|
}
|
||||||
@@ -96,7 +96,7 @@ final class request
|
|||||||
*/
|
*/
|
||||||
public string $uri {
|
public string $uri {
|
||||||
// Write
|
// Write
|
||||||
set (string $value) {
|
set(string $value) {
|
||||||
if (isset($this->{__PROPERTY__})) {
|
if (isset($this->{__PROPERTY__})) {
|
||||||
// The property is already initialized
|
// The property is already initialized
|
||||||
|
|
||||||
@@ -121,7 +121,7 @@ final class request
|
|||||||
*/
|
*/
|
||||||
public protocol $protocol {
|
public protocol $protocol {
|
||||||
// Write
|
// Write
|
||||||
set (protocol|string $value) {
|
set(protocol|string $value) {
|
||||||
if (isset($this->{__PROPERTY__})) {
|
if (isset($this->{__PROPERTY__})) {
|
||||||
// The property is already initialized
|
// The property is already initialized
|
||||||
|
|
||||||
@@ -131,23 +131,23 @@ final class request
|
|||||||
|
|
||||||
if ($value instanceof protocol) {
|
if ($value instanceof protocol) {
|
||||||
// Received implementation of HTTP version
|
// Received implementation of HTTP version
|
||||||
|
|
||||||
// Writing
|
// Writing
|
||||||
$this->protocol = $value;
|
$this->protocol = $value;
|
||||||
} else {
|
} else {
|
||||||
// Received a string literal (excected name of HTTP version)
|
// Received a string literal (excected name of HTTP version)
|
||||||
|
|
||||||
// Initializing implementator of HTTP version
|
// Initializing implementator of HTTP version
|
||||||
$protocol = protocol::tryFrom($value);
|
$protocol = protocol::tryFrom($value);
|
||||||
|
|
||||||
if ($protocol instanceof protocol) {
|
if ($protocol instanceof protocol) {
|
||||||
// Initialized implementator of HTTP version
|
// Initialized implementator of HTTP version
|
||||||
|
|
||||||
// Writing
|
// Writing
|
||||||
$this->protocol = $protocol;
|
$this->protocol = $protocol;
|
||||||
} else {
|
} else {
|
||||||
// Not initialized implementator of HTTP version
|
// Not initialized implementator of HTTP version
|
||||||
|
|
||||||
// Exit (fail)
|
// Exit (fail)
|
||||||
throw new exception_domain('Failed to recognize HTTP version: ' . $value, status::http_version_not_supported->value);
|
throw new exception_domain('Failed to recognize HTTP version: ' . $value, status::http_version_not_supported->value);
|
||||||
}
|
}
|
||||||
@@ -187,16 +187,16 @@ final class request
|
|||||||
*/
|
*/
|
||||||
public array $parameters {
|
public array $parameters {
|
||||||
// Write
|
// Write
|
||||||
set (array $value) {
|
set(array $value) {
|
||||||
if (isset($this->{__PROPERTY__})) {
|
if (isset($this->{__PROPERTY__})) {
|
||||||
// The property is already initialized
|
// The property is already initialized
|
||||||
|
|
||||||
// Exit (fail)
|
// Exit (fail)
|
||||||
throw new exception_runtime('The property is already initialized: ' . __PROPERTY__, status::internal_server_error->value);
|
throw new exception_runtime('The property is already initialized: ' . __PROPERTY__, status::internal_server_error->value);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Writing
|
// Writing
|
||||||
$this->parameters = $value;
|
$this->parameters = $value;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read
|
// Read
|
||||||
@@ -222,7 +222,7 @@ final class request
|
|||||||
*/
|
*/
|
||||||
public array $files {
|
public array $files {
|
||||||
// Write
|
// Write
|
||||||
set (array $value) {
|
set(array $value) {
|
||||||
if (isset($this->{__PROPERTY__})) {
|
if (isset($this->{__PROPERTY__})) {
|
||||||
// The property is already initialized
|
// The property is already initialized
|
||||||
|
|
||||||
@@ -233,14 +233,14 @@ final class request
|
|||||||
if (isset($this->method)) {
|
if (isset($this->method)) {
|
||||||
// Initialized method
|
// Initialized method
|
||||||
|
|
||||||
if ($this->method->body()) {
|
if ($this->method->body()) {
|
||||||
// Request with this method can has body
|
// Request with this method can has body
|
||||||
|
|
||||||
// Writing
|
// Writing
|
||||||
$this->files = $value;
|
$this->files = $value;
|
||||||
} else {
|
} else {
|
||||||
// Request with this method can not has body
|
// Request with this method can not has body
|
||||||
|
|
||||||
// Exit (fail)
|
// Exit (fail)
|
||||||
throw new exception_logic('Request with ' . $this->method->value . ' method can not has body therefore can not has files', status::internal_server_error->value);
|
throw new exception_logic('Request with ' . $this->method->value . ' method can not has body therefore can not has files', status::internal_server_error->value);
|
||||||
}
|
}
|
||||||
@@ -270,7 +270,7 @@ final class request
|
|||||||
*/
|
*/
|
||||||
public array $options {
|
public array $options {
|
||||||
// Write
|
// Write
|
||||||
set (array $value) {
|
set(array $value) {
|
||||||
if (isset($this->{__PROPERTY__})) {
|
if (isset($this->{__PROPERTY__})) {
|
||||||
// The property is already initialized
|
// The property is already initialized
|
||||||
|
|
||||||
@@ -334,7 +334,7 @@ final class request
|
|||||||
|
|
||||||
if (isset($headers)) {
|
if (isset($headers)) {
|
||||||
// Received headers
|
// Received headers
|
||||||
|
|
||||||
// Declaring the buffer of headers
|
// Declaring the buffer of headers
|
||||||
$buffer = [];
|
$buffer = [];
|
||||||
|
|
||||||
@@ -346,10 +346,10 @@ final class request
|
|||||||
|
|
||||||
if (empty($name)) {
|
if (empty($name)) {
|
||||||
// Not normalized name of header
|
// Not normalized name of header
|
||||||
|
|
||||||
// Exit (fail)
|
// Exit (fail)
|
||||||
throw new exception_domain('Failed to normalize name of header', status::internal_server_error->value);
|
throw new exception_domain('Failed to normalize name of header', status::internal_server_error->value);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Writing into the buffer of headers
|
// Writing into the buffer of headers
|
||||||
$buffer[$name] = $value;
|
$buffer[$name] = $value;
|
||||||
@@ -382,7 +382,7 @@ final class request
|
|||||||
|
|
||||||
if (!isset($headers)) {
|
if (!isset($headers)) {
|
||||||
// Received headers
|
// Received headers
|
||||||
|
|
||||||
// Declaring the buffer of headers
|
// Declaring the buffer of headers
|
||||||
$buffer = [];
|
$buffer = [];
|
||||||
|
|
||||||
@@ -394,10 +394,10 @@ final class request
|
|||||||
|
|
||||||
if (empty($name)) {
|
if (empty($name)) {
|
||||||
// Not normalized name of header
|
// Not normalized name of header
|
||||||
|
|
||||||
// Exit (fail)
|
// Exit (fail)
|
||||||
throw new exception_domain('Failed to normalize name of header', status::internal_server_error->value);
|
throw new exception_domain('Failed to normalize name of header', status::internal_server_error->value);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Writing into the buffer of headers
|
// Writing into the buffer of headers
|
||||||
$buffer[$name] = $value;
|
$buffer[$name] = $value;
|
||||||
@@ -410,7 +410,7 @@ final class request
|
|||||||
unset($buffer);
|
unset($buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($this->headers['content-type'] === content::json->value) {
|
if (str_starts_with($this->headers['content-type'], content::json->value)) {
|
||||||
// The body contains "application/json"
|
// The body contains "application/json"
|
||||||
|
|
||||||
// Initializing data from the input buffer
|
// Initializing data from the input buffer
|
||||||
@@ -438,10 +438,13 @@ final class request
|
|||||||
|
|
||||||
// Writing files from environment into the property
|
// Writing files from environment into the property
|
||||||
$this->files = $_FILES ?? [];
|
$this->files = $_FILES ?? [];
|
||||||
} else if ($this->method->body()) {
|
} else if ($this->method->body()) {
|
||||||
// Non POST method and can has body
|
// Non POST method and can has body
|
||||||
|
|
||||||
if (match($this->headers['content-type']) { content::form->value, content::encoded->value => true, default => false }) {
|
if (
|
||||||
|
str_starts_with($this->headers['content-type'], content::form->value) ||
|
||||||
|
str_starts_with($this->headers['content-type'], content::encoded->value)
|
||||||
|
) {
|
||||||
// Non POST method and the body content type is "multipart/form-data" or "application/x-www-form-urlencoded"
|
// Non POST method and the body content type is "multipart/form-data" or "application/x-www-form-urlencoded"
|
||||||
|
|
||||||
// Writing parameters and files from environment into the properties
|
// Writing parameters and files from environment into the properties
|
||||||
@@ -475,13 +478,13 @@ final class request
|
|||||||
*
|
*
|
||||||
* @return response Reponse for request
|
* @return response Reponse for request
|
||||||
*/
|
*/
|
||||||
public function response(): response
|
public function response(): response
|
||||||
{
|
{
|
||||||
// Exit (success)
|
// Exit (success)
|
||||||
return new response(protocol: $this->protocol, status: status::ok);
|
return new response(protocol: $this->protocol, status: status::ok);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Header
|
* Header
|
||||||
*
|
*
|
||||||
* Write a header to the headers property
|
* Write a header to the headers property
|
||||||
@@ -493,7 +496,7 @@ final class request
|
|||||||
*
|
*
|
||||||
* @return self The instance from which the method was called (fluent interface)
|
* @return self The instance from which the method was called (fluent interface)
|
||||||
*/
|
*/
|
||||||
public function header(string $name, string $value): self
|
public function header(string $name, string $value): self
|
||||||
{
|
{
|
||||||
// Normalizing name of header and writing to the headers property (https://www.rfc-editor.org/rfc/rfc7540#section-8.1.2)
|
// Normalizing name of header and writing to the headers property (https://www.rfc-editor.org/rfc/rfc7540#section-8.1.2)
|
||||||
$this->headers[mb_strtolower($name, 'UTF-8')] = $value;
|
$this->headers[mb_strtolower($name, 'UTF-8')] = $value;
|
||||||
|
@@ -320,7 +320,7 @@ final class response
|
|||||||
*/
|
*/
|
||||||
public function validate(request $request): self|false
|
public function validate(request $request): self|false
|
||||||
{
|
{
|
||||||
if (str_contains($request->headers['accept'], $this->headers['content-type'] ?? '')) {
|
if (str_contains($request->headers['accept'] ?? '', $this->headers['content-type'] ?? '')) {
|
||||||
// Validated with "accept" and "content-type"
|
// Validated with "accept" and "content-type"
|
||||||
|
|
||||||
// Exit (success)
|
// Exit (success)
|
||||||
@@ -453,10 +453,10 @@ final class response
|
|||||||
flush();
|
flush();
|
||||||
|
|
||||||
// Deinitializing headers property
|
// Deinitializing headers property
|
||||||
unset($this->headers);
|
$this->headers = [];
|
||||||
|
|
||||||
// Deinitializing headers
|
// Deinitializing headers
|
||||||
header_remove();
|
/* header_remove(); */
|
||||||
|
|
||||||
// Exit (success)
|
// Exit (success)
|
||||||
return $this;
|
return $this;
|
||||||
|
Reference in New Issue
Block a user