forked from mirzaev/minimal
		
	Compare commits
	
		
			4 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| e93ea5825e | |||
| c841250933 | |||
| beaf55f00b | |||
| 7ae1d6ac70 | 
							
								
								
									
										72
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										72
									
								
								README.md
									
									
									
									
									
								
							@@ -1,14 +1,10 @@
 | 
			
		||||
The MINIMAL framework that does **not limit your project with its own rules**, has **no dependencies**, implements the **best practices** of popular MVC-frameworks, it **VERY fast** and **optimized** for all the innovations in **PHP 8.2** 🤟
 | 
			
		||||
# MINIMAL
 | 
			
		||||
The best code-to-utility Framework
 | 
			
		||||
 | 
			
		||||
Can be configured to work with **any database** `core::$session` and **any HTML template engine** `$this->view`
 | 
			
		||||
*personally, i prefer **ArangoDB** and **Twig***
 | 
			
		||||
 | 
			
		||||
## Nearest plans (first half of 2025)
 | 
			
		||||
1. Add **middlewares** technology
 | 
			
		||||
2. Route sorting in the router `router::sort()`
 | 
			
		||||
3. Add trigger routes from within routes
 | 
			
		||||
4. Think about adding asynchronous executions
 | 
			
		||||
5. Write an article describing the principles of the framework
 | 
			
		||||
## Nearest plans (2025)
 | 
			
		||||
1. **Middlewares** technology
 | 
			
		||||
2. Route sorting `router::sort()`
 | 
			
		||||
3. Processing routes from within routes (request emulation)
 | 
			
		||||
 | 
			
		||||
## Installation 
 | 
			
		||||
Execute: `composer require mirzaev/minimal`
 | 
			
		||||
@@ -16,49 +12,37 @@ Execute: `composer require mirzaev/minimal`
 | 
			
		||||
## Usage
 | 
			
		||||
*index.php*
 | 
			
		||||
```php
 | 
			
		||||
// Initializing the router
 | 
			
		||||
$router = new router;
 | 
			
		||||
 | 
			
		||||
// Initializing of routes
 | 
			
		||||
$router
 | 
			
		||||
    ->write('/', 'catalog', 'index', 'GET')
 | 
			
		||||
	->write('/search', 'catalog', 'search', 'POST')
 | 
			
		||||
	->write('/session/connect/telegram', 'session', 'telegram', 'POST')
 | 
			
		||||
	->write('/product/$id', 'catalog', 'product', 'POST')
 | 
			
		||||
	->write('/$categories...', 'catalog', 'index', 'POST'); // Collector (since 0.3.0)
 | 
			
		||||
 | 
			
		||||
// Initializing the core
 | 
			
		||||
$core = new core(namespace: __NAMESPACE__, router: $router, controller: new controller(false), model: new model(false));
 | 
			
		||||
$core = new core(namespace: __NAMESPACE__);
 | 
			
		||||
 | 
			
		||||
// Handle the request
 | 
			
		||||
echo $core->start();
 | 
			
		||||
// Initializing routes
 | 
			
		||||
$core->router
 | 
			
		||||
	->write('/', new route('index', 'index'), 'GET')
 | 
			
		||||
	->write('/search', new route('search', 'search'), 'POST')
 | 
			
		||||
	->write('/product/create', new route('product', 'create'), 'PUT')
 | 
			
		||||
	->write('/product/$id', new route('product', 'read'), 'GET')
 | 
			
		||||
	->write('/product/$id', new route('product', 'read'), 'POST')
 | 
			
		||||
	->write('/$categories', new route('categories', 'read'), 'GET') // Collector (since 0.3.0)
 | 
			
		||||
;
 | 
			
		||||
 | 
			
		||||
// Handling the request
 | 
			
		||||
$core->start();
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
## Examples of projects based on MINIMAL
 | 
			
		||||
## Projects based on MINIMAL
 | 
			
		||||
 | 
			
		||||
### ebala
 | 
			
		||||
**Repository:** https://git.mirzaev.sexy/mirzaev/ebala<br>
 | 
			
		||||
**Repository:** https://git.svoboda.works/mirzaev/ebala<br>
 | 
			
		||||
**Github mirror:** https://github.com/mature-woman/ebala<br>
 | 
			
		||||
*I earned more than a **million rubles** from this project*<br>
 | 
			
		||||
*Repositories **may** be closed at the request of the customer*<br>
 | 
			
		||||
 | 
			
		||||
### huesos 
 | 
			
		||||
**Repository:** https://git.mirzaev.sexy/mirzaev/huesos<br>
 | 
			
		||||
**Guthub mirror:** https://github.com/mature-woman/huesos<br>
 | 
			
		||||
*The basis for developing chat-robots with Web App technology (for example for Telegram)*<br>
 | 
			
		||||
### Arming 
 | 
			
		||||
**Repository:** https://git.svoboda.works/weby/arming<br>
 | 
			
		||||
**Guthub mirror:** https://github.com/WEBY-GROUP/arming<br>
 | 
			
		||||
*Telegram chat-robot marketplace*<br>
 | 
			
		||||
 | 
			
		||||
### arming_bot 
 | 
			
		||||
**Repository:** https://git.mirzaev.sexy/mirzaev/arming_bot<br>
 | 
			
		||||
**Guthub mirror:** https://github.com/mature-woman/arming_bot<br>
 | 
			
		||||
*Chat-robot based on huesos*<br>
 | 
			
		||||
 | 
			
		||||
### notchat
 | 
			
		||||
**Repository:** https://git.mirzaev.sexy/mirzaev/notchat<br>
 | 
			
		||||
### not.chat
 | 
			
		||||
**Repository:** https://git.svoboda.works/mirzaev/notchat<br>
 | 
			
		||||
**Github mirror:** https://github.com/mature-woman/notchat<br>
 | 
			
		||||
*P2P chat project with different blockchains and smart stuff*<br>
 | 
			
		||||
 | 
			
		||||
### site-repression
 | 
			
		||||
**Link:** https://repression.mirzaev.sexy<br>
 | 
			
		||||
**Repository:** https://git.mirzaev.sexy/mirzaev/site-repression<br>
 | 
			
		||||
**Github mirror:** https://github.com/mature-woman/site-repression<br>
 | 
			
		||||
*A simple site for my article about **political repressions in Russia** and my **kidnapping by Wagner PMC operatives** from my house*<br>
 | 
			
		||||
*P2P chat project with blockchains and smart stuff*<br>
 | 
			
		||||
 
 | 
			
		||||
@@ -6,16 +6,16 @@ namespace mirzaev\minimal\http;
 | 
			
		||||
 | 
			
		||||
// Files of the project
 | 
			
		||||
use mirzaev\minimal\http\enumerations\method,
 | 
			
		||||
	mirzaev\minimal\http\enumerations\protocol,
 | 
			
		||||
	mirzaev\minimal\http\enumerations\status,
 | 
			
		||||
	mirzaev\minimal\http\enumerations\content,
 | 
			
		||||
	mirzaev\minimal\http\response;
 | 
			
		||||
mirzaev\minimal\http\enumerations\protocol,
 | 
			
		||||
mirzaev\minimal\http\enumerations\status,
 | 
			
		||||
mirzaev\minimal\http\enumerations\content,
 | 
			
		||||
mirzaev\minimal\http\response;
 | 
			
		||||
 | 
			
		||||
// Built-in libraries
 | 
			
		||||
use DomainException as exception_domain,
 | 
			
		||||
	InvalidArgumentException as exception_argument,
 | 
			
		||||
	RuntimeException as exception_runtime,
 | 
			
		||||
	LogicException as exception_logic;
 | 
			
		||||
InvalidArgumentException as exception_argument,
 | 
			
		||||
RuntimeException as exception_runtime,
 | 
			
		||||
LogicException as exception_logic;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Request
 | 
			
		||||
@@ -280,16 +280,16 @@ final class request
 | 
			
		||||
 | 
			
		||||
			// Writing
 | 
			
		||||
			$this->options = array_filter(
 | 
			
		||||
				$value,
 | 
			
		||||
				fn(string $key) => match ($key) {
 | 
			
		||||
					'post_max_size',
 | 
			
		||||
					'max_input_vars',
 | 
			
		||||
					'max_multipart_body_parts',
 | 
			
		||||
					'max_file_uploads',
 | 
			
		||||
					'upload_max_filesize' => true,
 | 
			
		||||
					default => throw new exception_domain("Failed to recognize option: $key", status::internal_server_error->value)
 | 
			
		||||
				},
 | 
			
		||||
				ARRAY_FILTER_USE_KEY
 | 
			
		||||
			$value,
 | 
			
		||||
			fn(string $key) => match ($key) {
 | 
			
		||||
				'post_max_size',
 | 
			
		||||
				'max_input_vars',
 | 
			
		||||
				'max_multipart_body_parts',
 | 
			
		||||
				'max_file_uploads',
 | 
			
		||||
				'upload_max_filesize' => true,
 | 
			
		||||
				default => throw new exception_domain("Failed to recognize option: $key", status::internal_server_error->value)
 | 
			
		||||
			},
 | 
			
		||||
			ARRAY_FILTER_USE_KEY
 | 
			
		||||
			);
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
@@ -324,13 +324,16 @@ final class request
 | 
			
		||||
		bool $environment = false
 | 
			
		||||
	) {
 | 
			
		||||
		// Writing method from argument into the property
 | 
			
		||||
		if (isset($method)) $this->method = $method;
 | 
			
		||||
		if (isset($method))
 | 
			
		||||
			$this->method = $method;
 | 
			
		||||
 | 
			
		||||
		// Writing URI from argument into the property
 | 
			
		||||
		if (isset($uri)) $this->uri = $uri;
 | 
			
		||||
		if (isset($uri))
 | 
			
		||||
			$this->uri = $uri;
 | 
			
		||||
 | 
			
		||||
		// Writing verstion of HTTP protocol from argument into the property
 | 
			
		||||
		if (isset($protocol)) $this->protocol = $protocol;
 | 
			
		||||
		if (isset($protocol))
 | 
			
		||||
			$this->protocol = $protocol;
 | 
			
		||||
 | 
			
		||||
		if (isset($headers)) {
 | 
			
		||||
			// Received headers
 | 
			
		||||
@@ -363,10 +366,12 @@ final class request
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		// Writing parameters from argument into the property
 | 
			
		||||
		if (isset($parameters)) $this->parameters = $parameters;
 | 
			
		||||
		if (isset($parameters))
 | 
			
		||||
			$this->parameters = $parameters;
 | 
			
		||||
 | 
			
		||||
		// Writing files from argument into the property
 | 
			
		||||
		if (isset($files)) $this->files = $files;
 | 
			
		||||
		if (isset($files))
 | 
			
		||||
			$this->files = $files;
 | 
			
		||||
 | 
			
		||||
		if ($environment) {
 | 
			
		||||
			// Requested to write values from environment
 | 
			
		||||
@@ -410,7 +415,7 @@ final class request
 | 
			
		||||
				unset($buffer);
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			if (str_starts_with($this->headers['content-type'], content::json->value)) {
 | 
			
		||||
			if (str_starts_with($this->headers['content-type'] ?? '', content::json->value)) {
 | 
			
		||||
				// The body contains "application/json"
 | 
			
		||||
 | 
			
		||||
				// Initializing data from the input buffer
 | 
			
		||||
@@ -467,8 +472,10 @@ final class request
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		// Validating of required properties
 | 
			
		||||
		if (empty($this->method)) throw new exception_argument('Failed to initialize method of the request', status::internal_server_error->value);
 | 
			
		||||
		if (empty($this->uri)) throw new exception_argument('Failed to initialize URI of the request', status::internal_server_error->value);
 | 
			
		||||
		if (empty($this->method))
 | 
			
		||||
			throw new exception_argument('Failed to initialize method of the request', status::internal_server_error->value);
 | 
			
		||||
		if (empty($this->uri))
 | 
			
		||||
			throw new exception_argument('Failed to initialize URI of the request', status::internal_server_error->value);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user