kernel pack, update and some fix
This commit is contained in:
parent
7cf3708e4d
commit
d3d5e3a8e5
2
composer.lock
generated
2
composer.lock
generated
@ -2562,5 +2562,5 @@
|
|||||||
"ext-zip": "*"
|
"ext-zip": "*"
|
||||||
},
|
},
|
||||||
"platform-dev": [],
|
"platform-dev": [],
|
||||||
"plugin-api-version": "2.3.0"
|
"plugin-api-version": "2.6.0"
|
||||||
}
|
}
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
<link href="https://fonts.googleapis.com/css?family=Poppins:300,400,500,600,700,800,900" rel="stylesheet">
|
<link href="https://fonts.googleapis.com/css?family=Poppins:300,400,500,600,700,800,900" rel="stylesheet">
|
||||||
|
|
||||||
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">
|
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">
|
||||||
|
<link rel="stylesheet" href="<?= $resources ?>/css/bootstrap.min.css">
|
||||||
<link rel="stylesheet" href="<?= $resources ?>/css/style.css">
|
<link rel="stylesheet" href="<?= $resources ?>/css/style.css">
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
37
kernel/console/controllers/KernelController.php
Normal file
37
kernel/console/controllers/KernelController.php
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace kernel\console\controllers;
|
||||||
|
|
||||||
|
use kernel\console\ConsoleController;
|
||||||
|
use kernel\helpers\Files;
|
||||||
|
use kernel\services\KernelService;
|
||||||
|
|
||||||
|
class KernelController extends ConsoleController
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws \Exception
|
||||||
|
*/
|
||||||
|
public function actionPackKernel(): void
|
||||||
|
{
|
||||||
|
if (!isset($this->argv['path'])) {
|
||||||
|
throw new \Exception('Missing kernel path "--path" specified');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (file_exists(ROOT_DIR . $this->argv['path'])) {
|
||||||
|
|
||||||
|
$tmpKernelDirFull = RESOURCES_DIR . '/tmp/ad/kernel/';
|
||||||
|
|
||||||
|
$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 {
|
||||||
|
$this->out->r("Ядро не найдено", 'red');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -28,3 +28,10 @@ App::$collector->group(["prefix" => "module"], callback: function (RouteCollecto
|
|||||||
App::$collector->console('update', [\kernel\console\controllers\ModuleController::class, 'actionUpdateModule']);
|
App::$collector->console('update', [\kernel\console\controllers\ModuleController::class, 'actionUpdateModule']);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
App::$collector->group(["prefix" => "kernel"], callback: function (RouteCollector $router){
|
||||||
|
// App::$collector->console('install', [\kernel\console\controllers\ModuleController::class, 'actionInstallModule']);
|
||||||
|
// App::$collector->console('uninstall', [\kernel\console\controllers\ModuleController::class, 'actionUninstallModule']);
|
||||||
|
App::$collector->console('pack', [\kernel\console\controllers\KernelController::class, 'actionPackKernel']);
|
||||||
|
App::$collector->console('update', [\kernel\console\controllers\KernelController::class, 'actionUpdateKernel']);
|
||||||
|
});
|
||||||
|
|
||||||
|
@ -74,7 +74,12 @@ class ModuleController extends AdminController
|
|||||||
public function actionDeactivate(): void
|
public function actionDeactivate(): void
|
||||||
{
|
{
|
||||||
$request = new Request();
|
$request = new Request();
|
||||||
$this->moduleService->deactivateModule($request->get("slug"));
|
$active_res = $this->moduleService->deactivateModule($request->get("slug"));
|
||||||
|
if (!$active_res){
|
||||||
|
Session::start();
|
||||||
|
Session::set("error", implode(";", $this->moduleService->getErrors()));
|
||||||
|
$this->redirect("/admin", 302);
|
||||||
|
}
|
||||||
$mod_info = $this->moduleService->getModuleInfoBySlug($request->get('slug'));
|
$mod_info = $this->moduleService->getModuleInfoBySlug($request->get('slug'));
|
||||||
|
|
||||||
$this->cgView->render("view.php", ['data' => $mod_info]);
|
$this->cgView->render("view.php", ['data' => $mod_info]);
|
||||||
@ -88,4 +93,18 @@ class ModuleController extends AdminController
|
|||||||
$this->cgView->render("view.php", ['data' => $mod_info]);
|
$this->cgView->render("view.php", ['data' => $mod_info]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function actionUpdate(): void
|
||||||
|
{
|
||||||
|
$request = new Request();
|
||||||
|
$active_res = $this->moduleService->updateModule($request->get("slug"));
|
||||||
|
if (!$active_res){
|
||||||
|
Session::start();
|
||||||
|
Session::set("error", implode(";", $this->moduleService->getErrors()));
|
||||||
|
$this->redirect("/admin", 302);
|
||||||
|
}
|
||||||
|
$mod_info = $this->moduleService->getModuleInfoBySlug($request->get('slug'));
|
||||||
|
|
||||||
|
$this->cgView->render("view.php", ['data' => $mod_info]);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -19,7 +19,7 @@ class Files
|
|||||||
|
|
||||||
$d = dir($d1);
|
$d = dir($d1);
|
||||||
while (false !== ($entry = $d->read())) {
|
while (false !== ($entry = $d->read())) {
|
||||||
if ($entry != '.' && $entry != '..') {
|
if ($entry != '.' && $entry != '..' && $entry != 'app_modules') {
|
||||||
$this->copy_folder("$d1/$entry", "$d2/$entry");
|
$this->copy_folder("$d1/$entry", "$d2/$entry");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -47,9 +47,6 @@ class Files
|
|||||||
{
|
{
|
||||||
$zip = new ZipArchive();
|
$zip = new ZipArchive();
|
||||||
$zip->open($destination, ZipArchive::CREATE | ZipArchive::OVERWRITE);
|
$zip->open($destination, ZipArchive::CREATE | ZipArchive::OVERWRITE);
|
||||||
// if ($include_source) {
|
|
||||||
// $zip->addEmptyDir(basename($source));
|
|
||||||
// }
|
|
||||||
|
|
||||||
if (is_file($source)) {
|
if (is_file($source)) {
|
||||||
$zip->addFile(basename($source));
|
$zip->addFile(basename($source));
|
||||||
@ -68,8 +65,7 @@ class Files
|
|||||||
|
|
||||||
foreach ($includes as $include) {
|
foreach ($includes as $include) {
|
||||||
if(is_dir($include)) {
|
if(is_dir($include)) {
|
||||||
// $folder .= '/' . $include->getFilename() . '/';
|
if ($include->getFilename() === 'app_modules') continue;
|
||||||
// $this->recursiveAddFile($zip, $include, $folder);
|
|
||||||
|
|
||||||
$tmpFolder = $folder . '/' . $include->getFilename() . '/';
|
$tmpFolder = $folder . '/' . $include->getFilename() . '/';
|
||||||
$this->recursiveAddFile($zip, $include, $tmpFolder);
|
$this->recursiveAddFile($zip, $include, $tmpFolder);
|
||||||
|
@ -12,6 +12,7 @@ App::$collector->group(["prefix" => "admin"], function (RouteCollector $router){
|
|||||||
App::$collector->get('/activate', [\kernel\controllers\ModuleController::class, 'actionActivate']);
|
App::$collector->get('/activate', [\kernel\controllers\ModuleController::class, 'actionActivate']);
|
||||||
App::$collector->get('/deactivate', [\kernel\controllers\ModuleController::class, 'actionDeactivate']);
|
App::$collector->get('/deactivate', [\kernel\controllers\ModuleController::class, 'actionDeactivate']);
|
||||||
App::$collector->get('/view', [\kernel\controllers\ModuleController::class, 'actionView']);
|
App::$collector->get('/view', [\kernel\controllers\ModuleController::class, 'actionView']);
|
||||||
|
App::$collector->get('/update', [\kernel\controllers\ModuleController::class, 'actionUpdate']);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
@ -13,6 +13,10 @@ class ModuleService
|
|||||||
{
|
{
|
||||||
protected array $errors = [];
|
protected array $errors = [];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $module
|
||||||
|
* @return false|array|string
|
||||||
|
*/
|
||||||
public function getModuleInfo(string $module): false|array|string
|
public function getModuleInfo(string $module): false|array|string
|
||||||
{
|
{
|
||||||
$info = [];
|
$info = [];
|
||||||
@ -27,21 +31,36 @@ class ModuleService
|
|||||||
return $info;
|
return $info;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
public function getErrors(): array
|
public function getErrors(): array
|
||||||
{
|
{
|
||||||
return $this->errors;
|
return $this->errors;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param $msg
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
public function addError($msg): void
|
public function addError($msg): void
|
||||||
{
|
{
|
||||||
$this->errors[] = $msg;
|
$this->errors[] = $msg;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $slug
|
||||||
|
* @return false|array|string
|
||||||
|
*/
|
||||||
public function getModuleInfoBySlug(string $slug): false|array|string
|
public function getModuleInfoBySlug(string $slug): false|array|string
|
||||||
{
|
{
|
||||||
return $this->getModuleInfo($this->getModuleDir($slug));
|
return $this->getModuleInfo($this->getModuleDir($slug));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $slug
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
public function isActive(string $slug): bool
|
public function isActive(string $slug): bool
|
||||||
{
|
{
|
||||||
$active_modules = Option::where("key", "active_modules")->first();
|
$active_modules = Option::where("key", "active_modules")->first();
|
||||||
@ -58,32 +77,19 @@ class ModuleService
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @throws \Exception
|
* @param string $module
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function toggleModule(string $module): void
|
public function toggleModule(string $module): void
|
||||||
{
|
{
|
||||||
$active_modules_info = Option::where("key", "active_modules")->first();
|
$active_modules_info = Option::where("key", "active_modules")->first();
|
||||||
$active_modules = json_decode($active_modules_info->value);
|
$active_modules = json_decode($active_modules_info->value);
|
||||||
if (in_array($module, $active_modules->modules)) {
|
if (in_array($module, $active_modules->modules)) {
|
||||||
unset($active_modules->modules[array_search($module, $active_modules->modules)]);
|
$this->deactivateModule($module);
|
||||||
$active_modules->modules = array_values($active_modules->modules);
|
|
||||||
$this->runDeactivateScript($this->getModuleInfoBySlug($module));
|
|
||||||
} else {
|
} else {
|
||||||
$module_info = $this->getModuleInfoBySlug($module);
|
$this->setActiveModule($module);
|
||||||
if (isset($module_info['dependence'])) {
|
|
||||||
$dependence_array = explode(';', $module_info['dependence']);
|
|
||||||
foreach ($dependence_array as $depend) {
|
|
||||||
if (!in_array($depend, $active_modules->modules)) {
|
|
||||||
throw new \Exception("first activate the $depend module");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
$active_modules->modules[] = $module;
|
|
||||||
$this->runInitScript($this->getModuleInfoBySlug($module));
|
|
||||||
}
|
|
||||||
$active_modules_info->value = json_encode($active_modules, JSON_UNESCAPED_UNICODE);
|
|
||||||
$active_modules_info->save();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $module
|
* @param string $module
|
||||||
@ -135,7 +141,7 @@ class ModuleService
|
|||||||
if ($str_for_exception !== '') {
|
if ($str_for_exception !== '') {
|
||||||
$str_for_exception .= ', ';
|
$str_for_exception .= ', ';
|
||||||
}
|
}
|
||||||
$str_for_exception .= "$mod";
|
$str_for_exception .= $mod;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -154,7 +160,11 @@ class ModuleService
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getModuleDir(string $slug)
|
/**
|
||||||
|
* @param string $slug
|
||||||
|
* @return false
|
||||||
|
*/
|
||||||
|
public function getModuleDir(string $slug): false
|
||||||
{
|
{
|
||||||
$module_paths = Option::where("key", "module_paths")->first();
|
$module_paths = Option::where("key", "module_paths")->first();
|
||||||
$dirs = [];
|
$dirs = [];
|
||||||
@ -175,6 +185,10 @@ class ModuleService
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param $mod_info
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
public function runInitScript($mod_info): void
|
public function runInitScript($mod_info): void
|
||||||
{
|
{
|
||||||
if (isset($mod_info['module_class'])){
|
if (isset($mod_info['module_class'])){
|
||||||
@ -186,6 +200,10 @@ class ModuleService
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param $mod_info
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
public function runDeactivateScript($mod_info): void
|
public function runDeactivateScript($mod_info): void
|
||||||
{
|
{
|
||||||
if (isset($mod_info['module_class'])){
|
if (isset($mod_info['module_class'])){
|
||||||
@ -197,6 +215,9 @@ class ModuleService
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
public function getActiveModules(): array
|
public function getActiveModules(): array
|
||||||
{
|
{
|
||||||
$modules = [];
|
$modules = [];
|
||||||
@ -222,6 +243,9 @@ class ModuleService
|
|||||||
return $modules;
|
return $modules;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
public function getModulesRouts(): array
|
public function getModulesRouts(): array
|
||||||
{
|
{
|
||||||
$routs = [];
|
$routs = [];
|
||||||
@ -235,6 +259,9 @@ class ModuleService
|
|||||||
return $routs;
|
return $routs;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
public function getModulesMigrationsPaths(): array
|
public function getModulesMigrationsPaths(): array
|
||||||
{
|
{
|
||||||
$migrationsPaths = [];
|
$migrationsPaths = [];
|
||||||
@ -249,9 +276,10 @@ class ModuleService
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @throws \Exception
|
* @param string $path
|
||||||
|
* @return bool
|
||||||
*/
|
*/
|
||||||
public function installModule(string $path): void
|
public function installModule(string $path): bool
|
||||||
{
|
{
|
||||||
$zip = new ZipArchive;
|
$zip = new ZipArchive;
|
||||||
$tmpModuleDir = md5(time());
|
$tmpModuleDir = md5(time());
|
||||||
@ -260,21 +288,18 @@ class ModuleService
|
|||||||
$tmpModuleDirFull = RESOURCES_DIR . '/tmp/ad/' . $tmpModuleDir . "/";
|
$tmpModuleDirFull = RESOURCES_DIR . '/tmp/ad/' . $tmpModuleDir . "/";
|
||||||
$zip->extractTo($tmpModuleDirFull);
|
$zip->extractTo($tmpModuleDirFull);
|
||||||
$zip->close();
|
$zip->close();
|
||||||
// $out->out->r('Архив распакован', 'green');
|
|
||||||
// } else {
|
|
||||||
// $this->out->r('Message: Ошибка чтения архива', 'red');
|
|
||||||
} else {
|
} else {
|
||||||
$zip->close();
|
$this->addError('unable to open zip archive');
|
||||||
throw new \Exception("unable to open zip archive");
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!file_exists($tmpModuleDirFull . "/app/manifest.json")) {
|
if (!file_exists($tmpModuleDirFull . "/app/manifest.json")) {
|
||||||
throw new \Exception('manifest.json not found');
|
$this->addError('manifest.json not found');
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$manifestJson = getConst(file_get_contents($tmpModuleDirFull . "/app/manifest.json"));
|
$manifestJson = getConst(file_get_contents($tmpModuleDirFull . "/app/manifest.json"));
|
||||||
$manifest = Manifest::getWithVars($manifestJson);
|
$manifest = Manifest::getWithVars($manifestJson);
|
||||||
// $this->out->r('manifest.json инициализирован', 'green');
|
|
||||||
|
|
||||||
$fileHelper = new Files();
|
$fileHelper = new Files();
|
||||||
$fileHelper->copy_folder($tmpModuleDirFull . '/app', $manifest['app_module_path']);
|
$fileHelper->copy_folder($tmpModuleDirFull . '/app', $manifest['app_module_path']);
|
||||||
@ -284,22 +309,22 @@ class ModuleService
|
|||||||
$fileHelper->copy_folder($tmpModuleDirFull . '/kernel', KERNEL_APP_MODULES_DIR . '/' . $manifest['slug']);
|
$fileHelper->copy_folder($tmpModuleDirFull . '/kernel', KERNEL_APP_MODULES_DIR . '/' . $manifest['slug']);
|
||||||
}
|
}
|
||||||
|
|
||||||
// $this->out->r("Удаляем временные файлы", 'green');
|
|
||||||
$fileHelper->recursiveRemoveDir($tmpModuleDirFull);
|
$fileHelper->recursiveRemoveDir($tmpModuleDirFull);
|
||||||
var_dump($tmpModuleDirFull);
|
var_dump($tmpModuleDirFull);
|
||||||
|
|
||||||
// $this->out->r("Модуль " . $manifest['name'] . " установлен", 'green');
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @throws \Exception
|
* @param string $path
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function uninstallModule(string $path): void
|
public function uninstallModule(string $path): void
|
||||||
{
|
{
|
||||||
$moduleInfo = $this->getModuleInfo(APP_DIR . '/modules/' . basename($path));
|
$moduleInfo = $this->getModuleInfo(APP_DIR . '/modules/' . basename($path));
|
||||||
|
|
||||||
if ($this->isActive($moduleInfo['slug'])) {
|
if ($this->isActive($moduleInfo['slug'])) {
|
||||||
$this->unsetActiveModule($moduleInfo['slug']);
|
$this->deactivateModule($moduleInfo['slug']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$fileHelper = new Files();
|
$fileHelper = new Files();
|
||||||
@ -311,6 +336,10 @@ class ModuleService
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $path
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
public function packModule(string $path): void
|
public function packModule(string $path): void
|
||||||
{
|
{
|
||||||
$moduleName = basename($path);
|
$moduleName = basename($path);
|
||||||
@ -321,20 +350,16 @@ class ModuleService
|
|||||||
$fileHelper->copy_folder(APP_DIR . '/modules/' . $moduleName, $tmpModuleDirFull . 'app/');
|
$fileHelper->copy_folder(APP_DIR . '/modules/' . $moduleName, $tmpModuleDirFull . 'app/');
|
||||||
$fileHelper->copy_folder(KERNEL_APP_MODULES_DIR . '/' . $moduleName, $tmpModuleDirFull . 'kernel/');
|
$fileHelper->copy_folder(KERNEL_APP_MODULES_DIR . '/' . $moduleName, $tmpModuleDirFull . 'kernel/');
|
||||||
|
|
||||||
// $this->out->r("Модуль собран во временную папку", 'green');
|
|
||||||
|
|
||||||
$fileHelper->pack($tmpModuleDirFull, RESOURCES_DIR . '/tmp/modules/' . $moduleName . '.itguild');
|
$fileHelper->pack($tmpModuleDirFull, RESOURCES_DIR . '/tmp/modules/' . $moduleName . '.itguild');
|
||||||
|
|
||||||
// $this->out->r("Архив создан", 'green');
|
|
||||||
$fileHelper->recursiveRemoveDir($tmpModuleDirFull);
|
$fileHelper->recursiveRemoveDir($tmpModuleDirFull);
|
||||||
|
|
||||||
// $this->out->r("Временная папка удалена", 'green');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @throws \Exception
|
* @param string $path
|
||||||
|
* @return bool
|
||||||
*/
|
*/
|
||||||
public function updateModule(string $path): void
|
public function updateModule(string $path): bool
|
||||||
{
|
{
|
||||||
$zip = new ZipArchive;
|
$zip = new ZipArchive;
|
||||||
$tmpModuleDir = md5(time());
|
$tmpModuleDir = md5(time());
|
||||||
@ -343,21 +368,18 @@ class ModuleService
|
|||||||
$tmpModuleDirFull = RESOURCES_DIR . '/tmp/ad/' . $tmpModuleDir . "/";
|
$tmpModuleDirFull = RESOURCES_DIR . '/tmp/ad/' . $tmpModuleDir . "/";
|
||||||
$zip->extractTo($tmpModuleDirFull);
|
$zip->extractTo($tmpModuleDirFull);
|
||||||
$zip->close();
|
$zip->close();
|
||||||
// $out->out->r('Архив распакован', 'green');
|
|
||||||
// } else {
|
|
||||||
// $this->out->r('Message: Ошибка чтения архива', 'red');
|
|
||||||
} else {
|
} else {
|
||||||
$zip->close();
|
$this->addError('unable to open zip archive');
|
||||||
throw new \Exception("unable to open zip archive");
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!file_exists($tmpModuleDirFull . "/app/manifest.json")) {
|
if (!file_exists($tmpModuleDirFull . "/app/manifest.json")) {
|
||||||
throw new \Exception('manifest.json not found');
|
$this->addError('manifest.json not found');
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$manifestJson = getConst(file_get_contents($tmpModuleDirFull . "/app/manifest.json"));
|
$manifestJson = getConst(file_get_contents($tmpModuleDirFull . "/app/manifest.json"));
|
||||||
$manifest = Manifest::getWithVars($manifestJson);
|
$manifest = Manifest::getWithVars($manifestJson);
|
||||||
// $this->out->r('manifest.json инициализирован', 'green');
|
|
||||||
|
|
||||||
$fileHelper = new Files();
|
$fileHelper = new Files();
|
||||||
if (isset($manifest['kernel_module_path'])) {
|
if (isset($manifest['kernel_module_path'])) {
|
||||||
@ -365,14 +387,14 @@ class ModuleService
|
|||||||
} else {
|
} else {
|
||||||
$fileHelper->copy_folder($tmpModuleDirFull . '/kernel', KERNEL_APP_MODULES_DIR . '/' . $manifest['slug']);
|
$fileHelper->copy_folder($tmpModuleDirFull . '/kernel', KERNEL_APP_MODULES_DIR . '/' . $manifest['slug']);
|
||||||
}
|
}
|
||||||
|
|
||||||
// $this->out->r("Удаляем временные файлы", 'green');
|
|
||||||
$fileHelper->recursiveRemoveDir($tmpModuleDirFull);
|
$fileHelper->recursiveRemoveDir($tmpModuleDirFull);
|
||||||
|
|
||||||
// $this->out->r("Модуль " . $manifest['name'] . " установлен", 'green');
|
return true;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
public function getDependencies(): array
|
public function getDependencies(): array
|
||||||
{
|
{
|
||||||
$modules_info = $this->getActiveModules();
|
$modules_info = $this->getActiveModules();
|
||||||
|
@ -48,5 +48,10 @@ $table->addAction(function ($row, $url) use ($moduleService){
|
|||||||
return "<a class='btn btn-primary' href='$url/view/?slug=$slug' style='margin: 3px; width: 150px;' >Просмотр</a>";
|
return "<a class='btn btn-primary' href='$url/view/?slug=$slug' style='margin: 3px; width: 150px;' >Просмотр</a>";
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$table->addAction(function ($row, $url) use ($moduleService){
|
||||||
|
$slug = $row['slug'];
|
||||||
|
return "<a class='btn btn-primary' href='$url/update/?slug=$slug' style='margin: 3px; width: 150px;' >Обновить</a>";
|
||||||
|
});
|
||||||
|
|
||||||
$table->create();
|
$table->create();
|
||||||
$table->render();
|
$table->render();
|
||||||
|
Loading…
Reference in New Issue
Block a user