new kernel, ms bearer
This commit is contained in:
parent
5285acae12
commit
2470c5dba8
@ -9,3 +9,5 @@ DB_PREFIX=''
|
|||||||
|
|
||||||
VIEWS_PATH=/views
|
VIEWS_PATH=/views
|
||||||
VIEWS_CACHE_PATH=/views_cache
|
VIEWS_CACHE_PATH=/views_cache
|
||||||
|
|
||||||
|
SECRET_KEY=''
|
@ -3,6 +3,7 @@
|
|||||||
namespace app\modules\module_shop\controllers;
|
namespace app\modules\module_shop\controllers;
|
||||||
|
|
||||||
use app\modules\module_shop\models\ModuleShop;
|
use app\modules\module_shop\models\ModuleShop;
|
||||||
|
use kernel\Request;
|
||||||
use kernel\RestController;
|
use kernel\RestController;
|
||||||
|
|
||||||
class ModuleShopRestController extends RestController
|
class ModuleShopRestController extends RestController
|
||||||
@ -13,4 +14,30 @@ class ModuleShopRestController extends RestController
|
|||||||
$this->model = new ModuleShop();
|
$this->model = new ModuleShop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function actionIndex(): void
|
||||||
|
{
|
||||||
|
$request = new Request();
|
||||||
|
$page = $request->get('page') ?? 1;
|
||||||
|
$perPage = $request->get('per_page') ?? 10;
|
||||||
|
$query = $this->model->query();
|
||||||
|
|
||||||
|
if ($page > 1) {
|
||||||
|
$query->skip(($page - 1) * $perPage)->take($perPage);
|
||||||
|
} else {
|
||||||
|
$query->take($perPage);
|
||||||
|
}
|
||||||
|
|
||||||
|
$query->groupBy("slug")->orderBy("id", "ASC");
|
||||||
|
$expand = $this->expand();
|
||||||
|
$expandParams = explode( ",", $request->get('expand') ?? "");
|
||||||
|
$finalExpand = array_intersect($expandParams, $expand);
|
||||||
|
if ($finalExpand) {
|
||||||
|
$res = $query->get()->load($finalExpand)->toArray();
|
||||||
|
} else {
|
||||||
|
$res = $query->get()->toArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->renderApi($res);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -3,6 +3,8 @@
|
|||||||
use kernel\App;
|
use kernel\App;
|
||||||
use kernel\CgRouteCollector;
|
use kernel\CgRouteCollector;
|
||||||
|
|
||||||
|
App::$collector->filter('bearer', [\kernel\modules\secure\middlewares\BearerAuthMiddleware::class, "handler"]);
|
||||||
|
|
||||||
App::$collector->group(["prefix" => "admin"], function (CgRouteCollector $router) {
|
App::$collector->group(["prefix" => "admin"], function (CgRouteCollector $router) {
|
||||||
App::$collector->group(["prefix" => "module_shop"], function (CgRouteCollector $router){
|
App::$collector->group(["prefix" => "module_shop"], function (CgRouteCollector $router){
|
||||||
App::$collector->get('/', [\app\modules\module_shop\controllers\ModuleShopController::class, 'actionIndex']);
|
App::$collector->get('/', [\app\modules\module_shop\controllers\ModuleShopController::class, 'actionIndex']);
|
||||||
@ -18,5 +20,7 @@ App::$collector->group(["prefix" => "admin"], function (CgRouteCollector $router
|
|||||||
});
|
});
|
||||||
|
|
||||||
App::$collector->group(["prefix" => "api"], function (CgRouteCollector $router){
|
App::$collector->group(["prefix" => "api"], function (CgRouteCollector $router){
|
||||||
|
App::$collector->group(['before' => 'bearer'], function (CgRouteCollector $router){
|
||||||
$router->rest("module_shop", [\app\modules\module_shop\controllers\ModuleShopRestController::class]);
|
$router->rest("module_shop", [\app\modules\module_shop\controllers\ModuleShopRestController::class]);
|
||||||
|
});
|
||||||
});
|
});
|
@ -6,6 +6,7 @@ $dotenv->load();
|
|||||||
|
|
||||||
include_once __DIR__ . "/bootstrap/db.php";
|
include_once __DIR__ . "/bootstrap/db.php";
|
||||||
include_once __DIR__ . "/bootstrap/header.php";
|
include_once __DIR__ . "/bootstrap/header.php";
|
||||||
|
include_once __DIR__ . "/bootstrap/secure.php";
|
||||||
const ROOT_DIR = __DIR__;
|
const ROOT_DIR = __DIR__;
|
||||||
const KERNEL_DIR = __DIR__ . "/kernel";
|
const KERNEL_DIR = __DIR__ . "/kernel";
|
||||||
const KERNEL_MODULES_DIR = __DIR__ . "/kernel/modules";
|
const KERNEL_MODULES_DIR = __DIR__ . "/kernel/modules";
|
||||||
|
8
bootstrap/secure.php
Normal file
8
bootstrap/secure.php
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$secure_config = [
|
||||||
|
'token_type' => 'JWT', // random_bytes, md5, crypt, hash, JWT
|
||||||
|
'token_expired_time' => "+30 days", // +1 day
|
||||||
|
];
|
||||||
|
|
||||||
|
\kernel\App::$secure = $secure_config;
|
@ -15,7 +15,9 @@
|
|||||||
"samejack/php-argv": "dev-master",
|
"samejack/php-argv": "dev-master",
|
||||||
"itguild/eloquent-table": "^0.4.1",
|
"itguild/eloquent-table": "^0.4.1",
|
||||||
"ext-zip": "*",
|
"ext-zip": "*",
|
||||||
"josantonius/session": "^2.0"
|
"josantonius/session": "^2.0",
|
||||||
|
"firebase/php-jwt": "^6.10",
|
||||||
|
"k-adam/env-editor": "^2.0"
|
||||||
},
|
},
|
||||||
"autoload": {
|
"autoload": {
|
||||||
"psr-4": {
|
"psr-4": {
|
||||||
|
154
composer.lock
generated
154
composer.lock
generated
@ -4,7 +4,7 @@
|
|||||||
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
||||||
"This file is @generated automatically"
|
"This file is @generated automatically"
|
||||||
],
|
],
|
||||||
"content-hash": "e4f9dc9c939855869a503f576ef50d53",
|
"content-hash": "da3890f2b5b477bf758306141b8c8583",
|
||||||
"packages": [
|
"packages": [
|
||||||
{
|
{
|
||||||
"name": "brick/math",
|
"name": "brick/math",
|
||||||
@ -273,6 +273,69 @@
|
|||||||
],
|
],
|
||||||
"time": "2024-02-18T20:23:39+00:00"
|
"time": "2024-02-18T20:23:39+00:00"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "firebase/php-jwt",
|
||||||
|
"version": "v6.10.1",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/firebase/php-jwt.git",
|
||||||
|
"reference": "500501c2ce893c824c801da135d02661199f60c5"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://api.github.com/repos/firebase/php-jwt/zipball/500501c2ce893c824c801da135d02661199f60c5",
|
||||||
|
"reference": "500501c2ce893c824c801da135d02661199f60c5",
|
||||||
|
"shasum": ""
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"php": "^8.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"guzzlehttp/guzzle": "^7.4",
|
||||||
|
"phpspec/prophecy-phpunit": "^2.0",
|
||||||
|
"phpunit/phpunit": "^9.5",
|
||||||
|
"psr/cache": "^2.0||^3.0",
|
||||||
|
"psr/http-client": "^1.0",
|
||||||
|
"psr/http-factory": "^1.0"
|
||||||
|
},
|
||||||
|
"suggest": {
|
||||||
|
"ext-sodium": "Support EdDSA (Ed25519) signatures",
|
||||||
|
"paragonie/sodium_compat": "Support EdDSA (Ed25519) signatures when libsodium is not present"
|
||||||
|
},
|
||||||
|
"type": "library",
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Firebase\\JWT\\": "src"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
|
"license": [
|
||||||
|
"BSD-3-Clause"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Neuman Vong",
|
||||||
|
"email": "neuman+pear@twilio.com",
|
||||||
|
"role": "Developer"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Anant Narayanan",
|
||||||
|
"email": "anant@php.net",
|
||||||
|
"role": "Developer"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": "A simple library to encode and decode JSON Web Tokens (JWT) in PHP. Should conform to the current spec.",
|
||||||
|
"homepage": "https://github.com/firebase/php-jwt",
|
||||||
|
"keywords": [
|
||||||
|
"jwt",
|
||||||
|
"php"
|
||||||
|
],
|
||||||
|
"support": {
|
||||||
|
"issues": "https://github.com/firebase/php-jwt/issues",
|
||||||
|
"source": "https://github.com/firebase/php-jwt/tree/v6.10.1"
|
||||||
|
},
|
||||||
|
"time": "2024-05-18T18:05:11+00:00"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "graham-campbell/result-type",
|
"name": "graham-campbell/result-type",
|
||||||
"version": "v1.1.3",
|
"version": "v1.1.3",
|
||||||
@ -337,16 +400,16 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "illuminate/collections",
|
"name": "illuminate/collections",
|
||||||
"version": "v11.27.2",
|
"version": "v11.29.0",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/illuminate/collections.git",
|
"url": "https://github.com/illuminate/collections.git",
|
||||||
"reference": "4d333ea19a27230b424b9af56f34cd658b5bbce2"
|
"reference": "2d99ccbb19e34450508ff3ab2f62ba90aa2e9793"
|
||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/illuminate/collections/zipball/4d333ea19a27230b424b9af56f34cd658b5bbce2",
|
"url": "https://api.github.com/repos/illuminate/collections/zipball/2d99ccbb19e34450508ff3ab2f62ba90aa2e9793",
|
||||||
"reference": "4d333ea19a27230b424b9af56f34cd658b5bbce2",
|
"reference": "2d99ccbb19e34450508ff3ab2f62ba90aa2e9793",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
"require": {
|
"require": {
|
||||||
@ -388,11 +451,11 @@
|
|||||||
"issues": "https://github.com/laravel/framework/issues",
|
"issues": "https://github.com/laravel/framework/issues",
|
||||||
"source": "https://github.com/laravel/framework"
|
"source": "https://github.com/laravel/framework"
|
||||||
},
|
},
|
||||||
"time": "2024-09-27T14:54:48+00:00"
|
"time": "2024-10-10T19:23:07+00:00"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "illuminate/conditionable",
|
"name": "illuminate/conditionable",
|
||||||
"version": "v11.27.2",
|
"version": "v11.29.0",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/illuminate/conditionable.git",
|
"url": "https://github.com/illuminate/conditionable.git",
|
||||||
@ -438,16 +501,16 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "illuminate/container",
|
"name": "illuminate/container",
|
||||||
"version": "v11.27.2",
|
"version": "v11.29.0",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/illuminate/container.git",
|
"url": "https://github.com/illuminate/container.git",
|
||||||
"reference": "bc49d144a20b0d432e1ac812c9e056594b6c6480"
|
"reference": "06dfc614aff58384b28ba5ad191f6a02d6b192cb"
|
||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/illuminate/container/zipball/bc49d144a20b0d432e1ac812c9e056594b6c6480",
|
"url": "https://api.github.com/repos/illuminate/container/zipball/06dfc614aff58384b28ba5ad191f6a02d6b192cb",
|
||||||
"reference": "bc49d144a20b0d432e1ac812c9e056594b6c6480",
|
"reference": "06dfc614aff58384b28ba5ad191f6a02d6b192cb",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
"require": {
|
"require": {
|
||||||
@ -485,11 +548,11 @@
|
|||||||
"issues": "https://github.com/laravel/framework/issues",
|
"issues": "https://github.com/laravel/framework/issues",
|
||||||
"source": "https://github.com/laravel/framework"
|
"source": "https://github.com/laravel/framework"
|
||||||
},
|
},
|
||||||
"time": "2024-10-08T13:34:53+00:00"
|
"time": "2024-10-11T15:30:11+00:00"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "illuminate/contracts",
|
"name": "illuminate/contracts",
|
||||||
"version": "v11.27.2",
|
"version": "v11.29.0",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/illuminate/contracts.git",
|
"url": "https://github.com/illuminate/contracts.git",
|
||||||
@ -672,7 +735,7 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "illuminate/macroable",
|
"name": "illuminate/macroable",
|
||||||
"version": "v11.27.2",
|
"version": "v11.29.0",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/illuminate/macroable.git",
|
"url": "https://github.com/illuminate/macroable.git",
|
||||||
@ -718,16 +781,16 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "illuminate/support",
|
"name": "illuminate/support",
|
||||||
"version": "v11.27.2",
|
"version": "v11.29.0",
|
||||||
"source": {
|
"source": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/illuminate/support.git",
|
"url": "https://github.com/illuminate/support.git",
|
||||||
"reference": "a567431e4820363d0bc28bdf14914ab16a2e63ef"
|
"reference": "fc86f3de6640a0fb204bf13e76037a7f191232d7"
|
||||||
},
|
},
|
||||||
"dist": {
|
"dist": {
|
||||||
"type": "zip",
|
"type": "zip",
|
||||||
"url": "https://api.github.com/repos/illuminate/support/zipball/a567431e4820363d0bc28bdf14914ab16a2e63ef",
|
"url": "https://api.github.com/repos/illuminate/support/zipball/fc86f3de6640a0fb204bf13e76037a7f191232d7",
|
||||||
"reference": "a567431e4820363d0bc28bdf14914ab16a2e63ef",
|
"reference": "fc86f3de6640a0fb204bf13e76037a7f191232d7",
|
||||||
"shasum": ""
|
"shasum": ""
|
||||||
},
|
},
|
||||||
"require": {
|
"require": {
|
||||||
@ -790,7 +853,7 @@
|
|||||||
"issues": "https://github.com/laravel/framework/issues",
|
"issues": "https://github.com/laravel/framework/issues",
|
||||||
"source": "https://github.com/laravel/framework"
|
"source": "https://github.com/laravel/framework"
|
||||||
},
|
},
|
||||||
"time": "2024-10-08T18:54:07+00:00"
|
"time": "2024-10-22T13:59:47+00:00"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "itguild/eloquent-table",
|
"name": "itguild/eloquent-table",
|
||||||
@ -975,6 +1038,57 @@
|
|||||||
],
|
],
|
||||||
"time": "2024-05-20T09:12:44+00:00"
|
"time": "2024-05-20T09:12:44+00:00"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "k-adam/env-editor",
|
||||||
|
"version": "2.0.0",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/K-Adam/php-env-editor.git",
|
||||||
|
"reference": "894855dff5df4e6fce3c83dd00941a19f99fc5d5"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://api.github.com/repos/K-Adam/php-env-editor/zipball/894855dff5df4e6fce3c83dd00941a19f99fc5d5",
|
||||||
|
"reference": "894855dff5df4e6fce3c83dd00941a19f99fc5d5",
|
||||||
|
"shasum": ""
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"php": ">=8.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"phpunit/phpunit": "9.5"
|
||||||
|
},
|
||||||
|
"type": "library",
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"EnvEditor\\": "src/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
|
"license": [
|
||||||
|
"MIT"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Adam Kecskes",
|
||||||
|
"email": "kecskes.adam@outlook.com"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": ".env editor library",
|
||||||
|
"keywords": [
|
||||||
|
"dot-env",
|
||||||
|
"env",
|
||||||
|
"env-editor",
|
||||||
|
"env-loader",
|
||||||
|
"env-php",
|
||||||
|
"env-writer"
|
||||||
|
],
|
||||||
|
"support": {
|
||||||
|
"issues": "https://github.com/K-Adam/php-env-editor/issues",
|
||||||
|
"source": "https://github.com/K-Adam/php-env-editor/tree/2.0.0"
|
||||||
|
},
|
||||||
|
"time": "2022-06-05T11:17:23+00:00"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "madesimple/php-arrays",
|
"name": "madesimple/php-arrays",
|
||||||
"version": "v2.1.0",
|
"version": "v2.1.0",
|
||||||
@ -2562,5 +2676,5 @@
|
|||||||
"ext-zip": "*"
|
"ext-zip": "*"
|
||||||
},
|
},
|
||||||
"platform-dev": [],
|
"platform-dev": [],
|
||||||
"plugin-api-version": "2.6.0"
|
"plugin-api-version": "2.3.0"
|
||||||
}
|
}
|
||||||
|
@ -5,6 +5,7 @@ namespace kernel;
|
|||||||
|
|
||||||
|
|
||||||
use kernel\helpers\Debug;
|
use kernel\helpers\Debug;
|
||||||
|
use kernel\modules\user\models\User;
|
||||||
use kernel\services\ModuleService;
|
use kernel\services\ModuleService;
|
||||||
use Phroute\Phroute\Dispatcher;
|
use Phroute\Phroute\Dispatcher;
|
||||||
|
|
||||||
@ -17,6 +18,10 @@ class App
|
|||||||
|
|
||||||
static Header $header;
|
static Header $header;
|
||||||
|
|
||||||
|
static User $user;
|
||||||
|
|
||||||
|
static array $secure;
|
||||||
|
|
||||||
public ModuleService $moduleService;
|
public ModuleService $moduleService;
|
||||||
|
|
||||||
public static Database $db;
|
public static Database $db;
|
||||||
|
0
kernel/CgRouteCollector.php
Executable file → Normal file
0
kernel/CgRouteCollector.php
Executable file → Normal file
0
kernel/Database.php
Executable file → Normal file
0
kernel/Database.php
Executable file → Normal file
0
kernel/Header.php
Executable file → Normal file
0
kernel/Header.php
Executable file → Normal file
10
kernel/Middleware.php
Normal file
10
kernel/Middleware.php
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel;
|
||||||
|
|
||||||
|
abstract class Middleware
|
||||||
|
{
|
||||||
|
|
||||||
|
abstract function handler();
|
||||||
|
|
||||||
|
}
|
0
kernel/ResponseType.php
Executable file → Normal file
0
kernel/ResponseType.php
Executable file → Normal file
@ -101,6 +101,12 @@ class RestController
|
|||||||
$this->renderApi($model->toArray());
|
$this->renderApi($model->toArray());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[NoReturn] public function returnError(int $code): void
|
||||||
|
{
|
||||||
|
http_response_code($code);
|
||||||
|
die('Forbidden');
|
||||||
|
}
|
||||||
|
|
||||||
#[NoReturn] protected function renderApi(array $data): void
|
#[NoReturn] protected function renderApi(array $data): void
|
||||||
{
|
{
|
||||||
header("Content-Type: application/json");
|
header("Content-Type: application/json");
|
||||||
@ -108,4 +114,6 @@ class RestController
|
|||||||
exit();
|
exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
@ -18,9 +18,19 @@
|
|||||||
<link rel="stylesheet" href="<?= $resources ?>/css/style.css">
|
<link rel="stylesheet" href="<?= $resources ?>/css/style.css">
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
<div class="wrapper d-flex align-items-stretch">
|
<div class="wrapper d-flex align-items-stretch">
|
||||||
|
<?php if (\kernel\Flash::hasMessage("error")): ?>
|
||||||
|
<div class="alert alert-danger alert-dismissible mainAlert">
|
||||||
|
<?= \kernel\Flash::getMessage("error"); ?>
|
||||||
|
<button type="button" class="btn-close closeAlertBtn"></button>
|
||||||
|
</div>
|
||||||
|
<?php endif; ?>
|
||||||
|
<?php if (\kernel\Flash::hasMessage("success")): ?>
|
||||||
|
<div class="alert alert-success alert-dismissible">
|
||||||
|
<?= \kernel\Flash::getMessage("success"); ?>
|
||||||
|
<button type="button" class="btn-close closeAlertBtn" ></button>
|
||||||
|
</div>
|
||||||
|
<?php endif; ?>
|
||||||
<!-- Page Content -->
|
<!-- Page Content -->
|
||||||
<div id="content" class="p-4 p-md-5">
|
<div id="content" class="p-4 p-md-5">
|
||||||
<?= $content ?>
|
<?= $content ?>
|
||||||
|
0
kernel/console/ConsoleApp.php
Executable file → Normal file
0
kernel/console/ConsoleApp.php
Executable file → Normal file
0
kernel/console/ConsoleController.php
Executable file → Normal file
0
kernel/console/ConsoleController.php
Executable file → Normal file
0
kernel/console/Out.php
Executable file → Normal file
0
kernel/console/Out.php
Executable file → Normal file
@ -69,7 +69,7 @@ class AdminConsoleController extends ConsoleController
|
|||||||
|
|
||||||
$this->optionService->createFromParams(
|
$this->optionService->createFromParams(
|
||||||
key: "active_modules",
|
key: "active_modules",
|
||||||
value: "{\"modules\":[\"admin_themes\", \"secure\"]}",
|
value: "{\"modules\":[\"admin_themes\", \"secure\", \"user\", \"menu\"]}",
|
||||||
label: "Активные модули"
|
label: "Активные модули"
|
||||||
);
|
);
|
||||||
$this->out->r("create option active_modules", "green");
|
$this->out->r("create option active_modules", "green");
|
||||||
@ -82,6 +82,25 @@ class AdminConsoleController extends ConsoleController
|
|||||||
]);
|
]);
|
||||||
$this->out->r("create item menu module", "green");
|
$this->out->r("create item menu module", "green");
|
||||||
|
|
||||||
|
$this->menuService->createItem([
|
||||||
|
"label" => "Пользователи",
|
||||||
|
"url" => "#",
|
||||||
|
"slug" => "user",
|
||||||
|
]);
|
||||||
|
$this->menuService->createItem([
|
||||||
|
"label" => "Список",
|
||||||
|
"url" => "/admin/user",
|
||||||
|
"slug" => "user_list",
|
||||||
|
"parent_slug" => "user",
|
||||||
|
]);
|
||||||
|
$this->menuService->createItem([
|
||||||
|
"label" => "Создать",
|
||||||
|
"url" => "/admin/user/create",
|
||||||
|
"slug" => "user_create",
|
||||||
|
"parent_slug" => "user",
|
||||||
|
]);
|
||||||
|
$this->out->r("create item menu user", "green");
|
||||||
|
|
||||||
$this->menuService->createItem([
|
$this->menuService->createItem([
|
||||||
"label" => "Настройки",
|
"label" => "Настройки",
|
||||||
"url" => "#",
|
"url" => "#",
|
||||||
|
@ -4,10 +4,17 @@ namespace kernel\console\controllers;
|
|||||||
|
|
||||||
use kernel\console\ConsoleController;
|
use kernel\console\ConsoleController;
|
||||||
use kernel\helpers\Files;
|
use kernel\helpers\Files;
|
||||||
use kernel\services\KernelService;
|
use ZipArchive;
|
||||||
|
|
||||||
class KernelController extends ConsoleController
|
class KernelController extends ConsoleController
|
||||||
{
|
{
|
||||||
|
protected Files $files;
|
||||||
|
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
parent::__construct();
|
||||||
|
$this->files = new Files();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
@ -19,19 +26,86 @@ class KernelController extends ConsoleController
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (file_exists(ROOT_DIR . $this->argv['path'])) {
|
if (file_exists(ROOT_DIR . $this->argv['path'])) {
|
||||||
|
$tmpKernelDirFull = RESOURCES_DIR . '/tmp/ad/kernel/kernel';
|
||||||
$tmpKernelDirFull = RESOURCES_DIR . '/tmp/ad/kernel/';
|
$this->files->copy_folder(KERNEL_DIR, $tmpKernelDirFull);
|
||||||
|
$this->out->r("Ядро скопировано во временную папку", 'green');
|
||||||
$fileHelper = new Files();
|
|
||||||
$fileHelper->copy_folder(KERNEL_DIR, $tmpKernelDirFull);
|
|
||||||
|
|
||||||
$fileHelper->pack($tmpKernelDirFull, RESOURCES_DIR . '/tmp/kernel/kernel.itguild');
|
|
||||||
|
|
||||||
$fileHelper->recursiveRemoveDir($tmpKernelDirFull);
|
|
||||||
$this->out->r("Ядро заархивировано", 'green');
|
|
||||||
} else {
|
} else {
|
||||||
$this->out->r("Ядро не найдено", 'red');
|
$this->out->r("Ядро не найдено", 'red');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (file_exists(ROOT_DIR . '/bootstrap')) {
|
||||||
|
$tmpBootstrapDirFull = RESOURCES_DIR . '/tmp/ad/kernel/bootstrap';
|
||||||
|
$this->files->copy_folder(ROOT_DIR . '/bootstrap', $tmpBootstrapDirFull);
|
||||||
|
$this->out->r("/bootstrap скопирован во временную папку", 'green');
|
||||||
|
} else {
|
||||||
|
$this->out->r("/bootstrap не найден", 'red');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (file_exists(ROOT_DIR . '/.env.example')) {
|
||||||
|
$tmpEnvDirFull = RESOURCES_DIR . '/tmp/ad/kernel/env.example';
|
||||||
|
copy(ROOT_DIR . '/.env.example', $tmpEnvDirFull);
|
||||||
|
$this->out->r("/.env.example скопирован во временную папку", 'green');
|
||||||
|
} else {
|
||||||
|
$this->out->r("/.env.example не найден", 'red');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (file_exists(ROOT_DIR . '/composer.json')) {
|
||||||
|
$tmpComposerDirFull = RESOURCES_DIR . '/tmp/ad/kernel/composer.json';
|
||||||
|
copy(ROOT_DIR . '/composer.json', $tmpComposerDirFull);
|
||||||
|
$this->out->r("/composer.json скопирован во временную папку", 'green');
|
||||||
|
} else {
|
||||||
|
$this->out->r("/composer.json не найден", 'red');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!is_dir(RESOURCES_DIR . '/tmp/app')) {
|
||||||
|
mkdir(RESOURCES_DIR . '/tmp/app');
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->files->pack(RESOURCES_DIR . '/tmp/ad/kernel/', RESOURCES_DIR . '/tmp/kernel/kernel.igk');
|
||||||
|
$this->files->recursiveRemoveDir(RESOURCES_DIR . '/tmp/ad/kernel/');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws \Exception
|
||||||
|
*/
|
||||||
|
public function actionUpdateKernel(): void
|
||||||
|
{
|
||||||
|
if (!isset($this->argv['path'])) {
|
||||||
|
throw new \Exception('Missing kernel path "--path" specified');
|
||||||
|
}
|
||||||
|
|
||||||
|
$zip = new ZipArchive;
|
||||||
|
if (file_exists(ROOT_DIR . $this->argv['path'])) {
|
||||||
|
$tmpKernelDir = md5(time());
|
||||||
|
$res = $zip->open(ROOT_DIR . $this->argv['path']);
|
||||||
|
if ($res === TRUE) {
|
||||||
|
$tmpKernelDirFull = RESOURCES_DIR . '/tmp/kernel/' . $tmpKernelDir . "/";
|
||||||
|
$zip->extractTo($tmpKernelDirFull);
|
||||||
|
$zip->close();
|
||||||
|
$this->files->recursiveRemoveKernelDir();
|
||||||
|
$this->files->copy_folder($tmpKernelDirFull . 'kernel' , ROOT_DIR . "/kernel");
|
||||||
|
|
||||||
|
if (isset($this->argv['bootstrap'])) {
|
||||||
|
$this->files->recursiveRemoveDir(ROOT_DIR . '/bootstrap');
|
||||||
|
$this->files->copy_folder($tmpKernelDirFull . 'bootstrap' , ROOT_DIR . '/bootstrap');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($this->argv['env'])) {
|
||||||
|
copy($tmpKernelDirFull . 'env.example', ROOT_DIR . '/.env.example');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($this->argv['composer'])) {
|
||||||
|
copy($tmpKernelDirFull . 'composer.json', ROOT_DIR . '/composer.json');
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->files->recursiveRemoveDir($tmpKernelDirFull);
|
||||||
|
$this->out->r('Ядро обновлено.', 'green');
|
||||||
|
} else {
|
||||||
|
$this->out->r('unable to open zip archive', 'red');
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$this->out->r("archive not found", 'red');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
25
kernel/console/controllers/SecureController.php
Normal file
25
kernel/console/controllers/SecureController.php
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\console\controllers;
|
||||||
|
|
||||||
|
use kernel\console\ConsoleController;
|
||||||
|
use kernel\services\TokenService;
|
||||||
|
use Random\RandomException;
|
||||||
|
|
||||||
|
class SecureController extends ConsoleController
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws RandomException
|
||||||
|
*/
|
||||||
|
public function actionCreateSecretKey(): void
|
||||||
|
{
|
||||||
|
$envFile = \EnvEditor\EnvFile::loadFrom(ROOT_DIR . "/.env");
|
||||||
|
|
||||||
|
$envFile->setValue("SECRET_KEY", TokenService::random_bytes(15));
|
||||||
|
|
||||||
|
$envFile->saveTo(ROOT_DIR . "/.env");
|
||||||
|
$this->out->r("Secret key successfully created.", "green");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
0
kernel/console/migrations/stubs/blank.stub
Executable file → Normal file
0
kernel/console/migrations/stubs/blank.stub
Executable file → Normal file
0
kernel/console/migrations/stubs/create.stub
Executable file → Normal file
0
kernel/console/migrations/stubs/create.stub
Executable file → Normal file
0
kernel/console/migrations/stubs/migration.create.stub
Executable file → Normal file
0
kernel/console/migrations/stubs/migration.create.stub
Executable file → Normal file
0
kernel/console/migrations/stubs/migration.stub
Executable file → Normal file
0
kernel/console/migrations/stubs/migration.stub
Executable file → Normal file
0
kernel/console/migrations/stubs/migration.update.stub
Executable file → Normal file
0
kernel/console/migrations/stubs/migration.update.stub
Executable file → Normal file
0
kernel/console/migrations/stubs/update.stub
Executable file → Normal file
0
kernel/console/migrations/stubs/update.stub
Executable file → Normal file
@ -17,6 +17,10 @@ App::$collector->group(["prefix" => "admin-theme"], callback: function (RouteCol
|
|||||||
App::$collector->console('uninstall', [\kernel\console\controllers\AdminThemeController::class, 'actionUninstallTheme']);
|
App::$collector->console('uninstall', [\kernel\console\controllers\AdminThemeController::class, 'actionUninstallTheme']);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
App::$collector->group(["prefix" => "secure"], callback: function (RouteCollector $router){
|
||||||
|
App::$collector->console('create-secret-key', [\kernel\console\controllers\SecureController::class, 'actionCreateSecretKey']);
|
||||||
|
});
|
||||||
|
|
||||||
App::$collector->group(["prefix" => "admin"], callback: function (RouteCollector $router){
|
App::$collector->group(["prefix" => "admin"], callback: function (RouteCollector $router){
|
||||||
App::$collector->console('init', [\kernel\console\controllers\AdminConsoleController::class, 'actionInit']);
|
App::$collector->console('init', [\kernel\console\controllers\AdminConsoleController::class, 'actionInit']);
|
||||||
});
|
});
|
||||||
|
@ -41,8 +41,14 @@ class ModuleController extends AdminController
|
|||||||
foreach (new DirectoryIterator($dir) as $fileInfo) {
|
foreach (new DirectoryIterator($dir) as $fileInfo) {
|
||||||
$info = [];
|
$info = [];
|
||||||
if($fileInfo->isDot()) continue;
|
if($fileInfo->isDot()) continue;
|
||||||
|
$mi = $this->moduleService->getModuleInfo($fileInfo->getPathname());
|
||||||
|
if (isset($mi['show_in_admin'])){
|
||||||
|
if ($mi['show_in_admin'] == 0){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
$info['id'] = $i;
|
$info['id'] = $i;
|
||||||
$modules_info[] = array_merge($info, $this->moduleService->getModuleInfo($fileInfo->getPathname()));
|
$modules_info[] = array_merge($info, $mi);
|
||||||
$i++;
|
$i++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -43,6 +43,21 @@ class Files
|
|||||||
rmdir($dir);
|
rmdir($dir);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function recursiveRemoveKernelDir(): void
|
||||||
|
{
|
||||||
|
$includes = new FilesystemIterator(KERNEL_DIR);
|
||||||
|
foreach ($includes as $include) {
|
||||||
|
if ($include->getFilename() === 'app_modules') continue;
|
||||||
|
|
||||||
|
if(is_dir($include) && !is_link($include)) {
|
||||||
|
$this->recursiveRemoveDir($include);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
unlink($include);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public function pack(string $source, string $destination/*, bool $include_source = true*/): void
|
public function pack(string $source, string $destination/*, bool $include_source = true*/): void
|
||||||
{
|
{
|
||||||
$zip = new ZipArchive();
|
$zip = new ZipArchive();
|
||||||
|
19
kernel/middlewares/AuthMiddleware.php
Normal file
19
kernel/middlewares/AuthMiddleware.php
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\middlewares;
|
||||||
|
|
||||||
|
use kernel\Middleware;
|
||||||
|
|
||||||
|
class AuthMiddleware extends Middleware
|
||||||
|
{
|
||||||
|
|
||||||
|
function handler()
|
||||||
|
{
|
||||||
|
if(!isset($_COOKIE['user_id']))
|
||||||
|
{
|
||||||
|
header('Location: /admin/login', true, 302);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -5,8 +5,9 @@ use kernel\modules\admin_themes\controllers\AdminThemeController;
|
|||||||
use Phroute\Phroute\RouteCollector;
|
use Phroute\Phroute\RouteCollector;
|
||||||
|
|
||||||
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
||||||
App::$collector->group(["prefix" => "settings"], function (RouteCollector $router){
|
App::$collector->group(["before" => "auth"], function (RouteCollector $router) {
|
||||||
App::$collector->group(["prefix" => "admin-themes"], function (RouteCollector $router){
|
App::$collector->group(["prefix" => "settings"], function (RouteCollector $router) {
|
||||||
|
App::$collector->group(["prefix" => "admin-themes"], function (RouteCollector $router) {
|
||||||
App::$collector->get('/', [AdminThemeController::class, 'actionIndex']);
|
App::$collector->get('/', [AdminThemeController::class, 'actionIndex']);
|
||||||
App::$collector->get('/activate', [AdminThemeController::class, 'actionActivate']);
|
App::$collector->get('/activate', [AdminThemeController::class, 'actionActivate']);
|
||||||
// App::$collector->get('/create', [\kernel\modules\menu\controllers\MenuController::class, 'actionCreate']);
|
// App::$collector->get('/create', [\kernel\modules\menu\controllers\MenuController::class, 'actionCreate']);
|
||||||
@ -17,4 +18,5 @@ App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
|||||||
// App::$collector->get('/delete/{id}', [\kernel\modules\menu\controllers\MenuController::class, 'actionDelete']);
|
// App::$collector->get('/delete/{id}', [\kernel\modules\menu\controllers\MenuController::class, 'actionDelete']);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
});
|
||||||
});
|
});
|
@ -4,7 +4,10 @@ use kernel\App;
|
|||||||
use kernel\CgRouteCollector;
|
use kernel\CgRouteCollector;
|
||||||
use Phroute\Phroute\RouteCollector;
|
use Phroute\Phroute\RouteCollector;
|
||||||
|
|
||||||
|
App::$collector->filter("auth", [\kernel\middlewares\AuthMiddleware::class, "handler"]);
|
||||||
|
|
||||||
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router) {
|
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router) {
|
||||||
|
App::$collector->group(["before" => "auth"], function (RouteCollector $router){
|
||||||
App::$collector->group(["prefix" => "settings"], function (RouteCollector $router){
|
App::$collector->group(["prefix" => "settings"], function (RouteCollector $router){
|
||||||
App::$collector->group(["prefix" => "menu"], function (RouteCollector $router){
|
App::$collector->group(["prefix" => "menu"], function (RouteCollector $router){
|
||||||
App::$collector->get('/', [\kernel\modules\menu\controllers\MenuController::class, 'actionIndex']);
|
App::$collector->get('/', [\kernel\modules\menu\controllers\MenuController::class, 'actionIndex']);
|
||||||
@ -17,6 +20,8 @@ App::$collector->group(["prefix" => "admin"], function (RouteCollector $router)
|
|||||||
App::$collector->get('/delete/{id}', [\kernel\modules\menu\controllers\MenuController::class, 'actionDelete']);
|
App::$collector->get('/delete/{id}', [\kernel\modules\menu\controllers\MenuController::class, 'actionDelete']);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
App::$collector->group(["prefix" => "api"], function (CgRouteCollector $router){
|
App::$collector->group(["prefix" => "api"], function (CgRouteCollector $router){
|
||||||
|
17
kernel/modules/menu/table/columns/MenuDeleteActionColumn.php
Normal file
17
kernel/modules/menu/table/columns/MenuDeleteActionColumn.php
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\menu\table\columns;
|
||||||
|
|
||||||
|
use Itguild\Tables\ActionColumn\ActionColumn;
|
||||||
|
|
||||||
|
class MenuDeleteActionColumn extends ActionColumn
|
||||||
|
{
|
||||||
|
|
||||||
|
protected string $prefix = "/delete/";
|
||||||
|
|
||||||
|
public function fetch(): string
|
||||||
|
{
|
||||||
|
$link = $this->baseUrl . $this->prefix . $this->id;
|
||||||
|
return " <a href='$link' class='btn btn-danger'>Удалить</a> ";
|
||||||
|
}
|
||||||
|
}
|
17
kernel/modules/menu/table/columns/MenuEditActionColumn.php
Normal file
17
kernel/modules/menu/table/columns/MenuEditActionColumn.php
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\menu\table\columns;
|
||||||
|
|
||||||
|
use Itguild\Tables\ActionColumn\ActionColumn;
|
||||||
|
|
||||||
|
class MenuEditActionColumn extends ActionColumn
|
||||||
|
{
|
||||||
|
|
||||||
|
protected string $prefix = "/update/";
|
||||||
|
|
||||||
|
public function fetch(): string
|
||||||
|
{
|
||||||
|
$link = $this->baseUrl . $this->prefix . $this->id;
|
||||||
|
return " <a href='$link' class='btn btn-success'>Редактировать</a> ";
|
||||||
|
}
|
||||||
|
}
|
17
kernel/modules/menu/table/columns/MenuViewActionColumn.php
Normal file
17
kernel/modules/menu/table/columns/MenuViewActionColumn.php
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\menu\table\columns;
|
||||||
|
|
||||||
|
use Itguild\Tables\ActionColumn\ActionColumn;
|
||||||
|
|
||||||
|
class MenuViewActionColumn extends ActionColumn
|
||||||
|
{
|
||||||
|
|
||||||
|
protected string $prefix = "/";
|
||||||
|
|
||||||
|
public function fetch(): string
|
||||||
|
{
|
||||||
|
$link = $this->baseUrl . $this->prefix . $this->id;
|
||||||
|
return " <a href='$link' class='btn btn-primary'>Просмотр</a> ";
|
||||||
|
}
|
||||||
|
}
|
@ -4,6 +4,7 @@ namespace kernel\modules\option\controllers;
|
|||||||
|
|
||||||
use JetBrains\PhpStorm\NoReturn;
|
use JetBrains\PhpStorm\NoReturn;
|
||||||
use kernel\AdminController;
|
use kernel\AdminController;
|
||||||
|
use kernel\Flash;
|
||||||
use kernel\helpers\Debug;
|
use kernel\helpers\Debug;
|
||||||
use kernel\modules\option\models\forms\CreateOptionForm;
|
use kernel\modules\option\models\forms\CreateOptionForm;
|
||||||
use kernel\modules\option\models\Option;
|
use kernel\modules\option\models\Option;
|
||||||
@ -33,9 +34,11 @@ class OptionController extends AdminController
|
|||||||
if ($optionForm->validate()) {
|
if ($optionForm->validate()) {
|
||||||
$option = $this->optionService->create($optionForm);
|
$option = $this->optionService->create($optionForm);
|
||||||
if ($option) {
|
if ($option) {
|
||||||
|
Flash::setMessage("success", "Опция успешно создана.");
|
||||||
$this->redirect('/admin/option');
|
$this->redirect('/admin/option');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Flash::setMessage("error", $optionForm->getErrorsStr());
|
||||||
$this->redirect('/admin/option/create');
|
$this->redirect('/admin/option/create');
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -95,6 +98,7 @@ class OptionController extends AdminController
|
|||||||
#[NoReturn] public function actionDelete(int $id): void
|
#[NoReturn] public function actionDelete(int $id): void
|
||||||
{
|
{
|
||||||
Option::find($id)->delete();
|
Option::find($id)->delete();
|
||||||
|
Flash::setMessage("success", "Опция успешно удалена.");
|
||||||
$this->redirect('/admin/option');
|
$this->redirect('/admin/option');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ class CreateOptionForm extends FormModel
|
|||||||
public function rules(): array
|
public function rules(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
'key' => 'required|min-str-len:1|max-str-len:50',
|
'key' => 'required|min-str-len:3|max-str-len:50',
|
||||||
'value' => '',
|
'value' => '',
|
||||||
'label' => '',
|
'label' => '',
|
||||||
'status' => ''
|
'status' => ''
|
||||||
|
@ -4,6 +4,7 @@ use kernel\App;
|
|||||||
use Phroute\Phroute\RouteCollector;
|
use Phroute\Phroute\RouteCollector;
|
||||||
|
|
||||||
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router) {
|
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router) {
|
||||||
|
App::$collector->group(["before" => "auth"], function (RouteCollector $router) {
|
||||||
App::$collector->group(["prefix" => "option"], callback: function (RouteCollector $router) {
|
App::$collector->group(["prefix" => "option"], callback: function (RouteCollector $router) {
|
||||||
App::$collector->get('/', [\kernel\modules\option\controllers\OptionController::class, 'actionIndex']);
|
App::$collector->get('/', [\kernel\modules\option\controllers\OptionController::class, 'actionIndex']);
|
||||||
App::$collector->get('/page/{page_number}', [\kernel\modules\option\controllers\OptionController::class, 'actionIndex']);
|
App::$collector->get('/page/{page_number}', [\kernel\modules\option\controllers\OptionController::class, 'actionIndex']);
|
||||||
@ -14,4 +15,5 @@ App::$collector->group(["prefix" => "admin"], function (RouteCollector $router)
|
|||||||
App::$collector->any("/edit/{id}", [\kernel\modules\option\controllers\OptionController::class, 'actionEdit']);
|
App::$collector->any("/edit/{id}", [\kernel\modules\option\controllers\OptionController::class, 'actionEdit']);
|
||||||
App::$collector->get('/delete/{id}', [\kernel\modules\option\controllers\OptionController::class, 'actionDelete']);
|
App::$collector->get('/delete/{id}', [\kernel\modules\option\controllers\OptionController::class, 'actionDelete']);
|
||||||
});
|
});
|
||||||
|
});
|
||||||
});
|
});
|
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\option\table\columns;
|
||||||
|
|
||||||
|
use Itguild\Tables\ActionColumn\ActionColumn;
|
||||||
|
|
||||||
|
class OptionDeleteActionColumn extends ActionColumn
|
||||||
|
{
|
||||||
|
protected string $prefix = "/delete/";
|
||||||
|
|
||||||
|
public function fetch(): string
|
||||||
|
{
|
||||||
|
$link = $this->baseUrl . $this->prefix . $this->id;
|
||||||
|
return " <a href='$link' class='btn btn-danger'>Удалить</a> ";
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\option\table\columns;
|
||||||
|
|
||||||
|
use Itguild\Tables\ActionColumn\ActionColumn;
|
||||||
|
|
||||||
|
class OptionEditActionColumn extends ActionColumn
|
||||||
|
{
|
||||||
|
protected string $prefix = "/update/";
|
||||||
|
|
||||||
|
public function fetch(): string
|
||||||
|
{
|
||||||
|
$link = $this->baseUrl . $this->prefix . $this->id;
|
||||||
|
return " <a href='$link' class='btn btn-success'>Редактировать</a> ";
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,18 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\option\table\columns;
|
||||||
|
|
||||||
|
use Itguild\Tables\ActionColumn\ActionColumn;
|
||||||
|
|
||||||
|
class OptionViewActionColumn extends ActionColumn
|
||||||
|
{
|
||||||
|
|
||||||
|
protected string $prefix = "/";
|
||||||
|
|
||||||
|
public function fetch()
|
||||||
|
{
|
||||||
|
$link = $this->baseUrl . $this->prefix . $this->id;
|
||||||
|
return " <a href='$link' class='btn btn-primary'>Просмотр</a> ";
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -4,7 +4,10 @@ namespace kernel\modules\post\controllers;
|
|||||||
|
|
||||||
use Illuminate\Database\Eloquent\Model;
|
use Illuminate\Database\Eloquent\Model;
|
||||||
use JetBrains\PhpStorm\NoReturn;
|
use JetBrains\PhpStorm\NoReturn;
|
||||||
|
use kernel\App;
|
||||||
|
use kernel\helpers\Debug;
|
||||||
use kernel\modules\post\models\Post;
|
use kernel\modules\post\models\Post;
|
||||||
|
use kernel\Request;
|
||||||
use kernel\RestController;
|
use kernel\RestController;
|
||||||
|
|
||||||
class PostRestController extends RestController
|
class PostRestController extends RestController
|
||||||
@ -19,4 +22,31 @@ class PostRestController extends RestController
|
|||||||
return ["user"];
|
return ["user"];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function actionIndex(): void
|
||||||
|
{
|
||||||
|
$request = new Request();
|
||||||
|
$page = $request->get('page') ?? 1;
|
||||||
|
$perPage = $request->get('per_page') ?? 10;
|
||||||
|
$query = $this->model->query();
|
||||||
|
if (App::$user){
|
||||||
|
$query->where("user_id", App::$user->id);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($page > 1) {
|
||||||
|
$query->skip(($page - 1) * $perPage)->take($perPage);
|
||||||
|
} else {
|
||||||
|
$query->take($perPage);
|
||||||
|
}
|
||||||
|
|
||||||
|
$expand = $this->expand();
|
||||||
|
$expandParams = explode( ",", $request->get('expand') ?? "");
|
||||||
|
$finalExpand = array_intersect($expandParams, $expand);
|
||||||
|
if ($finalExpand) {
|
||||||
|
$res = $query->get()->load($finalExpand)->toArray();
|
||||||
|
} else {
|
||||||
|
$res = $query->get()->toArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->renderApi($res);
|
||||||
|
}
|
||||||
}
|
}
|
@ -4,9 +4,11 @@ use kernel\App;
|
|||||||
use kernel\CgRouteCollector;
|
use kernel\CgRouteCollector;
|
||||||
use Phroute\Phroute\RouteCollector;
|
use Phroute\Phroute\RouteCollector;
|
||||||
|
|
||||||
|
App::$collector->filter('bearer', [\kernel\modules\secure\middlewares\BearerAuthMiddleware::class, "handler"]);
|
||||||
|
|
||||||
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
||||||
App::$collector->group(["prefix" => "post"], function (RouteCollector $router){
|
App::$collector->group(["before" => "auth"], function (RouteCollector $router) {
|
||||||
|
App::$collector->group(["prefix" => "post"], function (RouteCollector $router) {
|
||||||
App::$collector->get('/', [\kernel\modules\post\controllers\PostController::class, 'actionIndex']);
|
App::$collector->get('/', [\kernel\modules\post\controllers\PostController::class, 'actionIndex']);
|
||||||
App::$collector->get('/page/{page_number}', [\kernel\modules\post\controllers\PostController::class, 'actionIndex']);
|
App::$collector->get('/page/{page_number}', [\kernel\modules\post\controllers\PostController::class, 'actionIndex']);
|
||||||
App::$collector->get('/create', [\kernel\modules\post\controllers\PostController::class, 'actionCreate']);
|
App::$collector->get('/create', [\kernel\modules\post\controllers\PostController::class, 'actionCreate']);
|
||||||
@ -16,8 +18,11 @@ App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
|||||||
App::$collector->any("/edit/{id}", [\kernel\modules\post\controllers\PostController::class, 'actionEdit']);
|
App::$collector->any("/edit/{id}", [\kernel\modules\post\controllers\PostController::class, 'actionEdit']);
|
||||||
App::$collector->get('/delete/{id}', [\kernel\modules\post\controllers\PostController::class, 'actionDelete']);
|
App::$collector->get('/delete/{id}', [\kernel\modules\post\controllers\PostController::class, 'actionDelete']);
|
||||||
});
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
App::$collector->group(["prefix" => "api"], function (CgRouteCollector $router){
|
App::$collector->group(["prefix" => "api"], function (CgRouteCollector $router){
|
||||||
|
App::$collector->group(['before' => 'bearer'], function (CgRouteCollector $router){
|
||||||
$router->rest("post", [\kernel\modules\post\controllers\PostRestController::class]);
|
$router->rest("post", [\kernel\modules\post\controllers\PostRestController::class]);
|
||||||
|
});
|
||||||
});
|
});
|
16
kernel/modules/post/table/columns/PostDeleteActionColumn.php
Normal file
16
kernel/modules/post/table/columns/PostDeleteActionColumn.php
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\post\table\columns;
|
||||||
|
|
||||||
|
use Itguild\Tables\ActionColumn\ActionColumn;
|
||||||
|
|
||||||
|
class PostDeleteActionColumn extends ActionColumn
|
||||||
|
{
|
||||||
|
protected string $prefix = "/delete/";
|
||||||
|
|
||||||
|
public function fetch(): string
|
||||||
|
{
|
||||||
|
$link = $this->baseUrl . $this->prefix . $this->id;
|
||||||
|
return " <a href='$link' class='btn btn-danger'>Удалить</a> ";
|
||||||
|
}
|
||||||
|
}
|
16
kernel/modules/post/table/columns/PostEditActionColumn.php
Normal file
16
kernel/modules/post/table/columns/PostEditActionColumn.php
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\post\table\columns;
|
||||||
|
|
||||||
|
use Itguild\Tables\ActionColumn\ActionColumn;
|
||||||
|
|
||||||
|
class PostEditActionColumn extends ActionColumn
|
||||||
|
{
|
||||||
|
protected string $prefix = "/update/";
|
||||||
|
|
||||||
|
public function fetch(): string
|
||||||
|
{
|
||||||
|
$link = $this->baseUrl . $this->prefix . $this->id;
|
||||||
|
return " <a href='$link' class='btn btn-success'>Редактировать</a> ";
|
||||||
|
}
|
||||||
|
}
|
16
kernel/modules/post/table/columns/PostViewActionColumn.php
Normal file
16
kernel/modules/post/table/columns/PostViewActionColumn.php
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\post\table\columns;
|
||||||
|
|
||||||
|
use Itguild\Tables\ActionColumn\ActionColumn;
|
||||||
|
|
||||||
|
class PostViewActionColumn extends actionColumn
|
||||||
|
{
|
||||||
|
protected string $prefix = "/";
|
||||||
|
|
||||||
|
public function fetch(): string
|
||||||
|
{
|
||||||
|
$link = $this->baseUrl . $this->prefix . $this->id;
|
||||||
|
return " <a href='$link' class='btn btn-primary'>Просмотр</a> ";
|
||||||
|
}
|
||||||
|
}
|
@ -4,6 +4,8 @@ namespace kernel\modules\secure\controllers;
|
|||||||
|
|
||||||
use JetBrains\PhpStorm\NoReturn;
|
use JetBrains\PhpStorm\NoReturn;
|
||||||
use kernel\AdminController;
|
use kernel\AdminController;
|
||||||
|
use kernel\Flash;
|
||||||
|
use kernel\helpers\Debug;
|
||||||
use kernel\modules\secure\models\forms\LoginForm;
|
use kernel\modules\secure\models\forms\LoginForm;
|
||||||
use kernel\modules\user\service\UserService;
|
use kernel\modules\user\service\UserService;
|
||||||
|
|
||||||
@ -25,7 +27,7 @@ class SecureController extends AdminController
|
|||||||
$this->cgView->render('login.php');
|
$this->cgView->render('login.php');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function actionAuth(): void
|
#[NoReturn] public function actionAuth(): void
|
||||||
{
|
{
|
||||||
$loginForm = new LoginForm();
|
$loginForm = new LoginForm();
|
||||||
$loginForm->load($_REQUEST);
|
$loginForm->load($_REQUEST);
|
||||||
@ -39,21 +41,23 @@ class SecureController extends AdminController
|
|||||||
|
|
||||||
$user = $this->userService->getByField($field, $loginForm->getItem("username"));
|
$user = $this->userService->getByField($field, $loginForm->getItem("username"));
|
||||||
if (!$user){
|
if (!$user){
|
||||||
throw new \Exception(message: "User not found");
|
Flash::setMessage("error", "User not found.");
|
||||||
|
$this->redirect("/admin/login", code: 302);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (password_verify($loginForm->getItem("password"), $user->password_hash)) {
|
if (password_verify($loginForm->getItem("password"), $user->password_hash)) {
|
||||||
setcookie('user_id', $user->id, time()+60*60*24, '/', $_SERVER['SERVER_NAME'], false);
|
setcookie('user_id', $user->id, time()+60*60*24, '/', $_SERVER['SERVER_NAME'], false);
|
||||||
$this->redirect("/admin");
|
$this->redirect("/admin", code: 302);
|
||||||
} else {
|
} else {
|
||||||
$this->redirect("/admin/login");
|
Flash::setMessage("error", "Username or password incorrect.");
|
||||||
|
$this->redirect("/admin/login", code: 302);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[NoReturn] public function actionLogout(): void
|
#[NoReturn] public function actionLogout(): void
|
||||||
{
|
{
|
||||||
unset($_COOKIE['user_id']);
|
unset($_COOKIE['user_id']);
|
||||||
setcookie('user_id', "", -1, '/', $_SERVER['SERVER_NAME'], false);
|
setcookie('user_id', "", -1, '/', ".".$_SERVER['SERVER_NAME'], false);
|
||||||
$this->redirect("/", code: 302);
|
$this->redirect("/", code: 302);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
54
kernel/modules/secure/controllers/SecureRestController.php
Normal file
54
kernel/modules/secure/controllers/SecureRestController.php
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\secure\controllers;
|
||||||
|
|
||||||
|
use Firebase\JWT\JWT;
|
||||||
|
use Firebase\JWT\Key;
|
||||||
|
use JetBrains\PhpStorm\NoReturn;
|
||||||
|
use kernel\App;
|
||||||
|
use kernel\helpers\Debug;
|
||||||
|
use kernel\modules\user\models\User;
|
||||||
|
use kernel\Request;
|
||||||
|
use kernel\RestController;
|
||||||
|
use kernel\services\TokenService;
|
||||||
|
use Random\RandomException;
|
||||||
|
|
||||||
|
class SecureRestController extends RestController
|
||||||
|
{
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
$this->model = new User();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws RandomException
|
||||||
|
*/
|
||||||
|
#[NoReturn] public function actionAuth(): void
|
||||||
|
{
|
||||||
|
$request = new Request();
|
||||||
|
$data = $request->post();
|
||||||
|
$model = $this->model->where('username', $data['username'])->first();
|
||||||
|
$res = [];
|
||||||
|
if ($model) {
|
||||||
|
if (password_verify($data["password"], $model->password_hash)) {
|
||||||
|
$model->access_token_expires_at = date("Y-m-d H:i:s", strtotime(App::$secure['token_expired_time']));
|
||||||
|
$model->access_token = match (App::$secure['token_type']) {
|
||||||
|
"JWT" => TokenService::JWT($_ENV['SECRET_KEY'], 'HS256'),
|
||||||
|
"md5" => TokenService::md5(),
|
||||||
|
"crypt" => TokenService::crypt(),
|
||||||
|
"hash" => TokenService::hash('sha256'),
|
||||||
|
default => TokenService::random_bytes(20),
|
||||||
|
};
|
||||||
|
|
||||||
|
$res = [
|
||||||
|
"access_token" => $model->access_token,
|
||||||
|
"access_token_expires_at" => $model->access_token_expires_at,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
$model->save();
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->renderApi($res);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -4,5 +4,7 @@
|
|||||||
"author": "ITGuild",
|
"author": "ITGuild",
|
||||||
"slug": "secure",
|
"slug": "secure",
|
||||||
"description": "Secure module",
|
"description": "Secure module",
|
||||||
"routs": "routs/secure.php"
|
"routs": "routs/secure.php",
|
||||||
|
"dependence": "user",
|
||||||
|
"show_in_admin": 0
|
||||||
}
|
}
|
48
kernel/modules/secure/middlewares/BearerAuthMiddleware.php
Normal file
48
kernel/modules/secure/middlewares/BearerAuthMiddleware.php
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\secure\middlewares;
|
||||||
|
|
||||||
|
use JetBrains\PhpStorm\NoReturn;
|
||||||
|
use kernel\App;
|
||||||
|
use kernel\helpers\Debug;
|
||||||
|
use kernel\Middleware;
|
||||||
|
use kernel\modules\user\service\UserService;
|
||||||
|
use kernel\Request;
|
||||||
|
|
||||||
|
class BearerAuthMiddleware extends Middleware
|
||||||
|
{
|
||||||
|
protected UserService $userService;
|
||||||
|
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
$this->userService = new UserService();
|
||||||
|
}
|
||||||
|
|
||||||
|
function handler(): void
|
||||||
|
{
|
||||||
|
$request = new Request();
|
||||||
|
$authorization = $request->getHeader("Authorization");
|
||||||
|
if ($authorization){
|
||||||
|
$authorization = explode(" ", $authorization);
|
||||||
|
$type = $authorization[0];
|
||||||
|
$token = $authorization[1];
|
||||||
|
if ($type === "Bearer"){
|
||||||
|
$user = $this->userService->getByAccessToken($token);
|
||||||
|
if ($user){
|
||||||
|
if ($user->access_token_expires_at > date("Y-m-d")){
|
||||||
|
App::$user = $user;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->returnError(403);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[NoReturn] public function returnError(int $code): void
|
||||||
|
{
|
||||||
|
http_response_code($code);
|
||||||
|
die('Forbidden');
|
||||||
|
}
|
||||||
|
}
|
@ -1,16 +1,11 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
use kernel\App;
|
use kernel\App;
|
||||||
|
use kernel\CgRouteCollector;
|
||||||
use Phroute\Phroute\RouteCollector;
|
use Phroute\Phroute\RouteCollector;
|
||||||
|
|
||||||
App::$collector->filter("auth", function (){
|
App::$collector->filter("auth", [\kernel\middlewares\AuthMiddleware::class, "handler"]);
|
||||||
if(!isset($_COOKIE['user_id']))
|
App::$collector->filter('bearer', [\kernel\modules\secure\middlewares\BearerAuthMiddleware::class, "handler"]);
|
||||||
{
|
|
||||||
header('Location: /admin/login', true, 302);
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
||||||
App::$collector->group(["before" => "auth"], function (RouteCollector $router){
|
App::$collector->group(["before" => "auth"], function (RouteCollector $router){
|
||||||
@ -20,3 +15,10 @@ App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
|||||||
App::$collector->get('/logout', [\kernel\modules\secure\controllers\SecureController::class, 'actionLogout']);
|
App::$collector->get('/logout', [\kernel\modules\secure\controllers\SecureController::class, 'actionLogout']);
|
||||||
App::$collector->post('/auth', [\kernel\modules\secure\controllers\SecureController::class, 'actionAuth']);
|
App::$collector->post('/auth', [\kernel\modules\secure\controllers\SecureController::class, 'actionAuth']);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
App::$collector->group(["prefix" => "api"], function (CgRouteCollector $router){
|
||||||
|
App::$collector->group(["prefix" => "secure"], function (CgRouteCollector $router) {
|
||||||
|
App::$collector->post('/auth', [\kernel\modules\secure\controllers\SecureRestController::class, 'actionAuth']);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
@ -7,5 +7,5 @@
|
|||||||
"module_class": "kernel\\modules\\user\\UserModule",
|
"module_class": "kernel\\modules\\user\\UserModule",
|
||||||
"module_class_file": "{KERNEL_MODULES}/user/UserModule.php",
|
"module_class_file": "{KERNEL_MODULES}/user/UserModule.php",
|
||||||
"routs": "routs/user.php",
|
"routs": "routs/user.php",
|
||||||
"dependence": "menu"
|
"dependence": "menu,secure"
|
||||||
}
|
}
|
@ -19,6 +19,8 @@ return new class extends Migration
|
|||||||
$table->string('email', 255);
|
$table->string('email', 255);
|
||||||
$table->string('password_hash', 255);
|
$table->string('password_hash', 255);
|
||||||
$table->integer('role')->default(1);
|
$table->integer('role')->default(1);
|
||||||
|
$table->string('access_token', 255)->nullable(true);
|
||||||
|
$table->dateTime('access_token_expires_at')->nullable(true);
|
||||||
$table->timestamps();
|
$table->timestamps();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -7,6 +7,8 @@ use Illuminate\Database\Eloquent\Model;
|
|||||||
* @property string $username
|
* @property string $username
|
||||||
* @property string $email
|
* @property string $email
|
||||||
* @property string $password_hash
|
* @property string $password_hash
|
||||||
|
* @property string $access_token
|
||||||
|
* @property string $access_token_expires_at
|
||||||
* @method static find($id)
|
* @method static find($id)
|
||||||
*/
|
*/
|
||||||
class User extends Model {
|
class User extends Model {
|
||||||
@ -15,7 +17,7 @@ class User extends Model {
|
|||||||
const ADMIN_USER_ROLE = 9;
|
const ADMIN_USER_ROLE = 9;
|
||||||
|
|
||||||
protected $table = 'user';
|
protected $table = 'user';
|
||||||
protected $fillable = ['username', 'email', 'password_hash', 'role'];
|
protected $fillable = ['username', 'email', 'password_hash', 'role', 'access_token', 'access_token_expires_at'];
|
||||||
protected array $dates = ['deleted at'];
|
protected array $dates = ['deleted at'];
|
||||||
|
|
||||||
public static function labels(): array
|
public static function labels(): array
|
||||||
@ -24,7 +26,7 @@ class User extends Model {
|
|||||||
'username' => 'Логин',
|
'username' => 'Логин',
|
||||||
'email' => 'Email',
|
'email' => 'Email',
|
||||||
'created_at' => 'Создан',
|
'created_at' => 'Создан',
|
||||||
'updated_at' => 'Обновлен'
|
'updated_at' => 'Обновлен',
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7,7 +7,8 @@ use Phroute\Phroute\RouteCollector;
|
|||||||
|
|
||||||
|
|
||||||
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
||||||
App::$collector->group(["prefix" => "user"], callback: function (RouteCollector $router){
|
App::$collector->group(["before" => "auth"], function (RouteCollector $router) {
|
||||||
|
App::$collector->group(["prefix" => "user"], callback: function (RouteCollector $router) {
|
||||||
App::$collector->get('/', [\kernel\modules\user\controllers\UserController::class, 'actionIndex']);
|
App::$collector->get('/', [\kernel\modules\user\controllers\UserController::class, 'actionIndex']);
|
||||||
App::$collector->get('/page/{page_number}', [\kernel\modules\user\controllers\UserController::class, 'actionIndex']);
|
App::$collector->get('/page/{page_number}', [\kernel\modules\user\controllers\UserController::class, 'actionIndex']);
|
||||||
App::$collector->get('/create', [\kernel\modules\user\controllers\UserController::class, 'actionCreate']);
|
App::$collector->get('/create', [\kernel\modules\user\controllers\UserController::class, 'actionCreate']);
|
||||||
@ -17,4 +18,5 @@ App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
|||||||
App::$collector->any("/edit/{id}", [\kernel\modules\user\controllers\UserController::class, 'actionEdit']);
|
App::$collector->any("/edit/{id}", [\kernel\modules\user\controllers\UserController::class, 'actionEdit']);
|
||||||
App::$collector->get('/delete/{id}', [\kernel\modules\user\controllers\UserController::class, 'actionDelete']);
|
App::$collector->get('/delete/{id}', [\kernel\modules\user\controllers\UserController::class, 'actionDelete']);
|
||||||
});
|
});
|
||||||
|
});
|
||||||
});
|
});
|
@ -33,6 +33,11 @@ class UserService
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $field
|
||||||
|
* @param string $value
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
public function getByField(string $field, string $value)
|
public function getByField(string $field, string $value)
|
||||||
{
|
{
|
||||||
return User::where($field, $value)->first();
|
return User::where($field, $value)->first();
|
||||||
@ -72,4 +77,9 @@ class UserService
|
|||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getByAccessToken(string $token)
|
||||||
|
{
|
||||||
|
return $this->getByField("access_token", $token);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
16
kernel/modules/user/table/columns/UserDeleteActionColumn.php
Normal file
16
kernel/modules/user/table/columns/UserDeleteActionColumn.php
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\user\table\columns;
|
||||||
|
|
||||||
|
use Itguild\Tables\ActionColumn\ActionColumn;
|
||||||
|
|
||||||
|
class UserDeleteActionColumn extends ActionColumn
|
||||||
|
{
|
||||||
|
protected string $prefix = "/delete/";
|
||||||
|
|
||||||
|
public function fetch(): string
|
||||||
|
{
|
||||||
|
$link = $this->baseUrl . $this->prefix . $this->id;
|
||||||
|
return " <a href='$link' class='btn btn-danger'>Удалить</a> ";
|
||||||
|
}
|
||||||
|
}
|
16
kernel/modules/user/table/columns/UserEditActionColumn.php
Normal file
16
kernel/modules/user/table/columns/UserEditActionColumn.php
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\user\table\columns;
|
||||||
|
|
||||||
|
use Itguild\Tables\ActionColumn\ActionColumn;
|
||||||
|
|
||||||
|
class UserEditActionColumn extends ActionColumn
|
||||||
|
{
|
||||||
|
protected string $prefix = "/update/";
|
||||||
|
|
||||||
|
public function fetch(): string
|
||||||
|
{
|
||||||
|
$link = $this->baseUrl . $this->prefix . $this->id;
|
||||||
|
return " <a href='$link' class='btn btn-success'>Редактировать</a> ";
|
||||||
|
}
|
||||||
|
}
|
16
kernel/modules/user/table/columns/UserViewActionColumn.php
Normal file
16
kernel/modules/user/table/columns/UserViewActionColumn.php
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\modules\user\table\columns;
|
||||||
|
|
||||||
|
use Itguild\Tables\ActionColumn\ActionColumn;
|
||||||
|
|
||||||
|
class UserViewActionColumn extends ActionColumn
|
||||||
|
{
|
||||||
|
protected string $prefix = "/";
|
||||||
|
|
||||||
|
public function fetch(): string
|
||||||
|
{
|
||||||
|
$link = $this->baseUrl . $this->prefix . $this->id;
|
||||||
|
return " <a href='$link' class='btn btn-primary'>Просмотр</a> ";
|
||||||
|
}
|
||||||
|
}
|
@ -3,6 +3,7 @@
|
|||||||
use kernel\App;
|
use kernel\App;
|
||||||
use Phroute\Phroute\RouteCollector;
|
use Phroute\Phroute\RouteCollector;
|
||||||
|
|
||||||
|
App::$collector->filter("auth", [\kernel\middlewares\AuthMiddleware::class, "handler"]);
|
||||||
|
|
||||||
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
||||||
App::$collector->group(["before" => "auth"], function (RouteCollector $router){
|
App::$collector->group(["before" => "auth"], function (RouteCollector $router){
|
||||||
|
62
kernel/services/TokenService.php
Normal file
62
kernel/services/TokenService.php
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\services;
|
||||||
|
|
||||||
|
use Firebase\JWT\JWT;
|
||||||
|
use kernel\helpers\Debug;
|
||||||
|
use Random\RandomException;
|
||||||
|
|
||||||
|
class TokenService
|
||||||
|
{
|
||||||
|
|
||||||
|
public static function JWT(string|\OpenSSLCertificate|\OpenSSLAsymmetricKey $key, string $alg, array $payload = []): string
|
||||||
|
{
|
||||||
|
return JWT::encode(
|
||||||
|
payload: $payload,
|
||||||
|
key: $key,
|
||||||
|
alg: $alg
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws RandomException
|
||||||
|
*/
|
||||||
|
public static function random_bytes(int $ln): string
|
||||||
|
{
|
||||||
|
return bin2hex(random_bytes($ln));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws RandomException
|
||||||
|
*/
|
||||||
|
public static function md5(): string
|
||||||
|
{
|
||||||
|
return md5(microtime() . self::getSalt() . time());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws RandomException
|
||||||
|
*/
|
||||||
|
public static function crypt(): string
|
||||||
|
{
|
||||||
|
return crypt(microtime(), self::getSalt());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws RandomException
|
||||||
|
*/
|
||||||
|
public static function hash(string $alg): string
|
||||||
|
{
|
||||||
|
return hash($alg, self::getSalt());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws RandomException
|
||||||
|
*/
|
||||||
|
public static function getSalt(): string
|
||||||
|
{
|
||||||
|
return bin2hex(random_bytes(10));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user