button fix, kernel update
This commit is contained in:
parent
4ff9fa9ad3
commit
e75d21bd1b
@ -24,8 +24,8 @@ $table->columns([
|
|||||||
}
|
}
|
||||||
]);
|
]);
|
||||||
$table->beforePrint(function () {
|
$table->beforePrint(function () {
|
||||||
$btn = PrimaryBtn::create("Добавить модуль", "/admin/module_shop/module/create")->fetch();
|
$btn = PrimaryBtn::create("Добавить модуль", "/admin/module_shop/module/create", width: '200px')->fetch();
|
||||||
$btn .= PrimaryBtn::create("Добавить ядро", "/admin/module_shop/kernel/create")->fetch();
|
$btn .= PrimaryBtn::create("Добавить ядро", "/admin/module_shop/kernel/create", '400px')->fetch();
|
||||||
return $btn;
|
return $btn;
|
||||||
});
|
});
|
||||||
$table->addAction(ViewActionColumn::class);
|
$table->addAction(ViewActionColumn::class);
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
$secure_config = [
|
$secure_config = [
|
||||||
'web_auth_type' => 'email_code', // login_password, email_code
|
'web_auth_type' => 'login_password', // login_password, email_code
|
||||||
'token_type' => 'hash', // random_bytes, md5, crypt, hash, JWT
|
'token_type' => 'hash', // random_bytes, md5, crypt, hash, JWT
|
||||||
'token_expired_time' => "+30 days", // +1 day
|
'token_expired_time' => "+30 days", // +1 day
|
||||||
];
|
];
|
||||||
|
@ -6,9 +6,9 @@ class PrimaryBtn
|
|||||||
{
|
{
|
||||||
protected string $btn = '';
|
protected string $btn = '';
|
||||||
|
|
||||||
public function __construct(string $title, string $url)
|
public function __construct(string $title, string $url, $width)
|
||||||
{
|
{
|
||||||
$this->btn = "<a class='btn btn-primary' href='$url' style='margin: 3px; width: 150px;' >$title</a>";
|
$this->btn = "<a class='btn btn-primary' href='$url' style='margin: 3px; width: '$width >$title</a>";
|
||||||
}
|
}
|
||||||
|
|
||||||
public function fetch(): string
|
public function fetch(): string
|
||||||
@ -16,9 +16,9 @@ class PrimaryBtn
|
|||||||
return $this->btn;
|
return $this->btn;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function create(string $title, string $url): PrimaryBtn
|
public static function create(string $title, string $url, $width = '150px'): PrimaryBtn
|
||||||
{
|
{
|
||||||
return new self($title, $url);
|
return new self($title, $url, $width);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -27,7 +27,7 @@ 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/kernel';
|
||||||
$this->files->copy_folder(ROOT_DIR . $this->argv['path'], $tmpKernelDirFull);
|
$this->files->copyKernelFolder(ROOT_DIR . $this->argv['path'], $tmpKernelDirFull);
|
||||||
$this->out->r("Ядро скопировано во временную папку", 'green');
|
$this->out->r("Ядро скопировано во временную папку", 'green');
|
||||||
} else {
|
} else {
|
||||||
$this->out->r("Ядро не найдено", 'red');
|
$this->out->r("Ядро не найдено", 'red');
|
||||||
@ -35,7 +35,7 @@ class KernelController extends ConsoleController
|
|||||||
|
|
||||||
if (file_exists(ROOT_DIR . '/bootstrap')) {
|
if (file_exists(ROOT_DIR . '/bootstrap')) {
|
||||||
$tmpBootstrapDirFull = RESOURCES_DIR . '/tmp/ad/kernel/bootstrap';
|
$tmpBootstrapDirFull = RESOURCES_DIR . '/tmp/ad/kernel/bootstrap';
|
||||||
$this->files->copy_folder(ROOT_DIR . '/bootstrap', $tmpBootstrapDirFull);
|
$this->files->copyKernelFolder(ROOT_DIR . '/bootstrap', $tmpBootstrapDirFull);
|
||||||
$this->out->r("/bootstrap скопирован во временную папку", 'green');
|
$this->out->r("/bootstrap скопирован во временную папку", 'green');
|
||||||
} else {
|
} else {
|
||||||
$this->out->r("/bootstrap не найден", 'red');
|
$this->out->r("/bootstrap не найден", 'red');
|
||||||
@ -99,11 +99,11 @@ class KernelController extends ConsoleController
|
|||||||
$zip->extractTo($tmpKernelDirFull);
|
$zip->extractTo($tmpKernelDirFull);
|
||||||
$zip->close();
|
$zip->close();
|
||||||
$this->files->recursiveRemoveKernelDir();
|
$this->files->recursiveRemoveKernelDir();
|
||||||
$this->files->copy_folder($tmpKernelDirFull . 'kernel' , ROOT_DIR . "/kernel");
|
$this->files->copyKernelFolder($tmpKernelDirFull . 'kernel' , ROOT_DIR . "/kernel");
|
||||||
|
|
||||||
if (isset($this->argv['bootstrap'])) {
|
if (isset($this->argv['bootstrap'])) {
|
||||||
$this->files->recursiveRemoveDir(ROOT_DIR . '/bootstrap');
|
$this->files->recursiveRemoveDir(ROOT_DIR . '/bootstrap');
|
||||||
$this->files->copy_folder($tmpKernelDirFull . 'bootstrap' , ROOT_DIR . '/bootstrap');
|
$this->files->copyKernelFolder($tmpKernelDirFull . 'bootstrap' , ROOT_DIR . '/bootstrap');
|
||||||
copy($tmpKernelDirFull . '/bootstrap.php' , ROOT_DIR . '/bootstrap.php');
|
copy($tmpKernelDirFull . '/bootstrap.php' , ROOT_DIR . '/bootstrap.php');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6,13 +6,9 @@ use DirectoryIterator;
|
|||||||
use JetBrains\PhpStorm\NoReturn;
|
use JetBrains\PhpStorm\NoReturn;
|
||||||
use Josantonius\Session\Facades\Session;
|
use Josantonius\Session\Facades\Session;
|
||||||
use kernel\AdminController;
|
use kernel\AdminController;
|
||||||
use kernel\EntityRelation;
|
|
||||||
use kernel\helpers\Debug;
|
use kernel\helpers\Debug;
|
||||||
use kernel\models\Option;
|
use kernel\models\Option;
|
||||||
use kernel\modules\module_shop_client\services\ModuleShopClientService;
|
|
||||||
use kernel\modules\user\service\UserService;
|
|
||||||
use kernel\Request;
|
use kernel\Request;
|
||||||
use kernel\services\MigrationService;
|
|
||||||
use kernel\services\ModuleService;
|
use kernel\services\ModuleService;
|
||||||
|
|
||||||
class ModuleController extends AdminController
|
class ModuleController extends AdminController
|
||||||
|
@ -7,11 +7,38 @@ use ZipArchive;
|
|||||||
|
|
||||||
class Files
|
class Files
|
||||||
{
|
{
|
||||||
public function copy_folder($d1, $d2): void
|
public function copy_folder($d1, $d2, int $permissions = 0775, bool $recursive = true): void
|
||||||
{
|
{
|
||||||
if (is_dir($d1)) {
|
if (is_dir($d1)) {
|
||||||
if (!file_exists($d2)){
|
if (!file_exists($d2)){
|
||||||
$_d2 = mkdir($d2, permissions: 0774, recursive: true);
|
$old_mask = umask(0);
|
||||||
|
$_d2 = mkdir($d2, permissions: $permissions, recursive: $recursive);
|
||||||
|
umask($old_mask);
|
||||||
|
if (!$_d2) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$d = dir($d1);
|
||||||
|
while (false !== ($entry = $d->read())) {
|
||||||
|
if ($entry != '.' && $entry != '..') {
|
||||||
|
$this->copy_folder("$d1/$entry", "$d2/$entry");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$d->close();
|
||||||
|
} else {
|
||||||
|
copy($d1, $d2);
|
||||||
|
chmod($d2, permissions: $permissions);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function copyKernelFolder($d1, $d2, int $permissions = 0775, bool $recursive = true): void
|
||||||
|
{
|
||||||
|
if (is_dir($d1)) {
|
||||||
|
if (!file_exists($d2)){
|
||||||
|
$old_mask = umask(0);
|
||||||
|
$_d2 = mkdir($d2, permissions: $permissions, recursive: $recursive);
|
||||||
|
umask($old_mask);
|
||||||
if (!$_d2) {
|
if (!$_d2) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -20,12 +47,13 @@ class Files
|
|||||||
$d = dir($d1);
|
$d = dir($d1);
|
||||||
while (false !== ($entry = $d->read())) {
|
while (false !== ($entry = $d->read())) {
|
||||||
if ($entry != '.' && $entry != '..' && $entry != 'app_modules') {
|
if ($entry != '.' && $entry != '..' && $entry != 'app_modules') {
|
||||||
$this->copy_folder("$d1/$entry", "$d2/$entry");
|
$this->copyKernelFolder("$d1/$entry", "$d2/$entry");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$d->close();
|
$d->close();
|
||||||
} else {
|
} else {
|
||||||
copy($d1, $d2);
|
copy($d1, $d2);
|
||||||
|
chmod($d2, permissions: $permissions);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
16
kernel/helpers/Version.php
Normal file
16
kernel/helpers/Version.php
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\helpers;
|
||||||
|
|
||||||
|
class Version
|
||||||
|
{
|
||||||
|
public static function getIntVersionByString(string $version): int
|
||||||
|
{
|
||||||
|
$version = preg_replace('/[^0-9]+/', '', $version);
|
||||||
|
return match (strlen($version)) {
|
||||||
|
1 => intval($version) * 100,
|
||||||
|
2 => intval($version) * 10,
|
||||||
|
3 => intval($version),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "Kernel",
|
"name": "Kernel",
|
||||||
"version": "0.1",
|
"version": "0.1.1",
|
||||||
"author": "ITGuild",
|
"author": "ITGuild",
|
||||||
"slug": "kernel",
|
"slug": "kernel",
|
||||||
"type": "kernel",
|
"type": "kernel",
|
||||||
|
@ -12,8 +12,9 @@ use kernel\helpers\Files;
|
|||||||
use kernel\helpers\RESTClient;
|
use kernel\helpers\RESTClient;
|
||||||
use kernel\helpers\SMTP;
|
use kernel\helpers\SMTP;
|
||||||
use kernel\Mailing;
|
use kernel\Mailing;
|
||||||
use kernel\modules\module_shop_client\services\ModuleShopClientService;
|
|
||||||
use kernel\Request;
|
use kernel\Request;
|
||||||
|
use kernel\services\AdminThemeService;
|
||||||
|
use kernel\services\KernelService;
|
||||||
use kernel\services\ModuleService;
|
use kernel\services\ModuleService;
|
||||||
use kernel\services\ModuleShopService;
|
use kernel\services\ModuleShopService;
|
||||||
use kernel\services\TokenService;
|
use kernel\services\TokenService;
|
||||||
@ -24,6 +25,7 @@ class ModuleShopClientController extends AdminController
|
|||||||
|
|
||||||
protected Client $client;
|
protected Client $client;
|
||||||
protected ModuleService $moduleService;
|
protected ModuleService $moduleService;
|
||||||
|
protected KernelService $kernelService;
|
||||||
|
|
||||||
protected function init(): void
|
protected function init(): void
|
||||||
{
|
{
|
||||||
@ -32,6 +34,7 @@ class ModuleShopClientController extends AdminController
|
|||||||
|
|
||||||
$this->client = new Client();
|
$this->client = new Client();
|
||||||
$this->moduleService = new ModuleService();
|
$this->moduleService = new ModuleService();
|
||||||
|
$this->kernelService = new KernelService();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -55,6 +58,8 @@ class ModuleShopClientController extends AdminController
|
|||||||
'page_number' => $page_number,
|
'page_number' => $page_number,
|
||||||
'module_count' => $module_count,
|
'module_count' => $module_count,
|
||||||
'per_page' => $per_page,
|
'per_page' => $per_page,
|
||||||
|
'kernelService' => new KernelService(),
|
||||||
|
'adminThemeService' => new AdminThemeService(),
|
||||||
]);
|
]);
|
||||||
} else {
|
} else {
|
||||||
$this->cgView->render("module_shop_error_connection.php");
|
$this->cgView->render("module_shop_error_connection.php");
|
||||||
@ -112,6 +117,35 @@ class ModuleShopClientController extends AdminController
|
|||||||
$this->redirect('/admin/module_shop_client', 302);
|
$this->redirect('/admin/module_shop_client', 302);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function actionRenderKernelUpdateForm(): void
|
||||||
|
{
|
||||||
|
$this->cgView->render("kernel_update.php");
|
||||||
|
}
|
||||||
|
|
||||||
|
#[NoReturn] public function actionKernelUpdate(): void
|
||||||
|
{
|
||||||
|
$modules_info = RESTClient::request($_ENV['MODULE_SHOP_URL'] . '/api/module_shop/gb_slug');
|
||||||
|
|
||||||
|
$modules_info = json_decode($modules_info->getBody()->getContents(), true);
|
||||||
|
foreach ($modules_info as $module) {
|
||||||
|
if ($module['slug'] === 'kernel') {
|
||||||
|
$path = $module['path_to_archive'];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (isset($path)) {
|
||||||
|
Files::uploadByUrl($_ENV['MODULE_SHOP_URL'] . $path, RESOURCES_DIR . "/tmp/kernel");
|
||||||
|
if ($this->kernelService->updateKernel('/resources/tmp/kernel/' . basename($path))) {
|
||||||
|
Flash::setMessage("success", "Ядро успешно обновлено.");
|
||||||
|
} else {
|
||||||
|
Flash::setMessage("error", "Ошибка обновления ядра.");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
Flash::setMessage("error", "Ошибка обновления ядра.");
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->redirect('/admin/module_shop_client', 302);
|
||||||
|
}
|
||||||
|
|
||||||
#[NoReturn] public function actionDelete(): void
|
#[NoReturn] public function actionDelete(): void
|
||||||
{
|
{
|
||||||
$request = new Request();
|
$request = new Request();
|
||||||
@ -123,6 +157,47 @@ class ModuleShopClientController extends AdminController
|
|||||||
$this->redirect('/admin/module_shop_client', 302);
|
$this->redirect('/admin/module_shop_client', 302);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function actionSearch(int $page_number = 1): void
|
||||||
|
{
|
||||||
|
$request = new Request();
|
||||||
|
$filters = $request->get();
|
||||||
|
if ($this->moduleService->issetModuleShopToken()) {
|
||||||
|
if ($this->moduleService->isServerAvailable()) {
|
||||||
|
$modules_info = [];
|
||||||
|
$per_page = 8;
|
||||||
|
$modules = RESTClient::request($_ENV['MODULE_SHOP_URL'] . '/api/module_shop/gb_slug');
|
||||||
|
$modules = json_decode($modules->getBody()->getContents(), true);
|
||||||
|
foreach ($modules as $module) {
|
||||||
|
foreach ($filters as $key => $value) {
|
||||||
|
if ($value === '') continue;
|
||||||
|
if ($module[$key] !== $value) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
$modules_info[] = $module;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$module_count = count($modules_info);
|
||||||
|
$modules_info = array_slice($modules_info, $per_page * ($page_number - 1), $per_page);
|
||||||
|
|
||||||
|
$this->cgView->render("index.php", [
|
||||||
|
'modules_info' => $modules_info,
|
||||||
|
'moduleService' => $this->moduleService,
|
||||||
|
'page_number' => $page_number,
|
||||||
|
'module_count' => $module_count,
|
||||||
|
'per_page' => $per_page,
|
||||||
|
'kernelService' => new KernelService(),
|
||||||
|
'adminThemeService' => new AdminThemeService(),
|
||||||
|
]);
|
||||||
|
} else {
|
||||||
|
$this->cgView->render("module_shop_error_connection.php");
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
$this->cgView->render("login_at_module_shop.php");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @throws Exception
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
@ -131,13 +206,6 @@ class ModuleShopClientController extends AdminController
|
|||||||
$request = new Request();
|
$request = new Request();
|
||||||
$address = $request->post("email");
|
$address = $request->post("email");
|
||||||
|
|
||||||
// $mailing = new Mailing();
|
|
||||||
// $mailing->send_html("login_by_code.php", ['code' => mt_rand(100000, 999999)], [
|
|
||||||
// 'address' => $address,
|
|
||||||
// 'subject' => "Код авторизации",
|
|
||||||
// "from_name" => $_ENV['APP_NAME']
|
|
||||||
// ]);
|
|
||||||
|
|
||||||
$moduleShopService = new ModuleShopService();
|
$moduleShopService = new ModuleShopService();
|
||||||
$result = $moduleShopService->email_auth($address);
|
$result = $moduleShopService->email_auth($address);
|
||||||
|
|
||||||
@ -153,13 +221,6 @@ class ModuleShopClientController extends AdminController
|
|||||||
$request = new Request();
|
$request = new Request();
|
||||||
$code = $request->post("code");
|
$code = $request->post("code");
|
||||||
|
|
||||||
// $mailing = new Mailing();
|
|
||||||
// $mailing->send_html("login_by_code.php", ['code' => mt_rand(100000, 999999)], [
|
|
||||||
// 'address' => $address,
|
|
||||||
// 'subject' => "Код авторизации",
|
|
||||||
// "from_name" => $_ENV['APP_NAME']
|
|
||||||
// ]);
|
|
||||||
|
|
||||||
$moduleShopService = new ModuleShopService();
|
$moduleShopService = new ModuleShopService();
|
||||||
$result = $moduleShopService->code_check($code);
|
$result = $moduleShopService->code_check($code);
|
||||||
|
|
||||||
|
@ -15,8 +15,17 @@ App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
|||||||
App::$collector->get('/view/{id}', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionView']);
|
App::$collector->get('/view/{id}', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionView']);
|
||||||
App::$collector->get('/delete', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionDelete']);
|
App::$collector->get('/delete', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionDelete']);
|
||||||
App::$collector->get('/update', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionUpdate']);
|
App::$collector->get('/update', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionUpdate']);
|
||||||
|
App::$collector->get('/search', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionSearch']);
|
||||||
App::$collector->post('/auth', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionAuth']);
|
App::$collector->post('/auth', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionAuth']);
|
||||||
App::$collector->post('/code_check', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionCodeCheck']);
|
App::$collector->post('/code_check', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionCodeCheck']);
|
||||||
|
App::$collector->group(["prefix" => "kernel"], function (RouteCollector $router) {
|
||||||
|
App::$collector->get('/update_form', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionRenderKernelUpdateForm']);
|
||||||
|
App::$collector->post('/update', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionKernelUpdate']);
|
||||||
|
});
|
||||||
|
App::$collector->group(["prefix" => "admin_theme"], function (RouteCollector $router) {
|
||||||
|
App::$collector->get('/install', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionAdminThemeInstall']);
|
||||||
|
App::$collector->post('/update', [\kernel\modules\module_shop_client\controllers\ModuleShopClientController::class, 'actionAdminThemeUpdate']);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
@ -5,6 +5,8 @@
|
|||||||
* @var int $page_number
|
* @var int $page_number
|
||||||
* @var int $per_page
|
* @var int $per_page
|
||||||
* @var \kernel\services\ModuleService $moduleService
|
* @var \kernel\services\ModuleService $moduleService
|
||||||
|
* @var \kernel\services\KernelService $kernelService
|
||||||
|
* @var \kernel\services\AdminThemeService $adminThemeService
|
||||||
*/
|
*/
|
||||||
|
|
||||||
use Itguild\Tables\ListJsonTable;
|
use Itguild\Tables\ListJsonTable;
|
||||||
@ -15,6 +17,7 @@ $meta['columns'] = [
|
|||||||
"name" => "Название",
|
"name" => "Название",
|
||||||
"author" => "Автор",
|
"author" => "Автор",
|
||||||
"version" => "Версия",
|
"version" => "Версия",
|
||||||
|
"type" => "Тип",
|
||||||
"description" => "Описание",
|
"description" => "Описание",
|
||||||
"installations" => "Установки",
|
"installations" => "Установки",
|
||||||
"views" => "Просмотры"
|
"views" => "Просмотры"
|
||||||
@ -27,6 +30,7 @@ $meta['total'] = $module_count;
|
|||||||
|
|
||||||
$info_to_table['meta'] = $meta;
|
$info_to_table['meta'] = $meta;
|
||||||
$info_to_table['data'] = $modules_info;
|
$info_to_table['data'] = $modules_info;
|
||||||
|
$info_to_table['filters'] = ['type'];
|
||||||
|
|
||||||
$table = new ListJsonTable(json_encode($info_to_table, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE));
|
$table = new ListJsonTable(json_encode($info_to_table, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE));
|
||||||
|
|
||||||
@ -37,16 +41,18 @@ $table->addAction(function ($row, $url) use ($moduleService) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
$table->addAction(function ($row, $url) use ($moduleService){
|
$table->addAction(function ($row, $url) use ($moduleService){
|
||||||
|
if ($row['slug'] !== 'kernel') {
|
||||||
if ($moduleService->isInstall($row['slug'])) {
|
if ($moduleService->isInstall($row['slug'])) {
|
||||||
$url = "$url/delete/?slug=" . $row['slug'];
|
$url = "$url/delete/?slug=" . $row['slug'];
|
||||||
|
|
||||||
return \kernel\widgets\IconBtn\IconBtnDeleteWidget::create(['url' => $url])->run();
|
return \kernel\widgets\IconBtn\IconBtnDeleteWidget::create(['url' => $url])->run();
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
$url = "$url/install/?id=" . $row['id'];
|
$url = "$url/install/?id=" . $row['id'];
|
||||||
|
|
||||||
return \kernel\widgets\IconBtn\IconBtnInstallWidget::create(['url' => $url])->run();
|
return \kernel\widgets\IconBtn\IconBtnInstallWidget::create(['url' => $url])->run();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
});
|
});
|
||||||
|
|
||||||
$table->addAction(function ($row, $url) use ($moduleService) {
|
$table->addAction(function ($row, $url) use ($moduleService) {
|
||||||
@ -62,6 +68,39 @@ $table->addAction(function ($row, $url) use ($moduleService){
|
|||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$table->addAction(function ($row, $url) use ($kernelService) {
|
||||||
|
$slug = $row['slug'];
|
||||||
|
if ($slug === 'kernel') {
|
||||||
|
if (!$kernelService->isLastVersion()) {
|
||||||
|
$url = "$url/kernel/update_form/";
|
||||||
|
|
||||||
|
return \kernel\widgets\IconBtn\IconBtnUpdateWidget::create(['url' => $url])->run();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
$table->addAction(function ($row, $url) use ($adminThemeService) {
|
||||||
|
$type = $row['type'];
|
||||||
|
$slug = $row['slug'];
|
||||||
|
if ($type === 'admin_theme') {
|
||||||
|
if ($adminThemeService->isInstall($slug)) {
|
||||||
|
if (!$adminThemeService->isLastVersion($slug)) {
|
||||||
|
$url = "$url/admin_theme/update/";
|
||||||
|
|
||||||
|
return \kernel\widgets\IconBtn\IconBtnUpdateWidget::create(['url' => $url])->run();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
$table->afterPrint(function () {
|
||||||
|
return \kernel\IGTabel\btn\PrimaryBtn::create('Сбросить все фильтры', '/admin/module_shop_client')->fetch();
|
||||||
|
});
|
||||||
|
|
||||||
\kernel\widgets\ModuleTabsWidget::create()->run();
|
\kernel\widgets\ModuleTabsWidget::create()->run();
|
||||||
|
|
||||||
$table->create();
|
$table->create();
|
||||||
|
39
kernel/modules/module_shop_client/views/kernel_update.php
Normal file
39
kernel/modules/module_shop_client/views/kernel_update.php
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
use itguild\forms\ActiveForm;
|
||||||
|
|
||||||
|
\kernel\widgets\ModuleTabsWidget::create()->run();
|
||||||
|
|
||||||
|
echo \kernel\helpers\Html::h(2, "Выберите нужные файлы для обновления");
|
||||||
|
|
||||||
|
$form = new ActiveForm();
|
||||||
|
$form->beginForm("/admin/module_shop_client/kernel/update/", enctype: 'multipart/form-data');
|
||||||
|
|
||||||
|
$form->field(\itguild\forms\inputs\Select::class, "files[]", [
|
||||||
|
'class' => "form-control",
|
||||||
|
'multiple' => "multiple",
|
||||||
|
])
|
||||||
|
->setLabel("Дополнительные файлы")
|
||||||
|
->setOptions([
|
||||||
|
'env.example' => 'env.example',
|
||||||
|
'bootstrap.php' => 'bootstrap',
|
||||||
|
'composer.json' => 'composer.json',
|
||||||
|
])
|
||||||
|
->render();
|
||||||
|
?>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-2">
|
||||||
|
<?php
|
||||||
|
$form->field(\itguild\forms\inputs\Button::class, name: "btn-submit", params: [
|
||||||
|
'class' => "btn btn-primary ",
|
||||||
|
'value' => 'Отправить',
|
||||||
|
'typeInput' => 'submit'
|
||||||
|
])
|
||||||
|
->render();
|
||||||
|
?>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<?php
|
||||||
|
$form->endForm();
|
@ -2,20 +2,24 @@
|
|||||||
|
|
||||||
namespace kernel\services;
|
namespace kernel\services;
|
||||||
|
|
||||||
|
use DirectoryIterator;
|
||||||
use kernel\helpers\Debug;
|
use kernel\helpers\Debug;
|
||||||
use kernel\helpers\Manifest;
|
use kernel\helpers\Manifest;
|
||||||
|
use kernel\helpers\RESTClient;
|
||||||
use kernel\models\Option;
|
use kernel\models\Option;
|
||||||
|
|
||||||
class AdminThemeService
|
class AdminThemeService
|
||||||
{
|
{
|
||||||
protected Option $option;
|
protected Option $option;
|
||||||
protected string $active_theme;
|
protected string $active_theme;
|
||||||
|
protected ModuleService $moduleService;
|
||||||
|
|
||||||
|
|
||||||
public function __construct()
|
public function __construct()
|
||||||
{
|
{
|
||||||
$this->option = new Option();
|
$this->option = new Option();
|
||||||
$this->findActiveAdminTheme();
|
$this->findActiveAdminTheme();
|
||||||
|
$this->moduleService = new ModuleService();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function findActiveAdminTheme(): void
|
public function findActiveAdminTheme(): void
|
||||||
@ -56,4 +60,43 @@ class AdminThemeService
|
|||||||
return $info;
|
return $info;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function isInstall(string $slug): bool
|
||||||
|
{
|
||||||
|
$adminThemePaths = Option::where("key", "admin_theme_paths")->first();
|
||||||
|
$dirs = [];
|
||||||
|
if ($adminThemePaths) {
|
||||||
|
$path = json_decode($adminThemePaths->value);
|
||||||
|
foreach ($path->paths as $p) {
|
||||||
|
$dirs[] = getConst($p);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
foreach ($dirs as $dir) {
|
||||||
|
foreach (new DirectoryIterator($dir) as $fileInfo) {
|
||||||
|
if ($fileInfo->isDot()) continue;
|
||||||
|
if ($this->getAdminThemeInfo($fileInfo->getPathname())['slug'] === $slug) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function isLastVersion(string $slug): bool
|
||||||
|
{
|
||||||
|
if ($this->moduleService->isServerAvailable()) {
|
||||||
|
$modules_info = RESTClient::request($_ENV['MODULE_SHOP_URL'] . '/api/module_shop/gb_slug');
|
||||||
|
|
||||||
|
$modules_info = json_decode($modules_info->getBody()->getContents(), true);
|
||||||
|
|
||||||
|
$themeInfo = $this->getAdminThemeInfo($slug);
|
||||||
|
foreach ($modules_info as $mod) {
|
||||||
|
if ($mod['slug'] === $themeInfo['slug'] && $mod['version'] === $themeInfo['version']) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
99
kernel/services/KernelService.php
Normal file
99
kernel/services/KernelService.php
Normal file
@ -0,0 +1,99 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\services;
|
||||||
|
|
||||||
|
use kernel\helpers\Debug;
|
||||||
|
use kernel\helpers\Files;
|
||||||
|
use kernel\helpers\Manifest;
|
||||||
|
use kernel\helpers\RESTClient;
|
||||||
|
use kernel\helpers\Version;
|
||||||
|
use kernel\Request;
|
||||||
|
use ZipArchive;
|
||||||
|
|
||||||
|
class KernelService
|
||||||
|
{
|
||||||
|
protected null|bool $serverAvailable = null;
|
||||||
|
protected ModuleService $moduleService;
|
||||||
|
protected Files $files;
|
||||||
|
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
$this->moduleService = new ModuleService();
|
||||||
|
$this->files = new Files();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getKernelInfo(): false|array|string
|
||||||
|
{
|
||||||
|
$info = [];
|
||||||
|
$info['path'] = KERNEL_DIR;
|
||||||
|
if (file_exists(KERNEL_DIR . "/manifest.json")) {
|
||||||
|
$manifest = json_decode(file_get_contents(KERNEL_DIR . "/manifest.json"), true);
|
||||||
|
$manifest = getConst($manifest);
|
||||||
|
$info = array_merge($info, $manifest);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $info;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function isLastVersion(): bool
|
||||||
|
{
|
||||||
|
if ($this->moduleService->isServerAvailable()) {
|
||||||
|
$modules_info = RESTClient::request($_ENV['MODULE_SHOP_URL'] . '/api/module_shop/gb_slug');
|
||||||
|
|
||||||
|
$modules_info = json_decode($modules_info->getBody()->getContents(), true);
|
||||||
|
|
||||||
|
$kernel_info = $this->getKernelInfo();
|
||||||
|
|
||||||
|
$kernelVersion = Version::getIntVersionByString($kernel_info['version']);
|
||||||
|
|
||||||
|
foreach ($modules_info as $mod) {
|
||||||
|
$modVersion = Version::getIntVersionByString($mod['version']);
|
||||||
|
if ($mod['slug'] === $kernel_info['slug'] && $modVersion <= $kernelVersion) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function updateKernel(string $path): bool
|
||||||
|
{
|
||||||
|
$request = new Request();
|
||||||
|
$files = $request->post('files');
|
||||||
|
|
||||||
|
$zip = new ZipArchive;
|
||||||
|
if (file_exists(ROOT_DIR . $path)) {
|
||||||
|
$tmpKernelDir = md5(time());
|
||||||
|
$res = $zip->open(ROOT_DIR . $path);
|
||||||
|
if ($res === TRUE) {
|
||||||
|
$tmpKernelDirFull = RESOURCES_DIR . '/tmp/kernel/' . $tmpKernelDir . "/";
|
||||||
|
$zip->extractTo($tmpKernelDirFull);
|
||||||
|
$zip->close();
|
||||||
|
$this->files->recursiveRemoveKernelDir();
|
||||||
|
$this->files->copyKernelFolder($tmpKernelDirFull . 'kernel' , ROOT_DIR . "/kernel");
|
||||||
|
|
||||||
|
foreach ($files as $file) {
|
||||||
|
if ($file === 'bootstrap.php') {
|
||||||
|
$this->files->recursiveRemoveDir(ROOT_DIR . '/bootstrap');
|
||||||
|
$this->files->copyKernelFolder($tmpKernelDirFull . 'bootstrap' , ROOT_DIR . '/bootstrap');
|
||||||
|
}
|
||||||
|
if ($file === 'env.example') {
|
||||||
|
copy($tmpKernelDirFull . $file , ROOT_DIR . '/.' . $file);
|
||||||
|
chmod(ROOT_DIR . '/.' . $file, 0775);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
copy($tmpKernelDirFull . $file , ROOT_DIR . '/' . $file);
|
||||||
|
chmod(ROOT_DIR . '/' . $file, 0775);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->files->recursiveRemoveDir($tmpKernelDirFull);
|
||||||
|
unlink(ROOT_DIR . $path);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
@ -9,8 +9,8 @@ use kernel\helpers\Debug;
|
|||||||
use kernel\helpers\Files;
|
use kernel\helpers\Files;
|
||||||
use kernel\helpers\Manifest;
|
use kernel\helpers\Manifest;
|
||||||
use kernel\helpers\RESTClient;
|
use kernel\helpers\RESTClient;
|
||||||
|
use kernel\helpers\Version;
|
||||||
use kernel\models\Option;
|
use kernel\models\Option;
|
||||||
use MongoDB\Driver\Session;
|
|
||||||
use ZipArchive;
|
use ZipArchive;
|
||||||
|
|
||||||
class ModuleService
|
class ModuleService
|
||||||
@ -308,7 +308,12 @@ class ModuleService
|
|||||||
$manifest = Manifest::getWithVars($manifestJson);
|
$manifest = Manifest::getWithVars($manifestJson);
|
||||||
|
|
||||||
$fileHelper = new Files();
|
$fileHelper = new Files();
|
||||||
|
if (isset($manifest['app_module_path'])) {
|
||||||
$fileHelper->copy_folder($tmpModuleDirFull . 'app', $manifest['app_module_path']);
|
$fileHelper->copy_folder($tmpModuleDirFull . 'app', $manifest['app_module_path']);
|
||||||
|
} else {
|
||||||
|
$fileHelper->copy_folder($tmpModuleDirFull . 'app', APP_DIR . '/modules/' . $manifest['slug']);
|
||||||
|
}
|
||||||
|
|
||||||
if (isset($manifest['kernel_module_path'])) {
|
if (isset($manifest['kernel_module_path'])) {
|
||||||
$fileHelper->copy_folder($tmpModuleDirFull . 'kernel', $manifest['kernel_module_path']);
|
$fileHelper->copy_folder($tmpModuleDirFull . 'kernel', $manifest['kernel_module_path']);
|
||||||
} else {
|
} else {
|
||||||
@ -316,6 +321,7 @@ class ModuleService
|
|||||||
}
|
}
|
||||||
|
|
||||||
$fileHelper->recursiveRemoveDir($tmpModuleDirFull);
|
$fileHelper->recursiveRemoveDir($tmpModuleDirFull);
|
||||||
|
unlink(ROOT_DIR . $path);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -392,8 +398,12 @@ class ModuleService
|
|||||||
$manifest = Manifest::getWithVars($manifestJson);
|
$manifest = Manifest::getWithVars($manifestJson);
|
||||||
|
|
||||||
$fileHelper = new Files();
|
$fileHelper = new Files();
|
||||||
|
if (isset($manifest['app_module_path'])) {
|
||||||
$fileHelper->copy_folder($tmpModuleDirFull . 'app/manifest.json', $manifest['app_module_path'] . '/manifest.json');
|
$fileHelper->copy_folder($tmpModuleDirFull . 'app/manifest.json', $manifest['app_module_path'] . '/manifest.json');
|
||||||
|
} else {
|
||||||
|
$fileHelper->copy_folder($tmpModuleDirFull . 'app/manifest.json', APP_DIR . '/modules/' . $manifest['slug'] . '/manifest.json');
|
||||||
|
}
|
||||||
|
|
||||||
if (isset($manifest['kernel_module_path'])) {
|
if (isset($manifest['kernel_module_path'])) {
|
||||||
$fileHelper->copy_folder($tmpModuleDirFull . 'kernel', $manifest['kernel_module_path']);
|
$fileHelper->copy_folder($tmpModuleDirFull . 'kernel', $manifest['kernel_module_path']);
|
||||||
} else {
|
} else {
|
||||||
@ -401,6 +411,8 @@ class ModuleService
|
|||||||
}
|
}
|
||||||
$fileHelper->recursiveRemoveDir($tmpModuleDirFull);
|
$fileHelper->recursiveRemoveDir($tmpModuleDirFull);
|
||||||
|
|
||||||
|
unlink(ROOT_DIR . $path);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -448,9 +460,13 @@ class ModuleService
|
|||||||
$modules_info = RESTClient::request($_ENV['MODULE_SHOP_URL'] . '/api/module_shop/gb_slug');
|
$modules_info = RESTClient::request($_ENV['MODULE_SHOP_URL'] . '/api/module_shop/gb_slug');
|
||||||
|
|
||||||
$modules_info = json_decode($modules_info->getBody()->getContents(), true);
|
$modules_info = json_decode($modules_info->getBody()->getContents(), true);
|
||||||
|
|
||||||
$mod_info = $this->getModuleInfoBySlug($slug);
|
$mod_info = $this->getModuleInfoBySlug($slug);
|
||||||
|
|
||||||
|
$currentVersion = Version::getIntVersionByString($mod_info['version']);
|
||||||
foreach ($modules_info as $mod) {
|
foreach ($modules_info as $mod) {
|
||||||
if ($mod['slug'] === $mod_info['slug'] && $mod['version'] === $mod_info['version']) {
|
$modVersion = Version::getIntVersionByString($mod['version']);
|
||||||
|
if ($mod['slug'] === $mod_info['slug'] && $modVersion <= $currentVersion) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user