Compare commits
12 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
a2650ab53f | ||
|
|
0558bb121d | ||
|
|
b5ecb1fc86 | ||
|
|
618d0029fa | ||
|
|
4f38812468 | ||
|
|
b263351289 | ||
|
|
2657310000 | ||
|
|
7d5538ad35 | ||
|
|
c2a14307ae | ||
|
|
ddb82ee395 | ||
|
|
a095b76e8d | ||
|
|
70810412f4 |
12
.env.dist
12
.env.dist
@@ -8,12 +8,12 @@
|
||||
#
|
||||
# Real environment variables win over .env files.
|
||||
|
||||
# PROD / DEV
|
||||
# DEBUG / DEV / PROD
|
||||
APP_MODE=DEV
|
||||
APP_NODES_FILE=application/config/app.php
|
||||
CLI_NODES_FILE=application/config/app-cli.php
|
||||
APP_COMPONENTS_FILE=application/config/components.php
|
||||
CONTAINER_INI=application/config/container.php
|
||||
APP_NODES_FILE=config/app.php
|
||||
CLI_NODES_FILE=config/app-cli.php
|
||||
APP_COMPONENTS_FILE=config/components.php
|
||||
CONTAINER_INI=config/container.php
|
||||
CONTAINER_CACHE=var/cache/container
|
||||
|
||||
# Default page
|
||||
@@ -21,5 +21,5 @@ PAGE404="/templates/error/404.tpl"
|
||||
PAGE501="/templates/error/501.tpl"
|
||||
|
||||
# Users environment
|
||||
MYSQL_PARAM='{"host":"host.docker.internal", "user":"***user***", "pass":"***password***","base":"***basename***", "logsEnable":true}'
|
||||
MYSQL_PARAM='{"host":"host.docker.internal", "user":"***user***", "pass":"***password***","base":"***basename***", "charset":"utf8mb4", "logsEnable":true}'
|
||||
REDIS_PARAM='{"host":"127.0.0.1","port":6379,"connectTimeout":2.5,"backoff":{"algorithm":1,"base":500,"cap":750}, "database":0, "defaultExpire":300}'
|
||||
|
||||
@@ -9,5 +9,5 @@ composer create-project rmphp/skeleton project-name
|
||||
```
|
||||
|
||||
```bash
|
||||
composer create-project rmphp/skeleton:"^4.7" project-name
|
||||
composer create-project rmphp/skeleton:"^5.1" project-name
|
||||
```
|
||||
|
||||
@@ -1,41 +0,0 @@
|
||||
<?php
|
||||
|
||||
namespace Base\Application;
|
||||
|
||||
use Exception;
|
||||
use ReflectionClass;
|
||||
use Rmphp\Storage\Component\AbstractDataObject;
|
||||
|
||||
abstract class AbstractDTO extends AbstractDataObject {
|
||||
|
||||
/**
|
||||
* @param array|object ...$data
|
||||
* @return static
|
||||
* @throws Exception
|
||||
*/
|
||||
public static function fromData(array|object ...$data) : static {
|
||||
$array = array_map(function($item) {
|
||||
return (is_object($item)) ? get_object_vars($item) : $item;
|
||||
}, $data);
|
||||
return self::fromArray(array_merge(...$array));
|
||||
}
|
||||
|
||||
/**
|
||||
* @param object $data
|
||||
* @return static
|
||||
* @throws Exception
|
||||
*/
|
||||
public static function fromObject(object $data) : static {
|
||||
return self::fromArray(get_object_vars($data));
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @param array $data
|
||||
* @return static
|
||||
* @throws Exception
|
||||
*/
|
||||
public static function fromArray(array $data) : static {
|
||||
return self::fillObject(new ReflectionClass(static::class), new static(), $data);
|
||||
}
|
||||
}
|
||||
@@ -1,16 +0,0 @@
|
||||
<?php
|
||||
|
||||
|
||||
namespace Base\Application;
|
||||
|
||||
use Throwable;
|
||||
|
||||
class DTOException extends \Exception {
|
||||
|
||||
public array $data;
|
||||
|
||||
public function __construct($message="", $code=0, array $data = [], Throwable $previous=null) {
|
||||
parent::__construct($message, $code, $previous);
|
||||
$this->data = $data;
|
||||
}
|
||||
}
|
||||
@@ -3,33 +3,19 @@
|
||||
namespace Base\Controllers;
|
||||
|
||||
use Base\Application\ApplicationException;
|
||||
use Base\Application\DTOException;
|
||||
use Base\Domain\DomainException;
|
||||
use Exception;
|
||||
use Throwable;
|
||||
|
||||
abstract class AbstractPageController extends AbstractController {
|
||||
|
||||
/**
|
||||
* @param Exception $exception
|
||||
* @param array $data
|
||||
* @return void
|
||||
*/
|
||||
public function exceptionPage(Exception $exception, array $data = []) : void {
|
||||
$this->logException($exception, $data);
|
||||
$this->syslogger()->warning($exception->getMessage()." on ".$exception->getFile().":".$exception->getLine(), $data);
|
||||
$this->template()->setSubtemplate("main", "/error/errpage.tpl", [
|
||||
"errorText" => "<span style='color:red'>Error: ".$exception->getMessage()." (".$exception->getCode().")"."</span>"
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param Throwable $e
|
||||
* @return string
|
||||
*/
|
||||
public function checkError(Throwable $e) : string {
|
||||
($e instanceof Exception) ? $this->logException($e) : $this->logError($e);
|
||||
if($e instanceof DTOException || $e instanceof DomainException || $e instanceof ApplicationException) return $e->getMessage();
|
||||
if($e instanceof DomainException || $e instanceof ApplicationException) return $e->getMessage();
|
||||
return "Ошибка. Дата и время: ".date("d-m-Y H:i:s");
|
||||
}
|
||||
}
|
||||
|
||||
0
application/base/Domain/ValueObject/.gitkeep
Normal file
0
application/base/Domain/ValueObject/.gitkeep
Normal file
@@ -1,6 +1,6 @@
|
||||
<?php
|
||||
|
||||
namespace Base\Controllers;
|
||||
namespace Base\Handlers;
|
||||
|
||||
use Laminas\Diactoros\Response\HtmlResponse;
|
||||
use Laminas\Diactoros\Response\JsonResponse;
|
||||
@@ -1,3 +1,3 @@
|
||||
#!/usr/bin/php
|
||||
<?php
|
||||
require_once dirname(__FILE__).'/console.php';
|
||||
require_once dirname(__FILE__).'/cli.php';
|
||||
|
||||
@@ -1,3 +0,0 @@
|
||||
#!/usr/bin/php
|
||||
<?php
|
||||
require_once dirname(__FILE__).'/console.php';
|
||||
@@ -1,5 +0,0 @@
|
||||
<?php
|
||||
return [
|
||||
"application/config/container/services.php",
|
||||
"application/config/container/settings.php",
|
||||
];
|
||||
@@ -5,7 +5,7 @@
|
||||
"minimum-stability": "dev",
|
||||
"prefer-stable" : true,
|
||||
"require": {
|
||||
"php": "^8.1",
|
||||
"php": "^8.3",
|
||||
"ext-json": "*",
|
||||
"ext-yaml": "*",
|
||||
"laminas/laminas-diactoros": "^2.5",
|
||||
@@ -17,7 +17,7 @@
|
||||
"rmphp/router": "^2.0",
|
||||
"rmphp/session": "^1.1",
|
||||
"rmphp/redis": "^1.0",
|
||||
"rmphp/storage": "^6.0",
|
||||
"rmphp/storage": "^12.0",
|
||||
"symfony/dotenv": "^6.2"
|
||||
},
|
||||
"autoload": {
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
<?php
|
||||
# Example:
|
||||
# ['key'=>'/', "action"=>"App\\Main\\Controllers\\IndexController", "method"=>"index"],
|
||||
# ['key'=>'', 'router'=>'application/config/routes-cli/routes.php'],
|
||||
# ['key'=>'', 'router'=>'config/routes-cli/routes.php'],
|
||||
# ['key'=>'/', 'router'=>[]],
|
||||
|
||||
return [
|
||||
@@ -5,9 +5,9 @@
|
||||
|
||||
# Example:
|
||||
# ['key'=>'/', "action"=>"App\\Main\\Controllers\\IndexController", "method"=>"index"],
|
||||
# ['key'=>'/', 'router'=>'application/config/routes/main/routes.php'],
|
||||
# ['key'=>'/', 'router'=>'config/routes/main/routes.php'],
|
||||
# ['key'=>'/', 'router'=>[]],
|
||||
|
||||
return [
|
||||
['key'=>'/', 'router'=>'application/config/routes/routes.php'],
|
||||
['key'=>'/', 'router'=>'config/routes/routes.php'],
|
||||
];
|
||||
@@ -4,17 +4,17 @@ return [
|
||||
/**
|
||||
* Путь к файлу фабрики возвращающий реализацию RouterInterface или сам экземпляр класса
|
||||
*/
|
||||
\Rmphp\Foundation\RouterInterface::class => 'application/config/components/routerFactory.php',
|
||||
\Rmphp\Foundation\RouterInterface::class => 'config/components/routerFactory.php',
|
||||
/**
|
||||
* Путь к файлу фабрики возвращающий реализацию TemplateInterface или сам экземпляр класса
|
||||
*/
|
||||
\Rmphp\Foundation\TemplateInterface::class => 'application/config/components/templateFactory.php',
|
||||
\Rmphp\Foundation\TemplateInterface::class => 'config/components/templateFactory.php',
|
||||
/**
|
||||
* Путь к файлу фабрики возвращающий реализацию PSR-3 LoggerInterface или сам экземпляр класса
|
||||
*/
|
||||
\Psr\Log\LoggerInterface::class => 'application/config/components/loggerFactory.php',
|
||||
\Psr\Log\LoggerInterface::class => 'config/components/loggerFactory.php',
|
||||
/**
|
||||
* Путь к файлу фабрики возвращающий реализацию PSR-11 ContainerInterface или сам экземпляр класса
|
||||
*/
|
||||
\Psr\Container\ContainerInterface::class => 'application/config/components/containerFactory.php',
|
||||
\Psr\Container\ContainerInterface::class => 'config/components/containerFactory.php',
|
||||
];
|
||||
@@ -2,18 +2,18 @@
|
||||
|
||||
use DI\ContainerBuilder;
|
||||
|
||||
$containerIni = (getenv("CONTAINER_INI")) ?: "application/config/container.php";
|
||||
$containerIni = (getenv("CONTAINER_INI")) ?: "config/container.php";
|
||||
$containerCache = (getenv("CONTAINER_CACHE")) ?: "var/cache/container";
|
||||
|
||||
$dependencies = require dirname(__DIR__,3).'/'.$containerIni;
|
||||
$dependencies = require dirname(__DIR__,2).'/'.$containerIni;
|
||||
|
||||
$dependenciesCollection = array_map(function ($dependenciesFile){
|
||||
return require dirname(__DIR__,3)."/".$dependenciesFile;
|
||||
return require dirname(__DIR__,2)."/".$dependenciesFile;
|
||||
}, $dependencies);
|
||||
|
||||
try {
|
||||
$builder = new ContainerBuilder();
|
||||
if(getenv("APP_MODE") == "PROD") $builder->enableCompilation(dirname(__DIR__,3)."/".$containerCache);
|
||||
if(getenv("APP_MODE") == "PROD") $builder->enableCompilation(dirname(__DIR__,2)."/".$containerCache);
|
||||
$builder->addDefinitions(array_replace_recursive(...$dependenciesCollection));
|
||||
return $builder->build();
|
||||
} catch (Exception $e) {echo $e->getMessage();}
|
||||
@@ -1,2 +1,2 @@
|
||||
<?php
|
||||
return (new \Monolog\Logger('system'))->pushHandler(new \Monolog\Handler\StreamHandler(dirname(__DIR__, 3).'/var/logs/log'.date('Ymd').'.log'));
|
||||
return (new \Monolog\Logger('system'))->pushHandler(new \Monolog\Handler\StreamHandler(dirname(__DIR__, 2).'/var/logs/log'.date('Ymd').'.log'));
|
||||
6
config/container.php
Normal file
6
config/container.php
Normal file
@@ -0,0 +1,6 @@
|
||||
<?php
|
||||
return [
|
||||
"config/container/params.php",
|
||||
"config/container/services.php",
|
||||
"config/container/settings.php",
|
||||
];
|
||||
6
config/container/params.php
Normal file
6
config/container/params.php
Normal file
@@ -0,0 +1,6 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
'MYSQL_PARAM' => json_decode(getenv("MYSQL_PARAM"), true),
|
||||
'REDIS_PARAM' => json_decode(getenv("REDIS_PARAM"), true),
|
||||
];
|
||||
@@ -4,7 +4,7 @@ use Rmphp\Storage\Mysql\MysqlStorage;
|
||||
use Rmphp\Storage\Mysql\MysqlStorageInterface;
|
||||
|
||||
return [
|
||||
MysqlStorageInterface::class => DI\create(MysqlStorage::class)->constructor(json_decode(getenv("MYSQL_PARAM"), true)),
|
||||
MysqlStorageInterface::class => DI\create(MysqlStorage::class)->constructor(DI\get("MYSQL_PARAM")),
|
||||
'App\Domain\Repository\*RepositoryInterface' => DI\autowire('App\Infrastructure\Repository\*Repository'),
|
||||
'App\*\Domain\Repository\*RepositoryInterface' => DI\autowire('App\*\Infrastructure\Repository\*Repository'),
|
||||
];
|
||||
@@ -1,6 +1,6 @@
|
||||
<?php
|
||||
|
||||
$cashFile = preg_replace("'.application.*$'",'', __DIR__).'/var/routes/'.md5(__FILE__);
|
||||
$cashFile = dirname(__DIR__,2).'/var/routes/'.md5(__FILE__);
|
||||
|
||||
if(getenv("APP_MODE") == "PROD" && file_exists($cashFile)){
|
||||
return unserialize(file_get_contents($cashFile));
|
||||
@@ -23,7 +23,7 @@ $app = new App();
|
||||
$response = $app->handler($request, new Response());
|
||||
(new ResponseEmitter())->emit($response);
|
||||
|
||||
if(($response->getStatusCode() !== 200 && getenv("APP_MODE") == 'DEV') || in_array("Dev", $response->getHeader("App-Mode"))){
|
||||
if(($response->getStatusCode() !== 200 && in_array(getenv("APP_MODE"), ['DEBUG', 'DEV'])) || in_array("Dev", $response->getHeader("App-Mode"))){
|
||||
$app->syslogger()->dump("Response", $response);
|
||||
addShutdownInfo($app->syslogger()->getLogs());
|
||||
}
|
||||
|
||||
@@ -8,7 +8,7 @@
|
||||
|
||||
namespace App\Infrastructure\Handlers;
|
||||
|
||||
use Base\Controllers\AbstractHandler;
|
||||
use Base\Handlers\AbstractHandler;
|
||||
use Psr\Http\Message\ResponseInterface;
|
||||
|
||||
class IndexHandler extends AbstractHandler {
|
||||
|
||||
Reference in New Issue
Block a user